summaryrefslogtreecommitdiff
path: root/src/or/relay.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2012-11-11 22:20:59 -0500
committerNick Mathewson <nickm@torproject.org>2012-11-12 08:28:09 -0500
commitf473d83deaf893c6efe49094cfc5d9b435e7fcb9 (patch)
tree4732843f92e299cd46cb4ff6c13ab8d2b91f075f /src/or/relay.c
parent0523c8de7d7f775e9a89134340f88ae00bde158b (diff)
downloadtor-f473d83deaf893c6efe49094cfc5d9b435e7fcb9.tar.gz
tor-f473d83deaf893c6efe49094cfc5d9b435e7fcb9.zip
Possible fix for bug 7212
This is the simplest possible workaround: make it safe to call circuit_cell_queue_clear() on a non-attached circuit, and make it safe-but-a-LD_BUG-warning to call update_circuit_on_cmux() on a non-attached circuit. LocalWords: unstage src Untracked
Diffstat (limited to 'src/or/relay.c')
-rw-r--r--src/or/relay.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/src/or/relay.c b/src/or/relay.c
index bd99d91dca..0f0d1df414 100644
--- a/src/or/relay.c
+++ b/src/or/relay.c
@@ -1976,7 +1976,8 @@ cell_queue_pop(cell_queue_t *queue)
* circuit mux.
*/
void
-update_circuit_on_cmux(circuit_t *circ, cell_direction_t direction)
+update_circuit_on_cmux_(circuit_t *circ, cell_direction_t direction,
+ const char *file, int lineno)
{
channel_t *chan = NULL;
or_circuit_t *or_circ = NULL;
@@ -1999,7 +2000,11 @@ update_circuit_on_cmux(circuit_t *circ, cell_direction_t direction)
cmux = chan->cmux;
/* Cmux sanity check */
- tor_assert(circuitmux_is_circuit_attached(cmux, circ));
+ if (! circuitmux_is_circuit_attached(cmux, circ)) {
+ log_warn(LD_BUG, "called on non-attachd circuit from %s:%d",
+ file, lineno);
+ return;
+ }
tor_assert(circuitmux_attached_circuit_direction(cmux, circ) == direction);
assert_cmux_ok_paranoid(chan);
@@ -2334,7 +2339,8 @@ circuit_clear_cell_queue(circuit_t *circ, channel_t *chan)
cell_queue_clear(queue);
/* Update the cell counter in the cmux */
- update_circuit_on_cmux(circ, direction);
+ if (chan->cmux && circuitmux_is_circuit_attached(chan->cmux, circ))
+ update_circuit_on_cmux(circ, direction);
}
/** Fail with an assert if the circuit mux on chan is corrupt