diff options
author | nari <nari@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2012-02-19 03:07:59 +0000 |
---|---|---|
committer | nari <nari@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2012-02-19 03:07:59 +0000 |
commit | 55e6e9e3848433ccb095b352545bb97b0fb21603 (patch) | |
tree | b79a47437420a7396e0c8a52de3d669146746f50 /gc.c | |
parent | 541e1aff202013c1de8c4e462e070bbe40b283c4 (diff) | |
download | ruby-55e6e9e3848433ccb095b352545bb97b0fb21603.tar.gz |
* gc.c (gc_clear_mark_on_sweep_slots): uses slot_sweep() for
unsweeped slots, because some dead objects might be marked in
next the mark phase by false pointers. [ruby-core:42672]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@34689 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'gc.c')
-rw-r--r-- | gc.c | 3 |
1 files changed, 1 insertions, 2 deletions
@@ -2627,8 +2627,7 @@ gc_clear_mark_on_sweep_slots(rb_objspace_t *objspace) if (objspace->heap.sweep_slots) { while (heaps_increment(objspace)); while (objspace->heap.sweep_slots) { - scan = objspace->heap.sweep_slots; - gc_clear_slot_bits(scan); + slot_sweep(objspace, objspace->heap.sweep_slots); objspace->heap.sweep_slots = objspace->heap.sweep_slots->next; } } |