--- libev/ev_epoll.c 2007/11/06 00:10:04 1.20 +++ libev/ev_epoll.c 2007/11/06 00:52:33 1.21 @@ -57,7 +57,7 @@ if (eventcnt < 0) { if (errno != EINTR) - syserr (); + syserr ("(libev) epoll_wait"); return; } @@ -110,7 +110,16 @@ static void epoll_fork (EV_P) { - epoll_fd = epoll_create (256); + for (;;) + { + epoll_fd = epoll_create (256); + + if (epoll_fd >= 0) + break; + + syserr ("(libev) epoll_create"); + } + fcntl (epoll_fd, F_SETFD, FD_CLOEXEC); fd_rearm_all (EV_A);