diff options
author | Jean Boussier <[email protected]> | 2023-11-13 08:13:33 +0100 |
---|---|---|
committer | Jean Boussier <[email protected]> | 2023-11-13 08:57:57 +0100 |
commit | f1b95095d6635567cc5820b3eb40d9618faa73ed (patch) | |
tree | 2c96ce94c67494085e292e21056ceeb84a6efac7 /gc.c | |
parent | a1887f4dc2e62455a605944468e59e647f698f1a (diff) |
Revert "Wrap rb_objspace_reachable_objects_from_root with RB_VM_LOCK"
This reverts commit 76dc327eeffefe02577999fe5f8215f762a581b6.
Diffstat (limited to 'gc.c')
-rw-r--r-- | gc.c | 28 |
1 files changed, 12 insertions, 16 deletions
@@ -11987,23 +11987,19 @@ objspace_reachable_objects_from_root(rb_objspace_t *objspace, void (func)(const { if (during_gc) rb_bug("objspace_reachable_objects_from_root() is not supported while during_gc == true"); - RB_VM_LOCK_ENTER(); - { - rb_ractor_t *cr = GET_RACTOR(); - struct root_objects_data data = { - .func = func, - .data = passing_data, - }; - struct gc_mark_func_data_struct mfd = { - .mark_func = root_objects_from, - .data = &data, - }, *prev_mfd = cr->mfd; + rb_ractor_t *cr = GET_RACTOR(); + struct root_objects_data data = { + .func = func, + .data = passing_data, + }; + struct gc_mark_func_data_struct mfd = { + .mark_func = root_objects_from, + .data = &data, + }, *prev_mfd = cr->mfd; - cr->mfd = &mfd; - gc_mark_roots(objspace, &data.category); - cr->mfd = prev_mfd; - } - RB_VM_LOCK_LEAVE(); + cr->mfd = &mfd; + gc_mark_roots(objspace, &data.category); + cr->mfd = prev_mfd; } /* |