[#16116] RCRchive shutting down — "David A. Black" <dblack@...>

Hi everyone --

22 messages 2008/04/03
[#16119] Re: [ANN] RCRchive shutting down — "Robert Dober" <robert.dober@...> 2008/04/03

This is quite sad news, I feel that a mailing list does not offer all

[#16121] Re: [ANN] RCRchive shutting down — Yukihiro Matsumoto <matz@...> 2008/04/03

Hi,

[#16122] Re: [ANN] RCRchive shutting down — "Robert Dober" <robert.dober@...> 2008/04/03

On Thu, Apr 3, 2008 at 12:01 PM, Yukihiro Matsumoto <matz@ruby-lang.org> wrote:

[#16123] issue tracking (Re: [ANN] RCRchive shutting down) — Yukihiro Matsumoto <matz@...> 2008/04/03

Hi,

[#16124] Re: issue tracking (Re: [ANN] RCRchive shutting down) — "Meinrad Recheis" <meinrad.recheis@...> 2008/04/03

On Thu, Apr 3, 2008 at 1:13 PM, Yukihiro Matsumoto <matz@ruby-lang.org> wrote:

[#16128] RUBY_IMPLEMENTATION — Yukihiro Matsumoto <matz@...>

Hi,

60 messages 2008/04/03
[#16139] Re: RUBY_IMPLEMENTATION — Paul Brannan <pbrannan@...> 2008/04/03

On Thu, Apr 03, 2008 at 11:41:41PM +0900, Yukihiro Matsumoto wrote:

[#16143] Re: RUBY_IMPLEMENTATION — Eric Hodel <drbrain@...7.net> 2008/04/03

On Apr 3, 2008, at 10:59 AM, Paul Brannan wrote:

[#16146] Re: RUBY_IMPLEMENTATION — Yukihiro Matsumoto <matz@...> 2008/04/03

Hi,

[#16147] Re: RUBY_IMPLEMENTATION — Ezra Zygmuntowicz <ezmobius@...> 2008/04/03

[#16149] Re: RUBY_IMPLEMENTATION — Charles Oliver Nutter <charles.nutter@...> 2008/04/03

Ezra Zygmuntowicz wrote:

[#16155] Re: RUBY_IMPLEMENTATION — "Yemi I. D. Bedu" <yemi@...> 2008/04/03

Hello,

[#16158] Re: RUBY_IMPLEMENTATION — Charles Oliver Nutter <charles.nutter@...> 2008/04/03

Yemi I. D. Bedu wrote:

[#16175] Re: RUBY_IMPLEMENTATION — Eleanor McHugh <eleanor@...> 2008/04/04

On 4 Apr 2008, at 00:23, Charles Oliver Nutter wrote:

[#16194] Re: RUBY_IMPLEMENTATION — Chris Cummer <chris@...> 2008/04/04

On 4-Apr-08, at 3:05 AM, Eleanor McHugh wrote:

[#16195] Re: RUBY_IMPLEMENTATION — "Luis Lavena" <luislavena@...> 2008/04/04

On Fri, Apr 4, 2008 at 2:15 PM, Chris Cummer <chris@postal-code.com> wrote:

[#16240] syntax request — "ry dahl" <ry@...>

Often times when one has many long arguments and orders them like this

42 messages 2008/04/06
[#16263] Re: syntax request — "Bill Kelly" <billk@...> 2008/04/07

[#16266] Re: syntax request — "David A. Black" <dblack@...> 2008/04/08

On Tue, 8 Apr 2008, Bill Kelly wrote:

[#16282] Re: syntax request — Paul Brannan <pbrannan@...> 2008/04/08

On Tue, Apr 08, 2008 at 02:23:26PM +0900, David A. Black wrote:

[#16290] Could someone confirm signal handling is broken on OSX? — Dave Thomas <dave@...>

I've raised this before, but no one replied. I'd like to double check

12 messages 2008/04/08

[#16359] design meeting — Yukihiro Matsumoto <matz@...>

Hi,

18 messages 2008/04/12

[#16397] Ruby 1.8.7-preview1 has been released — "Akinori MUSHA" <knu@...>

Folks,

16 messages 2008/04/15

[#16482] Performance on method dispatch for methods defined via define_method — "Robert Dober" <robert.dober@...>

Hi

32 messages 2008/04/22
[#16483] Re: Performance on method dispatch for methods defined via define_method — Paul Brannan <pbrannan@...> 2008/04/22

On Wed, Apr 23, 2008 at 12:39:29AM +0900, Robert Dober wrote:

[#16484] Re: Performance on method dispatch for methods defined via define_method — "Robert Dober" <robert.dober@...> 2008/04/22

On Tue, Apr 22, 2008 at 8:46 PM, Paul Brannan <pbrannan@atdesk.com> wrote:

[#16487] Re: Performance on method dispatch for methods defined via define_method — "David A. Black" <dblack@...> 2008/04/22

Hi --

[#16488] Re: Performance on method dispatch for methods defined via define_method — "Robert Dober" <robert.dober@...> 2008/04/22

On Tue, Apr 22, 2008 at 10:44 PM, David A. Black <dblack@rubypal.com> wrote:

[#16490] Re: Performance on method dispatch for methods defined via define_method — "David A. Black" <dblack@...> 2008/04/22

Hi --

[#16501] Re: Performance on method dispatch for methods defined via define_method — ts <decoux@...> 2008/04/23

Robert Dober wrote:

[#16507] Drop :: as a . synonym — "David A. Black" <dblack@...>

Hi --

50 messages 2008/04/23
[#16511] Re: [RCR] Drop :: as a . synonym — Charles Oliver Nutter <charles.nutter@...> 2008/04/23

David A. Black wrote:

[#16512] Re: [RCR] Drop :: as a . synonym — "David A. Black" <dblack@...> 2008/04/23

Hi --

[#16525] Re: [RCR] Drop :: as a . synonym — Charles Oliver Nutter <charles.nutter@...> 2008/04/23

David A. Black wrote:

[#16527] Re: [RCR] Drop :: as a . synonym — "David A. Black" <dblack@...> 2008/04/23

Hi --

[#16534] Re: [RCR] Drop :: as a . synonym — Thomas Enebo <Thomas.Enebo@...> 2008/04/23

David A. Black wrote:

[#16546] Re: [RCR] Drop :: as a . synonym — "David A. Black" <dblack@...> 2008/04/24

Hi --

[#16552] Re: [RCR] Drop :: as a . synonym — "Jeremy McAnally" <jeremymcanally@...> 2008/04/24

Or changing #send to private...or (insert progressive but code

[#16564] Re: [RCR] Drop :: as a . synonym — Charles Oliver Nutter <charles.nutter@...> 2008/04/24

Jeremy McAnally wrote:

[#16567] Re: [RCR] Drop :: as a . synonym — "David A. Black" <dblack@...> 2008/04/24

Hi --

[#16570] Re: [RCR] Drop :: as a . synonym — Yukihiro Matsumoto <matz@...> 2008/04/24

Hi,

[#16531] Re: [RCR] Drop :: as a . synonym — "Eric Mahurin" <eric.mahurin@...> 2008/04/23

On Wed, Apr 23, 2008 at 9:21 AM, David A. Black <dblack@rubypal.com> wrote:

Re: ruby_init() and C call stack in Ruby 1.9

From: "Suraj N. Kurapati" <sunaku@...>
Date: 2008-04-18 01:41:34 UTC
List: ruby-core #16436
Nobuyoshi Nakada wrote:
>> Suraj N. Kurapati wrote in [ruby-core:16432]:
>>> Yukihiro Matsumoto wrote:
>>>> No Ruby object should be referred from stack region lower than the
>>>> position at the time of ruby_init() invocation.
>>>
>>> For Ruby 1.8, I was able to guarantee this assumption by only using
>>> Ruby's C API inside a POSIX thread:  the thread preserves the C call
>>> stack for the life of the Ruby interpreter.
>>>
>>> However, for Ruby 1.9, it is not possible to invoke ruby_init()
>>> inside a POSIX thread (as both you and Nobu have explained in
>>> ruby-core:15759 and ruby-core:15760).
>>>
>>> Therefore, how can I guarantee this assumption for Ruby 1.9?
> 
> Why can't you call ruby_sysinit() and ruby_init() in the maint
> thread?

Good question.  Allow me to explain my use case:

I invoke a Verilog simulator by specifying the path to my shared
object file.  The simulator loads my shared object file and
immediately it invokes a predefined function.  (Note that the
simulator is the main thread.)

Inside this function, I call ruby_init() and then register (with the
simulator) a callback function that must be executed at the start of
the simulation.

After this function returns, the simulator does some other
initialization and then prepares to begin the simulation.

Since I registered a start-of-simulation callback, the simulator
first invokes my callback function (from a *different* C call stack
position in a lower region of memory than the invocation of the
predefined function) before really beginning the simulation.

As a result, any usage of Ruby's C API inside my callback function
causes a segmentation fault.  This is because Ruby was initialized
in one stack region, but now the Ruby C API is being used in a lower
stack region.

For this reason, I am very interested in shielding Ruby from the
main thread's inconsistent C call stack by running Ruby inside a
pthread.  The pthread preserves (for the life of the Ruby
interpreter) the C call stack where ruby_init() was called.

For example, here is some pseudocode describing this technique:

void* the_ruby_protector(void* dummy)
{
   ruby_init();

   // wait for start-of-simulation callback
   protector_is_done();  // wake up wait_for_protector() callers
   wait_for_simulator();

   // use the Ruby C API
   rb_funcall( ... );
   rb_const_get( ... );
}

void the_predefined_function()
{
   pthread_create( ... the_ruby_protector ...);

   // wait until protector is finished initializing Ruby
   wait_for_protector();
}

void the_callback_function()
{
   // resume the protector (allow it to continue executing)
   simulator_is_done();  // wake up wait_for_simulator() callers
   wait_for_protector();
}

The wait_for() and is_done() functions are just wrappers around
pthread_mutex synchronization primitives.  They allow one thread to
be running at a time.

>> I really wish Ruby's C API was like OpenGL: a state machine.
>> It doesn't matter from what stack position you query/modify the
>> machine  state.
> 
> OpenGL has its own GC?

Excellent point.  However, it could theoretically have its own GC
and hide that fact from a user by malloc()ing its own stack region
instead of relying on the C call stack position during init.  :-)

In This Thread