From a0bc4ebb4f706d75607019b747b5927620b4017c Mon Sep 17 00:00:00 2001 From: Greg Haerr Date: Tue, 19 Nov 2024 18:55:30 -0800 Subject: [PATCH] Add proper max malloc and errno handling to std malloc/realloc Allow malloc libc test to run since max alloc is rejected properly --- elkscmd/test/libc/malloc.c | 6 +----- libc/malloc/malloc.c | 12 +++++++++++- 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/elkscmd/test/libc/malloc.c b/elkscmd/test/libc/malloc.c index 50d93d0ce..5e5626536 100644 --- a/elkscmd/test/libc/malloc.c +++ b/elkscmd/test/libc/malloc.c @@ -15,18 +15,14 @@ TEST_CASE(malloc_malloc_free) { free(p); } - /* TODO:BUG: causes hang at 100% CPU */ -#if 0 errno = 0; - p = malloc((size_t) - 1); + p = malloc((size_t)-1); if (p == NULL) { EXPECT_EQ(errno, ENOMEM); } else { EXPECT_EQ(errno, 0); - memset(p, 0xff, (size_t) - 1); free(p); } -#endif /* strange sizes are fine; memory is writable and free-able */ for (int i = 1; i < 1024; i += 123) { diff --git a/libc/malloc/malloc.c b/libc/malloc/malloc.c index 7db49fea9..cc7d31a1e 100644 --- a/libc/malloc/malloc.c +++ b/libc/malloc/malloc.c @@ -11,6 +11,7 @@ #include #include +#include #include "_malloc.h" @@ -190,8 +191,16 @@ malloc(size_t size) register mem __wcnear *ptr = 0; register unsigned int sz; + errno = 0; if (size == 0) - return 0; /* ANSI STD */ + return 0; /* ANSI STD, no error */ + + /* Minor oops here, sbrk has a signed argument */ + if((int)size < 0 || size > (((unsigned)-1) >> 1) - sizeof(mem) * 3) + { + errno = ENOMEM; + return 0; + } sz = size + sizeof(mem) * 2 - 1; sz /= sizeof(mem); @@ -281,6 +290,7 @@ malloc(size_t size) #ifndef MCHUNK ptr = __mini_malloc(size); #endif + if( ptr == 0) errno = ENOMEM; #ifdef VERBOSE if( ptr == 0 ) __noise("MALLOC FAIL", 0);