summaryrefslogtreecommitdiff
path: root/src/or/circuitlist.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2005-12-05 19:45:54 +0000
committerNick Mathewson <nickm@torproject.org>2005-12-05 19:45:54 +0000
commitd2123388adc8af36a19446a8eee7ee64eeef90ec (patch)
tree04e61461392a05d4f56e38238c2a6e0986d1029c /src/or/circuitlist.c
parentfedc9c8a605b07d2c1e1c2e8b08f80c1051dbf47 (diff)
downloadtor-d2123388adc8af36a19446a8eee7ee64eeef90ec.tar.gz
tor-d2123388adc8af36a19446a8eee7ee64eeef90ec.zip
Better fix for last bug: avoids trying to double-mark circuits.
svn:r5511
Diffstat (limited to 'src/or/circuitlist.c')
-rw-r--r--src/or/circuitlist.c24
1 files changed, 14 insertions, 10 deletions
diff --git a/src/or/circuitlist.c b/src/or/circuitlist.c
index c9db1e9da2..6ab5a10a52 100644
--- a/src/or/circuitlist.c
+++ b/src/or/circuitlist.c
@@ -458,20 +458,24 @@ circuit_get_by_edge_conn(connection_t *conn)
return circ;
}
-/** Return a new list of all circuits that have <b>conn</b> as n_conn or
- * p_conn, including those marked for close.
+/** For each circuits that have <b>conn</b> as n_conn or p_conn, unlink the
+ * circuit from the orconn,circid map, and mark it for close if it hasn't
+ * been marked already.
*/
-smartlist_t *
-circuit_get_all_on_orconn(connection_t *conn)
+void
+circuit_unlink_all_from_or_conn(connection_t *conn)
{
- smartlist_t *res = smartlist_create();
circuit_t *circ;
-
- for (circ=global_circuitlist;circ;circ = circ->next) {
- if (circ->p_conn == conn || circ->n_conn == conn)
- smartlist_add(res, circ);
+ for (circ = global_circuitlist; circ; circ = circ->next) {
+ if (circ->n_conn == conn || circ->p_conn == conn) {
+ if (circ->n_conn == conn)
+ circuit_set_circid_orconn(circ, 0, NULL, N_CONN_CHANGED);
+ if (circ->p_conn == conn)
+ circuit_set_circid_orconn(circ, 0, NULL, P_CONN_CHANGED);
+ if (!circ->marked_for_close)
+ circuit_mark_for_close(circ);
+ }
}
- return res;
}
/** Return a circ such that: