Remove unwarranted uses of 'goto'.
This commit is contained in:
parent
d2566b1431
commit
4018cc9c9b
@ -1636,16 +1636,14 @@ arena_mask_unset(arena_t *arena, unsigned bin)
|
|||||||
static unsigned
|
static unsigned
|
||||||
arena_bins_search(arena_t *arena, size_t size)
|
arena_bins_search(arena_t *arena, size_t size)
|
||||||
{
|
{
|
||||||
unsigned ret, minbin, i;
|
unsigned minbin, i;
|
||||||
int bit;
|
int bit;
|
||||||
|
|
||||||
assert(QUANTUM_CEILING(size) == size);
|
assert(QUANTUM_CEILING(size) == size);
|
||||||
assert((size >> opt_quantum_2pow) >= bin_shift);
|
assert((size >> opt_quantum_2pow) >= bin_shift);
|
||||||
|
|
||||||
if (size > bin_maxsize) {
|
if (size > bin_maxsize)
|
||||||
ret = UINT_MAX;
|
return (UINT_MAX);
|
||||||
goto RETURN;
|
|
||||||
}
|
|
||||||
|
|
||||||
minbin = (size >> opt_quantum_2pow) - bin_shift;
|
minbin = (size >> opt_quantum_2pow) - bin_shift;
|
||||||
assert(minbin < NBINS);
|
assert(minbin < NBINS);
|
||||||
@ -1654,14 +1652,11 @@ arena_bins_search(arena_t *arena, size_t size)
|
|||||||
& (UINT_MAX << (minbin % (sizeof(int) << 3))));
|
& (UINT_MAX << (minbin % (sizeof(int) << 3))));
|
||||||
if (bit != 0) {
|
if (bit != 0) {
|
||||||
/* Usable allocation found. */
|
/* Usable allocation found. */
|
||||||
ret = (i * (sizeof(int) << 3)) + bit - 1;
|
return ((i * (sizeof(int) << 3)) + bit - 1);
|
||||||
goto RETURN;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = UINT_MAX;
|
return (UINT_MAX);
|
||||||
RETURN:
|
|
||||||
return (ret);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static __inline void
|
static __inline void
|
||||||
@ -2657,58 +2652,55 @@ arena_frag_reg_alloc(arena_t *arena, size_t size, bool fit)
|
|||||||
static region_t *
|
static region_t *
|
||||||
arena_split_reg_alloc(arena_t *arena, size_t size, bool fit)
|
arena_split_reg_alloc(arena_t *arena, size_t size, bool fit)
|
||||||
{
|
{
|
||||||
region_t *ret;
|
|
||||||
|
|
||||||
if (arena->split != NULL) {
|
if (arena->split == NULL)
|
||||||
|
return (NULL);
|
||||||
|
|
||||||
#ifdef MALLOC_STATS
|
#ifdef MALLOC_STATS
|
||||||
arena->stats.split.nrequests++;
|
arena->stats.split.nrequests++;
|
||||||
#endif
|
#endif
|
||||||
if (region_next_size_get(&arena->split->sep) >= size) {
|
if (region_next_size_get(&arena->split->sep) >= size) {
|
||||||
|
region_t *ret;
|
||||||
|
|
||||||
if (fit) {
|
if (fit) {
|
||||||
size_t total_size;
|
size_t total_size;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Use split, but try to use the beginning for
|
* Use split, but try to use the beginning for smaller
|
||||||
* smaller regions, and the end for larger
|
* regions, and the end for larger regions. This
|
||||||
* regions. This reduces fragmentation in some
|
* reduces fragmentation in some pathological use
|
||||||
* pathological use cases. It tends to group
|
* cases. It tends to group short-lived (smaller)
|
||||||
* short-lived (smaller) regions, which
|
* regions, which increases the effectiveness of
|
||||||
* increases the effectiveness of coalescing.
|
* coalescing.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
total_size =
|
total_size = region_next_size_get(&arena->split->sep);
|
||||||
region_next_size_get(&arena->split->sep);
|
|
||||||
assert(size % quantum == 0);
|
assert(size % quantum == 0);
|
||||||
|
|
||||||
if (total_size - size >= QUANTUM_CEILING(
|
if (total_size - size >=
|
||||||
sizeof(region_small_sizer_t))) {
|
QUANTUM_CEILING(sizeof(region_small_sizer_t))) {
|
||||||
if (size <= bin_maxsize) {
|
if (size <= bin_maxsize) {
|
||||||
region_t *next;
|
region_t *next;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Carve space from the
|
* Carve space from the beginning of
|
||||||
* beginning of split.
|
* split.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* ret. */
|
/* ret. */
|
||||||
ret = arena->split;
|
ret = arena->split;
|
||||||
region_next_size_set(&ret->sep,
|
region_next_size_set(&ret->sep, size);
|
||||||
size);
|
assert(region_next_free_get(&ret->sep)
|
||||||
assert(region_next_free_get(
|
== false);
|
||||||
&ret->sep) == false);
|
|
||||||
|
|
||||||
/* next. */
|
/* next. */
|
||||||
next = (region_t *)&((char *)
|
next = (region_t *)&((char *)ret)[size];
|
||||||
ret)[size];
|
|
||||||
region_next_size_set(&next->sep,
|
region_next_size_set(&next->sep,
|
||||||
total_size - size);
|
total_size - size);
|
||||||
assert(size >=
|
assert(size >= QUANTUM_CEILING(sizeof(
|
||||||
QUANTUM_CEILING(sizeof(
|
|
||||||
region_small_sizer_t)));
|
region_small_sizer_t)));
|
||||||
region_prev_free_unset(
|
region_prev_free_unset(&next->sep);
|
||||||
&next->sep);
|
region_next_free_unset(&next->sep);
|
||||||
region_next_free_unset(
|
|
||||||
&next->sep);
|
|
||||||
|
|
||||||
/* Update split. */
|
/* Update split. */
|
||||||
arena->split = next;
|
arena->split = next;
|
||||||
@ -2716,10 +2708,7 @@ arena_split_reg_alloc(arena_t *arena, size_t size, bool fit)
|
|||||||
region_t *prev;
|
region_t *prev;
|
||||||
size_t prev_size;
|
size_t prev_size;
|
||||||
|
|
||||||
/*
|
/* Carve space from the end of split. */
|
||||||
* Carve space from the end of
|
|
||||||
* split.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* prev. */
|
/* prev. */
|
||||||
prev_size = total_size - size;
|
prev_size = total_size - size;
|
||||||
@ -2735,19 +2724,16 @@ arena_split_reg_alloc(arena_t *arena, size_t size, bool fit)
|
|||||||
/* ret. */
|
/* ret. */
|
||||||
ret = (region_t *)&((char *)
|
ret = (region_t *)&((char *)
|
||||||
prev)[prev_size];
|
prev)[prev_size];
|
||||||
region_next_size_set(&ret->sep,
|
region_next_size_set(&ret->sep, size);
|
||||||
size);
|
region_prev_free_unset(&ret->sep);
|
||||||
region_prev_free_unset(
|
region_next_free_unset(&ret->sep);
|
||||||
&ret->sep);
|
|
||||||
region_next_free_unset(
|
|
||||||
&ret->sep);
|
|
||||||
|
|
||||||
#ifdef MALLOC_DEBUG
|
#ifdef MALLOC_DEBUG
|
||||||
{
|
{
|
||||||
region_t *next;
|
region_t *next;
|
||||||
|
|
||||||
/* next. */
|
/* next. */
|
||||||
next = (region_t *)&((char *) ret)
|
next = (region_t *)&((char *)ret)
|
||||||
[region_next_size_get(&ret->sep)];
|
[region_next_size_get(&ret->sep)];
|
||||||
assert(region_prev_free_get(&next->sep)
|
assert(region_prev_free_get(&next->sep)
|
||||||
== false);
|
== false);
|
||||||
@ -2759,9 +2745,9 @@ arena_split_reg_alloc(arena_t *arena, size_t size, bool fit)
|
|||||||
#endif
|
#endif
|
||||||
} else {
|
} else {
|
||||||
/*
|
/*
|
||||||
* split is close enough to the right
|
* Split is close enough to the right size that
|
||||||
* size that there isn't enough room to
|
* there isn't enough room to create a
|
||||||
* create a neighboring region.
|
* neighboring region.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* ret. */
|
/* ret. */
|
||||||
@ -2778,8 +2764,8 @@ arena_split_reg_alloc(arena_t *arena, size_t size, bool fit)
|
|||||||
next = (region_t *)&((char *)
|
next = (region_t *)&((char *)
|
||||||
ret)[region_next_size_get(
|
ret)[region_next_size_get(
|
||||||
&ret->sep)];
|
&ret->sep)];
|
||||||
assert(region_prev_free_get(
|
assert(region_prev_free_get(&next->sep)
|
||||||
&next->sep) == false);
|
== false);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -2792,8 +2778,7 @@ arena_split_reg_alloc(arena_t *arena, size_t size, bool fit)
|
|||||||
/* ret. */
|
/* ret. */
|
||||||
ret = arena->split;
|
ret = arena->split;
|
||||||
arena->split = NULL;
|
arena->split = NULL;
|
||||||
assert(region_next_free_get(&ret->sep)
|
assert(region_next_free_get(&ret->sep) == false);
|
||||||
== false);
|
|
||||||
|
|
||||||
#ifdef MALLOC_DEBUG
|
#ifdef MALLOC_DEBUG
|
||||||
{
|
{
|
||||||
@ -2808,13 +2793,16 @@ arena_split_reg_alloc(arena_t *arena, size_t size, bool fit)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
region_next_contig_set(&ret->sep);
|
region_next_contig_set(&ret->sep);
|
||||||
goto RETURN;
|
return (ret);
|
||||||
} else if (size <= bin_maxsize) {
|
}
|
||||||
|
/* If we get here, split has failed to service the request. */
|
||||||
|
|
||||||
|
if (size <= bin_maxsize) {
|
||||||
region_t *reg;
|
region_t *reg;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The split region is too small to service a small
|
* The split region is too small to service a small request.
|
||||||
* request. Clear split.
|
* Clear split.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
reg = arena->split;
|
reg = arena->split;
|
||||||
@ -2824,11 +2812,8 @@ arena_split_reg_alloc(arena_t *arena, size_t size, bool fit)
|
|||||||
|
|
||||||
arena_delay_cache(arena, reg);
|
arena_delay_cache(arena, reg);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
ret = NULL;
|
return (NULL);
|
||||||
RETURN:
|
|
||||||
return (ret);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -2916,17 +2901,15 @@ arena_bin_reg_alloc(arena_t *arena, size_t size, bool fit)
|
|||||||
#ifdef MALLOC_STATS
|
#ifdef MALLOC_STATS
|
||||||
arena->stats.bins[bin].nserviced++;
|
arena->stats.bins[bin].nserviced++;
|
||||||
#endif
|
#endif
|
||||||
goto RETURN;
|
return (ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Look at frag to see whether it's large enough. */
|
/* Look at frag to see whether it's large enough. */
|
||||||
ret = arena_frag_reg_alloc(arena, size, fit);
|
ret = arena_frag_reg_alloc(arena, size, fit);
|
||||||
if (ret != NULL)
|
if (ret != NULL)
|
||||||
goto RETURN;
|
|
||||||
|
|
||||||
ret = NULL;
|
|
||||||
RETURN:
|
|
||||||
return (ret);
|
return (ret);
|
||||||
|
|
||||||
|
return (NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Look in large_regions for a large enough region. */
|
/* Look in large_regions for a large enough region. */
|
||||||
@ -2946,10 +2929,8 @@ arena_large_reg_alloc(arena_t *arena, size_t size, bool fit)
|
|||||||
region_next_size_set(&key.sep, size);
|
region_next_size_set(&key.sep, size);
|
||||||
node = RB_NFIND(region_tree_s, &arena->large_regions,
|
node = RB_NFIND(region_tree_s, &arena->large_regions,
|
||||||
&key.next.u.l.node);
|
&key.next.u.l.node);
|
||||||
if (node == NULL) {
|
if (node == NULL)
|
||||||
ret = NULL;
|
return (NULL);
|
||||||
goto RETURN;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Cached large region found. */
|
/* Cached large region found. */
|
||||||
ret = node->reg;
|
ret = node->reg;
|
||||||
@ -2973,7 +2954,6 @@ arena_large_reg_alloc(arena_t *arena, size_t size, bool fit)
|
|||||||
arena->stats.large.nserviced++;
|
arena->stats.large.nserviced++;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
RETURN:
|
|
||||||
return (ret);
|
return (ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2985,10 +2965,8 @@ arena_chunk_reg_alloc(arena_t *arena, size_t size, bool fit)
|
|||||||
chunk_node_t *chunk;
|
chunk_node_t *chunk;
|
||||||
|
|
||||||
chunk = chunk_alloc(chunk_size);
|
chunk = chunk_alloc(chunk_size);
|
||||||
if (chunk == NULL) {
|
if (chunk == NULL)
|
||||||
ret = NULL;
|
return (NULL);
|
||||||
goto RETURN;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef MALLOC_DEBUG
|
#ifdef MALLOC_DEBUG
|
||||||
{
|
{
|
||||||
@ -3042,7 +3020,6 @@ arena_chunk_reg_alloc(arena_t *arena, size_t size, bool fit)
|
|||||||
if (fit)
|
if (fit)
|
||||||
arena_reg_fit(arena, size, ret, (arena->split == NULL));
|
arena_reg_fit(arena, size, ret, (arena->split == NULL));
|
||||||
|
|
||||||
RETURN:
|
|
||||||
return (ret);
|
return (ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3063,16 +3040,16 @@ arena_reg_alloc(arena_t *arena, size_t size, bool fit)
|
|||||||
if (size <= bin_maxsize) {
|
if (size <= bin_maxsize) {
|
||||||
ret = arena_bin_reg_alloc(arena, size, fit);
|
ret = arena_bin_reg_alloc(arena, size, fit);
|
||||||
if (ret != NULL)
|
if (ret != NULL)
|
||||||
goto RETURN;
|
return (ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = arena_large_reg_alloc(arena, size, fit);
|
ret = arena_large_reg_alloc(arena, size, fit);
|
||||||
if (ret != NULL)
|
if (ret != NULL)
|
||||||
goto RETURN;
|
return (ret);
|
||||||
|
|
||||||
ret = arena_split_reg_alloc(arena, size, fit);
|
ret = arena_split_reg_alloc(arena, size, fit);
|
||||||
if (ret != NULL)
|
if (ret != NULL)
|
||||||
goto RETURN;
|
return (ret);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Only try allocating from frag here if size is large, since
|
* Only try allocating from frag here if size is large, since
|
||||||
@ -3082,16 +3059,14 @@ arena_reg_alloc(arena_t *arena, size_t size, bool fit)
|
|||||||
if (size > bin_maxsize) {
|
if (size > bin_maxsize) {
|
||||||
ret = arena_frag_reg_alloc(arena, size, fit);
|
ret = arena_frag_reg_alloc(arena, size, fit);
|
||||||
if (ret != NULL)
|
if (ret != NULL)
|
||||||
goto RETURN;
|
return (ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = arena_chunk_reg_alloc(arena, size, fit);
|
ret = arena_chunk_reg_alloc(arena, size, fit);
|
||||||
if (ret != NULL)
|
if (ret != NULL)
|
||||||
goto RETURN;
|
|
||||||
|
|
||||||
ret = NULL;
|
|
||||||
RETURN:
|
|
||||||
return (ret);
|
return (ret);
|
||||||
|
|
||||||
|
return (NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void *
|
static void *
|
||||||
@ -3109,8 +3084,7 @@ arena_malloc(arena_t *arena, size_t size)
|
|||||||
quantum_size = region_ceiling(size);
|
quantum_size = region_ceiling(size);
|
||||||
if (quantum_size < size) {
|
if (quantum_size < size) {
|
||||||
/* size is large enough to cause size_t wrap-around. */
|
/* size is large enough to cause size_t wrap-around. */
|
||||||
ret = NULL;
|
return (NULL);
|
||||||
goto RETURN;
|
|
||||||
}
|
}
|
||||||
assert(quantum_size >= QUANTUM_CEILING(sizeof(region_small_sizer_t)));
|
assert(quantum_size >= QUANTUM_CEILING(sizeof(region_small_sizer_t)));
|
||||||
|
|
||||||
@ -3118,8 +3092,7 @@ arena_malloc(arena_t *arena, size_t size)
|
|||||||
reg = arena_reg_alloc(arena, quantum_size, true);
|
reg = arena_reg_alloc(arena, quantum_size, true);
|
||||||
if (reg == NULL) {
|
if (reg == NULL) {
|
||||||
malloc_mutex_unlock(&arena->mtx);
|
malloc_mutex_unlock(&arena->mtx);
|
||||||
ret = NULL;
|
return (NULL);
|
||||||
goto RETURN;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef MALLOC_STATS
|
#ifdef MALLOC_STATS
|
||||||
@ -3151,7 +3124,6 @@ arena_malloc(arena_t *arena, size_t size)
|
|||||||
memset(next->sep.prev_red, 0xa5, MALLOC_RED);
|
memset(next->sep.prev_red, 0xa5, MALLOC_RED);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
RETURN:
|
|
||||||
return (ret);
|
return (ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3184,8 +3156,7 @@ arena_palloc(arena_t *arena, size_t alignment, size_t size)
|
|||||||
quantum_size = region_ceiling(size);
|
quantum_size = region_ceiling(size);
|
||||||
if (quantum_size < size) {
|
if (quantum_size < size) {
|
||||||
/* size is large enough to cause size_t wrap-around. */
|
/* size is large enough to cause size_t wrap-around. */
|
||||||
ret = NULL;
|
return (NULL);
|
||||||
goto RETURN;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -3206,8 +3177,7 @@ arena_palloc(arena_t *arena, size_t alignment, size_t size)
|
|||||||
|
|
||||||
if (alloc_size < quantum_size) {
|
if (alloc_size < quantum_size) {
|
||||||
/* size_t wrap-around occurred. */
|
/* size_t wrap-around occurred. */
|
||||||
ret = NULL;
|
return (NULL);
|
||||||
goto RETURN;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
malloc_mutex_lock(&arena->mtx);
|
malloc_mutex_lock(&arena->mtx);
|
||||||
@ -3215,8 +3185,7 @@ arena_palloc(arena_t *arena, size_t alignment, size_t size)
|
|||||||
reg = arena_reg_alloc(arena, alloc_size, false);
|
reg = arena_reg_alloc(arena, alloc_size, false);
|
||||||
if (reg == NULL) {
|
if (reg == NULL) {
|
||||||
malloc_mutex_unlock(&arena->mtx);
|
malloc_mutex_unlock(&arena->mtx);
|
||||||
ret = NULL;
|
return (NULL);
|
||||||
goto RETURN;
|
|
||||||
}
|
}
|
||||||
if (reg == old_split) {
|
if (reg == old_split) {
|
||||||
/*
|
/*
|
||||||
@ -3360,7 +3329,6 @@ arena_palloc(arena_t *arena, size_t alignment, size_t size)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
RETURN:
|
|
||||||
assert(((uintptr_t)ret & (alignment - 1)) == 0);
|
assert(((uintptr_t)ret & (alignment - 1)) == 0);
|
||||||
return (ret);
|
return (ret);
|
||||||
}
|
}
|
||||||
@ -3376,11 +3344,10 @@ arena_calloc(arena_t *arena, size_t num, size_t size)
|
|||||||
|
|
||||||
ret = arena_malloc(arena, num * size);
|
ret = arena_malloc(arena, num * size);
|
||||||
if (ret == NULL)
|
if (ret == NULL)
|
||||||
goto RETURN;
|
return (NULL);
|
||||||
|
|
||||||
memset(ret, 0, num * size);
|
memset(ret, 0, num * size);
|
||||||
|
|
||||||
RETURN:
|
|
||||||
return (ret);
|
return (ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3559,7 +3526,6 @@ arena_stats(arena_t *arena, size_t *allocated, size_t *total)
|
|||||||
static bool
|
static bool
|
||||||
arena_new(arena_t *arena)
|
arena_new(arena_t *arena)
|
||||||
{
|
{
|
||||||
bool ret;
|
|
||||||
unsigned i;
|
unsigned i;
|
||||||
|
|
||||||
malloc_mutex_init(&arena->mtx);
|
malloc_mutex_init(&arena->mtx);
|
||||||
@ -3580,10 +3546,8 @@ arena_new(arena_t *arena)
|
|||||||
assert(opt_ndelay > 0);
|
assert(opt_ndelay > 0);
|
||||||
arena->delayed = (region_t **)base_alloc(opt_ndelay
|
arena->delayed = (region_t **)base_alloc(opt_ndelay
|
||||||
* sizeof(region_t *));
|
* sizeof(region_t *));
|
||||||
if (arena->delayed == NULL) {
|
if (arena->delayed == NULL)
|
||||||
ret = true;
|
return (true);
|
||||||
goto RETURN;
|
|
||||||
}
|
|
||||||
memset(arena->delayed, 0, opt_ndelay * sizeof(region_t *));
|
memset(arena->delayed, 0, opt_ndelay * sizeof(region_t *));
|
||||||
arena->next_delayed = 0;
|
arena->next_delayed = 0;
|
||||||
|
|
||||||
@ -3597,9 +3561,7 @@ arena_new(arena_t *arena)
|
|||||||
arena->magic = ARENA_MAGIC;
|
arena->magic = ARENA_MAGIC;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
ret = false;
|
return (false);
|
||||||
RETURN:
|
|
||||||
return (ret);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Create a new arena and insert it into the arenas array at index ind. */
|
/* Create a new arena and insert it into the arenas array at index ind. */
|
||||||
@ -3744,22 +3706,18 @@ huge_malloc(arena_t *arena, size_t size)
|
|||||||
chunk_size = CHUNK_CEILING(size);
|
chunk_size = CHUNK_CEILING(size);
|
||||||
if (chunk_size == 0) {
|
if (chunk_size == 0) {
|
||||||
/* size is large enough to cause size_t wrap-around. */
|
/* size is large enough to cause size_t wrap-around. */
|
||||||
ret = NULL;
|
return (NULL);
|
||||||
goto RETURN;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Allocate a chunk node with which to track the chunk. */
|
/* Allocate a chunk node with which to track the chunk. */
|
||||||
node = base_chunk_node_alloc();
|
node = base_chunk_node_alloc();
|
||||||
if (node == NULL) {
|
if (node == NULL)
|
||||||
ret = NULL;
|
return (NULL);
|
||||||
goto RETURN;
|
|
||||||
}
|
|
||||||
|
|
||||||
ret = chunk_alloc(chunk_size);
|
ret = chunk_alloc(chunk_size);
|
||||||
if (ret == NULL) {
|
if (ret == NULL) {
|
||||||
base_chunk_node_dealloc(node);
|
base_chunk_node_dealloc(node);
|
||||||
ret = NULL;
|
return (NULL);
|
||||||
goto RETURN;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Insert node into chunks. */
|
/* Insert node into chunks. */
|
||||||
@ -3776,7 +3734,6 @@ huge_malloc(arena_t *arena, size_t size)
|
|||||||
#endif
|
#endif
|
||||||
malloc_mutex_unlock(&chunks_mtx);
|
malloc_mutex_unlock(&chunks_mtx);
|
||||||
|
|
||||||
RETURN:
|
|
||||||
return (ret);
|
return (ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3908,16 +3865,13 @@ ipalloc(arena_t *arena, size_t alignment, size_t size)
|
|||||||
* Allocate a chunk node with which to track the chunk.
|
* Allocate a chunk node with which to track the chunk.
|
||||||
*/
|
*/
|
||||||
node = base_chunk_node_alloc();
|
node = base_chunk_node_alloc();
|
||||||
if (node == NULL) {
|
if (node == NULL)
|
||||||
ret = NULL;
|
return (NULL);
|
||||||
goto RETURN;
|
|
||||||
}
|
|
||||||
|
|
||||||
ret = chunk_alloc(alloc_size);
|
ret = chunk_alloc(alloc_size);
|
||||||
if (ret == NULL) {
|
if (ret == NULL) {
|
||||||
base_chunk_node_dealloc(node);
|
base_chunk_node_dealloc(node);
|
||||||
ret = NULL;
|
return (NULL);
|
||||||
goto RETURN;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
offset = (uintptr_t)ret & (alignment - 1);
|
offset = (uintptr_t)ret & (alignment - 1);
|
||||||
@ -3967,11 +3921,8 @@ ipalloc(arena_t *arena, size_t alignment, size_t size)
|
|||||||
arena->stats.npalloc++;
|
arena->stats.npalloc++;
|
||||||
malloc_mutex_unlock(&arena->mtx);
|
malloc_mutex_unlock(&arena->mtx);
|
||||||
#endif
|
#endif
|
||||||
RETURN:
|
if (opt_junk)
|
||||||
if (opt_junk) {
|
|
||||||
if (ret != NULL)
|
|
||||||
memset(ret, 0xa5, size);
|
memset(ret, 0xa5, size);
|
||||||
}
|
|
||||||
assert(((uintptr_t)ret & (alignment - 1)) == 0);
|
assert(((uintptr_t)ret & (alignment - 1)) == 0);
|
||||||
return (ret);
|
return (ret);
|
||||||
}
|
}
|
||||||
@ -4087,7 +4038,7 @@ iralloc(arena_t *arena, void *ptr, size_t size)
|
|||||||
if (region_ceiling(size) <= (chunk_size >> 1)) {
|
if (region_ceiling(size) <= (chunk_size >> 1)) {
|
||||||
ret = arena_malloc(arena, size);
|
ret = arena_malloc(arena, size);
|
||||||
if (ret == NULL)
|
if (ret == NULL)
|
||||||
goto RETURN;
|
return (NULL);
|
||||||
if (opt_junk)
|
if (opt_junk)
|
||||||
memset(ret, 0xa5, size);
|
memset(ret, 0xa5, size);
|
||||||
|
|
||||||
@ -4098,7 +4049,7 @@ iralloc(arena_t *arena, void *ptr, size_t size)
|
|||||||
} else {
|
} else {
|
||||||
ret = huge_malloc(arena, size);
|
ret = huge_malloc(arena, size);
|
||||||
if (ret == NULL)
|
if (ret == NULL)
|
||||||
goto RETURN;
|
return (NULL);
|
||||||
if (opt_junk)
|
if (opt_junk)
|
||||||
memset(ret, 0xa5, size);
|
memset(ret, 0xa5, size);
|
||||||
|
|
||||||
@ -4122,7 +4073,6 @@ iralloc(arena_t *arena, void *ptr, size_t size)
|
|||||||
arena->stats.nralloc++;
|
arena->stats.nralloc++;
|
||||||
malloc_mutex_unlock(&arena->mtx);
|
malloc_mutex_unlock(&arena->mtx);
|
||||||
#endif
|
#endif
|
||||||
RETURN:
|
|
||||||
return (ret);
|
return (ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user