aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2018-05-09 12:11:14 -0400
committerNick Mathewson <nickm@torproject.org>2018-05-09 12:11:14 -0400
commit50328533e3595b9cc2d3fc72f81f56572c9e732d (patch)
treee7b19bf63087103c82d79bca1a4e9d371feec8ce
parent0c19ce7bdece5906e035e71d3fb682632c8bb9cb (diff)
downloadtor-50328533e3595b9cc2d3fc72f81f56572c9e732d.tar.gz
tor-50328533e3595b9cc2d3fc72f81f56572c9e732d.zip
Add we_are_fully_hibernating() to distinguish hibernation states
We want to tell "shut down" from "shutting down".
-rw-r--r--src/or/hibernate.c15
-rw-r--r--src/or/hibernate.h1
2 files changed, 15 insertions, 1 deletions
diff --git a/src/or/hibernate.c b/src/or/hibernate.c
index 98f32adb1c..f73b0420d3 100644
--- a/src/or/hibernate.c
+++ b/src/or/hibernate.c
@@ -877,13 +877,26 @@ hibernate_begin_shutdown(void)
hibernate_begin(HIBERNATE_STATE_EXITING, time(NULL));
}
-/** Return true iff we are currently hibernating. */
+/**
+ * Return true iff we are currently hibernating -- that is, if we are in
+ * any non-live state.
+ */
MOCK_IMPL(int,
we_are_hibernating,(void))
{
return hibernate_state != HIBERNATE_STATE_LIVE;
}
+/**
+ * Return true iff we are currently _fully_ hibernating -- that is, if we are
+ * in a state where we expect to handle no network activity at all.
+ */
+MOCK_IMPL(int,
+we_are_fully_hibernating,(void))
+{
+ return hibernate_state == HIBERNATE_STATE_DORMANT;
+}
+
/** If we aren't currently dormant, close all connections and become
* dormant. */
static void
diff --git a/src/or/hibernate.h b/src/or/hibernate.h
index 85fb42864b..84558bb2f1 100644
--- a/src/or/hibernate.h
+++ b/src/or/hibernate.h
@@ -25,6 +25,7 @@ void accounting_add_bytes(size_t n_read, size_t n_written, int seconds);
int accounting_record_bandwidth_usage(time_t now, or_state_t *state);
void hibernate_begin_shutdown(void);
MOCK_DECL(int, we_are_hibernating, (void));
+MOCK_DECL(int, we_are_fully_hibernating,(void));
void consider_hibernation(time_t now);
int getinfo_helper_accounting(control_connection_t *conn,
const char *question, char **answer,