summaryrefslogtreecommitdiff
path: root/src/or/circuitbuild.c
diff options
context:
space:
mode:
authorRoger Dingledine <arma@torproject.org>2007-07-29 04:38:21 +0000
committerRoger Dingledine <arma@torproject.org>2007-07-29 04:38:21 +0000
commiteca2a300609437ab390eac6fb5a81be006fa1af7 (patch)
tree8905dff055827bae24a4ff1363f83ae336f5b999 /src/or/circuitbuild.c
parentafcc3a4785c7171311734d8391f384eee558ec79 (diff)
downloadtor-eca2a300609437ab390eac6fb5a81be006fa1af7.tar.gz
tor-eca2a300609437ab390eac6fb5a81be006fa1af7.zip
make progress towards retrying our bridges when they're all
down and we get a new socks request svn:r10967
Diffstat (limited to 'src/or/circuitbuild.c')
-rw-r--r--src/or/circuitbuild.c37
1 files changed, 29 insertions, 8 deletions
diff --git a/src/or/circuitbuild.c b/src/or/circuitbuild.c
index 83f4a50a1a..58879674c4 100644
--- a/src/or/circuitbuild.c
+++ b/src/or/circuitbuild.c
@@ -294,7 +294,7 @@ origin_circuit_init(uint8_t purpose, int onehop_tunnel,
return circ;
}
-/** Build a new circuit for <b>purpose</b>. If <b>info</b>
+/** Build a new circuit for <b>purpose</b>. If <b>exit</b>
* is defined, then use that as your exit router, else choose a suitable
* exit node.
*
@@ -2860,17 +2860,19 @@ learned_bridge_descriptor(routerinfo_t *ri)
int
any_bridge_descriptors_known(void)
{
+ tor_assert(get_options()->UseBridges);
return choose_random_entry(NULL)!=NULL ? 1 : 0;
}
-#if 0
/** Return 1 if we have at least one descriptor for a bridge and
- * all descriptors we know are down. Else return 0. */
-int
-all_bridges_down(void)
+ * all descriptors we know are down. Else return 0. If <b>act</b> is
+ * 1, then mark the down bridges up; else just observe and report. */
+static int
+bridges_retry_helper(int act)
{
routerinfo_t *ri;
int any_known = 0;
+ int any_running = 0;
if (!entry_guards)
entry_guards = smartlist_create();
SMARTLIST_FOREACH(entry_guards, entry_guard_t *, e,
@@ -2879,12 +2881,31 @@ all_bridges_down(void)
if (ri && ri->purpose == ROUTER_PURPOSE_BRIDGE) {
any_known = 1;
if (ri->is_running)
- return 0; /* some bridge is both known and running */
+ any_running = 1; /* some bridge is both known and running */
+ else if (act) { /* mark it for retry */
+ ri->is_running = 1;
+ e->can_retry = 1;
+ e->bad_since = 0;
+ }
}
});
- return any_known;
+ return any_known && !any_running;
+}
+
+/** Do we know any descriptors for our bridges, and are they all
+ * down? */
+int
+bridges_should_be_retried(void)
+{
+ return bridges_retry_helper(0);
+}
+
+/** Mark all down known bridges up. */
+void
+bridges_retry_all(void)
+{
+ bridges_retry_helper(1);
}
-#endif
/** Release all storage held by the list of entry guards and related
* memory structs. */