From: Zeev Suraski Date: Fri, 9 Jul 1999 11:03:56 +0000 (+0000) Subject: * Support recoverable failure from erealloc() X-Git-Tag: BEFORE_REMOVING_GC_STEP1~3 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=6abe9c34d9be62d62a2841635fd733802f15e83c;p=php * Support recoverable failure from erealloc() * Fix the shutdown code on an unrecoverable erealloc() failure --- diff --git a/Zend/zend_alloc.c b/Zend/zend_alloc.c index 576356420c..740b424f95 100644 --- a/Zend/zend_alloc.c +++ b/Zend/zend_alloc.c @@ -200,9 +200,9 @@ ZEND_API void *_ecalloc(size_t nmemb, size_t size) #if ZEND_DEBUG -ZEND_API void *_erealloc(void *ptr, size_t size, char *filename, uint lineno) +ZEND_API void *_erealloc(void *ptr, size_t size, int allow_failure, char *filename, uint lineno) #else -ZEND_API void *_erealloc(void *ptr, size_t size) +ZEND_API void *_erealloc(void *ptr, size_t size, int allow_failure) #endif { mem_header *p = (mem_header *) ((char *)ptr-sizeof(mem_header)-PLATFORM_PADDING); @@ -220,10 +220,12 @@ ZEND_API void *_erealloc(void *ptr, size_t size) REMOVE_POINTER_FROM_LIST(p); p = (mem_header *) realloc(p,sizeof(mem_header)+size+PLATFORM_PADDING+END_ALIGNMENT(size)+END_MAGIC_SIZE); if (!p) { - fprintf(stderr,"FATAL: erealloc(): Unable to allocate %ld bytes\n", (long) size); - HANDLE_UNBLOCK_INTERRUPTIONS(); - zend_bailout(); + if (!allow_failure) { + fprintf(stderr,"FATAL: erealloc(): Unable to allocate %ld bytes\n", (long) size); + exit(1); + } ADD_POINTER_TO_LIST(orig); + HANDLE_UNBLOCK_INTERRUPTIONS(); return (void *)NULL; } ADD_POINTER_TO_LIST(p); diff --git a/Zend/zend_alloc.h b/Zend/zend_alloc.h index 2b847be488..c47687df50 100644 --- a/Zend/zend_alloc.h +++ b/Zend/zend_alloc.h @@ -55,41 +55,44 @@ ZEND_API char *zend_strndup(const char *s, unsigned int length); BEGIN_EXTERN_C() #if ZEND_DEBUG -ZEND_API void *_emalloc(size_t size,char *filename,uint lineno); -ZEND_API void _efree(void *ptr,char *filename,uint lineno); -ZEND_API void *_ecalloc(size_t nmemb, size_t size,char *filename,uint lineno); -ZEND_API void *_erealloc(void *ptr, size_t size,char *filename,uint lineno); -ZEND_API char *_estrdup(const char *s,char *filename,uint lineno); -ZEND_API char *_estrndup(const char *s, unsigned int length,char *filename,uint lineno); +ZEND_API void *_emalloc(size_t size, char *filename, uint lineno); +ZEND_API void _efree(void *ptr, char *filename, uint lineno); +ZEND_API void *_ecalloc(size_t nmemb, size_t size, char *filename, uint lineno); +ZEND_API void *_erealloc(void *ptr, size_t size, int allow_failure, char *filename, uint lineno); +ZEND_API char *_estrdup(const char *s, char *filename, uint lineno); +ZEND_API char *_estrndup(const char *s, unsigned int length, char *filename, uint lineno); ZEND_API void _persist_alloc(void *ptr, char *filename, uint lineno); -#define emalloc(size) _emalloc((size),__FILE__,__LINE__) -#define efree(ptr) _efree((ptr),__FILE__,__LINE__) -#define ecalloc(nmemb,size) _ecalloc((nmemb),(size),__FILE__,__LINE__) -#define erealloc(ptr,size) _erealloc((ptr),(size),__FILE__,__LINE__) -#define estrdup(s) _estrdup((s),__FILE__,__LINE__) -#define estrndup(s,length) _estrndup((s),(length),__FILE__,__LINE__) -#define persist_alloc(p) _persist_alloc((p),__FILE__,__LINE__) +#define emalloc(size) _emalloc((size),__FILE__,__LINE__) +#define efree(ptr) _efree((ptr),__FILE__,__LINE__) +#define ecalloc(nmemb,size) _ecalloc((nmemb),(size),__FILE__,__LINE__) +#define erealloc(ptr,size) _erealloc((ptr),(size),0,__FILE__,__LINE__) +#define erealloc_recoverable(ptr,size) _erealloc((ptr),(size),1,__FILE__,__LINE__) +#define estrdup(s) _estrdup((s),__FILE__,__LINE__) +#define estrndup(s,length) _estrndup((s),(length),__FILE__,__LINE__) +#define persist_alloc(p) _persist_alloc((p),__FILE__,__LINE__) #else ZEND_API void *_emalloc(size_t size); ZEND_API void _efree(void *ptr); ZEND_API void *_ecalloc(size_t nmemb, size_t size); -ZEND_API void *_erealloc(void *ptr, size_t size); +ZEND_API void *_erealloc(void *ptr, size_t size, int allow_failure); ZEND_API char *_estrdup(const char *s); ZEND_API char *_estrndup(const char *s, unsigned int length); ZEND_API void _persist_alloc(void *ptr); -#define emalloc(size) _emalloc((size)) -#define efree(ptr) _efree((ptr)) -#define ecalloc(nmemb,size) _ecalloc((nmemb),(size)) -#define erealloc(ptr,size) _erealloc((ptr),(size)) -#define estrdup(s) _estrdup((s)) -#define estrndup(s,length) _estrndup((s),(length)) -#define persist_alloc(p) _persist_alloc((p)) +#define emalloc(size) _emalloc((size)) +#define efree(ptr) _efree((ptr)) +#define ecalloc(nmemb,size) _ecalloc((nmemb),(size)) +#define erealloc(ptr,size) _erealloc((ptr),(size),0) +#define erealloc_recoverable(ptr,size) _erealloc((ptr),(size),1) +#define estrdup(s) _estrdup((s)) +#define estrndup(s,length) _estrndup((s),(length)) +#define persist_alloc(p) _persist_alloc((p)) #endif #define pemalloc(size,persistent) ((persistent)?malloc(size):emalloc(size)) #define pefree(ptr,persistent) ((persistent)?free(ptr):efree(ptr)) #define pecalloc(nmemb,size,persistent) ((persistent)?calloc((nmemb),(size)):ecalloc((nmemb),(size))) #define perealloc(ptr,size,persistent) ((persistent)?realloc((ptr),(size)):erealloc((ptr),(size))) +#define perealloc_recoverable(ptr,size,persistent) ((persistent)?realloc((ptr),(size)):erealloc_recoverable((ptr),(size))) #define pestrdup(s,persistent) ((persistent)?strdup(s):estrdup(s)) #define safe_estrdup(ptr) ((ptr)?(estrdup(ptr)):(empty_string)) diff --git a/Zend/zend_hash.c b/Zend/zend_hash.c index 2fb21f00c1..285cc840f8 100644 --- a/Zend/zend_hash.c +++ b/Zend/zend_hash.c @@ -631,7 +631,7 @@ static int if_full_do_resize(HashTable *ht) if ((ht->nNumOfElements > ht->nTableSize) && (ht->nHashSizeIndex < nNumPrimeNumbers - 1)) { /* Let's double the table size */ - t = (Bucket **) perealloc(ht->arBuckets, PrimeNumbers[ht->nHashSizeIndex + 1] * sizeof(Bucket *),ht->persistent); + t = (Bucket **) perealloc_recoverable(ht->arBuckets, PrimeNumbers[ht->nHashSizeIndex + 1] * sizeof(Bucket *),ht->persistent); if (t) { HANDLE_BLOCK_INTERRUPTIONS(); ht->arBuckets = t;