summaryrefslogtreecommitdiff
path: root/src/common/timers.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2017-09-11 13:48:39 -0400
committerNick Mathewson <nickm@torproject.org>2017-09-11 13:48:39 -0400
commit72ea4a8f081318c60c460cef5d9daf55e399c434 (patch)
treed5b98ca36b4fdeb4eef0d949764cfc11d4f7c2da /src/common/timers.c
parent7a83cf75dc55dbac91ff5c0daf7c7418493cbea7 (diff)
downloadtor-72ea4a8f081318c60c460cef5d9daf55e399c434.tar.gz
tor-72ea4a8f081318c60c460cef5d9daf55e399c434.zip
Extract the important parts of the run-pending-timers function.
Our unit tests will need this, so that they can simulate advancing time without getting libevent involved.
Diffstat (limited to 'src/common/timers.c')
-rw-r--r--src/common/timers.c26
1 files changed, 18 insertions, 8 deletions
diff --git a/src/common/timers.c b/src/common/timers.c
index 6f4a6c30f0..c43c49c083 100644
--- a/src/common/timers.c
+++ b/src/common/timers.c
@@ -29,6 +29,8 @@
#include "orconfig.h"
+#define TOR_TIMERS_PRIVATE
+
#include "compat.h"
#include "compat_libevent.h"
#include "timers.h"
@@ -148,6 +150,21 @@ libevent_timer_reschedule(void)
event_add(global_timer_event, &d);
}
+/** Run the callback of every timer that has expired, based on the current
+ * output of monotime_get(). */
+STATIC void
+timers_run_pending(void)
+{
+ monotime_t now;
+ monotime_get(&now);
+ timer_advance_to_cur_time(&now);
+
+ tor_timer_t *t;
+ while ((t = timeouts_get(global_timeouts))) {
+ t->callback.cb(t, t->callback.arg, &now);
+ }
+}
+
/**
* Invoked when the libevent timer has expired: see which tor_timer_t events
* have fired, activate their callbacks, and reschedule the libevent timer.
@@ -159,14 +176,7 @@ libevent_timer_callback(evutil_socket_t fd, short what, void *arg)
(void)what;
(void)arg;
- monotime_t now;
- monotime_get(&now);
- timer_advance_to_cur_time(&now);
-
- tor_timer_t *t;
- while ((t = timeouts_get(global_timeouts))) {
- t->callback.cb(t, t->callback.arg, &now);
- }
+ timers_run_pending();
libevent_timer_reschedule();
}