diff options
author | rl1987 <rl1987@sdf.lonestar.org> | 2014-08-19 22:12:19 +0300 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2014-08-20 15:29:55 -0400 |
commit | 197d8550094d0509bed9e682b4a7b723dd948141 (patch) | |
tree | dbd1b94c8244a788013c87a404be085caa52f4fa /src | |
parent | 2937de21803174e14873f68b34ba8a6c62285c45 (diff) | |
download | tor-197d8550094d0509bed9e682b4a7b723dd948141.tar.gz tor-197d8550094d0509bed9e682b4a7b723dd948141.zip |
Rewriting entry_is_time_to_retry() using table approach.
Diffstat (limited to 'src')
-rw-r--r-- | src/or/entrynodes.c | 37 |
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 |