summaryrefslogtreecommitdiff
path: root/src/or
diff options
context:
space:
mode:
authorrl1987 <rl1987@sdf.lonestar.org>2014-08-19 22:12:19 +0300
committerNick Mathewson <nickm@torproject.org>2014-08-20 15:29:55 -0400
commit197d8550094d0509bed9e682b4a7b723dd948141 (patch)
treedbd1b94c8244a788013c87a404be085caa52f4fa /src/or
parent2937de21803174e14873f68b34ba8a6c62285c45 (diff)
downloadtor-197d8550094d0509bed9e682b4a7b723dd948141.tar.gz
tor-197d8550094d0509bed9e682b4a7b723dd948141.zip
Rewriting entry_is_time_to_retry() using table approach.
Diffstat (limited to 'src/or')
-rw-r--r--src/or/entrynodes.c37
1 files changed, 27 insertions, 10 deletions
diff --git a/src/or/entrynodes.c b/src/or/entrynodes.c
index 365b9274ec..b9a0bf4a99 100644
--- a/src/or/entrynodes.c
+++ b/src/or/entrynodes.c
@@ -159,18 +159,35 @@ entry_guard_set_status(entry_guard_t *e, const node_t *node,
static int
entry_is_time_to_retry(const entry_guard_t *e, time_t now)
{
- long diff;
+ struct guard_retry_period_s {
+ time_t period_duration;
+ time_t interval_during_period;
+ };
+
+ struct guard_retry_period_s periods[] = {
+ { 6*60*60, 60*60 },
+ { 3*24*60*60, 4*60*60 },
+ { 7*24*60*60, 18*60*60 },
+ { TIME_MAX, 36*60*60 }
+ };
+
+ time_t ith_deadline_for_retry;
+ time_t unreachable_for;
+ int i;
+
if (e->last_attempted < e->unreachable_since)
return 1;
- diff = now - e->unreachable_since;
- if (diff < 6*60*60)
- return now > (e->last_attempted + 60*60);
- else if (diff < 3*24*60*60)
- return now > (e->last_attempted + 4*60*60);
- else if (diff < 7*24*60*60)
- return now > (e->last_attempted + 18*60*60);
- else
- return now > (e->last_attempted + 36*60*60);
+
+ unreachable_for = now - e->unreachable_since;
+
+ for (i = 0; ; i++) {
+ if (unreachable_for <= periods[i].period_duration) {
+ ith_deadline_for_retry = e->last_attempted +
+ periods[i].interval_during_period;
+
+ return (now > ith_deadline_for_retry);
+ }
+ }
}
/** Return the node corresponding to <b>e</b>, if <b>e</b> is