[tor-commits] [tor/master] Don't cannibalize already cannibalized circuits

nickm at torproject.org nickm at torproject.org
Wed Feb 29 20:17:36 UTC 2012


commit 2755b09c52f78f233ed96aef41d283eb52cc89e8
Author: Sebastian Hahn <sebastian at torproject.org>
Date:   Sat Feb 25 17:58:09 2012 +0100

    Don't cannibalize already cannibalized circuits
    
    This ensures we don't build circuits that have 5 hops or more. Patch
    contributed by wanoskarnet, thanks!
---
 changes/bug5231      |    5 +++++
 src/or/circuitlist.c |    1 +
 2 files changed, 6 insertions(+), 0 deletions(-)

diff --git a/changes/bug5231 b/changes/bug5231
new file mode 100644
index 0000000..f64f7b6
--- /dev/null
+++ b/changes/bug5231
@@ -0,0 +1,5 @@
+  o Minor bugfixes:
+    - Ensure we don't cannibalize circuits that are longer than three hops
+      already, so we don't end up making circuits with 5 or more hops. Patch
+      contributed by wanoskarnet. Fixes bug 5231; bugfix on 0.1.0.1-rc which
+      introduced cannibalization.
diff --git a/src/or/circuitlist.c b/src/or/circuitlist.c
index 49a9b05..85f5291 100644
--- a/src/or/circuitlist.c
+++ b/src/or/circuitlist.c
@@ -1086,6 +1086,7 @@ circuit_find_to_cannibalize(uint8_t purpose, extend_info_t *info,
           (!need_capacity || circ->build_state->need_capacity) &&
           (internal == circ->build_state->is_internal) &&
           circ->remaining_relay_early_cells &&
+          circ->build_state->desired_path_len == DEFAULT_ROUTE_LEN &&
           !circ->build_state->onehop_tunnel &&
           !circ->isolation_values_set) {
         if (info) {





More information about the tor-commits mailing list