* gc.c (rb_gc_giveup_promoted_writebarrier): remove `rest_sweep()'
because all of remembered objects are called for gc_mark_children(). git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@41550 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
7396fbb0b5
commit
b4f907ea29
@ -1,3 +1,8 @@
|
|||||||
|
Sat Jun 22 06:05:36 2013 Koichi Sasada <ko1@atdot.net>
|
||||||
|
|
||||||
|
* gc.c (rb_gc_giveup_promoted_writebarrier): remove `rest_sweep()'
|
||||||
|
because all of remembered objects are called for gc_mark_children().
|
||||||
|
|
||||||
Sat Jun 22 05:08:03 2013 Koichi Sasada <ko1@atdot.net>
|
Sat Jun 22 05:08:03 2013 Koichi Sasada <ko1@atdot.net>
|
||||||
|
|
||||||
* gc.c (rgengc_rememberset_mark): call gc_mark_children() for
|
* gc.c (rgengc_rememberset_mark): call gc_mark_children() for
|
||||||
|
7
gc.c
7
gc.c
@ -3806,13 +3806,6 @@ rb_gc_giveup_promoted_writebarrier(VALUE obj)
|
|||||||
rgengc_report(2, objspace, "rb_gc_giveup_writebarrier: %p (%s)%s\n", (void *)obj, obj_type_name(obj),
|
rgengc_report(2, objspace, "rb_gc_giveup_writebarrier: %p (%s)%s\n", (void *)obj, obj_type_name(obj),
|
||||||
rgengc_remembered(objspace, obj) ? " (already remembered)" : "");
|
rgengc_remembered(objspace, obj) ? " (already remembered)" : "");
|
||||||
|
|
||||||
/* need to sweep all slots before demote */
|
|
||||||
/* TODO: check delayed sweeping slot or not
|
|
||||||
* if delayed sweepling slot, then mark it
|
|
||||||
* else demote simple
|
|
||||||
*/
|
|
||||||
rest_sweep(objspace);
|
|
||||||
|
|
||||||
RVALUE_DEMOTE(obj);
|
RVALUE_DEMOTE(obj);
|
||||||
rgengc_remember(objspace, obj);
|
rgengc_remember(objspace, obj);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user