Never mind. This mark_current_machine_context() error is due to uninitialized stack C variables in code that not part of MRI, thus is not fixable. On 1/21/11 6:29 PM, Kurt Stephens wrote: > I've been drilling deep into MRI's gc. > Does anyone regularly run MRI against valgrind? > I'm seeing quite a few errors on OS X 10.6.6 64-bit. > > e.g.: > > ==36412== Use of uninitialised value of size 8 > ==36412== at 0x100054542: mark_current_machine_context (in ./ruby) > ==36412== by 0x10005473A: gc_marks (in ./ruby) > ==36412== by 0x1000558EA: rb_newobj (in ./ruby) > ==36412== by 0x100055E48: rb_node_newnode (in ./ruby) > ==36412== by 0x100099AA4: gettable_gen (in ./ruby) > ==36412== by 0x1000B752E: ruby_yyparse (in ./ruby) > ==36412== by 0x1000B8FC9: yycompile0 (in ./ruby) > ==36412== by 0x10017F7A2: thread_suppress_tracing (in ./ruby) > ==36412== by 0x100096E1F: rb_parser_compile_file (in ./ruby) > ==36412== by 0x1000FBC1B: load_file_internal (in ./ruby) > ==36412== by 0x10003C5CE: rb_ensure (in ./ruby) > ==36412== by 0x1000F950D: rb_load_file (in ./ruby) > ==36412== > ==36412== Conditional jump or move depends on uninitialised value(s) > ==36412== at 0x100051CAB: gc_mark_children (in ./ruby) > ==36412== by 0x100054622: mark_current_machine_context (in ./ruby) > ==36412== by 0x10005473A: gc_marks (in ./ruby) > ==36412== by 0x1000558EA: rb_newobj (in ./ruby) > ==36412== by 0x100055E48: rb_node_newnode (in ./ruby) > ==36412== by 0x100099AA4: gettable_gen (in ./ruby) > ==36412== by 0x1000B752E: ruby_yyparse (in ./ruby) > ==36412== by 0x1000B8FC9: yycompile0 (in ./ruby) > ==36412== by 0x10017F7A2: thread_suppress_tracing (in ./ruby) > ==36412== by 0x100096E1F: rb_parser_compile_file (in ./ruby) > ==36412== by 0x1000FBC1B: load_file_internal (in ./ruby) > ==36412== by 0x10003C5CE: rb_ensure (in ./ruby) >