# HG changeset patch # User Timo Sirainen # Date 1232073386 18000 # Node ID 685a5e3565b028a3172bae3df0ca1f9f091a4331 # Parent b8357fbedc8f78bf4ef88fc5e121829eaecb805c mempool system clean: Don't break if realloc() shrinks the memory area. diff -r b8357fbedc8f -r 685a5e3565b0 src/lib/mempool-system-clean.c --- a/src/lib/mempool-system-clean.c Thu Jan 15 17:21:18 2009 -0500 +++ b/src/lib/mempool-system-clean.c Thu Jan 15 21:36:26 2009 -0500 @@ -136,6 +136,7 @@ size_t old_size, size_t new_size) { void *new_mem; + size_t old_alloc_size; if (unlikely(new_size == 0 || new_size > SSIZE_T_MAX)) i_panic("Trying to allocate %"PRIuSIZE_T" bytes", new_size); @@ -146,14 +147,15 @@ i_assert(old_size == (size_t)-1 || old_size <= malloc_usable_size(mem)); #endif - memcpy(new_mem, mem, mem_get_size(mem)); - pool_system_clean_free(pool, mem); + old_alloc_size = mem_get_size(mem); + memcpy(new_mem, mem, I_MIN(old_alloc_size, new_size)); if (old_size < new_size) { /* clear new data */ memset((char *)new_mem + old_size, 0, new_size - old_size); } + pool_system_clean_free(pool, mem); } return new_mem;