summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorroot <root>2010-03-27 02:26:27 +0000
committerroot <root>2010-03-27 02:26:27 +0000
commit211bdfec955fb41eb57d90de71bf4b2f4bd935d9 (patch)
treeda2e2074a260752d744ecc71f39bc628651fa3d2
parent2a3e4b8fa36efec935b58f217f396d35e28c45c3 (diff)
*** empty log message ***
-rw-r--r--Changes2
-rw-r--r--ev_kqueue.c8
2 files changed, 8 insertions, 2 deletions
diff --git a/Changes b/Changes
index d554cee..c681e23 100644
--- a/Changes
+++ b/Changes
@@ -8,6 +8,8 @@ TODO: win32 write() to socket for signal handling
- applied win32 fixes by Michael Lenaghan (also James Mansion).
- replace EV_MINIMAL by EV_FEATURES.
- remove dependency on sys/queue.h on freebsd (patch by Vanilla Hsu).
+ - add (undocumented) EV_ENABLE when adding events with kqueue,
+ this might help (helpfully pointed out by Tilghman Lesher).
- configure now prepends -O3, not appends it, so one can still
override it.
- disable poll backend on AIX, the poll header spams the namespace
diff --git a/ev_kqueue.c b/ev_kqueue.c
index 53f2dc1..8e46c2a 100644
--- a/ev_kqueue.c
+++ b/ev_kqueue.c
@@ -52,6 +52,10 @@ kqueue_change (EV_P_ int fd, int filter, int flags, int fflags)
EV_SET (&kqueue_changes [kqueue_changecnt - 1], fd, filter, flags, fflags, 0, 0);
}
+/* OS X at least needs this */
+#ifndef EV_ENABLE
+# define EV_ENABLE 0
+#endif
#ifndef NOTE_EOF
# define NOTE_EOF 0
#endif
@@ -72,10 +76,10 @@ kqueue_modify (EV_P_ int fd, int oev, int nev)
/* event requests even when oev == nev */
if (nev & EV_READ)
- kqueue_change (EV_A_ fd, EVFILT_READ , EV_ADD, NOTE_EOF);
+ kqueue_change (EV_A_ fd, EVFILT_READ , EV_ADD | EV_ENABLE, NOTE_EOF);
if (nev & EV_WRITE)
- kqueue_change (EV_A_ fd, EVFILT_WRITE, EV_ADD, NOTE_EOF);
+ kqueue_change (EV_A_ fd, EVFILT_WRITE, EV_ADD | EV_ENABLE, NOTE_EOF);
}
static void