summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2007-05-24 18:12:41 +0000
committerNick Mathewson <nickm@torproject.org>2007-05-24 18:12:41 +0000
commit9aaf3d182f51f079dfc42ee92d3d19553dcc1efe (patch)
treed7611273647181121cb693488cda4feb204ffe16
parent79707437d993f9c382602502d168dae259b02c55 (diff)
downloadtor-9aaf3d182f51f079dfc42ee92d3d19553dcc1efe.tar.gz
tor-9aaf3d182f51f079dfc42ee92d3d19553dcc1efe.zip
r12934@catbus: nickm | 2007-05-24 14:11:18 -0400
When freeing slack buffers, free the buffers at the end of the freelist first. svn:r10313
-rw-r--r--src/or/buffers.c23
1 files changed, 21 insertions, 2 deletions
diff --git a/src/or/buffers.c b/src/or/buffers.c
index d043198337..88f696f10b 100644
--- a/src/or/buffers.c
+++ b/src/or/buffers.c
@@ -259,18 +259,37 @@ buf_shrink_freelists(void)
for (j = 0; j < 2; ++j) {
free_mem_list_t *list = j ? &free_mem_list_16k : &free_mem_list_4k;
if (list->lowwater > list->slack) {
- int i;
+ int i, n_to_skip, n_to_free;
+ char **ptr;
log_info(LD_GENERAL, "We haven't used %d/%d allocated %d-byte buffer "
"memory chunks since the last call; freeing all but %d of them",
list->lowwater, list->len, (int)list->chunksize, list->slack);
+ /* Skip over the slack and non-lowwater entries */
+ n_to_free = list->lowwater - list->slack;
+ n_to_skip = list->len - n_to_free;
+ for (ptr = &list->list, i = 0; i < n_to_skip; ++i) {
+ char *mem = *ptr;
+ tor_assert(mem);
+ ptr = (char**)mem;
+ }
+ /* And free the remaining entries. */
+ for (i = 0; i < n_to_free; ++i) {
+ char *mem = *ptr;
+ tor_assert(mem);
+ *ptr = *(char**)mem;
+ tor_free(mem);
+ --list->len;
+ }
+#if 0
+ /* XXXX020 Put this code back if the above gives us nasty segfaults. */
for (i = list->slack; i < list->lowwater; ++i) {
- /* XXXX we should really free the last few entries, not the first. */
char *mem = list->list;
tor_assert(mem);
list->list = *(char**)mem;
tor_free(mem);
--list->len;
}
+#endif
}
list->lowwater = list->len;
}