diff options
author | root <root> | 2007-11-16 01:33:53 +0000 |
---|---|---|
committer | root <root> | 2007-11-16 01:33:53 +0000 |
commit | 42cf115660f3852e9cc3b91bd79b852a99d13065 (patch) | |
tree | 3374bf738306127d076a29c35b0e1f81a0f38fec /ev.c | |
parent | 22f1c28816978d9c971ec46d5a95110252b2deb9 (diff) |
add solaris port backend
Diffstat (limited to 'ev.c')
-rw-r--r-- | ev.c | 28 |
1 files changed, 24 insertions, 4 deletions
@@ -61,6 +61,10 @@ extern "C" { # define EV_USE_KQUEUE 1 # endif +# if HAVE_PORT_H && HAVE_PORT_H && HAVE_PORT_CREATE && !defined (EV_USE_PORT) +# define EV_USE_PORT 1 +# endif + #endif #include <math.h> @@ -95,6 +99,10 @@ extern "C" { # define EV_USE_MONOTONIC 1 #endif +#ifndef EV_USE_REALTIME +# define EV_USE_REALTIME 1 +#endif + #ifndef EV_USE_SELECT # define EV_USE_SELECT 1 # define EV_SELECT_USE_FD_SET 1 @@ -116,8 +124,8 @@ extern "C" { # define EV_USE_KQUEUE 0 #endif -#ifndef EV_USE_REALTIME -# define EV_USE_REALTIME 1 +#ifndef EV_USE_PORT +# define EV_USE_PORT 0 #endif /**/ @@ -712,6 +720,9 @@ childcb (EV_P_ struct ev_signal *sw, int revents) /*****************************************************************************/ +#if EV_USE_PORT +# include "ev_port.c" +#endif #if EV_USE_KQUEUE # include "ev_kqueue.c" #endif @@ -780,6 +791,9 @@ loop_init (EV_P_ unsigned int flags) flags |= 0x0000ffff; method = 0; +#if EV_USE_PORT + if (!method && (flags & EVMETHOD_PORT )) method = port_init (EV_A_ flags); +#endif #if EV_USE_KQUEUE if (!method && (flags & EVMETHOD_KQUEUE)) method = kqueue_init (EV_A_ flags); #endif @@ -803,6 +817,9 @@ loop_destroy (EV_P) { int i; +#if EV_USE_PORT + if (method == EVMETHOD_PORT ) port_destroy (EV_A); +#endif #if EV_USE_KQUEUE if (method == EVMETHOD_KQUEUE) kqueue_destroy (EV_A); #endif @@ -835,12 +852,15 @@ loop_destroy (EV_P) static void loop_fork (EV_P) { -#if EV_USE_EPOLL - if (method == EVMETHOD_EPOLL ) epoll_fork (EV_A); +#if EV_USE_PORT + if (method == EVMETHOD_PORT ) port_fork (EV_A); #endif #if EV_USE_KQUEUE if (method == EVMETHOD_KQUEUE) kqueue_fork (EV_A); #endif +#if EV_USE_EPOLL + if (method == EVMETHOD_EPOLL ) epoll_fork (EV_A); +#endif if (ev_is_active (&sigev)) { |