From f793748f4357f70668d8e8c2b90a88d2ff253566 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Mon, 11 Sep 2006 04:47:56 +0000 Subject: r18360: better handling of child process killing in standard mode (This used to be commit 6a2144caab60073b40577dc1f66f663f817d6cbd) --- source4/smbd/server.c | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/source4/smbd/server.c b/source4/smbd/server.c index cb9ae51f08..cf0efc6522 100644 --- a/source4/smbd/server.c +++ b/source4/smbd/server.c @@ -103,6 +103,19 @@ static void sig_hup(int sig) debug_schedule_reopen_logs(); } +static void sig_term(int sig) +{ +#if HAVE_GETPGRP + static int done_sigterm; + if (done_sigterm == 0 && getpgrp() == getpid()) { + DEBUG(0,("SIGTERM: killing children\n")); + done_sigterm = 1; + kill(-getpgrp(), SIGTERM); + } +#endif + exit(0); +} + /* setup signal masks */ @@ -130,6 +143,7 @@ static void setup_signals(void) BlockSignals(False, SIGTERM); CatchSignal(SIGHUP, sig_hup); + CatchSignal(SIGTERM, sig_term); } /* @@ -142,6 +156,11 @@ static void server_stdin_handler(struct event_context *event_ctx, struct fd_even uint8_t c; if (read(0, &c, 1) == 0) { DEBUG(0,("%s: EOF on stdin - terminating\n", binary_name)); +#if HAVE_GETPGRP + if (getpgrp() == getpid()) { + kill(-getpgrp(), SIGTERM); + } +#endif exit(0); } } -- cgit