summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorRoger Dingledine <arma@torproject.org>2002-12-23 06:48:14 +0000
committerRoger Dingledine <arma@torproject.org>2002-12-23 06:48:14 +0000
commitfbf4ca3ff810d148f7cc937ea7558666b5ede5a9 (patch)
tree5fb656f5965aebe6d7c20dba9f34fe5ae959c23f /src
parent7a18057357069a38918a65039b4a2ab63dbef4ec (diff)
downloadtor-fbf4ca3ff810d148f7cc937ea7558666b5ede5a9.tar.gz
tor-fbf4ca3ff810d148f7cc937ea7558666b5ede5a9.zip
bugfix: couldn't send two creates, two datas, and the destroy all at once
(amazing the odd behavior you get to test when you have a flaky modem connection) svn:r148
Diffstat (limited to 'src')
-rw-r--r--src/or/circuit.c1
-rw-r--r--src/or/command.c10
2 files changed, 8 insertions, 3 deletions
diff --git a/src/or/circuit.c b/src/or/circuit.c
index 49c09ba5d8..9b8f36784c 100644
--- a/src/or/circuit.c
+++ b/src/or/circuit.c
@@ -352,6 +352,7 @@ void circuit_about_to_close_connection(connection_t *conn) {
circuit_remove(circ);
if(circ->n_conn == conn) /* it's closing in front of us */
/* circ->p_conn should always be set */
+ assert(circ->p_conn);
connection_send_destroy(circ->p_aci, circ->p_conn);
if(circ->p_conn == conn) /* it's closing behind us */
if(circ->n_conn)
diff --git a/src/or/command.c b/src/or/command.c
index c725b22808..ab042c0609 100644
--- a/src/or/command.c
+++ b/src/or/command.c
@@ -300,10 +300,14 @@ void command_process_destroy_cell(cell_t *cell, connection_t *conn) {
onion_pending_remove(circ);
}
circuit_remove(circ);
- if(cell->aci == circ->p_aci) /* the destroy came from behind */
- connection_send_destroy(circ->n_aci, circ->n_conn);
- if(cell->aci == circ->n_aci) /* the destroy came from ahead */
+ if(cell->aci == circ->p_aci) { /* the destroy came from behind */
+ if(circ->n_conn) /* might not be defined, eg if it was just on the pending queue */
+ connection_send_destroy(circ->n_aci, circ->n_conn);
+ }
+ if(cell->aci == circ->n_aci) { /* the destroy came from ahead */
+ assert(circ->p_conn);
connection_send_destroy(circ->p_aci, circ->p_conn);
+ }
circuit_free(circ);
}