Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Commit 1048b16

Browse files
committed
Eagerly store a copy of object_id in finalizer table.
This makes the finalizer table fully self contained, so GC no longer need to delay cleaning the `obj_to_id_tbl`.
1 parent a8aa83c commit 1048b16

File tree

1 file changed

+10
-29
lines changed

1 file changed

+10
-29
lines changed

gc/default/default.c

+10-29
Original file line numberDiff line numberDiff line change
@@ -2632,7 +2632,7 @@ rb_gc_impl_pointer_to_heap_p(void *objspace_ptr, const void *ptr)
26322632
return is_pointer_to_heap(objspace_ptr, ptr);
26332633
}
26342634

2635-
#define ZOMBIE_OBJ_KEPT_FLAGS (FL_SEEN_OBJ_ID | FL_FINALIZE)
2635+
#define ZOMBIE_OBJ_KEPT_FLAGS (FL_FINALIZE)
26362636

26372637
void
26382638
rb_gc_impl_make_zombie(void *objspace_ptr, VALUE obj, void (*dfree)(void *), void *data)
@@ -2856,7 +2856,7 @@ rb_gc_impl_define_finalizer(void *objspace_ptr, VALUE obj, VALUE block)
28562856
rb_ary_push(table, block);
28572857
}
28582858
else {
2859-
table = rb_ary_new3(1, block);
2859+
table = rb_ary_new3(2, rb_gc_impl_object_id(objspace, obj), block);
28602860
rb_obj_hide(table);
28612861
st_add_direct(finalizer_table, obj, table);
28622862
}
@@ -2897,25 +2897,12 @@ rb_gc_impl_copy_finalizer(void *objspace_ptr, VALUE dest, VALUE obj)
28972897
}
28982898
}
28992899

2900-
static VALUE
2901-
get_object_id_in_finalizer(rb_objspace_t *objspace, VALUE obj)
2902-
{
2903-
if (FL_TEST_RAW(obj, FL_SEEN_OBJ_ID)) {
2904-
return rb_gc_impl_object_id(objspace, obj);
2905-
}
2906-
else {
2907-
VALUE id = ULL2NUM(objspace->next_object_id);
2908-
objspace->next_object_id += OBJ_ID_INCREMENT;
2909-
return id;
2910-
}
2911-
}
2912-
29132900
static VALUE
29142901
get_final(long i, void *data)
29152902
{
29162903
VALUE table = (VALUE)data;
29172904

2918-
return RARRAY_AREF(table, i);
2905+
return RARRAY_AREF(table, i + 1);
29192906
}
29202907

29212908
static void
@@ -2930,7 +2917,7 @@ run_final(rb_objspace_t *objspace, VALUE zombie)
29302917
FL_UNSET(zombie, FL_FINALIZE);
29312918
st_data_t table;
29322919
if (st_delete(finalizer_table, &key, &table)) {
2933-
rb_gc_run_obj_finalizer(get_object_id_in_finalizer(objspace, zombie), RARRAY_LEN(table), get_final, (void *)table);
2920+
rb_gc_run_obj_finalizer(RARRAY_AREF(table, 0), RARRAY_LEN(table) - 1, get_final, (void *)table);
29342921
}
29352922
else {
29362923
rb_bug("FL_FINALIZE flag is set, but finalizers are not found");
@@ -2956,10 +2943,6 @@ finalize_list(rb_objspace_t *objspace, VALUE zombie)
29562943
int lev = rb_gc_vm_lock();
29572944
{
29582945
GC_ASSERT(BUILTIN_TYPE(zombie) == T_ZOMBIE);
2959-
if (FL_TEST_RAW(zombie, FL_SEEN_OBJ_ID)) {
2960-
obj_free_object_id(objspace, zombie);
2961-
}
2962-
29632946
GC_ASSERT(page->heap->final_slots_count > 0);
29642947
GC_ASSERT(page->final_slots > 0);
29652948

@@ -3071,16 +3054,15 @@ rb_gc_impl_shutdown_free_objects(void *objspace_ptr)
30713054
}
30723055

30733056
static int
3074-
rb_gc_impl_shutdown_call_finalizer_i(st_data_t key, st_data_t val, st_data_t data)
3057+
rb_gc_impl_shutdown_call_finalizer_i(st_data_t key, st_data_t val, st_data_t _data)
30753058
{
3076-
rb_objspace_t *objspace = (rb_objspace_t *)data;
30773059
VALUE obj = (VALUE)key;
30783060
VALUE table = (VALUE)val;
30793061

30803062
GC_ASSERT(RB_FL_TEST(obj, FL_FINALIZE));
30813063
GC_ASSERT(RB_BUILTIN_TYPE(val) == T_ARRAY);
30823064

3083-
rb_gc_run_obj_finalizer(rb_gc_impl_object_id(objspace, obj), RARRAY_LEN(table), get_final, (void *)table);
3065+
rb_gc_run_obj_finalizer(RARRAY_AREF(table, 0), RARRAY_LEN(table) - 1, get_final, (void *)table);
30843066

30853067
FL_UNSET(obj, FL_FINALIZE);
30863068

@@ -3107,7 +3089,7 @@ rb_gc_impl_shutdown_call_finalizer(void *objspace_ptr)
31073089
}
31083090

31093091
while (finalizer_table->num_entries) {
3110-
st_foreach(finalizer_table, rb_gc_impl_shutdown_call_finalizer_i, (st_data_t)objspace);
3092+
st_foreach(finalizer_table, rb_gc_impl_shutdown_call_finalizer_i, 0);
31113093
}
31123094

31133095
/* run finalizers */
@@ -3564,12 +3546,11 @@ gc_sweep_plane(rb_objspace_t *objspace, rb_heap_t *heap, uintptr_t p, bits_t bit
35643546

35653547
rb_gc_event_hook(vp, RUBY_INTERNAL_EVENT_FREEOBJ);
35663548

3567-
bool has_object_id = FL_TEST_RAW(vp, FL_SEEN_OBJ_ID);
3549+
if (FL_TEST_RAW(vp, FL_SEEN_OBJ_ID)) {
3550+
obj_free_object_id(objspace, vp);
3551+
}
35683552
rb_gc_obj_free_vm_weak_references(vp);
35693553
if (rb_gc_obj_free(objspace, vp)) {
3570-
if (has_object_id) {
3571-
obj_free_object_id(objspace, vp);
3572-
}
35733554
// always add free slots back to the swept pages freelist,
35743555
// so that if we're compacting, we can re-use the slots
35753556
(void)VALGRIND_MAKE_MEM_UNDEFINED((void*)p, BASE_SLOT_SIZE);

0 commit comments

Comments
 (0)