summaryrefslogtreecommitdiff
path: root/gc.c
diff options
context:
space:
mode:
authornari <nari@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2012-10-05 09:19:49 +0000
committernari <nari@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2012-10-05 09:19:49 +0000
commit4c0f022f45a9221c2f97b2d21a9eb476f40b1d93 (patch)
tree8228c442a01d54fc48520ab34363583b7be48693 /gc.c
parentae114a8ee6ad606ec682fe0af26fa86c9e563237 (diff)
revert r37091
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@37096 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'gc.c')
-rw-r--r--gc.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/gc.c b/gc.c
index d34e70940b..c6bcb1698e 100644
--- a/gc.c
+++ b/gc.c
@@ -1457,7 +1457,8 @@ static int
chain_finalized_object(st_data_t key, st_data_t val, st_data_t arg)
{
RVALUE *p = (RVALUE *)key, **final_list = (RVALUE **)arg;
- if ((p->as.basic.flags & FL_FINALIZE) == FL_FINALIZE) {
+ if ((p->as.basic.flags & FL_FINALIZE) == FL_FINALIZE &&
+ !MARKED_IN_BITMAP(GET_HEAP_BITMAP(p), p)) {
if (BUILTIN_TYPE(p) != T_ZOMBIE) {
p->as.free.flags = T_ZOMBIE;
RDATA(p)->dfree = 0;
@@ -1499,17 +1500,20 @@ rb_objspace_call_finalizer(rb_objspace_t *objspace)
RVALUE *final_list = 0;
size_t i;
+ /* run finalizers */
rest_sweep(objspace);
if (ATOMIC_EXCHANGE(finalizing, 1)) return;
- /* run finalizers */
do {
+ /* XXX: this loop will make no sense */
+ /* because mark will not be removed */
finalize_deferred(objspace);
+ mark_tbl(objspace, finalizer_table);
+ gc_mark_stacked_objects(objspace);
st_foreach(finalizer_table, chain_finalized_object,
(st_data_t)&deferred_final_list);
} while (deferred_final_list);
-
/* force to run finalizer */
while (finalizer_table->num_entries) {
struct force_finalize_list *list = 0;