From: jjohnstn Date: Fri, 7 Oct 2005 18:07:26 +0000 (+0000) Subject: 2005-10-07 Bob Wilson X-Git-Tag: cgf-more-exit-sync~88 X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=b4990d76add01842fe7f151fbf84b71c7d60036a;p=pf3gnuchains%2Fpf3gnuchains4x.git 2005-10-07 Bob Wilson * libc/stdlib/mallocr.c (mALLOc, rEALLOCc, mEMALIGn): Set errno to ENOMEM on failure. --- diff --git a/newlib/ChangeLog b/newlib/ChangeLog index 47ebb843e3..f81f154a9a 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 02f6a5d158..cfa25545ff 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));