diff options
author | Peter Zhu <[email protected]> | 2022-02-08 14:28:18 -0500 |
---|---|---|
committer | Peter Zhu <[email protected]> | 2022-02-10 09:33:42 -0500 |
commit | 261753249996d46e00c2549fff2527816bf387db (patch) | |
tree | 18cdac9d656c91b7e397994fec8485dadb4c0d1c /gc.c | |
parent | 66b9ca8426eb3c6ea212b34b4c8e2b68ec54b92d (diff) |
Free cached mark stack chunks when freeing objspace
Cached mark stack chunks should also be freed when freeing objspace.
Notes
Notes:
Merged: https://github.com/ruby/ruby/pull/5536
Diffstat (limited to 'gc.c')
-rw-r--r-- | gc.c | 21 |
1 files changed, 19 insertions, 2 deletions
@@ -1778,6 +1778,7 @@ rb_objspace_alloc(void) } static void free_stack_chunks(mark_stack_t *); +static void mark_stack_free_cache(mark_stack_t *); static void heap_page_free(rb_objspace_t *objspace, struct heap_page *page); void @@ -1817,7 +1818,10 @@ rb_objspace_free(rb_objspace_t *objspace) } st_free_table(objspace->id_to_obj_tbl); st_free_table(objspace->obj_to_id_tbl); + free_stack_chunks(&objspace->mark_stack); + mark_stack_free_cache(&objspace->mark_stack); + free(objspace); } @@ -6092,9 +6096,8 @@ pop_mark_stack_chunk(mark_stack_t *stack) } static void -free_stack_chunks(mark_stack_t *stack) +mark_stack_chunk_list_free(stack_chunk_t *chunk) { - stack_chunk_t *chunk = stack->chunk; stack_chunk_t *next = NULL; while (chunk != NULL) { @@ -6105,6 +6108,20 @@ free_stack_chunks(mark_stack_t *stack) } static void +free_stack_chunks(mark_stack_t *stack) +{ + mark_stack_chunk_list_free(stack->chunk); +} + +static void +mark_stack_free_cache(mark_stack_t *stack) +{ + mark_stack_chunk_list_free(stack->cache); + stack->cache_size = 0; + stack->unused_cache_size = 0; +} + +static void push_mark_stack(mark_stack_t *stack, VALUE data) { VALUE obj = data; |