diff options
author | Miles Bader <miles@lsi.nec.co.jp> | 2003-10-16 10:12:45 +0000 |
---|---|---|
committer | Miles Bader <miles@lsi.nec.co.jp> | 2003-10-16 10:12:45 +0000 |
commit | 0a8bcf917a6e98593629e4641e2e9e12c7e5a8fa (patch) | |
tree | cf0ee449b70139f234803803d0ea2f81f1a1ebeb /libc/stdlib/malloc | |
parent | 2d421e4f94a0d6847efe7b12b1c2fd85762a44f6 (diff) |
Don't set errno if for zero SIZE returns.
Code formatting cleanup.
Diffstat (limited to 'libc/stdlib/malloc')
-rw-r--r-- | libc/stdlib/malloc/malloc.c | 25 |
1 files changed, 14 insertions, 11 deletions
diff --git a/libc/stdlib/malloc/malloc.c b/libc/stdlib/malloc/malloc.c index 98ac41cd7..5ba552d25 100644 --- a/libc/stdlib/malloc/malloc.c +++ b/libc/stdlib/malloc/malloc.c @@ -186,23 +186,26 @@ malloc (size_t size) __heap_check (&__malloc_heap, "malloc"); #endif -#if defined(__MALLOC_GLIBC_COMPAT__) - if (unlikely(size == 0)) - size++; +#ifdef __MALLOC_GLIBC_COMPAT__ + if (unlikely (size == 0)) + size++; #else /* Some programs will call malloc (0). Lets be strict and return NULL */ - if (unlikely(size == 0)) - goto oom; + if (unlikely (size == 0)) + return 0; #endif + /* Check if they are doing something dumb like malloc(-1) */ if (unlikely(((unsigned long)size > (unsigned long)(MALLOC_HEADER_SIZE*-2)))) - goto oom; + goto oom; mem = malloc_from_heap (size, &__malloc_heap); - if (unlikely(!mem)) { -oom: - __set_errno(ENOMEM); - return NULL; - } + if (unlikely (!mem)) + { + oom: + __set_errno (ENOMEM); + return 0; + } + return mem; } |