diff options
author | Nick Mathewson <nickm@torproject.org> | 2008-04-08 17:50:03 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2008-04-08 17:50:03 +0000 |
commit | a725d5da5e4166293b5c880c992634526e9d2949 (patch) | |
tree | 26ab29f9b8df89e4d99d5b63803450b4c6271c38 /src | |
parent | f8bacfd724cc3eea002e0c8bf9b55a0df9769cd0 (diff) | |
download | tor-a725d5da5e4166293b5c880c992634526e9d2949.tar.gz tor-a725d5da5e4166293b5c880c992634526e9d2949.zip |
r19247@catbus: nickm | 2008-04-08 13:50:01 -0400
Fix behavior of memarea freelists.
svn:r14321
Diffstat (limited to 'src')
-rw-r--r-- | src/common/memarea.c | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/src/common/memarea.c b/src/common/memarea.c index 67bebeccd3..070c3b59a3 100644 --- a/src/common/memarea.c +++ b/src/common/memarea.c @@ -68,16 +68,16 @@ static memarea_chunk_t *freelist = NULL; /** Helper: allocate a new memarea chunk of around <b>chunk_size</b> bytes. */ static memarea_chunk_t * -alloc_chunk(size_t sz) +alloc_chunk(size_t sz, int freelist_ok) { - (void)sz; /*XXXX021 remove this argument. */ - if (freelist) { + if (freelist && freelist_ok) { memarea_chunk_t *res = freelist; freelist = res->next_chunk; + res->next_chunk = NULL; --freelist_len; return res; } else { - size_t chunk_size = CHUNK_SIZE; + size_t chunk_size = freelist_ok ? CHUNK_SIZE : sz; memarea_chunk_t *res = tor_malloc_roundup(&chunk_size); res->next_chunk = NULL; res->mem_size = chunk_size - CHUNK_HEADER_SIZE; @@ -93,6 +93,7 @@ chunk_free(memarea_chunk_t *chunk) ++freelist_len; chunk->next_chunk = freelist; freelist = chunk; + chunk->next_mem = chunk->u.mem; } else { tor_free(chunk); } @@ -103,7 +104,7 @@ memarea_t * memarea_new(size_t chunk_size)/*XXXX021 remove this argument.*/ { memarea_t *head = tor_malloc(sizeof(memarea_t)); - head->first = alloc_chunk(chunk_size); + head->first = alloc_chunk(chunk_size, 1); (void)chunk_size; return head; } @@ -179,12 +180,12 @@ memarea_alloc(memarea_t *area, size_t sz) if (sz+CHUNK_HEADER_SIZE >= area->chunk_size) { /* This allocation is too big. Stick it in a special chunk, and put * that chunk second in the list. */ - memarea_chunk_t *new_chunk = alloc_chunk(sz+CHUNK_HEADER_SIZE); + memarea_chunk_t *new_chunk = alloc_chunk(sz+CHUNK_HEADER_SIZE, 0); new_chunk->next_chunk = chunk->next_chunk; chunk->next_chunk = new_chunk; chunk = new_chunk; } else { - memarea_chunk_t *new_chunk = alloc_chunk(area->chunk_size); + memarea_chunk_t *new_chunk = alloc_chunk(area->chunk_size, 1); new_chunk->next_chunk = chunk; area->first = chunk = new_chunk; } |