Unpoison freelist when iterating over it in gc_sweep_page
This commit is contained in:
parent
3a31b80bea
commit
d7df8c6964
Notes:
git
2022-05-05 04:49:46 +09:00
2
gc.c
2
gc.c
@ -5473,11 +5473,13 @@ gc_sweep_page(rb_objspace_t *objspace, rb_heap_t *heap, struct gc_sweep_context
|
|||||||
|
|
||||||
#if RGENGC_CHECK_MODE
|
#if RGENGC_CHECK_MODE
|
||||||
short freelist_len = 0;
|
short freelist_len = 0;
|
||||||
|
asan_unpoison_memory_region(&sweep_page->freelist, sizeof(RVALUE*), false);
|
||||||
RVALUE *ptr = sweep_page->freelist;
|
RVALUE *ptr = sweep_page->freelist;
|
||||||
while (ptr) {
|
while (ptr) {
|
||||||
freelist_len++;
|
freelist_len++;
|
||||||
ptr = ptr->as.free.next;
|
ptr = ptr->as.free.next;
|
||||||
}
|
}
|
||||||
|
asan_poison_memory_region(&sweep_page->freelist, sizeof(RVALUE*));
|
||||||
if (freelist_len != sweep_page->free_slots) {
|
if (freelist_len != sweep_page->free_slots) {
|
||||||
rb_bug("inconsistent freelist length: expected %d but was %d", sweep_page->free_slots, freelist_len);
|
rb_bug("inconsistent freelist length: expected %d but was %d", sweep_page->free_slots, freelist_len);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user