Remove unwarranted uses of 'goto'.

This commit is contained in:
jasone 2006-01-27 07:46:22 +00:00
parent d2566b1431
commit 4018cc9c9b

View File

@ -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);
} }