2006-07-03 01:17:05 +05:30
|
|
|
/* vi: set sw=4 ts=4: */
|
2006-03-28 04:53:43 +05:30
|
|
|
/*
|
2006-09-17 21:58:10 +05:30
|
|
|
* setlogcons: Send kernel messages to the current console or to console N
|
2006-03-28 04:53:43 +05:30
|
|
|
*
|
|
|
|
* Copyright (C) 2006 by Jan Kiszka <jan.kiszka@web.de>
|
|
|
|
*
|
|
|
|
* Based on setlogcons (kbd-1.12) by Andries E. Brouwer
|
|
|
|
*
|
2010-08-16 23:44:46 +05:30
|
|
|
* Licensed under GPLv2 or later, see file LICENSE in this source tree.
|
2006-03-28 04:53:43 +05:30
|
|
|
*/
|
2016-11-23 15:09:27 +05:30
|
|
|
//config:config SETLOGCONS
|
2017-07-19 01:31:24 +05:30
|
|
|
//config: bool "setlogcons (1.8 kb)"
|
2016-11-23 15:09:27 +05:30
|
|
|
//config: default y
|
|
|
|
//config: select PLATFORM_LINUX
|
|
|
|
//config: help
|
2017-07-21 13:20:55 +05:30
|
|
|
//config: This program redirects the output console of kernel messages.
|
2016-11-23 15:09:27 +05:30
|
|
|
|
2017-08-06 21:47:58 +05:30
|
|
|
//applet:IF_SETLOGCONS(APPLET_NOEXEC(setlogcons, setlogcons, BB_DIR_USR_SBIN, BB_SUID_DROP, setlogcons))
|
2016-11-23 15:09:27 +05:30
|
|
|
|
|
|
|
//kbuild:lib-$(CONFIG_SETLOGCONS) += setlogcons.o
|
2006-03-28 04:53:43 +05:30
|
|
|
|
2011-03-28 03:12:28 +05:30
|
|
|
//usage:#define setlogcons_trivial_usage
|
2014-07-04 17:28:57 +05:30
|
|
|
//usage: "[N]"
|
2011-03-28 03:12:28 +05:30
|
|
|
//usage:#define setlogcons_full_usage "\n\n"
|
2017-08-06 21:47:58 +05:30
|
|
|
//usage: "Pin kernel output to VT console N. Default:0 (do not pin)"
|
|
|
|
|
|
|
|
// Comment from kernel source:
|
|
|
|
/* ...
|
|
|
|
* By default, the kernel messages are always printed on the current virtual
|
|
|
|
* console. However, the user may modify that default with the
|
|
|
|
* TIOCL_SETKMSGREDIRECT ioctl call.
|
|
|
|
*
|
|
|
|
* This function sets the kernel message console to be @new. It returns the old
|
|
|
|
* virtual console number. The virtual terminal number 0 (both as parameter and
|
|
|
|
* return value) means no redirection (i.e. always printed on the currently
|
|
|
|
* active console).
|
|
|
|
*/
|
2011-03-28 03:12:28 +05:30
|
|
|
|
2007-05-27 00:30:18 +05:30
|
|
|
#include "libbb.h"
|
2006-03-28 04:53:43 +05:30
|
|
|
|
2007-10-11 15:35:36 +05:30
|
|
|
int setlogcons_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
|
2008-07-05 14:48:54 +05:30
|
|
|
int setlogcons_main(int argc UNUSED_PARAM, char **argv)
|
2006-03-28 04:53:43 +05:30
|
|
|
{
|
2018-04-17 01:18:32 +05:30
|
|
|
char *devname;
|
2006-03-28 04:53:43 +05:30
|
|
|
struct {
|
|
|
|
char fn;
|
|
|
|
char subarg;
|
2013-01-14 06:04:48 +05:30
|
|
|
} arg = {
|
2017-08-06 21:47:58 +05:30
|
|
|
11, /* redirect kernel messages (TIOCL_SETKMSGREDIRECT) */
|
|
|
|
0
|
2013-01-14 06:04:48 +05:30
|
|
|
};
|
2006-03-28 04:53:43 +05:30
|
|
|
|
2008-03-17 14:39:09 +05:30
|
|
|
if (argv[1])
|
|
|
|
arg.subarg = xatou_range(argv[1], 0, 63);
|
2006-03-28 04:53:43 +05:30
|
|
|
|
2018-04-17 01:18:32 +05:30
|
|
|
/* Can just call it on "/dev/tty1" always, but...
|
|
|
|
* in my testing, inactive (never opened) VTs are not
|
|
|
|
* redirected to, despite ioctl not failing.
|
|
|
|
*
|
|
|
|
* By using "/dev/ttyN", ensure it is activated.
|
|
|
|
*/
|
|
|
|
devname = xasprintf("/dev/tty%u", arg.subarg);
|
|
|
|
xioctl(xopen(devname, O_RDONLY), TIOCLINUX, &arg);
|
2006-03-28 04:53:43 +05:30
|
|
|
|
2008-05-19 13:48:50 +05:30
|
|
|
return EXIT_SUCCESS;
|
2006-03-28 04:53:43 +05:30
|
|
|
}
|