diff options
author | cinap_lenrek <cinap_lenrek@gmx.de> | 2012-08-19 10:50:39 +0200 |
---|---|---|
committer | cinap_lenrek <cinap_lenrek@gmx.de> | 2012-08-19 10:50:39 +0200 |
commit | be0301f45850ca70db0f2ec8258e73615a0ec7be (patch) | |
tree | 4342fe3532728924212e2f60ace3c0de5323c6a0 | |
parent | feb58cce49491a980012c42b9a2decc671e32f6c (diff) | |
download | plan9front-be0301f45850ca70db0f2ec8258e73615a0ec7be.tar.xz |
calloc: check multiplication overflow
-rw-r--r-- | sys/src/ape/lib/ap/gen/calloc.c | 14 | ||||
-rw-r--r-- | sys/src/libc/port/malloc.c | 7 |
2 files changed, 13 insertions, 8 deletions
diff --git a/sys/src/ape/lib/ap/gen/calloc.c b/sys/src/ape/lib/ap/gen/calloc.c index e52210d84..c080c7b3d 100644 --- a/sys/src/ape/lib/ap/gen/calloc.c +++ b/sys/src/ape/lib/ap/gen/calloc.c @@ -2,12 +2,14 @@ #include <string.h> void * -calloc(size_t nmemb, size_t size) +calloc(size_t n, size_t s) { - void *mp; + void *v; - nmemb = nmemb*size; - if(mp = malloc(nmemb)) - memset(mp, 0, nmemb); - return(mp); + if(n > 1 && ((size_t)-1)/n < s) + return 0; + n *= s; + if(v = malloc(n)) + memset(v, 0, n); + return v; } diff --git a/sys/src/libc/port/malloc.c b/sys/src/libc/port/malloc.c index 741316926..e23e1f53b 100644 --- a/sys/src/libc/port/malloc.c +++ b/sys/src/libc/port/malloc.c @@ -280,10 +280,13 @@ msize(void *v) } void* -calloc(ulong n, ulong szelem) +calloc(ulong n, ulong s) { void *v; - if(v = mallocz(n*szelem, 1)) + + if(n > 1 && ((ulong)-1)/n < s) + return nil; + if(v = mallocz(n*s, 1)) setmalloctag(v, getcallerpc(&n)); return v; } |