summaryrefslogtreecommitdiff
path: root/src/or/channel.h
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2014-04-18 12:50:04 -0400
committerNick Mathewson <nickm@torproject.org>2014-04-18 12:58:58 -0400
commit0d75344b0e0eafc89db89a974e87b16564cd8f0a (patch)
treec5dbe44f5b4ddbfa0855ce8cb3066c1095384d3a /src/or/channel.h
parentbb9b4c37f8e7f5cf78918f382e90d8b11ff42551 (diff)
downloadtor-0d75344b0e0eafc89db89a974e87b16564cd8f0a.tar.gz
tor-0d75344b0e0eafc89db89a974e87b16564cd8f0a.zip
Switch to random allocation on circuitIDs.
Fixes a possible root cause of 11553 by only making 64 attempts at most to pick a circuitID. Previously, we would test every possible circuit ID until we found one or ran out. This algorithm succeeds probabilistically. As the comment says: This potentially causes us to give up early if our circuit ID space is nearly full. If we have N circuit IDs in use, then we will reject a new circuit with probability (N / max_range) ^ MAX_CIRCID_ATTEMPTS. This means that in practice, a few percent of our circuit ID capacity will go unused. The alternative here, though, is to do a linear search over the whole circuit ID space every time we extend a circuit, which is not so great either. This makes new vs old clients distinguishable, so we should try to batch it with other patches that do that, like 11438.
Diffstat (limited to 'src/or/channel.h')
-rw-r--r--src/or/channel.h5
1 files changed, 0 insertions, 5 deletions
diff --git a/src/or/channel.h b/src/or/channel.h
index 29ba40e326..e63c94961f 100644
--- a/src/or/channel.h
+++ b/src/or/channel.h
@@ -150,11 +150,6 @@ struct channel_s {
unsigned wide_circ_ids:1;
/** Have we logged a warning about circID exhaustion on this channel? */
unsigned warned_circ_ids_exhausted:1;
- /*
- * Which circ_id do we try to use next on this connection? This is
- * always in the range 0..1<<15-1.
- */
- circid_t next_circ_id;
/* For how many circuits are we n_chan? What about p_chan? */
unsigned int num_n_circuits, num_p_circuits;