From: Miroslav Lichvar Date: Thu, 4 Jul 2024 14:11:19 +0000 (+0200) Subject: main: check for killed foreground process X-Git-Tag: 4.6-pre1~5 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=34be117c9cc4ea471b13dd009fd2b18db48c8226;p=thirdparty%2Fchrony.git main: check for killed foreground process On start, if the foreground process waiting for the daemon process to close the pipe (after finishing the RTC initialization, initstepslew, etc) is killed, terminate the daemon too assuming that whatever killed the foreground process it wanted all chronyd processes to stop. In the daemon, before closing the pipe file descriptor, send an empty message to check if the pipe isn't already closed on the other end. --- diff --git a/main.c b/main.c index cb240640..88ada202 100644 --- a/main.c +++ b/main.c @@ -215,7 +215,10 @@ post_init_ntp_hook(void *anything) REF_SetMode(ref_mode); } - /* Close the pipe to the foreground process so it can exit */ + /* Send an empty message to the foreground process so it can exit. + If that fails, indicating the process was killed, exit too. */ + if (!LOG_NotifyParent("")) + SCH_QuitProgram(); LOG_CloseParentFd(); CNF_AddSources(); @@ -338,8 +341,8 @@ go_daemon(void) close(pipefd[1]); r = read(pipefd[0], message, sizeof (message)); - if (r) { - if (r > 0) { + if (r != 1 || message[0] != '\0') { + if (r > 1) { /* Print the error message from the child */ message[sizeof (message) - 1] = '\0'; fprintf(stderr, "%s\n", message);