commit 1c017edac369a40c9a1633b0560e5f0d85b4e39e
parent ac8e26a41592e5a87a5613cfbeb4c5d975835e4d
Author: Taylor Yu <catalyst@torproject.org>
Date: Wed, 20 Sep 2017 16:54:56 -0500
Use correct sign for state file clock skew
or_state_load() was using an incorrect sign convention when calling
clock_skew_warning() to warn about state file clock skew. This caused
the wording of the warning to be incorrect about the direction of the
skew.
Diffstat:
2 files changed, 6 insertions(+), 2 deletions(-)
diff --git a/changes/bug23606 b/changes/bug23606
@@ -0,0 +1,4 @@
+ o Minor bugfixes (bootstrapping):
+ - When warning about state file clock skew, report the correct
+ direction for the detected skew. Fixes bug 23606; bugfix on
+ 0.2.8.1-alpha.
diff --git a/src/or/statefile.c b/src/or/statefile.c
@@ -404,8 +404,8 @@ or_state_load(void)
log_info(LD_GENERAL, "Loaded state from \"%s\"", fname);
/* Warn the user if their clock has been set backwards,
* they could be tricked into using old consensuses */
- time_t apparent_skew = new_state->LastWritten - time(NULL);
- if (apparent_skew > 0)
+ time_t apparent_skew = time(NULL) - new_state->LastWritten;
+ if (apparent_skew < 0)
clock_skew_warning(NULL, (long)apparent_skew, 1, LD_GENERAL,
"local state file", fname);
} else {