aboutsummaryrefslogtreecommitdiff
path: root/src/or/routerlist.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/or/routerlist.c')
-rw-r--r--src/or/routerlist.c23
1 files changed, 13 insertions, 10 deletions
diff --git a/src/or/routerlist.c b/src/or/routerlist.c
index c7ecd6a6b..c93177821 100644
--- a/src/or/routerlist.c
+++ b/src/or/routerlist.c
@@ -3159,16 +3159,7 @@ router_get_combined_status_by_descriptor_digest(const char *digest)
{
if (!routerstatus_by_desc_digest_map)
return NULL;
-#if 0
- /* XXXX020 this could conceivably be critical path when a whole lot
- * of descriptors fail. Maybe we should use a digest map instead.*/
- SMARTLIST_FOREACH(routerstatus_list, local_routerstatus_t *, lrs,
- if (!memcmp(lrs->status.descriptor_digest, digest))
- return lrs);
- return NULL;
-#else
return digestmap_get(routerstatus_by_desc_digest_map, digest);
-#endif
}
/** Given a nickname (possibly verbose, possibly a hexadecimal digest), return
@@ -4875,7 +4866,6 @@ router_reset_descriptor_download_failures(void)
rs->dl_status.n_download_failures = 0;
rs->dl_status.next_attempt_at = 0;
});
- /* XXXX020 reset extrainfo dl status too. */
tor_assert(networkstatus_list);
SMARTLIST_FOREACH(networkstatus_list, networkstatus_t *, ns,
SMARTLIST_FOREACH(ns->entries, routerstatus_t *, rs,
@@ -4884,6 +4874,19 @@ router_reset_descriptor_download_failures(void)
rs->need_to_mirror = 1;
}));
last_routerdesc_download_attempted = 0;
+ if (!routerlist)
+ return;
+ SMARTLIST_FOREACH(routerlist->routers, routerinfo_t *, ri,
+ {
+ ri->cache_info.ei_dl_status.n_download_failures = 0;
+ ri->cache_info.ei_dl_status.next_attempt_at = 0;
+ });
+ SMARTLIST_FOREACH(routerlist->old_routers, signed_descriptor_t *, sd,
+ {
+ sd->ei_dl_status.n_download_failures = 0;
+ sd->ei_dl_status.next_attempt_at = 0;
+ });
+
}
/** Any changes in a router descriptor's publication time larger than this are