MFC r288335:
Store PID after becoming a daemon() and not before to ensure the correct PID gets written to the PID file. PR: 203252
This commit is contained in:
parent
6cdda4a656
commit
8096b85f20
@ -166,17 +166,15 @@ main(int argc, char **argv)
|
||||
|
||||
if (demon) {
|
||||
fp = open(pidfile, O_WRONLY|O_CREAT, S_IRUSR|S_IRGRP|S_IROTH);
|
||||
if (fp >= 0) {
|
||||
sz1 = snprintf(buf, sizeof buf, "%ld\n",
|
||||
(long)getpid());
|
||||
if (sz1 > sizeof buf)
|
||||
sz1 = sizeof buf;
|
||||
write(fp, buf, sz1);
|
||||
close(fp);
|
||||
} else
|
||||
if (fp < 0)
|
||||
err(1, "%s", pidfile);
|
||||
if (daemon(0, 0) < 0)
|
||||
err(1, "daemon()");
|
||||
snprintf(buf, sizeof(buf), "%ld\n", (long)getpid());
|
||||
sz1 = strlen(buf);
|
||||
if (write(fp, buf, sz1) < 0)
|
||||
err(1, "%s", pidfile);
|
||||
close(fp);
|
||||
isdemon = 1;
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user