Mercurial > dropbear
diff dbmalloc.c @ 1569:c42e8ff42bd1
Only use malloc wrapper if fuzzing
author | Matt Johnston <matt@ucc.asn.au> |
---|---|
date | Thu, 01 Mar 2018 23:46:24 +0800 |
parents | 7209a6e30932 |
children | 1051e4eea25a |
line wrap: on
line diff
--- a/dbmalloc.c Thu Mar 01 23:46:07 2018 +0800 +++ b/dbmalloc.c Thu Mar 01 23:46:24 2018 +0800 @@ -1,6 +1,64 @@ #include "dbmalloc.h" #include "dbutil.h" + +void * m_calloc(size_t nmemb, size_t size) { + if (SIZE_T_MAX / nmemb < size) { + dropbear_exit("m_calloc failed"); + } + return m_malloc(nmemb*size); +} + +void * m_strdup(const char * str) { + char* ret; + unsigned int len; + len = strlen(str); + + ret = m_malloc(len+1); + if (ret == NULL) { + dropbear_exit("m_strdup failed"); + } + memcpy(ret, str, len+1); + return ret; +} + +#if !DROPBEAR_TRACKING_MALLOC + +/* Simple wrappers around malloc etc */ +void * m_malloc(size_t size) { + + void* ret; + + if (size == 0) { + dropbear_exit("m_malloc failed"); + } + ret = calloc(1, size); + if (ret == NULL) { + dropbear_exit("m_malloc failed"); + } + return ret; + +} + +void * m_realloc(void* ptr, size_t size) { + + void *ret; + + if (size == 0) { + dropbear_exit("m_realloc failed"); + } + ret = realloc(ptr, size); + if (ret == NULL) { + dropbear_exit("m_realloc failed"); + } + return ret; +} + + +#else + +/* For fuzzing */ + struct dbmalloc_header { unsigned int epoch; struct dbmalloc_header *prev; @@ -90,13 +148,6 @@ return &mem[sizeof(struct dbmalloc_header)]; } -void * m_calloc(size_t nmemb, size_t size) { - if (SIZE_T_MAX / nmemb < size) { - dropbear_exit("m_calloc failed"); - } - return m_malloc(nmemb*size); -} - void * m_realloc(void* ptr, size_t size) { char* mem = NULL; struct dbmalloc_header* header = NULL; @@ -128,17 +179,4 @@ free(header); } -void * m_strdup(const char * str) { - char* ret; - unsigned int len; - len = strlen(str); - - ret = m_malloc(len+1); - if (ret == NULL) { - dropbear_exit("m_strdup failed"); - } - memcpy(ret, str, len+1); - return ret; -} - - +#endif /* DROPBEAR_TRACKING_MALLOC */