aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorQingqing Li <liqingqing3@huawei.com>2022-09-22 15:32:56 -0400
committerDJ Delorie <dj@redhat.com>2022-09-22 15:32:56 -0400
commit774d43f27dbc730ee4b8b37bce4d5b3d5c0b74b6 (patch)
tree609c8125648c664b7a8362dcc0b0af1eceff8548
parentde477abcaaabb1f9815cb63876637a47a95e7ac1 (diff)
downloadglibc-774d43f27dbc730ee4b8b37bce4d5b3d5c0b74b6.zip
glibc-774d43f27dbc730ee4b8b37bce4d5b3d5c0b74b6.tar.gz
glibc-774d43f27dbc730ee4b8b37bce4d5b3d5c0b74b6.tar.bz2
malloc: Print error when oldsize is not equal to the current size.
This is used to detect errors early. The read of the oldsize is not protected by any lock, so check this value to avoid causing bigger mistakes. Reviewed-by: DJ Delorie <dj@redhat.com>
-rw-r--r--malloc/malloc.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/malloc/malloc.c b/malloc/malloc.c
index bfe1955..67ac661 100644
--- a/malloc/malloc.c
+++ b/malloc/malloc.c
@@ -4803,7 +4803,8 @@ _int_realloc (mstate av, mchunkptr oldp, INTERNAL_SIZE_T oldsize,
/* oldmem size */
if (__builtin_expect (chunksize_nomask (oldp) <= CHUNK_HDR_SZ, 0)
- || __builtin_expect (oldsize >= av->system_mem, 0))
+ || __builtin_expect (oldsize >= av->system_mem, 0)
+ || __builtin_expect (oldsize != chunksize (oldp), 0))
malloc_printerr ("realloc(): invalid old size");
check_inuse_chunk (av, oldp);