aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2009-05-12 13:54:21 -0400
committerNick Mathewson <nickm@torproject.org>2009-05-12 13:54:21 -0400
commit88d81ead83ded22db7eaf8090edd9ee0937b2dd5 (patch)
tree478a47e7a8719b64c86862ab598437381c6e7b68
parent9b32e8c141978c67ef70cc5eb0c68b459c131d41 (diff)
downloadtor-88d81ead83ded22db7eaf8090edd9ee0937b2dd5.tar.gz
tor-88d81ead83ded22db7eaf8090edd9ee0937b2dd5.zip
Better debugging output for bug 977 case.
(Don't crash immediately if we have leftover chunks to free after freeing chunks in a buffer freelist; instead log a debugging message that might help.)
-rw-r--r--ChangeLog3
-rw-r--r--src/or/buffers.c13
2 files changed, 15 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 3ca41e13b5..9359915c1e 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -3,6 +3,9 @@ Changes in version 0.2.1.15??? - ????-??-??
- Actually return -1 in the error case for read_bandwidth_usage. Bug
was harmless, we currently don't care for the return value anywhere.
Bugfix on 0.2.0.9-alpha.
+ - Provide a more useful log message if bug 977 (related to buffer
+ freelists) ever reappears, and do not crash right away.
+
Changes in version 0.2.1.14-rc - 2009-04-12
o Major features:
diff --git a/src/or/buffers.c b/src/or/buffers.c
index 00db5d0916..cdab5490d0 100644
--- a/src/or/buffers.c
+++ b/src/or/buffers.c
@@ -258,6 +258,7 @@ buf_shrink_freelists(int free_all)
int n_to_free = free_all ? freelists[i].cur_length :
(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 new_length = n_to_skip;
chunk_t **chp = &freelists[i].head;
chunk_t *chunk;
@@ -276,9 +277,19 @@ buf_shrink_freelists(int free_all)
tor_free(chunk);
chunk = next;
--n_to_free;
+ ++n_freed;
++freelists[i].n_free;
}
- tor_assert(!n_to_free);
+ if (n_to_free) {
+ log_warn(LD_BUG, "Freelist length for %d-byte chunks may have been "
+ "messed up somehow.", (int)freelists[i].alloc_size);
+ log_warn(LD_BUG, "There were %d chunks at the start. I decided to "
+ "keep %d. I wanted to free %d. I freed %d. I somehow think "
+ "I have %d left to free.",
+ freelists[i].cur_length, n_to_skip, orig_n_to_free,
+ n_freed, n_to_free);
+ }
+ // tor_assert(!n_to_free);
freelists[i].cur_length = new_length;
}
freelists[i].lowest_length = freelists[i].cur_length;