From: Lennart Poettering Date: Mon, 12 Jul 2010 22:51:48 +0000 (+0200) Subject: socket: when going down, flush all queued sockets X-Git-Tag: v3~19 X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=7c610628cd907b8d04dbfe28dd23a0fa958c7dcd;p=systemd socket: when going down, flush all queued sockets --- diff --git a/src/socket.c b/src/socket.c index f998cada..4a9c9399 100644 --- a/src/socket.c +++ b/src/socket.c @@ -1033,7 +1033,18 @@ static void socket_enter_running(Socket *s, int cfd) { /* We don't take connections anymore if we are supposed to * shut down anyway */ if (s->meta.job && s->meta.job->type == JOB_STOP) { - close_nointr_nofail(cfd); + if (cfd >= 0) + close_nointr_nofail(cfd); + else { + /* Flush all sockets by closing and reopening them */ + socket_close_fds(s); + + if ((r = socket_watch_fds(s)) < 0) { + log_warning("%s failed to watch sockets: %s", s->meta.id, strerror(-r)); + socket_enter_stop_pre(s, false); + } + } + return; }