From afa01962776013e8468de562e26aab59aaf53d69 Mon Sep 17 00:00:00 2001 From: Lorenz Stechauner <lorenz.stechauner@necronda.net> Date: Sat, 8 Jul 2023 01:05:18 +0200 Subject: [PATCH] Async: ignore ENOENT errors on remove --- src/async.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/async.c b/src/async.c index 61ca1ed..2f31e04 100644 --- a/src/async.c +++ b/src/async.c @@ -286,8 +286,8 @@ void async_thread(void) { if (async_exec(evt, async_e2a(events[i].events)) == 0) { logger_set_prefix(""); if (epoll_ctl(epoll_fd, EPOLL_CTL_DEL, evt->fd, NULL) == -1) { - if (errno == EBADF) { - // already closed fd, do not die + if (errno == EBADF || errno == ENOENT) { + // already closed fd or not found, do not die errno = 0; } else { critical("Unable to remove file descriptor from epoll instance"); @@ -316,8 +316,8 @@ void async_thread(void) { evt->to_cb(evt->arg); if (epoll_ctl(epoll_fd, EPOLL_CTL_DEL, evt->fd, NULL) == -1) { - if (errno == EBADF) { - // already closed fd, do not die + if (errno == EBADF || errno == ENOENT) { + // already closed fd or not found, do not die errno = 0; } else { critical("Unable to remove file descriptor from epoll instance");