[前][次][番号順一覧][スレッド一覧]

ruby-changes:17646

From: ko1 <ko1@a...>
Date: Mon, 1 Nov 2010 00:41:21 +0900 (JST)
Subject: [ruby-changes:17646] Ruby:r29654 (trunk): * gc.c (finalizer_table, objspace->final.table):

ko1	2010-11-01 00:41:14 +0900 (Mon, 01 Nov 2010)

  New Revision: 29654

  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=29654

  Log:
    * gc.c (finalizer_table, objspace->final.table):
      Create finalizer_table at Init_heap().
      Remove all null checks of finalizer_table.
    * gc.c (mark_tbl): skip if no table entries.
    * gc.c (slot_swee): remove useless need_call_final check.

  Modified files:
    trunk/ChangeLog
    trunk/gc.c

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 29653)
+++ ChangeLog	(revision 29654)
@@ -1,3 +1,13 @@
+Sun Oct 31 23:27:09 2010  Koichi Sasada  <ko1@a...>
+
+	* gc.c (finalizer_table, objspace->final.table):
+	  Create finalizer_table at Init_heap().
+	  Remove all null checks of finalizer_table.
+
+	* gc.c (mark_tbl): skip if no table entries.
+
+	* gc.c (slot_swee): remove useless need_call_final check.
+
 Sun Oct 31 22:32:08 2010  Nobuyoshi Nakada  <nobu@r...>
 
 	* gc.c (rb_objspace_free): finalizers should be called separately
Index: gc.c
===================================================================
--- gc.c	(revision 29653)
+++ gc.c	(revision 29654)
@@ -386,8 +386,6 @@
 #define global_List		objspace->global_list
 #define ruby_gc_stress		objspace->gc_stress
 
-#define need_call_final 	(finalizer_table && finalizer_table->num_entries)
-
 static void rb_objspace_call_finalizer(rb_objspace_t *objspace);
 
 #if defined(ENABLE_VM_OBJSPACE) && ENABLE_VM_OBJSPACE
@@ -1005,6 +1003,7 @@
     }
     heaps_inc = 0;
     objspace->profile.invoke_time = getrusage_time();
+    finalizer_table = st_init_numtable();
 }
 
 
@@ -1389,7 +1388,7 @@
 mark_tbl(rb_objspace_t *objspace, st_table *tbl, int lev)
 {
     struct mark_tbl_arg arg;
-    if (!tbl) return;
+    if (!tbl || tbl->num_entries == 0) return;
     arg.objspace = objspace;
     arg.lev = lev;
     st_foreach(tbl, mark_entry, (st_data_t)&arg);
@@ -1956,7 +1955,7 @@
         if (!(p->as.basic.flags & FL_MARK)) {
             if (p->as.basic.flags &&
                 ((deferred = obj_free(objspace, (VALUE)p)) ||
-                 ((FL_TEST(p, FL_FINALIZE)) && need_call_final))) {
+		 (FL_TEST(p, FL_FINALIZE)))) {
                 if (!deferred) {
                     p->as.free.flags = T_ZOMBIE;
                     RDATA(p)->dfree = 0;
@@ -2397,10 +2396,7 @@
 
     th->vm->self ? rb_gc_mark(th->vm->self) : rb_vm_mark(th->vm);
 
-    if (finalizer_table) {
-	mark_tbl(objspace, finalizer_table, 0);
-    }
-
+    mark_tbl(objspace, finalizer_table, 0);
     mark_current_machine_context(objspace, th);
 
     rb_gc_mark_symbols();
@@ -2760,11 +2756,9 @@
 undefine_final(VALUE os, VALUE obj)
 {
     rb_objspace_t *objspace = &rb_objspace;
+    st_data_t data = obj;
     rb_check_frozen(obj);
-    if (finalizer_table) {
-	st_data_t data = obj;
-	st_delete(finalizer_table, &data, 0);
-    }
+    st_delete(finalizer_table, &data, 0);
     FL_UNSET(obj, FL_FINALIZE);
     return obj;
 }
@@ -2803,9 +2797,6 @@
     block = rb_ary_new3(2, INT2FIX(rb_safe_level()), block);
     OBJ_FREEZE(block);
 
-    if (!finalizer_table) {
-	finalizer_table = st_init_numtable();
-    }
     if (st_lookup(finalizer_table, obj, &data)) {
 	table = (VALUE)data;
 	rb_ary_push(table, block);
@@ -2825,7 +2816,6 @@
     VALUE table;
     st_data_t data;
 
-    if (!finalizer_table) return;
     if (!FL_TEST(obj, FL_FINALIZE)) return;
     if (st_lookup(finalizer_table, obj, &data)) {
 	table = (VALUE)data;
@@ -2885,8 +2875,7 @@
     }
 
     key = (st_data_t)obj;
-    if (finalizer_table &&
-	st_delete(finalizer_table, &key, &table)) {
+    if (st_delete(finalizer_table, &key, &table)) {
 	run_finalizer(objspace, obj, objid, (VALUE)table);
     }
 }
@@ -2954,7 +2943,7 @@
     rb_objspace_call_finalizer(&rb_objspace);
 }
 
-void
+static void
 rb_objspace_call_finalizer(rb_objspace_t *objspace)
 {
     RVALUE *p, *pend;
@@ -2962,33 +2951,32 @@
     size_t i;
 
     /* run finalizers */
-    if (finalizer_table) {
-        gc_clear_mark_on_sweep_slots(objspace);
-	do {
-	    /* XXX: this loop will make no sense */
-	    /* because mark will not be removed */
-	    finalize_deferred(objspace);
-	    mark_tbl(objspace, finalizer_table, 0);
-	    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;
-	    st_foreach(finalizer_table, force_chain_object, (st_data_t)&list);
-	    while (list) {
-		struct force_finalize_list *curr = list;
-		run_finalizer(objspace, curr->obj, rb_obj_id(curr->obj), curr->table);
-		st_delete(finalizer_table, (st_data_t*)&curr->obj, 0);
-		list = curr->next;
-		xfree(curr);
-	    }
+    gc_clear_mark_on_sweep_slots(objspace);
+
+    do {
+	/* XXX: this loop will make no sense */
+	/* because mark will not be removed */
+	finalize_deferred(objspace);
+	mark_tbl(objspace, finalizer_table, 0);
+	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;
+	st_foreach(finalizer_table, force_chain_object, (st_data_t)&list);
+	while (list) {
+	    struct force_finalize_list *curr = list;
+	    run_finalizer(objspace, curr->obj, rb_obj_id(curr->obj), curr->table);
+	    st_delete(finalizer_table, (st_data_t*)&curr->obj, 0);
+	    list = curr->next;
+	    xfree(curr);
 	}
-	st_free_table(finalizer_table);
-	finalizer_table = 0;
     }
+
     /* finalizers are part of garbage collection */
     during_gc++;
+
     /* run data object's finalizers */
     for (i = 0; i < heaps_used; i++) {
 	p = objspace->heap.sorted[i].start; pend = objspace->heap.sorted[i].end;
@@ -3023,6 +3011,9 @@
     if (final_list) {
 	finalize_list(objspace, final_list);
     }
+
+    st_free_table(finalizer_table);
+    finalizer_table = 0;
 }
 
 void

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

[前][次][番号順一覧][スレッド一覧]