diff options
author | tarui <tarui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-05-29 16:32:59 +0000 |
---|---|---|
committer | tarui <tarui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-05-29 16:32:59 +0000 |
commit | d0914b355289eaa0498928752466d2ec5660cf2a (patch) | |
tree | 9dd2447b6331090f7b19ade4f2fe366321c2bb3e | |
parent | 2c1a7dc85eceb869c4c8c517b61c28335fc881f4 (diff) | |
download | ruby-d0914b355289eaa0498928752466d2ec5660cf2a.tar.gz |
* thread.c (RB_GC_SAVE_MACHINE_CONTEXT): start GC
by switching the thread if gc_stress == true
* gc.c (ruby_gc_stress_start): dotto.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@28078 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 7 | ||||
-rw-r--r-- | gc.c | 8 | ||||
-rw-r--r-- | thread.c | 3 |
3 files changed, 18 insertions, 0 deletions
@@ -1,3 +1,10 @@ +Sun May 30 01:25:48 2010 Masaya Tarui <tarui@ruby-lnag.org> + + * thread.c (RB_GC_SAVE_MACHINE_CONTEXT): start GC + by switching the thread if gc_stress == true + + * gc.c (ruby_gc_stress_start): dotto. + Sun May 30 00:02:39 2010 Yusuke Endoh <mame@tsg.ne.jp> * gc.c (force_chain_object, rb_objspace_call_finalizer): delete @@ -517,6 +517,14 @@ gc_stress_get(VALUE self) return ruby_gc_stress ? Qtrue : Qfalse; } +void +ruby_gc_stress_start(void) +{ + rb_objspace_t *objspace = &rb_objspace; + if(ruby_gc_stress) + rb_gc(); +} + /* * call-seq: * GC.stress = bool -> bool @@ -99,10 +99,13 @@ static void reset_unblock_function(rb_thread_t *th, const struct rb_unblock_call static inline void blocking_region_end(rb_thread_t *th, struct rb_blocking_region_buffer *region); +void ruby_gc_stress_start(void); + #define RB_GC_SAVE_MACHINE_CONTEXT(th) \ do { \ rb_gc_save_machine_context(th); \ SET_MACHINE_STACK_END(&(th)->machine_stack_end); \ + ruby_gc_stress_start(); \ } while (0) #define GVL_UNLOCK_BEGIN() do { \ |