summaryrefslogtreecommitdiffstats
path: root/third_party/libevent/event.c
diff options
context:
space:
mode:
Diffstat (limited to 'third_party/libevent/event.c')
-rw-r--r--third_party/libevent/event.c30
1 files changed, 19 insertions, 11 deletions
diff --git a/third_party/libevent/event.c b/third_party/libevent/event.c
index 726ffad..d7ccd3f 100644
--- a/third_party/libevent/event.c
+++ b/third_party/libevent/event.c
@@ -37,7 +37,7 @@
#ifdef HAVE_SYS_TIME_H
#include <sys/time.h>
#else
-#include <sys/_time.h>
+#include <sys/_libevent_time.h>
#endif
#include <sys/queue.h>
#include <stdio.h>
@@ -79,7 +79,7 @@ extern const struct eventop win32ops;
#endif
/* In order of preference */
-const struct eventop *eventops[] = {
+static const struct eventop *eventops[] = {
#ifdef HAVE_EVENT_PORTS
&evportops,
#endif
@@ -108,7 +108,6 @@ const struct eventop *eventops[] = {
struct event_base *current_base = NULL;
extern struct event_base *evsignal_base;
static int use_monotonic;
-static int use_monotonic_initialized;
/* Prototypes */
static void event_queue_insert(struct event_base *, struct event *, int);
@@ -125,14 +124,10 @@ static void
detect_monotonic(void)
{
#if defined(HAVE_CLOCK_GETTIME) && defined(CLOCK_MONOTONIC)
- if (use_monotonic_initialized)
- return;
-
struct timespec ts;
if (clock_gettime(CLOCK_MONOTONIC, &ts) == 0)
use_monotonic = 1;
- use_monotonic_initialized = 1;
#endif
}
@@ -198,7 +193,7 @@ event_base_new(void)
if (base->evbase == NULL)
event_errx(1, "%s: no event mechanism available", __func__);
- if (getenv("EVENT_SHOW_METHOD"))
+ if (evutil_getenv("EVENT_SHOW_METHOD"))
event_msgx("libevent using: %s\n",
base->evsel->name);
@@ -283,8 +278,13 @@ event_reinit(struct event_base *base)
/* prevent internal delete */
if (base->sig.ev_signal_added) {
+ /* we cannot call event_del here because the base has
+ * not been reinitialized yet. */
event_queue_remove(base, &base->sig.ev_signal,
EVLIST_INSERTED);
+ if (base->sig.ev_signal.ev_flags & EVLIST_ACTIVE)
+ event_queue_remove(base, &base->sig.ev_signal,
+ EVLIST_ACTIVE);
base->sig.ev_signal_added = 0;
}
@@ -326,8 +326,8 @@ event_base_priority_init(struct event_base *base, int npriorities)
/* Allocate our priority queues */
base->nactivequeues = npriorities;
- base->activequeues = (struct event_list **)calloc(base->nactivequeues,
- npriorities * sizeof(struct event_list *));
+ base->activequeues = (struct event_list **)
+ calloc(base->nactivequeues, sizeof(struct event_list *));
if (base->activequeues == NULL)
event_err(1, "%s: calloc", __func__);
@@ -470,6 +470,9 @@ event_base_loop(struct event_base *base, int flags)
struct timeval *tv_p;
int res, done;
+ /* clear time cache */
+ base->tv_cache.tv_sec = 0;
+
if (base->sig.ev_signal_added)
evsignal_base = base;
done = 0;
@@ -526,6 +529,9 @@ event_base_loop(struct event_base *base, int flags)
done = 1;
}
+ /* clear time cache */
+ base->tv_cache.tv_sec = 0;
+
event_debug(("%s: asked to terminate loop.", __func__));
return (0);
}
@@ -765,7 +771,7 @@ event_add(struct event *ev, const struct timeval *tv)
event_queue_insert(base, ev, EVLIST_TIMEOUT);
}
- return (0);
+ return (res);
}
int
@@ -890,6 +896,8 @@ timeout_correct(struct event_base *base, struct timeval *tv)
struct timeval *ev_tv = &(**pev).ev_timeout;
evutil_timersub(ev_tv, &off, ev_tv);
}
+ /* Now remember what the new time turned out to be. */
+ base->event_tv = *tv;
}
void