summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2012-09-18 16:20:01 -0400
committerNick Mathewson <nickm@torproject.org>2012-09-18 16:20:01 -0400
commit920c76a2fcc843bc58b79195414d3ed4b693e76e (patch)
tree95392e59c5ea244615d1643dd77e57aaaed453e7
parentf675e0a33efa5f32377e784b2612c2b6a5c9180b (diff)
parentaca325eb0c6b34ba0e1ef8df16c1cf44a98f9b6f (diff)
downloadtor-920c76a2fcc843bc58b79195414d3ed4b693e76e.tar.gz
tor-920c76a2fcc843bc58b79195414d3ed4b693e76e.zip
Merge remote-tracking branch 'origin/maint-0.2.3'
-rw-r--r--changes/bug68664
-rw-r--r--src/or/circuitbuild.c40
2 files changed, 40 insertions, 4 deletions
diff --git a/changes/bug6866 b/changes/bug6866
new file mode 100644
index 0000000000..561676b765
--- /dev/null
+++ b/changes/bug6866
@@ -0,0 +1,4 @@
+ o Minor bugfixes:
+ - Convert an assert in the pathbias code to a log message. Assert
+ appears to only be triggerable by Tor2Web mode. Fixes bug 6866;
+ bugfix on 0.2.3.17-beta.
diff --git a/src/or/circuitbuild.c b/src/or/circuitbuild.c
index 515312f0ea..840031da57 100644
--- a/src/or/circuitbuild.c
+++ b/src/or/circuitbuild.c
@@ -2657,8 +2657,24 @@ pathbias_count_first_hop(origin_circuit_t *circ)
}
/* Completely ignore one hop circuits */
- if (circ->build_state->onehop_tunnel) {
- tor_assert(circ->build_state->desired_path_len == 1);
+ if (circ->build_state->onehop_tunnel ||
+ circ->build_state->desired_path_len == 1) {
+ /* Check for inconsistency */
+ if (circ->build_state->desired_path_len != 1 ||
+ !circ->build_state->onehop_tunnel) {
+ if ((rate_msg = rate_limit_log(&first_hop_notice_limit,
+ approx_time()))) {
+ log_info(LD_BUG,
+ "One-hop circuit has length %d. Path state is %s. "
+ "Circuit is a %s currently %s. %s",
+ circ->build_state->desired_path_len,
+ pathbias_state_to_string(circ->path_state),
+ circuit_purpose_to_string(circ->_base.purpose),
+ circuit_state_to_string(circ->_base.state),
+ rate_msg);
+ }
+ tor_fragile_assert();
+ }
return 0;
}
@@ -2759,8 +2775,24 @@ pathbias_count_success(origin_circuit_t *circ)
}
/* Ignore one hop circuits */
- if (circ->build_state->onehop_tunnel) {
- tor_assert(circ->build_state->desired_path_len == 1);
+ if (circ->build_state->onehop_tunnel ||
+ circ->build_state->desired_path_len == 1) {
+ /* Check for consistency */
+ if (circ->build_state->desired_path_len != 1 ||
+ !circ->build_state->onehop_tunnel) {
+ if ((rate_msg = rate_limit_log(&success_notice_limit,
+ approx_time()))) {
+ log_info(LD_BUG,
+ "One-hop circuit has length %d. Path state is %s. "
+ "Circuit is a %s currently %s. %s",
+ circ->build_state->desired_path_len,
+ pathbias_state_to_string(circ->path_state),
+ circuit_purpose_to_string(circ->_base.purpose),
+ circuit_state_to_string(circ->_base.state),
+ rate_msg);
+ }
+ tor_fragile_assert();
+ }
return;
}