aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2017-05-18 10:06:06 -0400
committerNick Mathewson <nickm@torproject.org>2017-05-18 10:06:06 -0400
commit935cd77f62f036e615923742de278398aa85f2bf (patch)
tree03ff72fd113b67752b3920c88bc7b6cc2bb00b8a
parent492f8a7c448dbdbea1966bdb9fd1775d3cda16fb (diff)
parent2ba58f275cef6ae70c0d6f5a94f8bd3ff99f1e5e (diff)
downloadtor-935cd77f62f036e615923742de278398aa85f2bf.tar.gz
tor-935cd77f62f036e615923742de278398aa85f2bf.zip
Merge branch 'bug22252_029' into maint-0.3.0
-rw-r--r--changes/bug222523
-rw-r--r--src/or/circuitstats.c11
-rw-r--r--src/or/circuitstats.h3
-rw-r--r--src/or/config.c2
4 files changed, 17 insertions, 2 deletions
diff --git a/changes/bug22252 b/changes/bug22252
new file mode 100644
index 0000000000..42b9d8e095
--- /dev/null
+++ b/changes/bug22252
@@ -0,0 +1,3 @@
+ o Minor bugfixes (configuration):
+ - Do not crash when starting with LearnCircuitBuildTimeout 0.
+ Fixes bug 22252; bugfix on 0.2.9.3-alpha.
diff --git a/src/or/circuitstats.c b/src/or/circuitstats.c
index 48cb89dc37..6e73372550 100644
--- a/src/or/circuitstats.c
+++ b/src/or/circuitstats.c
@@ -107,10 +107,19 @@ get_circuit_build_timeout_ms(void)
int
circuit_build_times_disabled(const or_options_t *options)
{
+ return circuit_build_times_disabled_(options, 0);
+}
+
+/** As circuit_build_times_disabled, but take options as an argument. */
+int
+circuit_build_times_disabled_(const or_options_t *options,
+ int ignore_consensus)
+{
if (unit_tests) {
return 0;
} else {
- int consensus_disabled = networkstatus_get_param(NULL, "cbtdisabled",
+ int consensus_disabled =
+ ignore_consensus ? 0 : networkstatus_get_param(NULL, "cbtdisabled",
0, 0, 1);
int config_disabled = !options->LearnCircuitBuildTimeout;
int dirauth_disabled = options->AuthoritativeDir;
diff --git a/src/or/circuitstats.h b/src/or/circuitstats.h
index 23910276ae..c748f82d5e 100644
--- a/src/or/circuitstats.h
+++ b/src/or/circuitstats.h
@@ -18,6 +18,9 @@ double get_circuit_build_close_time_ms(void);
double get_circuit_build_timeout_ms(void);
int circuit_build_times_disabled(const or_options_t *options);
+int circuit_build_times_disabled_(const or_options_t *options,
+ int ignore_consensus);
+
int circuit_build_times_enough_to_compute(const circuit_build_times_t *cbt);
void circuit_build_times_update_state(const circuit_build_times_t *cbt,
or_state_t *state);
diff --git a/src/or/config.c b/src/or/config.c
index a527571cb0..9edc6b799b 100644
--- a/src/or/config.c
+++ b/src/or/config.c
@@ -3535,7 +3535,7 @@ options_validate(or_options_t *old_options, or_options_t *options,
int severity = LOG_NOTICE;
/* Be a little quieter if we've deliberately disabled
* LearnCircuitBuildTimeout. */
- if (circuit_build_times_disabled(options)) {
+ if (circuit_build_times_disabled_(options, 1)) {
severity = LOG_INFO;
}
log_fn(severity, LD_CONFIG, "You disabled LearnCircuitBuildTimeout, but "