diff options
| author | Denys Vlasenko <vda.linux@googlemail.com> | 2010-05-16 02:12:56 +0200 |
|---|---|---|
| committer | Denys Vlasenko <vda.linux@googlemail.com> | 2010-05-16 02:12:56 +0200 |
| commit | a29b055bf1c21fb65bfeb5fdd982dfcd15f2b360 (patch) | |
| tree | ed3f485dcd12a8d4c19832a439a0d96940b381d0 | |
| parent | 084e2284c700561732cc708ee557169be9d18308 (diff) | |
| download | busybox-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.c | 21 |
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]); |
