aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2018-10-12 03:22:09 +0200
committerKim Alvefur <zash@zash.se>2018-10-12 03:22:09 +0200
commit6d12622b2a12823a3a2e983e98bcb4c19c741982 (patch)
tree8025d448365b2e79271bf088c41bb0afe8720b0d
parentec7fb3ee614bdd315bd2657c22280bff0e0ed6b1 (diff)
downloadprosody-6d12622b2a12823a3a2e983e98bcb4c19c741982.tar.gz
prosody-6d12622b2a12823a3a2e983e98bcb4c19c741982.zip
net.server_epoll: Special handling of signal interrupts
-rw-r--r--net/server_epoll.lua2
-rw-r--r--util-src/poll.c5
2 files changed, 6 insertions, 1 deletions
diff --git a/net/server_epoll.lua b/net/server_epoll.lua
index cb83c8c3..0d05aee1 100644
--- a/net/server_epoll.lua
+++ b/net/server_epoll.lua
@@ -742,7 +742,7 @@ local function loop(once)
log("debug", "Removing unknown fd %d", fd);
poll:del(fd);
end
- elseif r ~= "timeout" then
+ elseif r ~= "timeout" and r ~= "signal" then
log("debug", "epoll_wait error: %s[%d]", r, w);
end
until once or (quitting and next(fds) == nil);
diff --git a/util-src/poll.c b/util-src/poll.c
index e5b5f70c..0ca0cf28 100644
--- a/util-src/poll.c
+++ b/util-src/poll.c
@@ -316,6 +316,11 @@ int Lwait(lua_State *L) {
lua_pushstring(L, "timeout");
return 2;
}
+ else if(ret < 0 && errno == EINTR) {
+ lua_pushnil(L);
+ lua_pushstring(L, "signal");
+ return 2;
+ }
else if(ret < 0) {
ret = errno;
lua_pushnil(L);