From 1bc015efddaf7dc4ddd1b6b6831c43e7ad4582c0 Mon Sep 17 00:00:00 2001 From: Waldemar Brodkorb Date: Wed, 31 Jan 2018 05:27:54 +0000 Subject: malloc: add malloc_usable_size() --- include/malloc.h | 2 ++ libc/stdlib/malloc-standard/malloc_usable_size.c | 14 ++++++++++++++ 2 files changed, 16 insertions(+) create mode 100644 libc/stdlib/malloc-standard/malloc_usable_size.c diff --git a/include/malloc.h b/include/malloc.h index b16a1105a..e52792381 100644 --- a/include/malloc.h +++ b/include/malloc.h @@ -162,6 +162,8 @@ extern int malloc_trim(size_t pad); /* Prints brief summary statistics on the stderr. */ extern void malloc_stats(void); +extern size_t malloc_usable_size(void *); + /* SVID2/XPG mallopt options */ #ifndef M_MXFAST # define M_MXFAST 1 /* UNUSED in this malloc */ diff --git a/libc/stdlib/malloc-standard/malloc_usable_size.c b/libc/stdlib/malloc-standard/malloc_usable_size.c new file mode 100644 index 000000000..c78c6a867 --- /dev/null +++ b/libc/stdlib/malloc-standard/malloc_usable_size.c @@ -0,0 +1,14 @@ +/* + malloc_usable_size - fully inspired by musl implementation +*/ + +#include "malloc.h" + +/* for malloc_usable_size */ +#define OVERHEAD (2*sizeof(size_t)) +#define CHUNK_SIZE(c) ((c)->size & -2) +#define MEM_TO_CHUNK(p) (struct malloc_chunk *)((char *)(p) - OVERHEAD) + +size_t malloc_usable_size(void *p) { + return p ? CHUNK_SIZE(MEM_TO_CHUNK(p)) - OVERHEAD : 0; +} -- cgit v1.2.3