diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/internal/dynlink.h | 1 | ||||
| -rw-r--r-- | src/malloc/calloc.c | 10 | ||||
| -rw-r--r-- | src/malloc/oldmalloc/malloc.c | 5 | 
3 files changed, 15 insertions, 1 deletions
| diff --git a/src/internal/dynlink.h b/src/internal/dynlink.h index b739add2..78baa080 100644 --- a/src/internal/dynlink.h +++ b/src/internal/dynlink.h @@ -107,5 +107,6 @@ hidden ptrdiff_t __tlsdesc_static(), __tlsdesc_dynamic();  hidden extern int __malloc_replaced;  hidden void __malloc_donate(char *, char *); +hidden int __malloc_allzerop(void *);  #endif diff --git a/src/malloc/calloc.c b/src/malloc/calloc.c index 322193ca..bf6bddca 100644 --- a/src/malloc/calloc.c +++ b/src/malloc/calloc.c @@ -2,6 +2,7 @@  #include <stdint.h>  #include <string.h>  #include <errno.h> +#include "dynlink.h"  static size_t mal0_clear(char *p, size_t n)  { @@ -23,6 +24,12 @@ static size_t mal0_clear(char *p, size_t n)  	}  } +static int allzerop(void *p) +{ +	return 0; +} +weak_alias(allzerop, __malloc_allzerop); +  void *calloc(size_t m, size_t n)  {  	if (n && m > (size_t)-1/n) { @@ -31,7 +38,8 @@ void *calloc(size_t m, size_t n)  	}  	n *= m;  	void *p = malloc(n); -	if (!p) return p; +	if (!p || (!__malloc_replaced && __malloc_allzerop(p))) +		return p;  	n = mal0_clear(p, n);  	return memset(p, 0, n);  } diff --git a/src/malloc/oldmalloc/malloc.c b/src/malloc/oldmalloc/malloc.c index 1c6b07ec..0a38690c 100644 --- a/src/malloc/oldmalloc/malloc.c +++ b/src/malloc/oldmalloc/malloc.c @@ -339,6 +339,11 @@ void *malloc(size_t n)  	return CHUNK_TO_MEM(c);  } +int __malloc_allzerop(void *p) +{ +	return IS_MMAPPED(MEM_TO_CHUNK(p)); +} +  void *realloc(void *p, size_t n)  {  	struct chunk *self, *next; | 
