X-Git-Url: https://git.llucax.com/software/libev.git/blobdiff_plain/228b0b302ab0857b23efad5a8b2429de2c0ccc00..edc31a9118d9252f091b336522858c4b3e36e2f8:/ev_kqueue.c?ds=inline diff --git a/ev_kqueue.c b/ev_kqueue.c index 8282fea..24c3015 100644 --- a/ev_kqueue.c +++ b/ev_kqueue.c @@ -133,6 +133,8 @@ kqueue_init (EV_P_ int flags) if ((kqueue_fd = kqueue ()) < 0) return 0; + fcntl (kqueue_fd, F_SETFD, FD_CLOEXEC); /* not sure if necessary, hopefully doesn't hurt */ + /* Check for Mac OS X kqueue bug. */ ch.ident = -1; ch.filter = EVFILT_READ; @@ -159,6 +161,29 @@ kqueue_init (EV_P_ int flags) kqueue_eventmax = 64; /* intiial number of events receivable per poll */ kqueue_events = malloc (sizeof (struct kevent) * kqueue_eventmax); + kqueue_changes = 0; + kqueue_changemax = 0; + kqueue_changecnt = 0; + return EVMETHOD_KQUEUE; } +static void +kqueue_destroy (EV_P) +{ + close (kqueue_fd); + + free (kqueue_events); + free (kqueue_changes); +} + +static void +kqueue_fork (EV_P) +{ + kqueue_fd = kqueue (); + fcntl (kqueue_fd, F_SETFD, FD_CLOEXEC); + + /* re-register interest in fds */ + fd_rearm_all (EV_A); +} +