mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2024-11-24 12:23:32 +01:00
Fix detach when setting circuit ID to 0 bug in circuit_set_circid_chan_helper() and add circuit_get_by_circid_channel_even_if_marked()
This commit is contained in:
parent
c097fb33fc
commit
b28119e6a8
@ -135,7 +135,7 @@ circuit_set_circid_chan_helper(circuit_t *circ, int direction,
|
||||
* attached), detach the circuit. ID changes require this because
|
||||
* circuitmux hashes on (channel_id, circuit_id).
|
||||
*/
|
||||
if (id != 0 && (old_chan != chan || old_id != id) &&
|
||||
if (old_id != 0 && (old_chan != chan || old_id != id) &&
|
||||
!(circ->marked_for_close)) {
|
||||
tor_assert(old_chan->cmux);
|
||||
circuitmux_detach_circuit(old_chan->cmux, circ);
|
||||
@ -986,6 +986,18 @@ circuit_get_by_circid_channel(circid_t circ_id, channel_t *chan)
|
||||
return circ;
|
||||
}
|
||||
|
||||
/** Return a circ such that:
|
||||
* - circ-\>n_circ_id or circ-\>p_circ_id is equal to <b>circ_id</b>, and
|
||||
* - circ is attached to <b>chan</b>, either as p_chan or n_chan.
|
||||
* Return NULL if no such circuit exists.
|
||||
*/
|
||||
circuit_t *
|
||||
circuit_get_by_circid_channel_even_if_marked(circid_t circ_id,
|
||||
channel_t *chan)
|
||||
{
|
||||
return circuit_get_by_circid_channel_impl(circ_id, chan);
|
||||
}
|
||||
|
||||
/** Return true iff the circuit ID <b>circ_id</b> is currently used by a
|
||||
* circuit, marked or not, on <b>chan</b>. */
|
||||
int
|
||||
|
@ -30,6 +30,9 @@ origin_circuit_t *origin_circuit_new(void);
|
||||
or_circuit_t *or_circuit_new(circid_t p_circ_id, channel_t *p_chan);
|
||||
circuit_t *circuit_get_by_circid_channel(circid_t circ_id,
|
||||
channel_t *chan);
|
||||
circuit_t *
|
||||
circuit_get_by_circid_channel_even_if_marked(circid_t circ_id,
|
||||
channel_t *chan);
|
||||
int circuit_id_in_use_on_channel(circid_t circ_id, channel_t *chan);
|
||||
circuit_t *circuit_get_by_edge_conn(edge_connection_t *conn);
|
||||
void circuit_unlink_all_from_channel(channel_t *chan, int reason);
|
||||
|
Loading…
Reference in New Issue
Block a user