From 6939ce648aae1bf7e515731c0547a54eb939c259 Mon Sep 17 00:00:00 2001 From: Lennart Poettering Date: Tue, 28 Feb 2017 16:08:40 +0100 Subject: service: refuse using PID 1 as MAINPID for a service --- src/core/service.c | 2 ++ 1 file changed, 2 insertions(+) (limited to 'src') diff --git a/src/core/service.c b/src/core/service.c index 5bc8df3e1c..74054887b9 100644 --- a/src/core/service.c +++ b/src/core/service.c @@ -3093,6 +3093,8 @@ static void service_notify_message(Unit *u, pid_t pid, char **tags, FDSet *fds) log_unit_warning(u, "Failed to parse MAINPID= field in notification message: %s", e); else if (pid == s->control_pid) log_unit_warning(u, "A control process cannot also be the main process"); + else if (pid == getpid() || pid == 1) + log_unit_warning(u, "Service manager can't be main process, ignoring sd_notify() MAINPID= field"); else { service_set_main_pid(s, pid); unit_watch_pid(UNIT(s), pid); -- cgit v1.2.3-54-g00ecf