From 675974ce30591e9cdbebeead65e63eec9772ee90 Mon Sep 17 00:00:00 2001 From: Tim Hentenaar Date: Thu, 14 Jul 2016 15:45:01 +0200 Subject: [PATCH] poll: Prevent libevent from spinning if POLLNVAL occurs This can happen, for example if libevent is being used to poll fds given by another library where the other library closes the fds without notifying the program using it that said fds were closed. In this case, libevent will simply spin on poll() since there are active fds, but won't call any event callback to handle the condition. In epoll case after socket closed it automatically removed from epfd, so IOW it will not spin in epoll* API, just a timeout. Fixes: #379 --- poll.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/poll.c b/poll.c index 51475934..fe440711 100644 --- a/poll.c +++ b/poll.c @@ -198,7 +198,7 @@ poll_dispatch(struct event_base *base, struct timeval *tv) res = 0; /* If the file gets closed notify */ - if (what & (POLLHUP|POLLERR)) + if (what & (POLLHUP|POLLERR|POLLNVAL)) what |= POLLIN|POLLOUT; if (what & POLLIN) res |= EV_READ; -- 2.40.0