[#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

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

[#44276] Re: 1.9.3 (以降) の BigDecimal について — Kenta Murata <muraken@...> 2011/07/31

=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@...>

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:44023] Re: [ruby-core:37707] [Ruby 1.9 - Bug #3781] FIBER_USE_NATIVE が有効だと落ちるスクリプトがある

From: Narihiro Nakamura <authornari@...>
Date: 2011-07-03 00:59:26 UTC
List: ruby-dev #44023
nariです。

2011年7月3日0:01 KOSAKI Motohiro <kosaki.motohiro@gmail.com>:
>> GC::Profiler.enable
>> a = []
>> 10000000.times{a << "a".dup}
>> p GC::Profiler.total_time
>>
>> パッチ適用後: 1.410000000000001
>> バッチ適用前: 1.4899999999999998
>>
>> と、4%くらい劣化してます。
>> これくらいなら入れしまっていいかもしれませんが。
>> うーん、バグ修正で4%も性能が落ちるのはなぁと正直悩んでます…。
>
> おお、結構効きますね。こちらでも測ってみました。nariさんのに加えて
> 16段に一回だけチェックするようにしたやつ
>
> trunk: 1.3090170000000483
> nariパッチ: 1.3393349999998874
> kosakiパッチ: 1.294899000000145
>
> 16に意味は全然ないのですが、何回かに一回だけチェックという論理で
> オーバーヘッドはほぼ無視できるようです。
> (元のより速くなってるのはたぶん測定誤差です。すいません)
>
>
> ~/ruby/trunk% svn diff
> Index: gc.c
> ===================================================================
> --- gc.c        (revision 32355)
> +++ gc.c        (working copy)
> @@ -1614,7 +1614,7 @@
>     obj->as.basic.flags |= FL_MARK;
>     objspace->heap.live_num++;
>
> -    if (lev > GC_LEVEL_MAX || (lev == 0 && stack_check())) {
> +    if (lev > GC_LEVEL_MAX || (((lev&0xF)==0) && stack_check())) {
>        if (!mark_stack_overflow) {
>            if (mark_stack_ptr - mark_stack < MARK_STACK_MAX) {
>                *mark_stack_ptr = ptr;
>
>

以下のベンチマークで測ってみました。

GC::Profiler.enable
a = []
def make_depth(b, lev)
  return b << "a" if (lev-=1) <= 0
  b << []; make_depth(b.first, lev)
  return b
end
200000.times{a << make_depth([], 200)}
p GC::Profiler.total_time

trunk: 9.31
nariパッチ: 9.63
kosakiパッチ: 10.25

maskする分遅くなってしまうような気がします。

やはり、遠藤さんの仰ったように、stack_check()の引数にGC_WARTER_MARKを渡すように修正するのが
よさそうだと思っています。

-- 
Narihiro Nakamura (nari)

In This Thread