mirror of
https://git.kernel.org/pub/scm/network/iproute2/iproute2.git
synced 2025-01-23 17:03:50 +08:00
arpd/ifstat/nstat/rtacct: use daemon()
A bunch of misc utils basically reimplement the daemon() function (the whole fork/close/chdir/etc...). Rather than do that, use daemon() as that will work under nommu Linux systems that lack fork(). Signed-off-by: Mike Frysinger <vapier@gentoo.org>
This commit is contained in:
parent
7f03191fda
commit
a7a9ddbb67
24
misc/arpd.c
24
misc/arpd.c
@ -775,27 +775,9 @@ int main(int argc, char **argv)
|
||||
|
||||
load_initial_table();
|
||||
|
||||
if (1) {
|
||||
int fd;
|
||||
pid_t pid = fork();
|
||||
|
||||
if (pid > 0)
|
||||
_exit(0);
|
||||
if (pid < 0) {
|
||||
perror("arpd: fork");
|
||||
goto do_abort;
|
||||
}
|
||||
|
||||
chdir("/");
|
||||
fd = open("/dev/null", O_RDWR);
|
||||
if (fd >= 0) {
|
||||
dup2(fd, 0);
|
||||
dup2(fd, 1);
|
||||
dup2(fd, 2);
|
||||
if (fd > 2)
|
||||
close(fd);
|
||||
}
|
||||
setsid();
|
||||
if (daemon(0, 0)) {
|
||||
perror("arpd: daemon");
|
||||
goto do_abort;
|
||||
}
|
||||
|
||||
openlog("arpd", LOG_PID | LOG_CONS, LOG_DAEMON);
|
||||
|
@ -663,10 +663,10 @@ int main(int argc, char *argv[])
|
||||
perror("ifstat: listen");
|
||||
exit(-1);
|
||||
}
|
||||
if (fork())
|
||||
exit(0);
|
||||
chdir("/");
|
||||
close(0); close(1); close(2); setsid();
|
||||
if (daemon(0, 0)) {
|
||||
perror("ifstat: daemon");
|
||||
exit(-1);
|
||||
}
|
||||
signal(SIGPIPE, SIG_IGN);
|
||||
signal(SIGCHLD, sigchild);
|
||||
server_loop(fd);
|
||||
|
@ -513,10 +513,10 @@ int main(int argc, char *argv[])
|
||||
perror("nstat: listen");
|
||||
exit(-1);
|
||||
}
|
||||
if (fork())
|
||||
exit(0);
|
||||
chdir("/");
|
||||
close(0); close(1); close(2); setsid();
|
||||
if (daemon(0, 0)) {
|
||||
perror("nstat: daemon");
|
||||
exit(-1);
|
||||
}
|
||||
signal(SIGPIPE, SIG_IGN);
|
||||
signal(SIGCHLD, sigchild);
|
||||
server_loop(fd);
|
||||
|
@ -524,10 +524,10 @@ int main(int argc, char *argv[])
|
||||
perror("rtacct: listen");
|
||||
exit(-1);
|
||||
}
|
||||
if (fork())
|
||||
exit(0);
|
||||
chdir("/");
|
||||
close(0); close(1); close(2); setsid();
|
||||
if (daemon(0, 0)) {
|
||||
perror("rtacct: daemon");
|
||||
exit(-1);
|
||||
}
|
||||
signal(SIGPIPE, SIG_IGN);
|
||||
signal(SIGCHLD, sigchild);
|
||||
server_loop(fd);
|
||||
|
Loading…
Reference in New Issue
Block a user