From 430935f4c50abff03a73cc3b08f3fb2719f21d8c Mon Sep 17 00:00:00 2001 From: Jakub Dabek Date: Fri, 23 Feb 2024 15:56:01 +0100 Subject: [PATCH] vmh: fix array update for contiguous allocation Array holding sizes of allocations was not updated correctly this fixes array update issue. Signed-off-by: Jakub Dabek --- zephyr/lib/regions_mm.c | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/zephyr/lib/regions_mm.c b/zephyr/lib/regions_mm.c index e901d7231543..1a0d4f00b5be 100644 --- a/zephyr/lib/regions_mm.c +++ b/zephyr/lib/regions_mm.c @@ -495,7 +495,7 @@ int vmh_free(struct vmh_heap *heap, void *ptr) size_t mem_block_iter, i, size_to_free, block_size, ptr_bit_array_offset, ptr_bit_array_position, physical_block_count, - check_offset, check_position, check_size; + check_offset, check_position, check_size, blocks_to_free; uintptr_t phys_aligned_ptr, phys_aligned_alloc_end, phys_block_ptr; bool ptr_range_found; @@ -581,10 +581,13 @@ int vmh_free(struct vmh_heap *heap, void *ptr) */ size_to_free = block_size; } - + blocks_to_free = size_to_free / block_size; retval = sys_mem_blocks_free_contiguous( heap->physical_blocks_allocators[mem_block_iter], ptr, - size_to_free / block_size); + blocks_to_free); + if (!retval) + sys_bitarray_clear_region(heap->allocation_sizes[mem_block_iter], + blocks_to_free, ptr_bit_array_position); } else { retval = sys_mem_blocks_free(heap->physical_blocks_allocators[mem_block_iter], 1, &ptr);