ИМЯ vcs, vcsa - память виртуальной консоли
ОПИСАНИЕ /dev/vcs0 представляет собой символьное устройство со старшим номером 7 и младшим 0, обычно имеет права доступа 0644 и принадлежит root.tty. Устройство указывает на память отображаемого в данный момент виртуального консольного терминала.
/dev/vcs[1-63] представляют собой символьные устройства виртуальных консольных терминалов, имеют старший номер 7 и младшие от 1 до 63, обычно имеют права доступа 0644 и принадлежат root.tty. /dev/vcsa[0-63] представляют собой те же устройства, но имеют атрибуты в виде чисел типа unsigned short (с порядком байт узла) и приставкой из четырех байтов, задающих размеры экрана и положение курсора: lines, columns, x, y. (x = y = 0 означает верхний левый угол экрана.)
При загрузке шрифта с 512 символами значение 9-го бита можно получить через ioctl(2) с помощью операции VT_GETHIFONTMASK (доступна в ядрах Linux версии 2.6.18 и новее) над /dev/tty[1-63]; третий аргумент ioctl(2) содержит указатель на unsigned short, куда возвращается результат.
Эти устройства заменяют операции ioctl(2) по снятию снимка экрана ioctl_console(2), и позволяют системному администратору контролировать доступ с помощью файловой системы.
Устройства для первых восьми виртуальных консолей могут быть созданы с помощью следующих команд:
for x in 0 1 2 3 4 5 6 7 8; do mknod -m 644 /dev/vcs$x c 7 $x; mknod -m 644 /dev/vcsa$x c 7 $[$x+128]; done chown root:tty /dev/vcs*
Запросы ioctl(2) не поддерживаются.
ФАЙЛЫ /dev/vcs[0-63] /dev/vcsa[0-63]
ВЕРСИИ Впервые появились в версии ядра Linux 1.1.92.
ПРИМЕР Вы можете сделать снимок экрана vt3, переключившись на vt1 и написав
cat /dev/vcs3 >foo
Заметим, что вывод не будет содержать символов новой строки, поэтому может потребоваться дополнительная обработка, например
fold -w 81 /dev/vcs3 | lpr
или (жуть)
xetterm -dump 3 -file /proc/self/fd/1
Устройство /dev/vcsa0 используется для поддержки дисплея Брайля. #include <linux/vt.h>
int main(void) { int fd; char *device = "/dev/vcsa2"; char *console = "/dev/tty2"; struct {unsigned char lines, cols, x, y;} scrn; unsigned short s; unsigned short mask; unsigned char ch, attrib;
fd = open(console, O_RDWR); if (fd < 0) { perror(console); exit(EXIT_FAILURE); } if (ioctl(fd, VT_GETHIFONTMASK, &mask) < 0) { perror("VT_GETHIFONTMASK"); exit(EXIT_FAILURE); } (void) close(fd); fd = open(device, O_RDWR); if (fd < 0) { perror(device); exit(EXIT_FAILURE); } (void) read(fd, &scrn, 4); (void) lseek(fd, 4 + 2*(scrn.y*scrn.cols + scrn.x), 0); (void) read(fd, &s, 2); ch = s & 0xff; if (attrib & mask) ch |= 0x100; attrib = ((s & ~mask) >> 8); printf("ch='%c' attrib=0x%02x\n", ch, attrib); attrib ^= 0x10; (void) lseek(fd, -1, 1); (void) write(fd, &attrib, 1); exit(EXIT_SUCCESS); }
СМОТРИТЕ ТАКЖЕ ioctl_console(2), tty(4), ttyS(4), gpm(8)
|