summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-07-16 08:46:15 +0000
committerko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-07-16 08:46:15 +0000
commited621c001e20b8f6fec152c76360371d8fed38c5 (patch)
tree89583af95aa1c3acdc3ec4889c82e4a776a3f17f
parent73ee1676b0cd82db62a577bf6ac69fc5b7e00c92 (diff)
* gc.c (link_free_heap_slot): removed.
* gc.c (slot_sweep): use `heaps_add_freeslot' instead of `link_free_heap_slot'. * gc.c (assign_heap_slot): use local variable `slot' instead of `heaps'. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@42000 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog10
-rw-r--r--gc.c23
2 files changed, 18 insertions, 15 deletions
diff --git a/ChangeLog b/ChangeLog
index 4c3387fe3d..de57946ddd 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,13 @@
+Tue Jul 16 17:43:22 2013 Koichi Sasada <ko1@atdot.net>
+
+ * gc.c (link_free_heap_slot): removed.
+
+ * gc.c (slot_sweep): use `heaps_add_freeslot' instead of
+ `link_free_heap_slot'.
+
+ * gc.c (assign_heap_slot): use local variable `slot' instead of
+ `heaps'.
+
Tue Jul 16 17:21:39 2013 Koichi Sasada <ko1@atdot.net>
* gc.c (assign_heap_slot): refactoring variable names.
diff --git a/gc.c b/gc.c
index 561c73f053..a470f9404f 100644
--- a/gc.c
+++ b/gc.c
@@ -733,13 +733,6 @@ allocate_sorted_heaps(rb_objspace_t *objspace, size_t next_heaps_length)
}
static void
-link_free_heap_slot(rb_objspace_t *objspace, struct heaps_slot *slot)
-{
- slot->free_next = objspace->heap.free_slots;
- objspace->heap.free_slots = slot;
-}
-
-static void
unlink_free_heap_slot(rb_objspace_t *objspace, struct heaps_slot *slot)
{
objspace->heap.free_slots = slot->free_next;
@@ -791,8 +784,8 @@ assign_heap_slot(rb_objspace_t *objspace)
MEMZERO((void*)slot, struct heaps_slot, 1);
slot->header = header;
- slot->next = objspace->heap.ptr;
+ slot->next = objspace->heap.ptr;
if (objspace->heap.ptr) objspace->heap.ptr->prev = slot;
objspace->heap.ptr = slot;
@@ -841,7 +834,7 @@ assign_heap_slot(rb_objspace_t *objspace)
slot_add_freeobj(objspace, slot, (VALUE)p);
}
- heaps_add_freeslot(objspace, heaps);
+ heaps_add_freeslot(objspace, slot);
}
static void
@@ -2294,12 +2287,12 @@ slot_sweep(rb_objspace_t *objspace, struct heaps_slot *sweep_slot)
unlink_heap_slot(objspace, sweep_slot);
}
else {
- if (freed_num + empty_num > 0) {
- link_free_heap_slot(objspace, sweep_slot);
- }
- else {
- sweep_slot->free_next = NULL;
- }
+ if (freed_num + empty_num > 0) {
+ heaps_add_freeslot(objspace, sweep_slot);
+ }
+ else {
+ sweep_slot->free_next = NULL;
+ }
objspace->heap.free_num += freed_num + empty_num;
}
objspace->total_freed_object_num += freed_num;