When starting the daemon, wait in the grandparent process for the parent
process to terminate before exiting to avoid systemd logging a warning
"Supervising process $PID which is not our child". Waiting for the pipe
to be closed by the kernel when the parent process exits is not
sufficient.
Reported-by: Jan Pazdziora <jpazdziora@redhat.com>
char message[1024];
int r;
+ /* Don't exit before the 'parent' */
+ waitpid(pid, NULL, 0);
+
close(pipefd[1]);
r = read(pipefd[0], message, sizeof (message));
if (r) {
if (pid < 0) {
LOG_FATAL("fork() failed : %s", strerror(errno));
} else if (pid > 0) {
- exit(0); /* In the 'parent' */
+ /* In the 'parent' */
+ close(pipefd[1]);
+ exit(0);
} else {
/* In the child we want to leave running as the daemon */