mirror of
https://github.com/samba-team/samba.git
synced 2025-01-11 05:18:09 +03:00
lib: talloc: Fix pool object accounting when doing talloc_realloc() in the ALWAYS_REALLOC compiled case.
tc_alloc_pool() or the fallback malloc can return NULL. Wait until we know we are returning a valid pointer before decrementing pool_hdr->object_count due to reallocing out of the talloc_pool. BUG: https://bugzilla.samba.org/show_bug.cgi?id=14540 Signed-off-by: Jeremy Allison <jra@samba.org> Reviewed-by: Andrew Bartlett <abartlet@samba.org>
This commit is contained in:
parent
86eb6423bd
commit
6e0aab0b40
@ -1901,8 +1901,6 @@ _PUBLIC_ void *_talloc_realloc(const void *context, void *ptr, size_t size, cons
|
|||||||
#if (ALWAYS_REALLOC != 0)
|
#if (ALWAYS_REALLOC != 0)
|
||||||
if (pool_hdr) {
|
if (pool_hdr) {
|
||||||
new_ptr = tc_alloc_pool(tc, size + TC_HDR_SIZE, 0);
|
new_ptr = tc_alloc_pool(tc, size + TC_HDR_SIZE, 0);
|
||||||
pool_hdr->object_count--;
|
|
||||||
|
|
||||||
if (new_ptr == NULL) {
|
if (new_ptr == NULL) {
|
||||||
new_ptr = malloc(TC_HDR_SIZE+size);
|
new_ptr = malloc(TC_HDR_SIZE+size);
|
||||||
malloced = true;
|
malloced = true;
|
||||||
@ -1912,6 +1910,11 @@ _PUBLIC_ void *_talloc_realloc(const void *context, void *ptr, size_t size, cons
|
|||||||
if (new_ptr) {
|
if (new_ptr) {
|
||||||
memcpy(new_ptr, tc, MIN(tc->size,size) + TC_HDR_SIZE);
|
memcpy(new_ptr, tc, MIN(tc->size,size) + TC_HDR_SIZE);
|
||||||
TC_INVALIDATE_FULL_CHUNK(tc);
|
TC_INVALIDATE_FULL_CHUNK(tc);
|
||||||
|
/*
|
||||||
|
* Only decrement the object count in the pool once
|
||||||
|
* we know we're returning a valid new_ptr.
|
||||||
|
*/
|
||||||
|
pool_hdr->object_count--;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
/* We're doing malloc then free here, so record the difference. */
|
/* We're doing malloc then free here, so record the difference. */
|
||||||
|
Loading…
Reference in New Issue
Block a user