diff options
author | Denys Vlasenko <vda.linux@googlemail.com> | 2017-04-07 19:13:09 +0200 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2017-04-07 19:13:09 +0200 |
commit | 42776708f21b8f7293627f88d8d5d3df00d8be1c (patch) | |
tree | e3d0af22b86aaeba888679501f1c83c346a79a99 | |
parent | 7121bb8023bf3e1760835bab5a16bd897ac3e878 (diff) |
init: dont send "Sent SIGTERM to all" msg to syslog: we just TERMed it!
While at it, explain FEATURE_INIT_SYSLOG
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r-- | init/init.c | 40 |
1 files changed, 22 insertions, 18 deletions
diff --git a/init/init.c b/init/init.c index 833759341..4d6355167 100644 --- a/init/init.c +++ b/init/init.c @@ -73,6 +73,10 @@ //config: bool "Enable init to write to syslog" //config: default y //config: depends on INIT || LINUXRC +//config: help +//config: If selected, some init messages are sent to syslog. +//config: Otherwise, they are sent to VT #5 if linux virtual tty is detected +//config: (if not, no separate logging is done). //config: //config:config FEATURE_INIT_QUIET //config: bool "Be quiet on boot (no 'init started:' message)" @@ -212,7 +216,9 @@ struct init_action { static struct init_action *init_action_list = NULL; +#if !ENABLE_FEATURE_INIT_SYSLOG static const char *log_console = VC_5; +#endif enum { L_LOG = 0x1, @@ -251,17 +257,16 @@ static void message(int where, const char *fmt, ...) msg[l++] = '\n'; msg[l] = '\0'; #else - { - static int log_fd = -1; - - msg[l++] = '\n'; - msg[l] = '\0'; + msg[l++] = '\n'; + msg[l] = '\0'; + if (where & L_LOG) { /* Take full control of the log tty, and never close it. * It's mine, all mine! Muhahahaha! */ + static int log_fd = -1; + if (log_fd < 0) { - if (!log_console) { - log_fd = STDERR_FILENO; - } else { + log_fd = STDERR_FILENO; + if (log_console) { log_fd = device_open(log_console, O_WRONLY | O_NONBLOCK | O_NOCTTY); if (log_fd < 0) { bb_error_msg("can't log to %s", log_console); @@ -271,11 +276,9 @@ static void message(int where, const char *fmt, ...) } } } - if (where & L_LOG) { - full_write(log_fd, msg, l); - if (log_fd == STDERR_FILENO) - return; /* don't print dup messages */ - } + full_write(log_fd, msg, l); + if (log_fd == STDERR_FILENO) + return; /* don't print dup messages */ } #endif @@ -325,8 +328,9 @@ static void console_init(void) * if TERM is set to linux (the default) */ if (!s || strcmp(s, "linux") == 0) putenv((char*)"TERM=vt102"); - if (!ENABLE_FEATURE_INIT_SYSLOG) - log_console = NULL; +# if !ENABLE_FEATURE_INIT_SYSLOG + log_console = NULL; +# endif } else #endif if (!s) @@ -541,8 +545,8 @@ static pid_t run(const struct init_action *a) } /* Log the process name and args */ - message(L_LOG, "starting pid %d, tty '%s': '%s'", - getpid(), a->terminal, a->command); + message(L_LOG, "starting pid %u, tty '%s': '%s'", + (int)getpid(), a->terminal, a->command); /* Now run it. The new program will take over this PID, * so nothing further in init.c should be run. */ @@ -757,7 +761,7 @@ static void run_shutdown_and_kill_processes(void) /* Send signals to every process _except_ pid 1 */ kill(-1, SIGTERM); - message(L_CONSOLE | L_LOG, "Sent SIG%s to all processes", "TERM"); + message(L_CONSOLE, "Sent SIG%s to all processes", "TERM"); sync(); sleep(1); |