summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/socketengine_epoll.cpp6
-rw-r--r--src/socketengine_kqueue.cpp6
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;
}