From 9f86edc4a9ef5762c03b7dc42d127c031c16483c Mon Sep 17 00:00:00 2001 From: Miles Bader Date: Tue, 30 Jul 2002 09:47:05 +0000 Subject: Update the size of grown/shrunk allocations. MALLOC_SET_SIZE now takes the user-address rather than the base-address. --- libc/stdlib/malloc/realloc.c | 32 ++++++++++++++++---------------- 1 file changed, 16 insertions(+), 16 deletions(-) (limited to 'libc/stdlib/malloc') diff --git a/libc/stdlib/malloc/realloc.c b/libc/stdlib/malloc/realloc.c index 34118ab5a..dbcb19ebe 100644 --- a/libc/stdlib/malloc/realloc.c +++ b/libc/stdlib/malloc/realloc.c @@ -38,32 +38,27 @@ realloc (void *mem, size_t new_size) if (new_size > size) /* Grow the block. */ { - void *new_mem = 0; - size_t ext_size = new_size - size; - void *ext_addr = base_mem + size; + size_t extra = new_size - size; __malloc_lock (); - ext_size = __heap_alloc_at (&__malloc_heap, ext_addr, ext_size); + extra = __heap_alloc_at (&__malloc_heap, base_mem + size, extra); __malloc_unlock (); - if (! ext_size) + if (extra) + /* Record the changed size. */ + MALLOC_SET_SIZE (mem, new_size); + else /* Our attempts to extend MEM in place failed, just allocate-and-copy. */ { - new_mem = malloc (new_size); + void *new_mem = malloc (new_size); if (new_mem) { memcpy (new_mem, mem, size); free (mem); } + mem = new_mem; } - - if (new_mem) - MALLOC_DEBUG (" realloc: returning 0x%lx" - " (base:0x%lx, total_size:%d)\n", - (long)new_mem, (long)new_mem - sizeof(size_t), size); - - return new_mem; } else if (new_size + HEAP_MIN_FREE_AREA_SIZE <= size) /* Shrink the block. */ @@ -71,9 +66,14 @@ realloc (void *mem, size_t new_size) __malloc_lock (); __heap_free (&__malloc_heap, base_mem + new_size, new_size - size); __malloc_unlock (); + MALLOC_SET_SIZE (mem, new_size); } - else - /* Do nothing. */ - return mem; + + if (mem) + MALLOC_DEBUG (" realloc: returning 0x%lx" + " (base:0x%lx, total_size:%d)\n", + (long)new_mem, (long)new_mem - sizeof(size_t), size); + + return mem; } } -- cgit v1.2.3