diff options
author | Peter Korsgaard | 2011-11-09 19:44:37 +0100 |
---|---|---|
committer | Denys Vlasenko | 2011-11-09 19:44:37 +0100 |
commit | 743edac6c84ac207d0bb4c3124b0e8fe450a38b4 (patch) | |
tree | d74290b238665a3369e191dd85e7a4b38f74aadb /debianutils/start_stop_daemon.c | |
parent | 7e21f0491cf3e72835cd9b515734caec56d41e70 (diff) | |
download | busybox-743edac6c84ac207d0bb4c3124b0e8fe450a38b4.zip busybox-743edac6c84ac207d0bb4c3124b0e8fe450a38b4.tar.gz |
bb_daemonize_or_rexec(): add flag to double-fork; use it in start-stop-daemon
Add a DAEMON_DOUBLE_FORK flag to make bb_daemonize double-fork so it isn't a
session leader, and hence doesn't get a controlling tty on Linux if a tty is
ever opened, similar to how libdaemon's daemon_fork or the big
start-stop-daemon does it - And use it in start-stop-daemon.
For details, see http://www.win.tue.nl/~aeb/linux/lk/lk-10.html#ss10.3
Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk>
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'debianutils/start_stop_daemon.c')
-rw-r--r-- | debianutils/start_stop_daemon.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/debianutils/start_stop_daemon.c b/debianutils/start_stop_daemon.c index 02609c0..495ed0a 100644 --- a/debianutils/start_stop_daemon.c +++ b/debianutils/start_stop_daemon.c @@ -474,7 +474,7 @@ int start_stop_daemon_main(int argc UNUSED_PARAM, char **argv) *--argv = startas; if (opt & OPT_BACKGROUND) { #if BB_MMU - bb_daemonize(DAEMON_DEVNULL_STDIO + DAEMON_CLOSE_EXTRA_FDS); + bb_daemonize(DAEMON_DEVNULL_STDIO + DAEMON_CLOSE_EXTRA_FDS + DAEMON_DOUBLE_FORK); /* DAEMON_DEVNULL_STDIO is superfluous - * it's always done by bb_daemonize() */ #else |