summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2017-02-28 08:28:46 -0500
committerNick Mathewson <nickm@torproject.org>2017-02-28 08:28:46 -0500
commit3a60214f32bc6e1ba6d8c6dd6c6abda0c5be1f1e (patch)
treeb574103acf29ca6e0e9023dbf6a5f80b755271e6
parent16f337e7639c42b5c6106d6bc9828cb9e6614054 (diff)
parent5e08fc85570173200935b62de2bffee81fed2fc1 (diff)
downloadtor-3a60214f32bc6e1ba6d8c6dd6c6abda0c5be1f1e.tar.gz
tor-3a60214f32bc6e1ba6d8c6dd6c6abda0c5be1f1e.zip
Merge remote-tracking branch 'public/bug21007_case2_030' into maint-0.3.0
-rw-r--r--changes/bug21007_case24
-rw-r--r--src/or/circuitbuild.c23
2 files changed, 26 insertions, 1 deletions
diff --git a/changes/bug21007_case2 b/changes/bug21007_case2
new file mode 100644
index 0000000000..43344449ec
--- /dev/null
+++ b/changes/bug21007_case2
@@ -0,0 +1,4 @@
+ o Minor bugfixes (guards):
+ - Don't warn about a missing guard state on timeout-measurement
+ circuits: they aren't supposed to be using guards. Fixes an
+ instance of bug 21007; bugfix on 0.3.0.1-alpha.
diff --git a/src/or/circuitbuild.c b/src/or/circuitbuild.c
index cd00034395..79962e8dbb 100644
--- a/src/or/circuitbuild.c
+++ b/src/or/circuitbuild.c
@@ -892,6 +892,27 @@ circuit_pick_extend_handshake(uint8_t *cell_type_out,
}
}
+/**
+ * Return true iff <b>purpose</b> is a purpose for a circuit which is
+ * allowed to have no guard configured, even if the circuit is multihop
+ * and guards are enabled.
+ */
+static int
+circuit_purpose_may_omit_guard(int purpose)
+{
+ switch (purpose) {
+ case CIRCUIT_PURPOSE_TESTING:
+ case CIRCUIT_PURPOSE_C_MEASURE_TIMEOUT:
+ /* Testing circuits may omit guards because they're measuring
+ * liveness or performance, and don't want guards to interfere. */
+ return 1;
+ default:
+ /* All other multihop circuits should use guards if guards are
+ * enabled. */
+ return 0;
+ }
+}
+
/** This is the backbone function for building circuits.
*
* If circ's first hop is closed, then we need to build a create
@@ -969,7 +990,7 @@ circuit_send_next_onion_skin(origin_circuit_t *circ)
guard_usable_t r;
if (! circ->guard_state) {
if (circuit_get_cpath_len(circ) != 1 &&
- circ->base_.purpose != CIRCUIT_PURPOSE_TESTING &&
+ ! circuit_purpose_may_omit_guard(circ->base_.purpose) &&
get_options()->UseEntryGuards) {
log_warn(LD_BUG, "%d-hop circuit %p with purpose %d has no "
"guard state",