[#44014] Re: [ruby-core:37707] [Ruby 1.9 - Bug #3781] FIBER_USE_NATIVE が有効だと落ちるスクリプトがある — Narihiro Nakamura <authornari@...>
nariです。
> 本当はgc_mark()の際に毎回stack_check()するのがいいと思うのですが、
nariです。
> GC::Profiler.enable
nariです。
[#44027] [RubyKaigi] Next version of Ruby 1.8 and 1.9 — "Yuki Sonoda (Yugui)" <yugui@...>
-----BEGIN PGP SIGNED MESSAGE-----
遠藤です。
ささだです.
[#44034] [Ruby 1.9 - Bug #4971][Open] Module#class_variables — Shugo Maeda <redmine@...>
[#44048] [Ruby 1.9 - Bug #4223] GC.stress = true で謎の ArgumentError — Motohiro KOSAKI <kosaki.motohiro@...>
=E3=82=80=E3=82=89=E3=81=9F=E3=81=A7=E3=81=99=E3=80=82
[#44122] [Ruby 1.9 - Bug #5036][Open] time_modify/struct_modifyの例外メッセージがサブクラスの情報を反映しない — Kazuki Tsujimoto <kazuki@...>
[#44130] w.r.o/bugreport.html のリダイレクト先について — "Shota Fukumori (sora_h)" <sorah@...>
sora_hです.
[#44156] [Ruby 1.9 - Feature #5053][Open] ruby コマンドと libruby の食い違いチェック — Makoto Kishimoto <redmine@...>
[#44157] Re: [ruby-changes:20532] akr:r32579 (trunk): * io.c (rb_update_max_fd): new function. — KOSAKI Motohiro <kosaki.motohiro@...>
akrさん、
[#44189] [Ruby 1.9 - Bug #5075][Assigned] invalid *fdp in Mac OS X and FreeBSD over recvmsg with SCM_RIGHTS — Yui NARUSE <naruse@...>
2011/7/22 Yui NARUSE <naruse@airemix.jp>:
In message <CANjopZGqKbM4O6vMkOHrZcD1YLLOJ86-hDHsK3C+px9kdrW4Eg@mail.gmail.com>
[#44201] [Ruby 1.9 - Bug #5081][Open] LionでTestSyslog が一件 failure — Motohiro KOSAKI <kosaki.motohiro@...>
[#44210] 1.9.3 (以降) の BigDecimal について — Tadayoshi Funaba <tadf@...>
BigDecimal() で整数、浮動小数点数、有理数などを受けとれるようになって、
変換には明示的なものとそうでないものがありますが、
=E3=82=80=E3=82=89=E3=81=9F=E3=81=A7=E3=81=99=E3=80=82 =20
> 後者の暗黙的変換については、相手の BigDecimal に合わせて精度を決定できます。
=E3=82=80=E3=82=89=E3=81=9F=E3=81=A7=E3=81=99=E3=80=82 =20
だから、現時点で精度を必須にするのはあまり意味がないんじゃないですかね。
=E3=82=80=E3=82=89=E3=81=9F=E3=81=A7=E3=81=99=E3=80=82 =20
[#44223] [Ruby 1.9 - Bug #5094][Assigned] Supported platforms of Ruby 1.9.3 — Yui NARUSE <naruse@...>
> == 成瀬の提案
卜部です
遠藤です。
(07/26/2011 12:38 PM), Yusuke ENDOH wrote:
遠藤です。
卜部で、前回のメールに書き忘れたことがあったとすれば、べつに192のク
遠藤です。
2011年7月26日22:39 Yusuke ENDOH <mame@tsg.ne.jp>:
[#44251] [Ruby 1.9 - Bug #372][Assigned] Rinda has a race condition — Motohiro KOSAKI <kosaki.motohiro@...>
[#44253] [Ruby 1.9 - Bug #5104][Open] test_rinda.rb の GC保護もれ — Tomoyuki Chikanaga <nagachika00@...>
[#44254] [Ruby 1.8 - Bug #5105][Open] CGI::Session#session_id の生成方法について — Masahiro Tomita <tommy@...>
とみたです。
(2011/07/27 19:47), とみたまさひろ wrote:
とみたです。
とみたです。
2011年7月29日20:04 とみたまさひろ <tommy@tmtm.org>:
(2011/07/29 23:55), Tanaka Akira wrote:
2011年8月13日17:31 NARUSE, Yui <naruse@airemix.jp>:
>> ふと思ったのですが、 openssl を使うときでも、/dev/urandom があるならば、
(2011/08/13 20:35), KOSAKI Motohiro wrote:
2011年8月13日23:12 NARUSE, Yui <naruse@airemix.jp>:
[ruby-dev:44030] Re: [ruby-core:37707] [Ruby 1.9 - Bug #3781] FIBER_USE_NATIVE が有効だと落ちるスクリプトがある
> nariです。
>
> ちと話を整理させてください。
> 本件で、GCに関するバグを直す方法は今のところ以下の2つの案があります。
>
> (1)gc_mark()時に必ずstack_check()を呼ぶようにする
> (2)GC_WATER_MARKをlev<=GC_LEVEL_MAXまでgc_mark()を呼び出せる(おおまかな)サイズにする
>
> (1)に関してはstack_check()の精度がよく、ギリギリまでマシンスタックを使
> うことができますが、gc_mark()の速度低下を引き起こすので、駄目そうな気配
> がしてます。
>
> 一方、(2)はstack_check()の精度が粗いのですが、gc_mark()の速度は変わりま
> せん。また、Fiber以外の環境で普通にRubyを使ってる範囲では、ギリギリまで
> マシンスタックを使うことはあまりないと思いますので、stack_check()を厳密
> にやりすぎるのもどうかという気持ちもあります。
>
> といったところで、速度面でも劣化がない(2)の修正をいれようと思うのですが
> いかがでしょうか?
いいと思います。
64bit 環境ではFiberのスタックを単に増やせばいいと思います。32bitではnative fiber
をやめるのと、最大fiber数減るの覚悟でスタック増やすのと二択ですけど、判断は
ささださんにおまかせしたい。
> 遠藤さんの仰ったような、stack_check()の引数にwater_markを入れるパッチを
> 作りました。本スレッドで上げてきたベンチマークプログラムの結果では性能
> 劣化はないことを確認しています。
>
>
> diff --git a/gc.c b/gc.c
> index d5b8dfd..d7b6fc3 100644
> --- a/gc.c
> +++ b/gc.c
> @@ -1277,7 +1277,9 @@ ruby_get_stack_grow_direction(volatile VALUE *addr)
> }
> #endif
>
> -#define GC_WATER_MARK 512
> +#define GC_LEVEL_MAX 250
> +#define MARK_CALL_FRAME_SIZE 28
28はあまりにもマジックナンバー過ぎるのでコメントを書くか、configureで似たような関数
コンパイルさせてみて計算するのがよいと思います。
> +#define GC_WATER_MARK (GC_LEVEL_MAX * MARK_CALL_FRAME_SIZE)
>
> size_t
> ruby_stack_length(VALUE **p)
> @@ -1289,28 +1291,30 @@ ruby_stack_length(VALUE **p)
> }
>
> static int
> -stack_check(void)
> +stack_check(int water_mark)
> {
> int ret;
> rb_thread_t *th = GET_THREAD();
> SET_STACK_END;
> - ret = STACK_LENGTH > STACK_LEVEL_MAX - GC_WATER_MARK;
> + ret = STACK_LENGTH > STACK_LEVEL_MAX - water_mark;
> #ifdef __ia64
> if (!ret) {
> ret = (VALUE*)rb_ia64_bsp() - th->machine_register_stack_start >
> - th->machine_register_stack_maxsize/sizeof(VALUE) - GC_WATER_MARK;
> + th->machine_register_stack_maxsize/sizeof(VALUE) - water_mark;
> }
> #endif
> return ret;
> }
>
> +#define WATER_MARK 512
> +
GC_WATER_MARKが存在するファイルで、WATER_MARKというdefineがでてくるのは
ひどいと思います。
> int
> ruby_stack_check(void)
> {
> #if defined(POSIX_SIGNAL) && defined(SIGSEGV) && defined(HAVE_SIGALTSTACK)
> return 0;
> #else
> - return stack_check();
> + return stack_check(WATER_MARK);
> #endif
> }
今気づいたのですが、この関数の仮定がFiberで成立してない気がします。
なかださんか、ささださんに言うべきだけど。
#if defined(POSIX_SIGNAL) && defined(SIGSEGV) && defined(HAVE_SIGALTSTACK)
の場合は、sigsegv()ハンドラで実際にSIGSEGVが配送されてからsysstack_errorをraiseするかどうか
決めてるけど、ここで判定に失敗してsysstackではなくrb_bugのほうに行ってしまうのもバグっぽい
気がします。FiberでGC以外が原因でstackあふれたときに同じくSEGVしてしまうので。