From f27e9657213a42fb500eb32f089d0df68e75f71c Mon Sep 17 00:00:00 2001 From: Emil Renner Berthing Date: Sun, 27 Jan 2013 12:04:56 +0100 Subject: io: ignore protocol errors on accept --- lem/io/server.c | 21 ++++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/lem/io/server.c b/lem/io/server.c index 7ed0319..2240254 100644 --- a/lem/io/server.c +++ b/lem/io/server.c @@ -99,9 +99,16 @@ server__accept(lua_State *T, struct ev_io *w, int mt) int sock = accept(w->fd, NULL, NULL); if (sock < 0) { - if (errno == EAGAIN || errno == EINTR || errno == ECONNABORTED) + switch (errno) { + case EAGAIN: case EINTR: case ECONNABORTED: + case ENETDOWN: case EPROTO: case ENOPROTOOPT: + case EHOSTDOWN: +#ifdef ENONET + case ENONET: +#endif + case EHOSTUNREACH: case EOPNOTSUPP: case ENETUNREACH: return 0; - + } lua_pushnil(T); lua_pushfstring(T, "error accepting connection: %s", strerror(errno)); @@ -182,8 +189,16 @@ server_autospawn_cb(EV_P_ struct ev_io *w, int revents) /* dequeue the incoming connection */ sock = accept(w->fd, NULL, NULL); if (sock < 0) { - if (errno == EAGAIN || errno == EINTR || errno == ECONNABORTED) + switch (errno) { + case EAGAIN: case EINTR: case ECONNABORTED: + case ENETDOWN: case EPROTO: case ENOPROTOOPT: + case EHOSTDOWN: +#ifdef ENONET + case ENONET: +#endif + case EHOSTUNREACH: case EOPNOTSUPP: case ENETUNREACH: return; + } lua_pushnil(T); lua_pushfstring(T, "error accepting connection: %s", strerror(errno)); -- cgit v1.2.1