2001-03-17 04:17:14 +05:30
|
|
|
/* vi: set sw=4 ts=4: */
|
|
|
|
/*
|
|
|
|
* Utility routines.
|
|
|
|
*
|
2003-09-01 14:23:32 +05:30
|
|
|
* Copyright (C) many different people. If you wrote this, please
|
|
|
|
* acknowledge your work.
|
2001-03-17 04:17:14 +05:30
|
|
|
*
|
2006-05-20 00:59:19 +05:30
|
|
|
* Licensed under GPLv2 or later, see file LICENSE in this tarball for details.
|
2001-03-17 04:17:14 +05:30
|
|
|
*/
|
|
|
|
|
|
|
|
#include "libbb.h"
|
|
|
|
|
2004-03-15 13:59:22 +05:30
|
|
|
/* From <linux/kd.h> */
|
2006-03-11 00:52:06 +05:30
|
|
|
enum { KDGKBTYPE = 0x4B33 }; /* get keyboard type */
|
2001-03-17 04:17:14 +05:30
|
|
|
|
2003-09-01 14:23:32 +05:30
|
|
|
static int open_a_console(const char *fnam)
|
2001-03-17 04:17:14 +05:30
|
|
|
{
|
|
|
|
int fd;
|
|
|
|
|
2003-09-01 14:23:32 +05:30
|
|
|
/* try read-write */
|
2001-03-17 04:17:14 +05:30
|
|
|
fd = open(fnam, O_RDWR);
|
|
|
|
|
|
|
|
/* if failed, try read-only */
|
|
|
|
if (fd < 0 && errno == EACCES)
|
|
|
|
fd = open(fnam, O_RDONLY);
|
|
|
|
|
|
|
|
/* if failed, try write-only */
|
|
|
|
if (fd < 0 && errno == EACCES)
|
|
|
|
fd = open(fnam, O_WRONLY);
|
|
|
|
|
|
|
|
return fd;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Get an fd for use with kbd/console ioctls.
|
|
|
|
* We try several things because opening /dev/console will fail
|
|
|
|
* if someone else used X (which does a chown on /dev/console).
|
|
|
|
*/
|
2008-08-06 05:02:27 +05:30
|
|
|
int FAST_FUNC get_console_fd_or_die(void)
|
2001-03-17 04:17:14 +05:30
|
|
|
{
|
2007-02-17 21:22:02 +05:30
|
|
|
static const char *const console_names[] = {
|
|
|
|
DEV_CONSOLE, CURRENT_VC, CURRENT_TTY
|
2003-09-01 14:23:32 +05:30
|
|
|
};
|
|
|
|
|
2007-02-17 21:22:02 +05:30
|
|
|
int fd;
|
|
|
|
|
2003-09-01 14:23:32 +05:30
|
|
|
for (fd = 2; fd >= 0; fd--) {
|
|
|
|
int fd4name;
|
2007-04-12 06:02:05 +05:30
|
|
|
int choice_fd;
|
2003-09-01 14:23:32 +05:30
|
|
|
char arg;
|
|
|
|
|
2007-02-17 21:22:02 +05:30
|
|
|
fd4name = open_a_console(console_names[fd]);
|
2007-02-03 22:58:39 +05:30
|
|
|
chk_std:
|
2007-04-12 06:02:05 +05:30
|
|
|
choice_fd = (fd4name >= 0 ? fd4name : fd);
|
2003-09-01 14:23:32 +05:30
|
|
|
|
|
|
|
arg = 0;
|
2007-04-12 06:02:05 +05:30
|
|
|
if (ioctl(choice_fd, KDGKBTYPE, &arg) == 0)
|
|
|
|
return choice_fd;
|
|
|
|
if (fd4name >= 0) {
|
2003-09-01 14:23:32 +05:30
|
|
|
close(fd4name);
|
|
|
|
fd4name = -1;
|
|
|
|
goto chk_std;
|
|
|
|
}
|
|
|
|
}
|
2001-03-17 04:17:14 +05:30
|
|
|
|
2008-08-06 05:02:27 +05:30
|
|
|
bb_error_msg_and_die("can't open console");
|
|
|
|
/*return fd; - total failure */
|
2001-03-17 04:17:14 +05:30
|
|
|
}
|
2008-05-19 13:48:50 +05:30
|
|
|
|
|
|
|
/* From <linux/vt.h> */
|
|
|
|
enum {
|
|
|
|
VT_ACTIVATE = 0x5606, /* make vt active */
|
|
|
|
VT_WAITACTIVE = 0x5607 /* wait for vt active */
|
|
|
|
};
|
|
|
|
|
2008-06-27 08:22:20 +05:30
|
|
|
void FAST_FUNC console_make_active(int fd, const int vt_num)
|
2008-05-19 13:48:50 +05:30
|
|
|
{
|
|
|
|
xioctl(fd, VT_ACTIVATE, (void *)(ptrdiff_t)vt_num);
|
|
|
|
xioctl(fd, VT_WAITACTIVE, (void *)(ptrdiff_t)vt_num);
|
|
|
|
}
|