2000-02-09 01:28:47 +05:30
|
|
|
/* vi: set sw=4 ts=4: */
|
1999-10-21 03:38:37 +05:30
|
|
|
/*
|
|
|
|
* Mini loadkmap implementation for busybox
|
|
|
|
*
|
|
|
|
* Copyright (C) 1998 Enrique Zanardi <ezanardi@ull.es>
|
|
|
|
*
|
2006-07-12 13:26:04 +05:30
|
|
|
* Licensed under GPLv2 or later, see file LICENSE in this tarball for details.
|
1999-10-21 03:38:37 +05:30
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
1999-10-05 21:54:54 +05:30
|
|
|
#include <errno.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include <stdio.h>
|
2001-01-27 13:54:39 +05:30
|
|
|
#include <string.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <unistd.h>
|
1999-10-05 21:54:54 +05:30
|
|
|
#include <sys/ioctl.h>
|
2001-02-20 11:44:08 +05:30
|
|
|
#include "busybox.h"
|
1999-10-05 21:54:54 +05:30
|
|
|
|
2000-10-25 22:18:15 +05:30
|
|
|
#define BINARY_KEYMAP_MAGIC "bkeymap"
|
|
|
|
|
2000-07-09 00:25:24 +05:30
|
|
|
/* From <linux/kd.h> */
|
|
|
|
struct kbentry {
|
|
|
|
unsigned char kb_table;
|
|
|
|
unsigned char kb_index;
|
|
|
|
unsigned short kb_value;
|
|
|
|
};
|
2003-11-21 14:57:02 +05:30
|
|
|
/* sets one entry in translation table */
|
|
|
|
#define KDSKBENT 0x4B47
|
2000-07-09 00:25:24 +05:30
|
|
|
|
|
|
|
/* From <linux/keyboard.h> */
|
2003-11-21 14:57:02 +05:30
|
|
|
#define NR_KEYS 128
|
|
|
|
#define MAX_NR_KEYMAPS 256
|
2000-07-09 00:25:24 +05:30
|
|
|
|
2000-02-09 01:28:47 +05:30
|
|
|
int loadkmap_main(int argc, char **argv)
|
|
|
|
{
|
|
|
|
struct kbentry ke;
|
2003-11-21 14:57:02 +05:30
|
|
|
int i, j, fd;
|
|
|
|
u_short ibuff[NR_KEYS];
|
|
|
|
char flags[MAX_NR_KEYMAPS];
|
|
|
|
char buff[7];
|
1999-10-05 21:54:54 +05:30
|
|
|
|
2000-10-25 22:18:15 +05:30
|
|
|
if (argc != 1)
|
2003-03-19 14:43:01 +05:30
|
|
|
bb_show_usage();
|
2000-04-19 09:29:10 +05:30
|
|
|
|
2003-11-21 14:57:02 +05:30
|
|
|
fd = bb_xopen(CURRENT_VC, O_RDWR);
|
2000-02-09 01:28:47 +05:30
|
|
|
|
2003-11-21 14:57:02 +05:30
|
|
|
if ((bb_full_read(0, buff, 7) != 7) || (strncmp(buff, BINARY_KEYMAP_MAGIC, 7) != 0))
|
2003-03-19 14:43:01 +05:30
|
|
|
bb_error_msg_and_die("This is not a valid binary keymap.");
|
1999-10-05 21:54:54 +05:30
|
|
|
|
2003-11-21 14:57:02 +05:30
|
|
|
if (bb_full_read(0, flags, MAX_NR_KEYMAPS) != MAX_NR_KEYMAPS)
|
2003-03-19 14:43:01 +05:30
|
|
|
bb_perror_msg_and_die("Error reading keymap flags");
|
2000-02-09 01:28:47 +05:30
|
|
|
|
|
|
|
for (i = 0; i < MAX_NR_KEYMAPS; i++) {
|
|
|
|
if (flags[i] == 1) {
|
2003-11-21 14:57:02 +05:30
|
|
|
bb_full_read(0, ibuff, NR_KEYS * sizeof(u_short));
|
2000-02-09 01:28:47 +05:30
|
|
|
for (j = 0; j < NR_KEYS; j++) {
|
|
|
|
ke.kb_index = j;
|
|
|
|
ke.kb_table = i;
|
|
|
|
ke.kb_value = ibuff[j];
|
|
|
|
ioctl(fd, KDSKBENT, &ke);
|
|
|
|
}
|
|
|
|
}
|
1999-10-05 21:54:54 +05:30
|
|
|
}
|
2003-11-21 14:57:02 +05:30
|
|
|
|
2004-03-15 13:59:22 +05:30
|
|
|
/* Don't bother to close files. Exit does that
|
2000-03-23 06:39:18 +05:30
|
|
|
* automagically, so we can save a few bytes */
|
|
|
|
/* close(fd); */
|
2000-10-25 22:18:15 +05:30
|
|
|
return EXIT_SUCCESS;
|
1999-10-05 21:54:54 +05:30
|
|
|
}
|