From: Lennart Poettering Date: Thu, 22 May 2014 07:56:21 +0000 (+0900) Subject: socket: properly handle if our service vanished during runtime X-Git-Tag: v213~33 X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=640ace4a8de907994a1b95f6d368c3e6a8fcf60f socket: properly handle if our service vanished during runtime --- diff --git a/src/core/socket.c b/src/core/socket.c index 05af8fe9d..aca20fd10 100644 --- a/src/core/socket.c +++ b/src/core/socket.c @@ -1503,6 +1503,12 @@ static void socket_enter_running(Socket *s, int cfd) { } if (!pending) { + if (!UNIT_ISSET(s->service)) { + log_error_unit(UNIT(s)->id, "%s: service to activate vanished, refusing activation.", UNIT(s)->id); + r = -ENOENT; + goto fail; + } + r = manager_add_job(UNIT(s)->manager, JOB_START, UNIT_DEREF(s->service), JOB_REPLACE, true, &error, NULL); if (r < 0) goto fail;