[#44014] Re: [ruby-core:37707] [Ruby 1.9 - Bug #3781] FIBER_USE_NATIVE が有効だと落ちるスクリプトがある — Narihiro Nakamura <authornari@...>

nariです。

14 messages 2011/07/02
[#44019] Re: [ruby-core:37707] [Ruby 1.9 - Bug #3781] FIBER_USE_NATIVE が有効だと落ちるスクリプトがある — KOSAKI Motohiro <kosaki.motohiro@...> 2011/07/02

> 本当はgc_mark()の際に毎回stack_check()するのがいいと思うのですが、

[#44027] [RubyKaigi] Next version of Ruby 1.8 and 1.9 — "Yuki Sonoda (Yugui)" <yugui@...>

-----BEGIN PGP SIGNED MESSAGE-----

16 messages 2011/07/03

[#44156] [Ruby 1.9 - Feature #5053][Open] ruby コマンドと libruby の食い違いチェック — Makoto Kishimoto <redmine@...>

20 messages 2011/07/19

[#44185] [Ruby 1.9 - Bug #5074][Open] "[BUG] cfp consistency error - send" on TestEnumerator#test_feed_yielder (test/ruby/test_enumerator.rb) — Shota Fukumori <sorah@...>

10 messages 2011/07/22

[#44189] [Ruby 1.9 - Bug #5075][Assigned] invalid *fdp in Mac OS X and FreeBSD over recvmsg with SCM_RIGHTS — Yui NARUSE <naruse@...>

12 messages 2011/07/22

[#44210] 1.9.3 (以降) の BigDecimal について — Tadayoshi Funaba <tadf@...>

BigDecimal() で整数、浮動小数点数、有理数などを受けとれるようになって、

14 messages 2011/07/23
[#44275] Re: 1.9.3 (以降) の BigDecimal について — Tadayoshi Funaba <tadf@...> 2011/07/30

変換には明示的なものとそうでないものがありますが、

[#44223] [Ruby 1.9 - Bug #5094][Assigned] Supported platforms of Ruby 1.9.3 — Yui NARUSE <naruse@...>

21 messages 2011/07/25
[#44229] Re: [Ruby 1.9 - Bug #5094][Assigned] Supported platforms of Ruby 1.9.3 — KOSAKI Motohiro <kosaki.motohiro@...> 2011/07/25

> == 成瀬の提案

[#44230] Re: [Ruby 1.9 - Bug #5094][Assigned] Supported platforms of Ruby 1.9.3 — Urabe Shyouhei <shyouhei@...> 2011/07/26

卜部です

[#44236] Re: [Ruby 1.9 - Bug #5094][Assigned] Supported platforms of Ruby 1.9.3 — Yusuke ENDOH <mame@...> 2011/07/26

遠藤です。

[#44254] [Ruby 1.8 - Bug #5105][Open] CGI::Session#session_id の生成方法について — Masahiro Tomita <tommy@...>

14 messages 2011/07/27
[#44256] [Ruby 1.8 - Bug #5105] CGI::Session#session_id の生成方法について — Yui NARUSE <naruse@...> 2011/07/27

[#44258] Re: [Ruby 1.8 - Bug #5105] CGI::Session#session_id の生成方法について — とみたまさひろ <tommy@...> 2011/07/27

とみたです。

[#44262] Re: [Ruby 1.8 - Bug #5105] CGI::Session#session_id の生成方法について — "NARUSE, Yui" <naruse@...> 2011/07/27

(2011/07/27 19:47), とみたまさひろ wrote:

[#44263] Re: [Ruby 1.8 - Bug #5105] CGI::Session#session_id の生成方法について — とみたまさひろ <tommy@...> 2011/07/27

とみたです。

[#44270] Re: [Ruby 1.8 - Bug #5105] CGI::Session#session_id の生成方法について — とみたまさひろ <tommy@...> 2011/07/29

とみたです。

[#44271] Re: [Ruby 1.8 - Bug #5105] CGI::Session#session_id の生成方法について — Tanaka Akira <akr@...> 2011/07/29

2011年7月29日20:04 とみたまさひろ <tommy@tmtm.org>:

[ruby-dev:44051] [Ruby 1.9 - Bug #4988] ObjectSpace.#define_finalizer内でMutexをロックして解放しないまま抜けるとabortする

From: Shyouhei Urabe <shyouhei@...>
Date: 2011-07-07 16:19:58 UTC
List: ruby-dev #44051
Issue #4988 has been updated by Shyouhei Urabe.


=begin
at_exitの中からvm->main_threadが見えないようにするためにわざとruby_vm_run_at_exit_hooks()を今の位置で呼んでるんでしたっけ。
だとしたらこのパッチではダメですが。

 Index: thread.c
 ===================================================================
 --- thread.c    (revision 32440)
 +++ thread.c    (working copy)
 @@ -334,6 +334,14 @@
  static void rb_mutex_unlock_all(rb_mutex_t *mutex, rb_thread_t *th);
  static void rb_mutex_abandon_all(rb_mutex_t *mutexes);
 
 +static void
 +mutex_unlock_all_i(rb_vm_t *vm)
 +{
 +    rb_thread_t *th = vm->main_thread;
 +    if (th)
 +        rb_mutex_unlock_all(th->keeping_mutexes, th);
 +}
 +
  void
  rb_thread_terminate_all(void)
  {
 @@ -363,6 +371,7 @@
         }
         POP_TAG();
      }
 +    ruby_vm_at_exit(mutex_unlock_all_i);
  }
 
  static void
 Index: vm.c
 ===================================================================
 --- vm.c        (revision 32440)
 +++ vm.c        (working copy)
 @@ -1567,6 +1567,7 @@
         struct rb_objspace *objspace = vm->objspace;
  #endif 
         rb_gc_force_recycle(vm->self);
 +       ruby_vm_run_at_exit_hooks(vm);
         vm->main_thread = 0;
         if (th) {
             thread_free(th);
 @@ -1580,7 +1581,6 @@
             rb_objspace_free(objspace);
         }
  #endif
 -       ruby_vm_run_at_exit_hooks(vm);
         rb_vm_gvl_destroy(vm);
         ruby_xfree(vm);
         ruby_current_vm = 0;

=end
----------------------------------------
Bug #4988: ObjectSpace.#define_finalizer内でMutexをロックして解放しないまま抜けるとabortする
http://redmine.ruby-lang.org/issues/4988

Author: Masaki Matsushita
Status: Open
Priority: Normal
Assignee: 
Category: 
Target version: 
ruby -v: ruby 1.9.3dev (2011-07-07 trunk 32437) [x86_64-linux]


=begin
次のコードを実行すると、

 ObjectSpace.define_finalizer("") do
   Mutex.new.lock
 end
 
以下のようにabortします。

 [BUG] thread_free: keeping_mutexes must be NULL (0x1fa0510:0x21f8ac0)
 ruby 1.9.3dev (2011-07-07 trunk 32437) [x86_64-linux]
 
 -- Control frame information -----------------------------------------------
 
 
 -- C level backtrace information -------------------------------------------
 ../ruby_trunk/bin/ruby() [0x529687] vm_dump.c:796
 ../ruby_trunk/bin/ruby() [0x576768] error.c:258
 ../ruby_trunk/bin/ruby(rb_bug+0xa2) [0x577bc2] error.c:270
 ../ruby_trunk/bin/ruby(ruby_vm_destruct+0x17f) [0x52741f] vm.c:1744
 ../ruby_trunk/bin/ruby(ruby_cleanup+0x283) [0x4174c3] eval.c:184
 ../ruby_trunk/bin/ruby(ruby_run_node+0x3d) [0x4176cd] eval.c:241
 ../ruby_trunk/bin/ruby() [0x414849] main.c:38
 /lib/x86_64-linux-gnu/libc.so.6(__libc_start_main+0xff) [0x7f7785469eff]
 ../ruby_trunk/bin/ruby() [0x414739] 

また、ruby 1.9.2p180ではabortせず、SEGVしました。

インタプリタの終了処理の際、eval.cのruby_cleanup()ではthread.cのrb_thread_terminate_all()が呼ばれ、そこからさらにrb_mutex_unlock_all()が呼ばれて全てのMutexが解放された後に
ruby_finalize_1()が呼ばれてrb_gc_call_finalizer_at_exit()でfinalizerが実行されますが、finalizer内で新たにMutexをロックして解放しないまま抜けてしまうと、
その後呼ばれるruby_vm_destruct()内のthread_free()で落ちます。

rb_gc_call_finalizer_at_exit()をrb_thread_terminate_all()よりも先に呼ぶようにしたところabortしなくなったので、パッチを添付します。

=end


-- 
http://redmine.ruby-lang.org

In This Thread

Prev Next