diff --git a/newlib/ChangeLog b/newlib/ChangeLog index 47ebb843e..f81f154a9 100644 --- a/newlib/ChangeLog +++ b/newlib/ChangeLog @@ -1,3 +1,8 @@ +2005-10-07 Bob Wilson + + * libc/stdlib/mallocr.c (mALLOc, rEALLOCc, mEMALIGn): Set errno + to ENOMEM on failure. + 2005-10-06 Ralf Corsepius * libc/include/stdint.h: Add [u]int_fast_t types. diff --git a/newlib/libc/stdlib/mallocr.c b/newlib/libc/stdlib/mallocr.c index 02f6a5d15..cfa25545f 100644 --- a/newlib/libc/stdlib/mallocr.c +++ b/newlib/libc/stdlib/mallocr.c @@ -268,6 +268,7 @@ extern "C" { #include /* needed for malloc_stats */ #include /* needed for overflow checks */ +#include /* needed to set errno to ENOMEM */ #ifdef WIN32 #define WIN32_LEAN_AND_MEAN @@ -335,6 +336,7 @@ extern void __malloc_unlock(); #define RDECL struct _reent *reent_ptr; #endif +#define RERRNO reent_ptr->_errno #define RCALL reent_ptr, #define RONECALL reent_ptr @@ -344,6 +346,7 @@ extern void __malloc_unlock(); #define RARG #define RONEARG #define RDECL +#define RERRNO errno #define RCALL #define RONECALL @@ -2341,7 +2344,10 @@ Void_t* mALLOc(RARG bytes) RDECL size_t bytes; /* Check for overflow and just fail, if so. */ if (nb > INT_MAX || nb < bytes) + { + RERRNO = ENOMEM; return 0; + } MALLOC_LOCK; @@ -2804,7 +2810,10 @@ Void_t* rEALLOc(RARG oldmem, bytes) RDECL Void_t* oldmem; size_t bytes; /* Check for overflow and just fail, if so. */ if (nb > INT_MAX || nb < bytes) + { + RERRNO = ENOMEM; return 0; + } #if HAVE_MMAP if (chunk_is_mmapped(oldp)) @@ -3037,7 +3046,10 @@ Void_t* mEMALIGn(RARG alignment, bytes) RDECL size_t alignment; size_t bytes; /* Check for overflow. */ if (nb > INT_MAX || nb < bytes) + { + RERRNO = ENOMEM; return 0; + } m = (char*)(mALLOc(RCALL nb + alignment + MINSIZE));