diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/socketengine_epoll.cpp | 6 | ||||
-rw-r--r-- | src/socketengine_kqueue.cpp | 6 |
2 files changed, 6 insertions, 6 deletions
diff --git a/src/socketengine_epoll.cpp b/src/socketengine_epoll.cpp index 7d35997c5..63b1fc10d 100644 --- a/src/socketengine_epoll.cpp +++ b/src/socketengine_epoll.cpp @@ -91,15 +91,15 @@ bool EPollEngine::DelFd(EventHandler* eh) ev.data.fd = fd; int i = epoll_ctl(EngineHandle, EPOLL_CTL_DEL, fd, &ev); - CurrentSetSize--; - ref[fd] = NULL; - if (i < 0) { ServerInstance->Log(DEBUG,"epoll: List deletion failure: %s",strerror(errno)); return false; } + CurrentSetSize--; + ref[fd] = NULL; + return true; } diff --git a/src/socketengine_kqueue.cpp b/src/socketengine_kqueue.cpp index 15d0e30bc..ef5c507a1 100644 --- a/src/socketengine_kqueue.cpp +++ b/src/socketengine_kqueue.cpp @@ -94,9 +94,6 @@ bool KQueueEngine::DelFd(EventHandler* eh) struct kevent ke; EV_SET(&ke, fd, eh->Readable() ? EVFILT_READ : EVFILT_WRITE, EV_DELETE, 0, 0, NULL); - CurrentSetSize--; - ref[fd] = NULL; - int i = kevent(EngineHandle, &ke, 1, 0, 0, NULL); if (i == -1) { @@ -104,6 +101,9 @@ bool KQueueEngine::DelFd(EventHandler* eh) return false; } + CurrentSetSize--; + ref[fd] = NULL; + return true; } |