From 6b9881804602256d08f5b938d3746fa2a5a8c735 Mon Sep 17 00:00:00 2001 From: David Wilson Date: Tue, 15 May 2018 01:32:46 +0100 Subject: [PATCH] issue #249: epoll distinguishes between hangup and disconnect ..typical Linux, for certain descriptor types only. So our receive mask must match both, and normalize it into a read event like every other poller. --- mitogen/parent.py | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/mitogen/parent.py b/mitogen/parent.py index 3cfff8fb..693a82b7 100644 --- a/mitogen/parent.py +++ b/mitogen/parent.py @@ -633,6 +633,9 @@ class EpollPoller(Poller): self._wfds.pop(fd, None) self._control(fd) + _inmask = (getattr(select, 'EPOLLIN', 0) | + getattr(select, 'EPOLLHUP', 0)) + def poll(self, timeout=None): the_timeout = -1 if timeout is not None: @@ -640,7 +643,7 @@ class EpollPoller(Poller): events, _ = mitogen.core.io_op(self._epoll.poll, the_timeout) for fd, event in events: - if event & select.EPOLLIN and fd in self._rfds: + if event & self._inmask and fd in self._rfds: # Events can still be read for an already-discarded fd. mitogen.core._vv and IOLOG.debug('%r: POLLIN: %r', self, fd) yield self._rfds[fd]