summaryrefslogtreecommitdiff
path: root/src/or
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2013-01-03 13:26:59 -0500
committerNick Mathewson <nickm@torproject.org>2013-01-03 13:26:59 -0500
commit677d18278e5b27a43f3f56906d97a9575d26c6f4 (patch)
treedb322a2f85308254d3e9e4411b7563e107b7f28a /src/or
parent30e139389bd8301f62ee24481d0f5484544fc5de (diff)
downloadtor-677d18278e5b27a43f3f56906d97a9575d26c6f4.tar.gz
tor-677d18278e5b27a43f3f56906d97a9575d26c6f4.zip
Better handling (I think) for onionskin timing w jumpy clocks
The fix: Instead of clipping huge/negative times, ignore them as probably invalid.
Diffstat (limited to 'src/or')
-rw-r--r--src/or/cpuworker.c25
1 files changed, 12 insertions, 13 deletions
diff --git a/src/or/cpuworker.c b/src/or/cpuworker.c
index 42f7b9572c..52a0117d39 100644
--- a/src/or/cpuworker.c
+++ b/src/or/cpuworker.c
@@ -320,19 +320,18 @@ connection_cpu_process_inbuf(connection_t *conn)
tor_gettimeofday(&tv_end);
timersub(&tv_end, &rpl.started_at, &tv_diff);
usec_roundtrip = ((int64_t)tv_diff.tv_sec)*1000000 + tv_diff.tv_usec;
- if (usec_roundtrip < 0 ||
- usec_roundtrip > MAX_BELIEVABLE_ONIONSKIN_DELAY) {
- usec_roundtrip = MAX_BELIEVABLE_ONIONSKIN_DELAY;
- }
- ++onionskins_n_processed[rpl.handshake_type];
- onionskins_usec_internal[rpl.handshake_type] += rpl.n_usec;
- onionskins_usec_roundtrip[rpl.handshake_type] += usec_roundtrip;
- if (onionskins_n_processed[rpl.handshake_type] >= 500000) {
- /* Scale down every 500000 handshakes. On a busy server, that's
- * less impressive than it sounds. */
- onionskins_n_processed[rpl.handshake_type] /= 2;
- onionskins_usec_internal[rpl.handshake_type] /= 2;
- onionskins_usec_roundtrip[rpl.handshake_type] /= 2;
+ if (usec_roundtrip >= 0 &&
+ usec_roundtrip < MAX_BELIEVABLE_ONIONSKIN_DELAY) {
+ ++onionskins_n_processed[rpl.handshake_type];
+ onionskins_usec_internal[rpl.handshake_type] += rpl.n_usec;
+ onionskins_usec_roundtrip[rpl.handshake_type] += usec_roundtrip;
+ if (onionskins_n_processed[rpl.handshake_type] >= 500000) {
+ /* Scale down every 500000 handshakes. On a busy server, that's
+ * less impressive than it sounds. */
+ onionskins_n_processed[rpl.handshake_type] /= 2;
+ onionskins_usec_internal[rpl.handshake_type] /= 2;
+ onionskins_usec_roundtrip[rpl.handshake_type] /= 2;
+ }
}
}
/* parse out the circ it was talking about */