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:
hselasky 2015-10-13 08:21:15 +00:00
parent 6cdda4a656
commit 8096b85f20

View File

@ -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;
}