The daemon's child shouldn't go on with the for loop
over ctl_sock's -- it is solely the parent daemon's job. So just break out of the loop in the child. MFC after: 5 days
This commit is contained in:
parent
125b96351a
commit
8eb0508fe1
@ -496,16 +496,17 @@ main(int argc, char *argv[], char **envp)
|
||||
(struct sockaddr *)&his_addr,
|
||||
&addrlen);
|
||||
if (fd >= 0) {
|
||||
if ((pid = fork()) == 0) {
|
||||
/* child */
|
||||
(void) dup2(fd, 0);
|
||||
(void) dup2(fd, 1);
|
||||
close(ctl_sock[i]);
|
||||
} else
|
||||
if ((pid = fork()) == 0)
|
||||
break;
|
||||
else
|
||||
close(fd);
|
||||
}
|
||||
}
|
||||
if (pid == 0) {
|
||||
/* child */
|
||||
(void) dup2(fd, 0);
|
||||
(void) dup2(fd, 1);
|
||||
close(ctl_sock[i]);
|
||||
if (pfh != NULL)
|
||||
pidfile_close(pfh);
|
||||
break;
|
||||
|
Loading…
Reference in New Issue
Block a user