From b072022022b7d6c3f29001560603479ae6ba883c Mon Sep 17 00:00:00 2001 From: Daniel Micay Date: Tue, 6 Oct 2020 17:34:35 -0400 Subject: [PATCH] perform init sanity checks before MPK unsealing --- h_malloc.c | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/h_malloc.c b/h_malloc.c index 68e63cdb..feb8d575 100644 --- a/h_malloc.c +++ b/h_malloc.c @@ -1612,9 +1612,9 @@ EXPORT size_t h_malloc_usable_size(H_MALLOC_USABLE_SIZE_CONST void *p) { return 0; } - thread_unseal_metadata(); - if (p < get_slab_region_end() && p >= ro.slab_region_start) { + thread_unseal_metadata(); + memory_corruption_check_small(p); thread_seal_metadata(); @@ -1623,6 +1623,8 @@ EXPORT size_t h_malloc_usable_size(H_MALLOC_USABLE_SIZE_CONST void *p) { } enforce_init(); + thread_unseal_metadata(); + struct region_allocator *ra = ro.region_allocator; mutex_lock(&ra->lock); struct region_metadata *region = regions_find(p); @@ -1641,10 +1643,10 @@ EXPORT size_t h_malloc_object_size(void *p) { return 0; } - thread_unseal_metadata(); - void *slab_region_end = get_slab_region_end(); if (p < slab_region_end && p >= ro.slab_region_start) { + thread_unseal_metadata(); + struct slab_size_class_info size_class_info = slab_size_class(p); size_t class = size_class_info.class; size_t size_class = size_classes[class]; @@ -1681,6 +1683,8 @@ EXPORT size_t h_malloc_object_size(void *p) { return SIZE_MAX; } + thread_unseal_metadata(); + struct region_allocator *ra = ro.region_allocator; mutex_lock(&ra->lock); struct region_metadata *region = regions_find(p);