From b248ed620fb9ab4eb2534fd493d83e26e0cdfbcc Mon Sep 17 00:00:00 2001 From: Nick Mathewson Date: Wed, 9 May 2007 21:43:41 +0000 Subject: r12704@catbus: nickm | 2007-05-09 17:43:34 -0400 Periodically clean the freelist of buffer memory chunks. svn:r10149 --- src/or/buffers.c | 29 +++++++++++++++++++++++++++-- 1 file changed, 27 insertions(+), 2 deletions(-) (limited to 'src/or/buffers.c') diff --git a/src/or/buffers.c b/src/or/buffers.c index 6273c6699b..6296ffa7c7 100644 --- a/src/or/buffers.c +++ b/src/or/buffers.c @@ -161,7 +161,7 @@ _split_range(buf_t *buf, char *at, size_t *len, /** DOCDOC */ static char *free_mem_list = NULL; static int free_mem_list_len = 0; -/*XXXX020 Actually remove stuff from freelist when it gets too big */ +static int free_mem_list_lowwater = 0; /** DOCDOC */ static void @@ -194,7 +194,8 @@ buf_get_initial_mem(buf_t *buf) if (free_mem_list) { mem = free_mem_list; free_mem_list = *(char**)mem; - --free_mem_list_len; + if (--free_mem_list_len < free_mem_list_lowwater) + free_mem_list_lowwater = free_mem_list_len; log_info(LD_GENERAL, "Got buf mem from freelist. Freelist has %d entries.", free_mem_list_len); } else { @@ -209,6 +210,30 @@ buf_get_initial_mem(buf_t *buf) buf->cur = buf->mem; } +/** DOCDOC 64k of 4k buffers. */ +#define BUF_FREELIST_SLACK 16 + +/** DOCDOC */ +void +buf_shrink_freelist(void) +{ + if (free_mem_list_lowwater > BUF_FREELIST_SLACK) { + int i; + log_info(LD_GENERAL, "We haven't used %d/%d allocated buffer memory " + "chunks since the last call(); freeing all but %d of them", + free_mem_list_lowwater, free_mem_list_len, + BUF_FREELIST_SLACK); + for (i = BUF_FREELIST_SLACK; i < free_mem_list_lowwater; ++i) { + char *mem = free_mem_list; + tor_assert(mem); + free_mem_list = *(char**)mem; + tor_free(mem); + --free_mem_list_len; + } + } + free_mem_list_lowwater = free_mem_list_len; +} + /** Change a buffer's capacity. new_capacity must be \>= * buf->datalen. */ static void -- cgit v1.2.3-54-g00ecf