From: Robert Ransom Date: Fri, 12 Nov 2010 11:04:07 +0000 (-0800) Subject: Move the original log_info call out of the core of buf_shrink_freelists. X-Git-Tag: tor-0.2.2.18-alpha~13^2~2 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=81affe194905147f8e7692818dad786d3421f9a7;p=thirdparty%2Ftor.git Move the original log_info call out of the core of buf_shrink_freelists. Sending a log message to a control port can cause Tor to allocate a buffer, thereby changing the length of the freelist behind buf_shrink_freelists's back, thereby causing an assertion to fail. Fixes bug #1125. --- diff --git a/src/or/buffers.c b/src/or/buffers.c index 571f86de1f..5b53d12f80 100644 --- a/src/or/buffers.c +++ b/src/or/buffers.c @@ -259,12 +259,10 @@ buf_shrink_freelists(int free_all) (freelists[i].lowest_length - slack); int n_to_skip = freelists[i].cur_length - n_to_free; int orig_n_to_free = n_to_free, n_freed=0; + int orig_n_to_skip = n_to_skip; int new_length = n_to_skip; chunk_t **chp = &freelists[i].head; chunk_t *chunk; - log_info(LD_MM, "Cleaning freelist for %d-byte chunks: keeping %d, " - "dropping %d.", - (int)freelists[i].alloc_size, n_to_skip, n_to_free); while (n_to_skip) { tor_assert((*chp)->next); chp = &(*chp)->next; @@ -291,6 +289,9 @@ buf_shrink_freelists(int free_all) } // tor_assert(!n_to_free); freelists[i].cur_length = new_length; + log_info(LD_MM, "Cleaned freelist for %d-byte chunks: kept %d, " + "dropped %d.", + (int)freelists[i].alloc_size, orig_n_to_skip, orig_n_to_free); } freelists[i].lowest_length = freelists[i].cur_length; assert_freelist_ok(&freelists[i]);