diff options
| author | tedu <> | 2015-12-30 06:01:18 +0000 | 
|---|---|---|
| committer | tedu <> | 2015-12-30 06:01:18 +0000 | 
| commit | 43d3e77da291417f1d53ae05da95959b45334cb5 (patch) | |
| tree | 75612125febb4a43197363a9c1d7d1763791ff5d /src/lib/libc | |
| parent | 70faac3485d844275c45acf2ad85cab3c2fa242d (diff) | |
| download | openbsd-43d3e77da291417f1d53ae05da95959b45334cb5.tar.gz openbsd-43d3e77da291417f1d53ae05da95959b45334cb5.tar.bz2 openbsd-43d3e77da291417f1d53ae05da95959b45334cb5.zip | |
if somebody makes the mistake of disabling abort, don't deref null in
validate_junk. from Michal Mazurek
Diffstat (limited to '')
| -rw-r--r-- | src/lib/libc/stdlib/malloc.c | 6 | 
1 files changed, 4 insertions, 2 deletions
| diff --git a/src/lib/libc/stdlib/malloc.c b/src/lib/libc/stdlib/malloc.c index 36d2d717db..84d22507c0 100644 --- a/src/lib/libc/stdlib/malloc.c +++ b/src/lib/libc/stdlib/malloc.c | |||
| @@ -1,4 +1,4 @@ | |||
| 1 | /* $OpenBSD: malloc.c,v 1.177 2015/12/09 02:45:23 tedu Exp $ */ | 1 | /* $OpenBSD: malloc.c,v 1.178 2015/12/30 06:01:18 tedu Exp $ */ | 
| 2 | /* | 2 | /* | 
| 3 | * Copyright (c) 2008, 2010, 2011 Otto Moerbeek <otto@drijf.net> | 3 | * Copyright (c) 2008, 2010, 2011 Otto Moerbeek <otto@drijf.net> | 
| 4 | * Copyright (c) 2012 Matthew Dempsky <matthew@openbsd.org> | 4 | * Copyright (c) 2012 Matthew Dempsky <matthew@openbsd.org> | 
| @@ -1225,8 +1225,10 @@ validate_junk(void *p) { | |||
| 1225 | if (p == NULL) | 1225 | if (p == NULL) | 
| 1226 | return; | 1226 | return; | 
| 1227 | r = find(pool, p); | 1227 | r = find(pool, p); | 
| 1228 | if (r == NULL) | 1228 | if (r == NULL) { | 
| 1229 | wrterror("bogus pointer in validate_junk", p); | 1229 | wrterror("bogus pointer in validate_junk", p); | 
| 1230 | return; | ||
| 1231 | } | ||
| 1230 | REALSIZE(sz, r); | 1232 | REALSIZE(sz, r); | 
| 1231 | if (sz > 0 && sz <= MALLOC_MAXCHUNK) | 1233 | if (sz > 0 && sz <= MALLOC_MAXCHUNK) | 
| 1232 | sz -= mopts.malloc_canaries; | 1234 | sz -= mopts.malloc_canaries; | 
