From d256d4c0a6c6a258c4f6c6839dd53c7e304fa94f Mon Sep 17 00:00:00 2001 From: Nick Mathewson Date: Fri, 29 Sep 2017 09:26:16 -0400 Subject: Don't package cells onto marked circuits. This caused a BUG log when we noticed that the circuit had no channel. The likeliest culprit for exposing that behavior is d769cab3e5097980, where we made circuit_mark_for_close() NULL out the n_chan and p_chan fields of the circuit. Fixes bug 8185; bugfix on 0.2.5.4-alpha, I think. --- src/or/relay.c | 11 +++++++++++ 1 file changed, 11 insertions(+) (limited to 'src/or/relay.c') diff --git a/src/or/relay.c b/src/or/relay.c index daf354c34c..48c823423a 100644 --- a/src/or/relay.c +++ b/src/or/relay.c @@ -390,6 +390,11 @@ circuit_package_relay_cell(cell_t *cell, circuit_t *circ, { channel_t *chan; /* where to send the cell */ + if (circ->marked_for_close) { + /* Circuit is marked; send nothing. */ + return 0; + } + if (cell_direction == CELL_DIRECTION_OUT) { crypt_path_t *thishop; /* counter for repeated crypts */ chan = circ->n_chan; @@ -703,6 +708,12 @@ connection_edge_send_command(edge_connection_t *fromconn, return -1; } + if (circ->marked_for_close) { + /* The circuit has been marked, but not freed yet. When it's freed, it + * will mark this connection for close. */ + return -1; + } + return relay_send_command_from_edge(fromconn->stream_id, circ, relay_command, payload, payload_len, cpath_layer); -- cgit v1.2.3-54-g00ecf