summaryrefslogtreecommitdiff
path: root/lib/libc/stdlib/malloc.c
diff options
context:
space:
mode:
authorOtto Moerbeek <otto@cvs.openbsd.org>2006-05-14 19:53:41 +0000
committerOtto Moerbeek <otto@cvs.openbsd.org>2006-05-14 19:53:41 +0000
commit4181738578dc8abf5eeb10258967afa011caa514 (patch)
tree6e24e74edabf34ca85dd4343447b39a32149e92e /lib/libc/stdlib/malloc.c
parentea0c4863bd07766ddb282a62b58e8b74f8f8a03a (diff)
Fix the second malloc_ulimit regression: maintaining the free list
requires memory; try to make sure we have it. If all fails, leak instead of crash. Test case originally found by cloder@, fix tested by many.
Diffstat (limited to 'lib/libc/stdlib/malloc.c')
-rw-r--r--lib/libc/stdlib/malloc.c15
1 files changed, 12 insertions, 3 deletions
diff --git a/lib/libc/stdlib/malloc.c b/lib/libc/stdlib/malloc.c
index b858bbb739a..028eff2b2d5 100644
--- a/lib/libc/stdlib/malloc.c
+++ b/lib/libc/stdlib/malloc.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: malloc.c,v 1.82 2006/04/24 19:23:42 otto Exp $ */
+/* $OpenBSD: malloc.c,v 1.83 2006/05/14 19:53:40 otto Exp $ */
/*
* ----------------------------------------------------------------------------
@@ -1158,6 +1158,10 @@ imalloc(size_t size)
if (suicide)
abort();
+ /* does not matter if malloc_bytes fails */
+ if (px == NULL)
+ px = malloc_bytes(sizeof *px);
+
if (malloc_ptrguard && size == PTR_SIZE) {
ptralloc = 1;
size = malloc_pagesize;
@@ -1405,8 +1409,8 @@ free_pages(void *ptr, u_long index, struct pginfo * info)
mprotect(ptr, l, PROT_NONE);
/* Add to free-list. */
- if (px == NULL)
- px = imalloc(sizeof *px); /* This cannot fail... */
+ if (px == NULL && (px = malloc_bytes(sizeof *px)) == NULL)
+ goto not_return;
px->page = ptr;
px->pdir = spi;
px->size = l;
@@ -1766,6 +1770,11 @@ ifree(void *ptr)
free_pages(ptr, index, info);
else
free_bytes(ptr, index, info);
+
+ /* does not matter if malloc_bytes fails */
+ if (px == NULL)
+ px = malloc_bytes(sizeof *px);
+
return;
}