[#43465] GVL改善案 — KOSAKI Motohiro <kosaki.motohiro@...>
小崎です
[#43467] [Q] thread->interrupt_flag が適切に排他制御されていないように見える — KOSAKI Motohiro <kosaki.motohiro@...>
kosakiです
ささだです.
> ささだです.
ささだです.
> ささだです.
自己解決しました
ささだです.
>> ということは危ないのは RUBY_VM_SET_INTERRUPT() がロストしたときに、タイムアウトなしの
>>> ということは危ないのは RUBY_VM_SET_INTERRUPT() がロストしたときに、タイムアウトなしの
[#43468] Re: [ruby-changes:19438] Ruby:r31478 (trunk): * test/date/*.rb: use skip /w messages. — KOSAKI Motohiro <kosaki.motohiro@...>
2011/5/8 tadf <ko1@atdot.net>:
> 表示したい場合を除いてはskipよりもreturnを使うようお願いしています。
>> 表示したい場合を除いてはskipよりもreturnを使うようお願いしています。
[#43476] [Ruby 1.9 - Feature #4653][Open] [PATCH 1/1] new method Enumerable#rude_map — Shyouhei Urabe <shyouhei@...>
遠藤です。
(05/08/2011 11:21 PM), Yusuke ENDOH wrote:
遠藤です。
卜部です。
At Mon, 9 May 2011 16:35:31 +0900,
遠藤です。
[#43493] [Ruby 1.9 - Feature #4657][Open] add option to hide skip messages on unit/test — Shota Fukumori <sorah@...>
> -q, --hide-skipでskipメッセージが表示されなくなります。
(05/09/2011 06:31 PM), Shota Fukumori wrote:
> (05/09/2011 06:31 PM), Shota Fukumori wrote:
2011/5/9 KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com>:
> 2011/5/9 KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com>:
[#43502] draft schedule of Ruby 1.9.3 — "Yuki Sonoda (Yugui)" <yugui@...>
-----BEGIN PGP SIGNED MESSAGE-----
Hi
Hello,
(ruby-coreはずしました)
こんにちは、なかむら(う)です。
こんにちは、なかむら(う)です。
[#43549] RubyKaigi2011に'CRuby'コミッタの皆さまを招待いたします(締切:2011-06-15) — Kakutani Shintaro <shintaro.kakutani@...>
'CRuby'コミッタの皆さまへ
[#43554] [Ruby 1.9 - Bug #4696][Assigned] thread.c#lock_func() が spurious wakeup unsafe — Motohiro KOSAKI <kosaki.motohiro@...>
[#43606] [Ruby 1.9 - Bug #4808][Open] thread_wait_for() eats 100% of CPU power — Hidetoshi Nagai <nagai@...>
> いつからかは把握できていませんが (少なくとも 1.9.2p0 では発生しません),
[ruby-dev:43489] Re: [Q] thread->interrupt_flag が適切に排他制御されていないように見える
自己解決しました
> あれ,そうだったっけ>メインスレッドだけ.そんなことないような.
これはただのうっかりなので、おいとくとして
(RUBY_VM_SET_TIMER_INTERRUPT(vm->running_thread) なので自明だった)
> いや、あの。補足をお願いして良いですか。の返事がこれだとESP能力を
> 要求されてる感じです。ボスケテ
>
> static void
> timer_thread_function(void *arg)
> {
> rb_vm_t *vm = GET_VM(); /* TODO: fix me for Multi-VM */
>
> /* for time slice */
> RUBY_VM_SET_TIMER_INTERRUPT(vm->running_thread);
>
> /* check signal */
> rb_threadptr_check_signal(vm->main_thread);
>
> void
> rb_threadptr_check_signal(rb_thread_t *mth)
> {
> int sig;
>
> /* mth must be main_thread */
>
> if (!mth->exec_signal && (sig = rb_get_next_signal()) > 0) {
> enum rb_thread_status prev_status = mth->status;
> thread_debug("main_thread: %s, sig: %d\n",
> thread_status_name(prev_status), sig);
> mth->exec_signal = sig;
> if (mth->status != THREAD_KILLED) mth->status = THREAD_RUNNABLE;
> rb_threadptr_interrupt(mth);
> mth->status = prev_status;
> }
> }
>
> なので、メインスレッドが定期的に rb_threadptr_interrupt()呼ばれてるのは
> 自明なんですが、他のスレッドはどこからでしょうか?
タイマースレッドがrunning thread に配送されて、rb_threadptr_execute_interrupts_rec()で
/* signal handling */
if (th->exec_signal) {
(1)
}
/* exception from another thread */
if (th->thrown_errinfo) {
(2)
}
if (finalizer_interrupt) {
(3)
rb_gc_finalize_deferred();
}
のようになっているから、(1)と(2)はRUBY_VM_INTERRUPTED()を使っていないのでセーフ。
(3)は次のgcの時にもう一回フラグが立つからセーフということですね?
ということは危ないのは RUBY_VM_SET_INTERRUPT() がロストしたときに、タイムアウトなしの
スリープをしていて、vm->running_thread にならないから、タイマースレッドに
起こして貰えないケースでしょうか?