aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2015-11-02 15:36:09 -0500
committerNick Mathewson <nickm@torproject.org>2015-11-13 16:25:40 -0500
commitdd00fd0a1f3d9c30d94c00ce7f847298b4494c7d (patch)
treefd2d79998b301fab0313962e55dc00f0365c740a /src
parent65a6489e5e52ff9b80e10e5fdea0cdd3e1097810 (diff)
downloadtor-dd00fd0a1f3d9c30d94c00ce7f847298b4494c7d.tar.gz
tor-dd00fd0a1f3d9c30d94c00ce7f847298b4494c7d.zip
Change periodic.c to use libevent directly
Libevent's periodic timers aren't the right solution when the timeout potentially changes every time.
Diffstat (limited to 'src')
-rw-r--r--src/or/periodic.c52
-rw-r--r--src/or/periodic.h9
2 files changed, 30 insertions, 31 deletions
diff --git a/src/or/periodic.c b/src/or/periodic.c
index 8ae8333640..44e1714cb8 100644
--- a/src/or/periodic.c
+++ b/src/or/periodic.c
@@ -2,9 +2,16 @@
/* See LICENSE for licensing information */
#include "or.h"
+#include "compat_libevent.h"
#include "config.h"
#include "periodic.h"
+#ifdef HAVE_EVENT2_EVENT_H
+#include <event2/event.h>
+#else
+#include <event.h>
+#endif
+
static const int MAX_INTERVAL = 10 * 365 * 86400;
/** DOCDOC */
@@ -12,24 +19,21 @@ static void
periodic_event_set_interval(periodic_event_item_t *event,
time_t next_interval)
{
- /** update the interval time if it's changed */
- if (next_interval != event->interval) {
- tor_assert(next_interval < MAX_INTERVAL);
- struct timeval tv;
- tv.tv_sec = next_interval;
- tv.tv_usec = 0;
- event->interval = (int)next_interval;
- periodic_timer_update_interval(event->timer, &tv);
- }
+ tor_assert(next_interval < MAX_INTERVAL);
+ struct timeval tv;
+ tv.tv_sec = next_interval;
+ tv.tv_usec = 0;
+ event_add(event->ev, &tv);
}
/** Wraps dispatches for periodic events, <b>data</b> will be a pointer to the
* event that needs to be called */
static void
-periodic_event_dispatch(periodic_timer_t *timer, void *data)
+periodic_event_dispatch(evutil_socket_t fd, short what, void *data)
{
+ (void)fd;
+ (void)what;
periodic_event_item_t *event = data;
- tor_assert(timer == event->timer);
time_t now = time(NULL);
const or_options_t *options = get_options();
@@ -55,7 +59,8 @@ periodic_event_dispatch(periodic_timer_t *timer, void *data)
next_interval = 1;
}
- periodic_event_set_interval(event, next_interval);
+ struct timeval tv = { next_interval , 0 };
+ event_add(event->ev, &tv);
log_info(LD_GENERAL, "Dispatching %s", event->name);
}
@@ -72,24 +77,19 @@ periodic_event_reschedule(periodic_event_item_t *event)
void
periodic_event_launch(periodic_event_item_t *event)
{
- if (event->timer) { /** Already setup? This is a bug */
+ if (event->ev) { /** Already setup? This is a bug */
log_err(LD_BUG, "Initial dispatch should only be done once.");
tor_assert(0);
}
- struct timeval interval;
- interval.tv_sec = event->interval;
- interval.tv_usec = 0;
-
- periodic_timer_t *timer = periodic_timer_new(tor_libevent_get_base(),
- &interval,
- periodic_event_dispatch,
- event);
- tor_assert(timer);
- event->timer = timer;
+ event->ev = tor_event_new(tor_libevent_get_base(),
+ -1, 0,
+ periodic_event_dispatch,
+ event);
+ tor_assert(event->ev);
// Initial dispatch
- periodic_event_dispatch(timer, event);
+ periodic_event_dispatch(-1, EV_TIMEOUT, event);
}
/** DOCDOC */
@@ -98,9 +98,7 @@ periodic_event_destroy(periodic_event_item_t *event)
{
if (!event)
return;
- periodic_timer_free(event->timer);
- event->timer = 0;
- event->interval = 0;
+ tor_event_free(event->ev);
event->last_action_time = 0;
}
diff --git a/src/or/periodic.h b/src/or/periodic.h
index 2ab3db00a5..e57666c0c8 100644
--- a/src/or/periodic.h
+++ b/src/or/periodic.h
@@ -13,18 +13,19 @@
typedef int (*periodic_event_helper_t)(time_t now,
const or_options_t *options);
+struct event;
+
/** A single item for the periodic-events-function table. */
typedef struct periodic_event_item_t {
periodic_event_helper_t fn; /**< The function to run the event */
- int interval; /**< The interval for running the function (In seconds). */
time_t last_action_time; /**< The last time the function did something */
- periodic_timer_t *timer; /**< Timer object for this event */
+ struct event *ev; /**< Libevent callback we're using to implement this */
const char *name; /**< Name of the function -- for debug */
} periodic_event_item_t;
/** events will get their interval from first execution */
-#define PERIODIC_EVENT(fn) { fn##_callback, 0, 0, NULL, #fn }
-#define END_OF_PERIODIC_EVENTS { NULL, 0, 0, NULL, NULL }
+#define PERIODIC_EVENT(fn) { fn##_callback, 0, NULL, #fn }
+#define END_OF_PERIODIC_EVENTS { NULL, 0, NULL, NULL }
void periodic_event_launch(periodic_event_item_t *event);
void periodic_event_destroy(periodic_event_item_t *event);