Added 'dumpkmap' to allow people to dump a binary keymap, which can then be
loaded in by 'loadkmap' -- submitted by Arne Bernin <arne@matrix.loopback.org>
-Erik
diff --git a/dumpkmap.c b/dumpkmap.c
new file mode 100644
index 0000000..a497a07
--- /dev/null
+++ b/dumpkmap.c
@@ -0,0 +1,100 @@
+/* vi: set sw=4 ts=4: */
+/*
+ * Mini dumpkmap implementation for busybox
+ *
+ * Copyright (C) Arne Bernin <arne@matrix.loopback.org>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ *
+ */
+
+#include "internal.h"
+#include <errno.h>
+#include <fcntl.h>
+#include <stdio.h>
+#include <sys/ioctl.h>
+
+/* From <linux/kd.h> */
+struct kbentry {
+ unsigned char kb_table;
+ unsigned char kb_index;
+ unsigned short kb_value;
+};
+#define KDGKBENT 0x4B46 /* gets one entry in translation table */
+
+/* From <linux/keyboard.h> */
+#define NR_KEYS 128
+#define MAX_NR_KEYMAPS 256
+
+
+static const char dumpkmap_usage[] = "dumpkmap\n"
+#ifndef BB_FEATURE_TRIVIAL_HELP
+ "\nPrints out a binary keyboard translation table to standard input.\n"
+#endif
+ ;
+
+
+int dumpkmap_main(int argc, char **argv)
+{
+ struct kbentry ke;
+ int i, j, fd;
+ char flags[MAX_NR_KEYMAPS], magic[] = "bkeymap";
+
+ if (argc>=2 && *argv[1]=='-') {
+ usage(dumpkmap_usage);
+ }
+
+ fd = open("/dev/tty0", O_RDWR);
+ if (fd < 0) {
+ fprintf(stderr, "Error opening /dev/tty0: %s\n", strerror(errno));
+ return 1;
+ }
+
+ write(1, magic, 7);
+
+ for (i=0; i < MAX_NR_KEYMAPS; i++) flags[i]=0;
+ flags[0]=1;
+ flags[1]=1;
+ flags[2]=1;
+ flags[4]=1;
+ flags[5]=1;
+ flags[6]=1;
+ flags[8]=1;
+ flags[9]=1;
+ flags[10]=1;
+ flags[12]=1;
+
+ /* dump flags */
+ for (i=0; i < MAX_NR_KEYMAPS; i++) write(1,&flags[i],1);
+
+ for (i = 0; i < MAX_NR_KEYMAPS; i++) {
+ if (flags[i] == 1) {
+ for (j = 0; j < NR_KEYS; j++) {
+ ke.kb_index = j;
+ ke.kb_table = i;
+ if (ioctl(fd, KDGKBENT, &ke) < 0) {
+
+ fprintf(stderr, "ioctl returned: %s, %s, %s, %xqq\n",strerror(errno),(char *)&ke.kb_index,(char *)&ke.kb_table,(int)&ke.kb_value);
+ }
+ else {
+ write(1,&ke.kb_value,2);
+ }
+
+ }
+ }
+ }
+ close(fd);
+ return 0;
+}