2021-10-14 00:27:13 +00:00
|
|
|
#include "libc/bits/likely.h"
|
2020-09-07 04:39:00 +00:00
|
|
|
#include "libc/str/str.h"
|
|
|
|
#include "libc/sysv/errfuns.h"
|
2020-11-25 16:19:00 +00:00
|
|
|
#include "third_party/dlmalloc/dlmalloc.internal.h"
|
2020-09-07 04:39:00 +00:00
|
|
|
|
|
|
|
void *dlrealloc(void *oldmem, size_t bytes) {
|
|
|
|
void *mem = 0;
|
2021-10-14 00:27:13 +00:00
|
|
|
size_t oc, nb;
|
|
|
|
struct MallocState *m;
|
|
|
|
struct MallocChunk *oldp, *newp;
|
|
|
|
if (oldmem) {
|
|
|
|
if (LIKELY(bytes < MAX_REQUEST)) {
|
|
|
|
if (bytes) {
|
|
|
|
nb = request2size(bytes);
|
|
|
|
oldp = mem2chunk(oldmem);
|
2020-09-07 04:39:00 +00:00
|
|
|
#if !FOOTERS
|
2021-10-14 00:27:13 +00:00
|
|
|
m = g_dlmalloc;
|
|
|
|
#else /* FOOTERS */
|
|
|
|
m = get_mstate_for(oldp);
|
|
|
|
if (UNLIKELY(!ok_magic(m))) {
|
|
|
|
USAGE_ERROR_ACTION(m, oldmem);
|
|
|
|
return 0;
|
|
|
|
}
|
2020-09-07 04:39:00 +00:00
|
|
|
#endif /* FOOTERS */
|
2021-10-14 00:27:13 +00:00
|
|
|
if (!PREACTION(m)) {
|
|
|
|
newp = dlmalloc_try_realloc_chunk(m, oldp, nb, 1);
|
|
|
|
POSTACTION(m);
|
|
|
|
if (newp) {
|
|
|
|
check_inuse_chunk(m, newp);
|
|
|
|
mem = chunk2mem(newp);
|
|
|
|
} else if ((mem = dlmalloc(bytes))) {
|
|
|
|
oc = chunksize(oldp) - overhead_for(oldp);
|
|
|
|
memcpy(mem, oldmem, (oc < bytes) ? oc : bytes);
|
|
|
|
dlfree(oldmem);
|
|
|
|
}
|
2020-09-07 04:39:00 +00:00
|
|
|
}
|
2021-10-14 00:27:13 +00:00
|
|
|
} else {
|
|
|
|
dlfree(oldmem);
|
2020-09-07 04:39:00 +00:00
|
|
|
}
|
2021-10-14 00:27:13 +00:00
|
|
|
} else {
|
|
|
|
enomem();
|
2020-09-07 04:39:00 +00:00
|
|
|
}
|
2021-10-14 00:27:13 +00:00
|
|
|
} else {
|
|
|
|
mem = dlmalloc(bytes);
|
2020-09-07 04:39:00 +00:00
|
|
|
}
|
|
|
|
return mem;
|
|
|
|
}
|