mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2024-11-27 22:03:31 +01:00
Merge remote-tracking branch 'tor-gitlab/mr/333' into maint-0.4.5
This commit is contained in:
commit
59bbf8cde9
4
changes/bug40285_045
Normal file
4
changes/bug40285_045
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
o Minor bugfixes (controller):
|
||||||
|
- Fix a "BUG" warning that would appear when a controller chooses the
|
||||||
|
first hop for a circuit, and that circuit completes. Fixes
|
||||||
|
bug 40285; bugfix on 0.3.2.1-alpha.
|
@ -881,14 +881,22 @@ circuit_pick_extend_handshake(uint8_t *cell_type_out,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return true iff <b>purpose</b> is a purpose for a circuit which is
|
* Return true iff <b>circ</b> is allowed
|
||||||
* allowed to have no guard configured, even if the circuit is multihop
|
* to have no guard configured, even if the circuit is multihop
|
||||||
* and guards are enabled.
|
* and guards are enabled.
|
||||||
*/
|
*/
|
||||||
static int
|
static int
|
||||||
circuit_purpose_may_omit_guard(int purpose)
|
circuit_may_omit_guard(const origin_circuit_t *circ)
|
||||||
{
|
{
|
||||||
switch (purpose) {
|
if (BUG(!circ))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
if (circ->first_hop_from_controller) {
|
||||||
|
/* The controller picked the first hop: that bypasses the guard system. */
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (circ->base_.purpose) {
|
||||||
case CIRCUIT_PURPOSE_TESTING:
|
case CIRCUIT_PURPOSE_TESTING:
|
||||||
case CIRCUIT_PURPOSE_C_MEASURE_TIMEOUT:
|
case CIRCUIT_PURPOSE_C_MEASURE_TIMEOUT:
|
||||||
/* Testing circuits may omit guards because they're measuring
|
/* Testing circuits may omit guards because they're measuring
|
||||||
@ -1019,7 +1027,7 @@ circuit_build_no_more_hops(origin_circuit_t *circ)
|
|||||||
guard_usable_t r;
|
guard_usable_t r;
|
||||||
if (! circ->guard_state) {
|
if (! circ->guard_state) {
|
||||||
if (circuit_get_cpath_len(circ) != 1 &&
|
if (circuit_get_cpath_len(circ) != 1 &&
|
||||||
! circuit_purpose_may_omit_guard(circ->base_.purpose) &&
|
! circuit_may_omit_guard(circ) &&
|
||||||
get_options()->UseEntryGuards) {
|
get_options()->UseEntryGuards) {
|
||||||
log_warn(LD_BUG, "%d-hop circuit %p with purpose %d has no "
|
log_warn(LD_BUG, "%d-hop circuit %p with purpose %d has no "
|
||||||
"guard state",
|
"guard state",
|
||||||
|
@ -118,7 +118,8 @@
|
|||||||
* bandwidth measurement, reachability test and address discovery from an
|
* bandwidth measurement, reachability test and address discovery from an
|
||||||
* authority using the NETINFO cell. */
|
* authority using the NETINFO cell. */
|
||||||
#define CIRCUIT_PURPOSE_TESTING 21
|
#define CIRCUIT_PURPOSE_TESTING 21
|
||||||
/** A controller made this circuit and Tor should not use it. */
|
/** A controller made this circuit and Tor should not cannibalize it or attach
|
||||||
|
* streams to it without explicitly being told. */
|
||||||
#define CIRCUIT_PURPOSE_CONTROLLER 22
|
#define CIRCUIT_PURPOSE_CONTROLLER 22
|
||||||
/** This circuit is used for path bias probing only */
|
/** This circuit is used for path bias probing only */
|
||||||
#define CIRCUIT_PURPOSE_PATH_BIAS_TESTING 23
|
#define CIRCUIT_PURPOSE_PATH_BIAS_TESTING 23
|
||||||
|
@ -170,6 +170,18 @@ struct origin_circuit_t {
|
|||||||
* not try to negotiate further circuit padding. */
|
* not try to negotiate further circuit padding. */
|
||||||
unsigned padding_negotiation_failed : 1;
|
unsigned padding_negotiation_failed : 1;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* If this flag is set, then a controller chose the first hop of this
|
||||||
|
* circuit's path, and it's okay to ignore checks that we'd usually do
|
||||||
|
* on this circuit's first hop.
|
||||||
|
*
|
||||||
|
* This flag is distinct from the CIRCUIT_PURPOSE_CONTROLLER purpose: the
|
||||||
|
* purpose indicates _what tor can use the circuit for_. Controller-created
|
||||||
|
* circuits can still have the CIRCUIT_PURPOSE_GENERAL purpose if Tor is
|
||||||
|
* allowed to attach streams to them.
|
||||||
|
*/
|
||||||
|
unsigned first_hop_from_controller : 1;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tristate variable to guard against pathbias miscounting
|
* Tristate variable to guard against pathbias miscounting
|
||||||
* due to circuit purpose transitions changing the decision
|
* due to circuit purpose transitions changing the decision
|
||||||
|
@ -819,6 +819,7 @@ handle_control_extendcircuit(control_connection_t *conn,
|
|||||||
if (zero_circ) {
|
if (zero_circ) {
|
||||||
/* start a new circuit */
|
/* start a new circuit */
|
||||||
circ = origin_circuit_init(intended_purpose, 0);
|
circ = origin_circuit_init(intended_purpose, 0);
|
||||||
|
circ->first_hop_from_controller = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* now circ refers to something that is ready to be extended */
|
/* now circ refers to something that is ready to be extended */
|
||||||
|
Loading…
Reference in New Issue
Block a user