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

ruby-changes:25039

From: nari <ko1@a...>
Date: Fri, 5 Oct 2012 16:21:01 +0900 (JST)
Subject: [ruby-changes:25039] nari:r37091 (trunk): * gc.c (chain_finalized_object): remove to check a mark flag and

nari	2012-10-05 16:20:49 +0900 (Fri, 05 Oct 2012)

  New Revision: 37091

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

  Log:
    * gc.c (chain_finalized_object): remove to check a mark flag and
      marking since all objects are certainly unmarked with rest_sweep.
    
    * gc.c (rb_objspace_call_finalizer): remove to mark finalizable
      objects. The sweeping doesn't push T_ZOMBIE objects to the
      freelist.

  Modified files:
    trunk/ChangeLog
    trunk/gc.c

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 37090)
+++ ChangeLog	(revision 37091)
@@ -1,3 +1,12 @@
+Fri Oct  5 16:04:33 2012  Narihiro Nakamura  <authornari@g...>
+
+	* gc.c (chain_finalized_object): remove to check a mark flag and
+	  marking since all objects are certainly unmarked with rest_sweep.
+
+	* gc.c (rb_objspace_call_finalizer): remove to mark finalizable
+	  objects. The sweeping doesn't push T_ZOMBIE objects to the
+	  freelist.
+
 Thu Oct  4 23:40:04 2012  Narihiro Nakamura  <authornari@g...>
 
 	* gc.c (init_heap): call init_mark_stack before to allocate
Index: gc.c
===================================================================
--- gc.c	(revision 37090)
+++ gc.c	(revision 37091)
@@ -1442,8 +1442,7 @@
 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 &&
-        !MARKED_IN_BITMAP(GET_HEAP_BITMAP(p), p)) {
+    if ((p->as.basic.flags & FL_FINALIZE) == FL_FINALIZE) {
 	if (BUILTIN_TYPE(p) != T_ZOMBIE) {
 	    p->as.free.flags = T_ZOMBIE;
 	    RDATA(p)->dfree = 0;
@@ -1485,20 +1484,17 @@
     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;

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

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