aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDenys Vlasenko <vda.linux@googlemail.com>2010-05-16 02:12:56 +0200
committerDenys Vlasenko <vda.linux@googlemail.com>2010-05-16 02:12:56 +0200
commita29b055bf1c21fb65bfeb5fdd982dfcd15f2b360 (patch)
treeed3f485dcd12a8d4c19832a439a0d96940b381d0
parent084e2284c700561732cc708ee557169be9d18308 (diff)
downloadbusybox-w32-a29b055bf1c21fb65bfeb5fdd982dfcd15f2b360.tar.gz
busybox-w32-a29b055bf1c21fb65bfeb5fdd982dfcd15f2b360.tar.bz2
busybox-w32-a29b055bf1c21fb65bfeb5fdd982dfcd15f2b360.zip
setsid: check for setsid error directly
function old new delta setsid_main 74 66 -8 Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r--miscutils/setsid.c21
1 files changed, 17 insertions, 4 deletions
diff --git a/miscutils/setsid.c b/miscutils/setsid.c
index d7de1f149..fd3283e30 100644
--- a/miscutils/setsid.c
+++ b/miscutils/setsid.c
@@ -25,11 +25,24 @@ int setsid_main(int argc UNUSED_PARAM, char **argv)
25 /* setsid() is allowed only when we are not a process group leader. 25 /* setsid() is allowed only when we are not a process group leader.
26 * Otherwise our PID serves as PGID of some existing process group 26 * Otherwise our PID serves as PGID of some existing process group
27 * and cannot be used as PGID of a new process group. */ 27 * and cannot be used as PGID of a new process group. */
28 if (getpgrp() == getpid()) 28 if (setsid() < 0) {
29 if (fork_or_rexec(argv)) 29 pid_t pid = fork_or_rexec(argv);
30 exit(EXIT_SUCCESS); /* parent */ 30 if (pid != 0) {
31 /* parent */
32 /* TODO:
33 * we can waitpid(pid, &status, 0) and then even
34 * emulate exitcode, making the behavior consistent
35 * in both forked and non forked cases.
36 * However, the code is larger and upstream
37 * does not do such trick.
38 */
39 exit(EXIT_SUCCESS);
40 }
31 41
32 setsid(); /* no error possible */ 42 /* child */
43 /* now there should be no error: */
44 setsid();
45 }
33 46
34 BB_EXECVP(argv[1], argv + 1); 47 BB_EXECVP(argv[1], argv + 1);
35 bb_simple_perror_msg_and_die(argv[1]); 48 bb_simple_perror_msg_and_die(argv[1]);