#endif
#ifndef EV_STANDALONE
-# include "config.h"
+# ifdef EV_CONFIG_H
+# include EV_CONFIG_H
+# else
+# include "config.h"
+# endif
# if HAVE_CLOCK_GETTIME
# ifndef EV_USE_MONOTONIC
/**/
-/* darwin simply cannot be helped */
-#ifdef __APPLE__
-# undef EV_USE_POLL
-# undef EV_USE_KQUEUE
-#endif
-
#ifndef CLOCK_MONOTONIC
# undef EV_USE_MONOTONIC
# define EV_USE_MONOTONIC 0
anfd->reify = 0;
- method_modify (EV_A_ fd, anfd->events, events);
+ backend_modify (EV_A_ fd, anfd->events, events);
anfd->events = events;
}
}
}
-/* usually called after fork if method needs to re-arm all fds from scratch */
+/* usually called after fork if backend needs to re-arm all fds from scratch */
static void
fd_rearm_all (EV_P)
{
if (0 < (pid = waitpid (-1, &status, WNOHANG | WUNTRACED | WCONTINUED)))
{
/* make sure we are called again until all childs have been reaped */
+ /* we need to do it this way so that the callback gets called before we continue */
ev_feed_event (EV_A_ (W)sw, EV_SIGNAL);
child_reap (EV_A_ sw, pid, pid, status);
- child_reap (EV_A_ sw, 0, pid, status); /* this might trigger a watcher twice, but event catches that */
+ child_reap (EV_A_ sw, 0, pid, status); /* this might trigger a watcher twice, but feed_event catches that */
}
}
}
unsigned int
-ev_method (EV_P)
+ev_supported_backends (void)
+{
+ unsigned int flags = 0;
+
+ if (EV_USE_PORT ) flags |= EVBACKEND_PORT;
+ if (EV_USE_KQUEUE) flags |= EVBACKEND_KQUEUE;
+ if (EV_USE_EPOLL ) flags |= EVBACKEND_EPOLL;
+ if (EV_USE_POLL ) flags |= EVBACKEND_POLL;
+ if (EV_USE_SELECT) flags |= EVBACKEND_SELECT;
+
+ return flags;
+}
+
+unsigned int
+ev_recommended_backends (void)
+{
+ unsigned int flags = ev_supported_backends ();
+
+#ifndef __NetBSD__
+ /* kqueue is borked on everything but netbsd apparently */
+ /* it usually doesn't work correctly on anything but sockets and pipes */
+ flags &= ~EVBACKEND_KQUEUE;
+#endif
+#ifdef __APPLE__
+ // flags &= ~EVBACKEND_KQUEUE; for documentation
+ flags &= ~EVBACKEND_POLL;
+#endif
+
+ return flags;
+}
+
+unsigned int
+ev_backend (EV_P)
{
- return method;
+ return backend;
}
static void
loop_init (EV_P_ unsigned int flags)
{
- if (!method)
+ if (!backend)
{
#if EV_USE_MONOTONIC
{
now_floor = mn_now;
rtmn_diff = ev_rt_now - mn_now;
- if (!(flags & EVFLAG_NOENV) && !enable_secure () && getenv ("LIBEV_FLAGS"))
+ if (!(flags & EVFLAG_NOENV)
+ && !enable_secure ()
+ && getenv ("LIBEV_FLAGS"))
flags = atoi (getenv ("LIBEV_FLAGS"));
- if (!(flags & 0x0000ffff))
- flags |= 0x0000ffff;
+ if (!(flags & 0x0000ffffUL))
+ flags |= ev_recommended_backends ();
- method = 0;
+ backend = 0;
#if EV_USE_PORT
- if (!method && (flags & EVMETHOD_PORT )) method = port_init (EV_A_ flags);
+ if (!backend && (flags & EVBACKEND_PORT )) backend = port_init (EV_A_ flags);
#endif
#if EV_USE_KQUEUE
- if (!method && (flags & EVMETHOD_KQUEUE)) method = kqueue_init (EV_A_ flags);
+ if (!backend && (flags & EVBACKEND_KQUEUE)) backend = kqueue_init (EV_A_ flags);
#endif
#if EV_USE_EPOLL
- if (!method && (flags & EVMETHOD_EPOLL )) method = epoll_init (EV_A_ flags);
+ if (!backend && (flags & EVBACKEND_EPOLL )) backend = epoll_init (EV_A_ flags);
#endif
#if EV_USE_POLL
- if (!method && (flags & EVMETHOD_POLL )) method = poll_init (EV_A_ flags);
+ if (!backend && (flags & EVBACKEND_POLL )) backend = poll_init (EV_A_ flags);
#endif
#if EV_USE_SELECT
- if (!method && (flags & EVMETHOD_SELECT)) method = select_init (EV_A_ flags);
+ if (!backend && (flags & EVBACKEND_SELECT)) backend = select_init (EV_A_ flags);
#endif
ev_init (&sigev, sigcb);
int i;
#if EV_USE_PORT
- if (method == EVMETHOD_PORT ) port_destroy (EV_A);
+ if (backend == EVBACKEND_PORT ) port_destroy (EV_A);
#endif
#if EV_USE_KQUEUE
- if (method == EVMETHOD_KQUEUE) kqueue_destroy (EV_A);
+ if (backend == EVBACKEND_KQUEUE) kqueue_destroy (EV_A);
#endif
#if EV_USE_EPOLL
- if (method == EVMETHOD_EPOLL ) epoll_destroy (EV_A);
+ if (backend == EVBACKEND_EPOLL ) epoll_destroy (EV_A);
#endif
#if EV_USE_POLL
- if (method == EVMETHOD_POLL ) poll_destroy (EV_A);
+ if (backend == EVBACKEND_POLL ) poll_destroy (EV_A);
#endif
#if EV_USE_SELECT
- if (method == EVMETHOD_SELECT) select_destroy (EV_A);
+ if (backend == EVBACKEND_SELECT) select_destroy (EV_A);
#endif
for (i = NUMPRI; i--; )
array_free (prepare, EMPTY0);
array_free (check, EMPTY0);
- method = 0;
+ backend = 0;
}
static void
loop_fork (EV_P)
{
#if EV_USE_PORT
- if (method == EVMETHOD_PORT ) port_fork (EV_A);
+ if (backend == EVBACKEND_PORT ) port_fork (EV_A);
#endif
#if EV_USE_KQUEUE
- if (method == EVMETHOD_KQUEUE) kqueue_fork (EV_A);
+ if (backend == EVBACKEND_KQUEUE) kqueue_fork (EV_A);
#endif
#if EV_USE_EPOLL
- if (method == EVMETHOD_EPOLL ) epoll_fork (EV_A);
+ if (backend == EVBACKEND_EPOLL ) epoll_fork (EV_A);
#endif
if (ev_is_active (&sigev))
loop_init (EV_A_ flags);
- if (ev_method (EV_A))
+ if (ev_backend (EV_A))
return loop;
return 0;
loop_init (EV_A_ flags);
- if (ev_method (EV_A))
+ if (ev_backend (EV_A))
{
siginit (EV_A);
struct ev_loop *loop = ev_default_loop_ptr;
#endif
- if (method)
+ if (backend)
postfork = 1;
}
if (timercnt)
{
- ev_tstamp to = ((WT)timers [0])->at - mn_now + method_fudge;
+ ev_tstamp to = ((WT)timers [0])->at - mn_now + backend_fudge;
if (block > to) block = to;
}
#if EV_PERIODICS
if (periodiccnt)
{
- ev_tstamp to = ((WT)periodics [0])->at - ev_rt_now + method_fudge;
+ ev_tstamp to = ((WT)periodics [0])->at - ev_rt_now + backend_fudge;
if (block > to) block = to;
}
#endif
if (expect_false (block < 0.)) block = 0.;
}
- method_poll (EV_A_ block);
+ backend_poll (EV_A_ block);
/* update ev_rt_now, do magic */
time_update (EV_A);