summary refs log tree commit diff
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>1999-07-07 14:29:02 +0000
committerUlrich Drepper <drepper@redhat.com>1999-07-07 14:29:02 +0000
commit597d10a00a66955a0f3998e265eaa2d100d5b876 (patch)
tree9840994a1f95f33ab327f4cb14b72650ce0ef160
parent1823e76b95f8d188de1658eaf77e71e20508bcc8 (diff)
downloadglibc-597d10a00a66955a0f3998e265eaa2d100d5b876.tar.gz
glibc-597d10a00a66955a0f3998e265eaa2d100d5b876.tar.xz
glibc-597d10a00a66955a0f3998e265eaa2d100d5b876.zip
Update.
	* malloc/malloc.c (request2size): Take care of overflow in
	addition.
-rw-r--r--ChangeLog3
-rw-r--r--malloc/malloc.c5
2 files changed, 6 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 0b5f773a78..37e91a4653 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,8 @@
 1999-07-07  Ulrich Drepper  <drepper@cygnus.com>
 
+	* malloc/malloc.c (request2size): Take care of overflow in
+	addition.
+
 	* sysdeps/posix/getcwd.c: Correct last patch.  Handle getcwd
 	(NULL, != 0) correctly.
 
diff --git a/malloc/malloc.c b/malloc/malloc.c
index e096f00eeb..09085e81ad 100644
--- a/malloc/malloc.c
+++ b/malloc/malloc.c
@@ -1263,8 +1263,9 @@ static void      free_atfork();
 
 #define request2size(req, nb) \
  ((nb = (req) + (SIZE_SZ + MALLOC_ALIGN_MASK)),\
-  ((long)nb <= 0 ? 1 : ((nb < (MINSIZE + MALLOC_ALIGN_MASK) ? (nb = MINSIZE) :\
-                         (nb &= ~MALLOC_ALIGN_MASK)), 0)))
+  ((long)nb <= 0 || nb < (INTERNAL_SIZE_T) (req) \
+   ? 1 : ((nb < (MINSIZE + MALLOC_ALIGN_MASK) \
+	   ? (nb = MINSIZE) : (nb &= ~MALLOC_ALIGN_MASK)), 0)))
 
 /* Check if m has acceptable alignment */