From bdffebc95dd4e027a45853749b06f140d6f97ebc Mon Sep 17 00:00:00 2001 From: root Date: Tue, 6 Nov 2007 01:17:16 +0000 Subject: better fork --- ev_epoll.c | 11 +++-------- ev_kqueue.c | 11 +++-------- 2 files changed, 6 insertions(+), 16 deletions(-) diff --git a/ev_epoll.c b/ev_epoll.c index 2040103..9f5bd25 100644 --- a/ev_epoll.c +++ b/ev_epoll.c @@ -110,15 +110,10 @@ epoll_destroy (EV_P) static void epoll_fork (EV_P) { - for (;;) - { - epoll_fd = epoll_create (256); - - if (epoll_fd >= 0) - break; + close (epoll_fd); - syserr ("(libev) epoll_create"); - } + while ((epoll_fd = epoll_create (256)) < 0) + syserr ("(libev) epoll_create"); fcntl (epoll_fd, F_SETFD, FD_CLOEXEC); diff --git a/ev_kqueue.c b/ev_kqueue.c index 07d16e4..8d5021f 100644 --- a/ev_kqueue.c +++ b/ev_kqueue.c @@ -185,15 +185,10 @@ kqueue_destroy (EV_P) static void kqueue_fork (EV_P) { - for (;;) - { - kqueue_fd = kqueue (); - - if (kqueue_fd >= 0) - break; + close (kqueue_fd); - syserr ("(libev) kqueue"); - } + while ((kqueue_fd = kqueue ()) < 0) + syserr ("(libev) kqueue"); fcntl (kqueue_fd, F_SETFD, FD_CLOEXEC); -- cgit v1.2.3