From f6e9452b23e4aeb84c2c3cd12eaa10d802115fa6 Mon Sep 17 00:00:00 2001 From: ko1 Date: Tue, 17 Mar 2015 09:57:47 +0000 Subject: * benchmark/bm_vm1_gc_wb_ary(_promoted).rb: separate fastpath and slowpath for WB. Before this change bm_vm1_gc_wb_ary.rb tried to check the performance for WB slowpath (making a reference from oldobj to newobj). However, from Ruby 2.2, 3 GCs are needed to promote new objects because only 3 age objects are promted objects. To compare fastpath and slowpath, introduce new "promoted" version benchmark. bm_vm1_gc_wb_ary.rb is for fastpath and bm_vm1_gc_wb_ary_promoted.rb is for slowpath. * benchmark/bm_vm1_gc_wb_obj(_promtoed).rb: ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@49985 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- benchmark/bm_vm1_gc_wb_ary.rb | 6 ++---- benchmark/bm_vm1_gc_wb_ary_promoted.rb | 14 ++++++++++++++ benchmark/bm_vm1_gc_wb_obj.rb | 6 ++---- benchmark/bm_vm1_gc_wb_obj_promoted.rb | 17 +++++++++++++++++ 4 files changed, 35 insertions(+), 8 deletions(-) create mode 100644 benchmark/bm_vm1_gc_wb_ary_promoted.rb create mode 100644 benchmark/bm_vm1_gc_wb_obj_promoted.rb (limited to 'benchmark') diff --git a/benchmark/bm_vm1_gc_wb_ary.rb b/benchmark/bm_vm1_gc_wb_ary.rb index ecfab51dbf..e80538a2da 100644 --- a/benchmark/bm_vm1_gc_wb_ary.rb +++ b/benchmark/bm_vm1_gc_wb_ary.rb @@ -1,10 +1,8 @@ -long_lived = [] -GC.start -GC.start +short_lived_ary = [] i = 0 short_lived = '' while i<30_000_000 # while loop 1 - long_lived[0] = short_lived # write barrier + short_lived_ary[0] = short_lived # write barrier i+=1 end diff --git a/benchmark/bm_vm1_gc_wb_ary_promoted.rb b/benchmark/bm_vm1_gc_wb_ary_promoted.rb new file mode 100644 index 0000000000..612ec9f888 --- /dev/null +++ b/benchmark/bm_vm1_gc_wb_ary_promoted.rb @@ -0,0 +1,14 @@ +long_lived = [] + +if RUBY_VERSION > "2.2.0" + 3.times{ GC.start(immediate_mark: false, lazy_sweep: false) } +elsif + GC.start +end + +i = 0 +short_lived = '' +while i<30_000_000 # while loop 1 + long_lived[0] = short_lived # write barrier + i+=1 +end diff --git a/benchmark/bm_vm1_gc_wb_obj.rb b/benchmark/bm_vm1_gc_wb_obj.rb index 017eff4f94..9e0aadbbaf 100644 --- a/benchmark/bm_vm1_gc_wb_obj.rb +++ b/benchmark/bm_vm1_gc_wb_obj.rb @@ -1,13 +1,11 @@ class C attr_accessor :foo end -long_lived = C.new -GC.start -GC.start +short_lived_obj = C.new i = 0 short_lived = '' while i<30_000_000 # while loop 1 - long_lived.foo = short_lived # write barrier + short_lived_obj.foo = short_lived # write barrier i+=1 end diff --git a/benchmark/bm_vm1_gc_wb_obj_promoted.rb b/benchmark/bm_vm1_gc_wb_obj_promoted.rb new file mode 100644 index 0000000000..7967e83726 --- /dev/null +++ b/benchmark/bm_vm1_gc_wb_obj_promoted.rb @@ -0,0 +1,17 @@ +class C + attr_accessor :foo +end +long_lived = C.new + +if RUBY_VERSION > "2.2.0" + 3.times{ GC.start(immediate_mark: false, lazy_sweep: false) } +elsif + GC.start +end + +i = 0 +short_lived = '' +while i<30_000_000 # while loop 1 + long_lived.foo = short_lived # write barrier + i+=1 +end -- cgit v1.2.3