diff options
author | Nick Mathewson <nickm@torproject.org> | 2017-09-11 13:48:39 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2017-09-11 13:48:39 -0400 |
commit | 72ea4a8f081318c60c460cef5d9daf55e399c434 (patch) | |
tree | d5b98ca36b4fdeb4eef0d949764cfc11d4f7c2da /src | |
parent | 7a83cf75dc55dbac91ff5c0daf7c7418493cbea7 (diff) | |
download | tor-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')
-rw-r--r-- | src/common/timers.c | 26 | ||||
-rw-r--r-- | src/common/timers.h | 4 |
2 files changed, 22 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(); } diff --git a/src/common/timers.h b/src/common/timers.h index e816630e6d..d9602cd2ae 100644 --- a/src/common/timers.h +++ b/src/common/timers.h @@ -22,5 +22,9 @@ void timer_free(tor_timer_t *t); void timers_initialize(void); void timers_shutdown(void); +#ifdef TOR_TIMERS_PRIVATE +STATIC void timers_run_pending(void); +#endif + #endif |