Module Name: src
Committed By: tsutsui
Date: Sun Jul 20 11:14:57 UTC 2014
Modified Files:
src/sys/arch/luna68k/conf: files.luna68k
src/sys/arch/luna68k/dev: lunaws.c
Added Files:
src/sys/arch/luna68k/dev: omkbdmap.c omkbdmap.h
Log Message:
Pull LUNA's keyboard driver changes from OpenBSD/luna88k.
- split keyboard mapping definitions to new files, omkbdmap.[ch]
- add WSDISPLAY_COMPAT_RAWKBD support
(actually the name is wrong; it doesn't emit raw keycode but
converts MD code into PS/2 one as "raw keycode on x86" for Xorg server)
- allow to enter into ddb by CTRL+ALT(zenmen)+ESC
- remove unnecessary return values
Now LUNA's keyboard works on Xorg server without tweaks by xmodmap(1) etc.
To generate a diff of this commit:
cvs rdiff -u -r1.23 -r1.24 src/sys/arch/luna68k/conf/files.luna68k
cvs rdiff -u -r1.29 -r1.30 src/sys/arch/luna68k/dev/lunaws.c
cvs rdiff -u -r0 -r1.1 src/sys/arch/luna68k/dev/omkbdmap.c \
src/sys/arch/luna68k/dev/omkbdmap.h
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/arch/luna68k/conf/files.luna68k
diff -u src/sys/arch/luna68k/conf/files.luna68k:1.23 src/sys/arch/luna68k/conf/files.luna68k:1.24
--- src/sys/arch/luna68k/conf/files.luna68k:1.23 Tue Nov 15 13:25:44 2011
+++ src/sys/arch/luna68k/conf/files.luna68k Sun Jul 20 11:14:56 2014
@@ -1,5 +1,5 @@
#
-# $NetBSD: files.luna68k,v 1.23 2011/11/15 13:25:44 tsutsui Exp $
+# $NetBSD: files.luna68k,v 1.24 2014/07/20 11:14:56 tsutsui Exp $
#
maxpartitions 8
maxusers 2 8 64
@@ -42,9 +42,11 @@ file arch/luna68k/dev/sio.c sio
device siotty: tty
attach siotty at sio
file arch/luna68k/dev/siotty.c siotty needs-flag
+
device ws: wskbddev,wsmousedev
attach ws at sio
file arch/luna68k/dev/lunaws.c ws
+file arch/luna68k/dev/omkbdmap.c ws
device fb: wsemuldisplaydev
attach fb at mainbus
Index: src/sys/arch/luna68k/dev/lunaws.c
diff -u src/sys/arch/luna68k/dev/lunaws.c:1.29 src/sys/arch/luna68k/dev/lunaws.c:1.30
--- src/sys/arch/luna68k/dev/lunaws.c:1.29 Fri Jul 18 18:02:08 2014
+++ src/sys/arch/luna68k/dev/lunaws.c Sun Jul 20 11:14:56 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: lunaws.c,v 1.29 2014/07/18 18:02:08 tsutsui Exp $ */
+/* $NetBSD: lunaws.c,v 1.30 2014/07/20 11:14:56 tsutsui Exp $ */
/*-
* Copyright (c) 2000 The NetBSD Foundation, Inc.
@@ -31,8 +31,9 @@
#include <sys/cdefs.h> /* RCS ID & Copyright macro defns */
-__KERNEL_RCSID(0, "$NetBSD: lunaws.c,v 1.29 2014/07/18 18:02:08 tsutsui Exp $");
+__KERNEL_RCSID(0, "$NetBSD: lunaws.c,v 1.30 2014/07/20 11:14:56 tsutsui Exp $");
+#include "opt_wsdisplay_compat.h"
#include "wsmouse.h"
#include <sys/param.h>
@@ -46,6 +47,7 @@ __KERNEL_RCSID(0, "$NetBSD: lunaws.c,v 1
#include <dev/wscons/wsksymvar.h>
#include <dev/wscons/wsmousevar.h>
+#include <luna68k/dev/omkbdmap.h>
#include <luna68k/dev/sioreg.h>
#include <luna68k/dev/siovar.h>
@@ -78,16 +80,15 @@ struct ws_softc {
int sc_msbuttons, sc_msdx, sc_msdy;
#endif
void *sc_si;
+ int sc_rawkbd;
};
static void omkbd_input(void *, int);
-static int omkbd_decode(void *, int, u_int *, int *);
+static void omkbd_decode(void *, int, u_int *, int *);
static int omkbd_enable(void *, int);
static void omkbd_set_leds(void *, int);
static int omkbd_ioctl(void *, u_long, void *, int, struct lwp *);
-struct wscons_keydesc omkbd_keydesctab[];
-
static const struct wskbd_mapdata omkbd_keymapdata = {
omkbd_keydesctab,
KB_JP,
@@ -270,143 +271,48 @@ omkbd_input(void *v, int data)
u_int type;
int key;
- if (omkbd_decode(v, data, &type, &key))
- wskbd_input(sc->sc_wskbddev, type, key);
+ omkbd_decode(v, data, &type, &key);
+
+#ifdef WSDISPLAY_COMPAT_RAWKBD
+ if (sc->sc_rawkbd) {
+ uint8_t cbuf[2];
+ int c, j = 0;
+
+ c = omkbd_raw[key];
+ if (c != 0x00) {
+ /* fake extended scancode if necessary */
+ if (c & 0x80)
+ cbuf[j++] = 0xe0;
+ cbuf[j] = c & 0x7f;
+ if (type == WSCONS_EVENT_KEY_UP)
+ cbuf[j] |= 0x80;
+ j++;
+
+ wskbd_rawinput(sc->sc_wskbddev, cbuf, j);
+ }
+ } else
+#endif
+ {
+ if (sc->sc_wskbddev != NULL)
+ wskbd_input(sc->sc_wskbddev, type, key);
+ }
}
-static int
+static void
omkbd_decode(void *v, int datain, u_int *type, int *dataout)
{
*type = (datain & 0x80) ? WSCONS_EVENT_KEY_UP : WSCONS_EVENT_KEY_DOWN;
*dataout = datain & 0x7f;
- return 1;
}
-#define KC(n) KS_KEYCODE(n)
-
-static const keysym_t omkbd_keydesc_1[] = {
-/* pos command normal shifted */
- KC(0x9), KS_Tab,
- KC(0xa), KS_Control_L,
- KC(0xb), KS_Mode_switch, /* Kana */
- KC(0xc), KS_Shift_R,
- KC(0xd), KS_Shift_L,
- KC(0xe), KS_Caps_Lock,
- KC(0xf), KS_Meta_L, /* Zenmen */
- KC(0x10), KS_Escape,
- KC(0x11), KS_BackSpace,
- KC(0x12), KS_Return,
- KC(0x14), KS_space,
- KC(0x15), KS_Delete,
- KC(0x16), KS_Alt_L, /* Henkan */
- KC(0x17), KS_Alt_R, /* Kakutei */
- KC(0x18), KS_f11, /* Shokyo */
- KC(0x19), KS_f12, /* Yobidashi */
- KC(0x1a), KS_f13, /* Bunsetsu L */
- KC(0x1b), KS_f14, /* Bunsetsu R */
- KC(0x1c), KS_KP_Up,
- KC(0x1d), KS_KP_Left,
- KC(0x1e), KS_KP_Right,
- KC(0x1f), KS_KP_Down,
- /* KC(0x20), KS_f11, */
- /* KC(0x21), KS_f12, */
- KC(0x22), KS_1, KS_exclam,
- KC(0x23), KS_2, KS_quotedbl,
- KC(0x24), KS_3, KS_numbersign,
- KC(0x25), KS_4, KS_dollar,
- KC(0x26), KS_5, KS_percent,
- KC(0x27), KS_6, KS_ampersand,
- KC(0x28), KS_7, KS_apostrophe,
- KC(0x29), KS_8, KS_parenleft,
- KC(0x2a), KS_9, KS_parenright,
- KC(0x2b), KS_0,
- KC(0x2c), KS_minus, KS_equal,
- KC(0x2d), KS_asciicircum, KS_asciitilde,
- KC(0x2e), KS_backslash, KS_bar,
- /* KC(0x30), KS_f13, */
- /* KC(0x31), KS_f14, */
- KC(0x32), KS_q,
- KC(0x33), KS_w,
- KC(0x34), KS_e,
- KC(0x35), KS_r,
- KC(0x36), KS_t,
- KC(0x37), KS_y,
- KC(0x38), KS_u,
- KC(0x39), KS_i,
- KC(0x3a), KS_o,
- KC(0x3b), KS_p,
- KC(0x3c), KS_at, KS_grave,
- KC(0x3d), KS_bracketleft, KS_braceleft,
- KC(0x42), KS_a,
- KC(0x43), KS_s,
- KC(0x44), KS_d,
- KC(0x45), KS_f,
- KC(0x46), KS_g,
- KC(0x47), KS_h,
- KC(0x48), KS_j,
- KC(0x49), KS_k,
- KC(0x4a), KS_l,
- KC(0x4b), KS_semicolon, KS_plus,
- KC(0x4c), KS_colon, KS_asterisk,
- KC(0x4d), KS_bracketright, KS_braceright,
- KC(0x52), KS_z,
- KC(0x53), KS_x,
- KC(0x54), KS_c,
- KC(0x55), KS_v,
- KC(0x56), KS_b,
- KC(0x57), KS_n,
- KC(0x58), KS_m,
- KC(0x59), KS_comma, KS_less,
- KC(0x5a), KS_period, KS_greater,
- KC(0x5b), KS_slash, KS_question,
- KC(0x5c), KS_underscore,
- KC(0x60), KS_KP_Delete,
- KC(0x61), KS_KP_Add,
- KC(0x62), KS_KP_Subtract,
- KC(0x63), KS_KP_7,
- KC(0x64), KS_KP_8,
- KC(0x65), KS_KP_9,
- KC(0x66), KS_KP_4,
- KC(0x67), KS_KP_5,
- KC(0x68), KS_KP_6,
- KC(0x69), KS_KP_1,
- KC(0x6a), KS_KP_2,
- KC(0x6b), KS_KP_3,
- KC(0x6c), KS_KP_0,
- KC(0x6d), KS_KP_Decimal,
- KC(0x6e), KS_KP_Enter,
- KC(0x72), KS_f1,
- KC(0x73), KS_f2,
- KC(0x74), KS_f3,
- KC(0x75), KS_f4,
- KC(0x76), KS_f5,
- KC(0x77), KS_f6,
- KC(0x78), KS_f7,
- KC(0x79), KS_f8,
- KC(0x7a), KS_f9,
- KC(0x7b), KS_f10,
- KC(0x7c), KS_KP_Multiply,
- KC(0x7d), KS_KP_Divide,
- KC(0x7e), KS_KP_Equal,
- KC(0x7f), KS_KP_Separator,
-};
-
-#define SIZE(map) (sizeof(map)/sizeof(keysym_t))
-
-struct wscons_keydesc omkbd_keydesctab[] = {
- { KB_JP, 0, SIZE(omkbd_keydesc_1), omkbd_keydesc_1, },
- { 0, 0, 0, 0 },
-};
-
static void
ws_cngetc(void *v, u_int *type, int *data)
{
int code;
- do {
- code = syscngetc((dev_t)1);
- } while (!omkbd_decode(v, code, type, data));
+ code = syscngetc((dev_t)1);
+ omkbd_decode(v, code, type, data);
}
static void
@@ -446,6 +352,9 @@ omkbd_set_leds(void *v, int leds)
static int
omkbd_ioctl(void *v, u_long cmd, void *data, int flag, struct lwp *l)
{
+#ifdef WSDISPLAY_COMPAT_RAWKBD
+ struct ws_softc *sc = v;
+#endif
switch (cmd) {
case WSKBDIO_GTYPE:
@@ -455,6 +364,14 @@ omkbd_ioctl(void *v, u_long cmd, void *d
case WSKBDIO_GETLEDS:
case WSKBDIO_COMPLEXBELL: /* XXX capable of complex bell */
return 0;
+#ifdef WSDISPLAY_COMPAT_RAWKBD
+ case WSKBDIO_SETMODE:
+ sc->sc_rawkbd = *(int *)data == WSKBD_RAW;
+ return 0;
+ case WSKBDIO_GETMODE:
+ *(int *)data = sc->sc_rawkbd;
+ return 0;
+#endif
}
return EPASSTHROUGH;
}
Added files:
Index: src/sys/arch/luna68k/dev/omkbdmap.c
diff -u /dev/null src/sys/arch/luna68k/dev/omkbdmap.c:1.1
--- /dev/null Sun Jul 20 11:14:57 2014
+++ src/sys/arch/luna68k/dev/omkbdmap.c Sun Jul 20 11:14:56 2014
@@ -0,0 +1,303 @@
+/* $NetBSD: omkbdmap.c,v 1.1 2014/07/20 11:14:56 tsutsui Exp $ */
+/* $OpenBSD: omkbdmap.c,v 1.2 2013/11/16 18:31:44 miod Exp $ */
+
+/* Partially from:
+ * $NetBSD: omkbdmap.c,v 1.1 2014/07/20 11:14:56 tsutsui Exp $
+ *
+ * Copyright (c) 2000 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * This code is derived from software contributed to The NetBSD Foundation
+ * by Tohru Nishimura.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+ * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+ * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include "opt_wsdisplay_compat.h"
+
+#include <sys/types.h>
+
+#include <dev/wscons/wsksymdef.h>
+#include <dev/wscons/wsksymvar.h>
+
+#include <luna68k/dev/omkbdmap.h>
+
+#ifdef WSDISPLAY_COMPAT_RAWKBD
+
+/*
+ * Translate LUNA keycodes to US keyboard XT scancodes, for proper
+ * X11-over-wsmux operation.
+ *
+ * XXX: Needs re-think how we should treat RAWKBD code on NetBSD.
+ */
+const uint8_t omkbd_raw[0x80] = {
+ 0x00, /* 0x00 */
+ 0x00, /* 0x01 */
+ 0x00, /* 0x02 */
+ 0x00, /* 0x03 */
+ 0x00, /* 0x04 */
+ 0x00, /* 0x05 */
+ 0x00, /* 0x06 */
+ 0x00, /* 0x07 */
+ 0x00, /* 0x08 */
+ 0x0f, /* 0x09 */
+ 0x1d, /* 0x0a */
+ 0x70, /* 0x0b: Kana / No RAWKEY_XXX symbol */
+ 0x36, /* 0x0c */
+ 0x2a, /* 0x0d */
+ 0x3a, /* 0x0e */
+ 0x38, /* 0x0f: Zenmen */
+ 0x01, /* 0x10 */
+ 0x0e, /* 0x11 */
+ 0x1c, /* 0x12 */
+ 0x00, /* 0x13 */
+ 0x39, /* 0x14 */
+ 0xd3, /* 0x15 */
+ 0x38, /* 0x16: Henkan */
+ 0xb8, /* 0x17: Kakutei */
+ 0x57, /* 0x18: Shokyo */
+ 0x58, /* 0x19: Yobidashi */
+ 0x00, /* 0x1a: Bunsetsu L / f13 */
+ 0x00, /* 0x1b: Bunsetsu R / f14 */
+ 0x48, /* 0x1c */
+ 0x4b, /* 0x1d */
+ 0x4d, /* 0x1e */
+ 0x50, /* 0x1f */
+ 0x57, /* 0x20 */
+ 0x58, /* 0x21 */
+ 0x02, /* 0x22: exclam */
+ 0x03, /* 0x23: quotedbl */
+ 0x04, /* 0x24: numbersign */
+ 0x05, /* 0x25: dollar */
+ 0x06, /* 0x26: percent */
+ 0x07, /* 0x27: ampersand */
+ 0x08, /* 0x28: apostrophe */
+ 0x09, /* 0x29: parenleft */
+ 0x0a, /* 0x2a: parenright */
+ 0x0b, /* 0x2b */
+ 0x0c, /* 0x2c: equal */
+ 0x0d, /* 0x2d: asciitilde */
+ 0x7d, /* 0x2e: bar */
+ 0x00, /* 0x2f */
+ 0x00, /* 0x30: f13 */
+ 0x00, /* 0x31: f14 */
+ 0x10, /* 0x32 */
+ 0x11, /* 0x33 */
+ 0x12, /* 0x34 */
+ 0x13, /* 0x35 */
+ 0x14, /* 0x36 */
+ 0x15, /* 0x37 */
+ 0x16, /* 0x38 */
+ 0x17, /* 0x39 */
+ 0x18, /* 0x3a */
+ 0x19, /* 0x3b */
+ 0x1a, /* 0x3c: grave */
+ 0x1b, /* 0x3d: braceleft */
+ 0x00, /* 0x3e */
+ 0x00, /* 0x3f */
+ 0x00, /* 0x40 */
+ 0x00, /* 0x41 */
+ 0x1e, /* 0x42 */
+ 0x1f, /* 0x43 */
+ 0x20, /* 0x44 */
+ 0x21, /* 0x45 */
+ 0x22, /* 0x46 */
+ 0x23, /* 0x47 */
+ 0x24, /* 0x48 */
+ 0x25, /* 0x49 */
+ 0x26, /* 0x4a */
+ 0x27, /* 0x4b: plus */
+ 0x28, /* 0x4c: asterisk */
+ 0x2b, /* 0x4d: braceright */
+ 0x00, /* 0x4e */
+ 0x00, /* 0x4f */
+ 0x00, /* 0x50 */
+ 0x00, /* 0x51 */
+ 0x2c, /* 0x52 */
+ 0x2d, /* 0x53 */
+ 0x2e, /* 0x54 */
+ 0x2f, /* 0x55 */
+ 0x30, /* 0x56 */
+ 0x31, /* 0x57 */
+ 0x32, /* 0x58 */
+ 0x33, /* 0x59: less */
+ 0x34, /* 0x5a: greater */
+ 0x35, /* 0x5b: question */
+ 0x73, /* 0x5c: underscore */
+ 0x00, /* 0x5d */
+ 0x00, /* 0x5e */
+ 0x00, /* 0x5f */
+ 0x53, /* 0x60 */
+ 0x4e, /* 0x61 */
+ 0x4a, /* 0x62 */
+ 0x47, /* 0x63: KP 7 */
+ 0x48, /* 0x64: KP 8 */
+ 0x49, /* 0x65: KP 9 */
+ 0x4b, /* 0x66: KP 4 */
+ 0x4c, /* 0x67: KP 5 */
+ 0x4d, /* 0x68: KP 6 */
+ 0x4f, /* 0x69: KP 1 */
+ 0x50, /* 0x6a: KP 2 */
+ 0x51, /* 0x6b: KP 3 */
+ 0x52, /* 0x6c: KP 0 */
+ 0x53, /* 0x6d: KP Decimal */
+ 0x9c, /* 0x6e */
+ 0x00, /* 0x6f */
+ 0x00, /* 0x70 */
+ 0x00, /* 0x71 */
+ 0x3b, /* 0x72 */
+ 0x3c, /* 0x73 */
+ 0x3d, /* 0x74 */
+ 0x3e, /* 0x75 */
+ 0x3f, /* 0x76 */
+ 0x40, /* 0x77 */
+ 0x41, /* 0x78 */
+ 0x42, /* 0x79 */
+ 0x43, /* 0x7a */
+ 0x44, /* 0x7b */
+ 0x37, /* 0x7c */
+ 0xb5, /* 0x7d */
+ 0x76, /* 0x7E */
+ 0x00, /* 0x7f: KP Separator */
+};
+#endif
+
+#define KC(n) KS_KEYCODE(n)
+
+static const keysym_t omkbd_keydesc_jp[] = {
+/* pos command normal shifted */
+ KC(0x09), KS_Tab,
+ KC(0x0a), KS_Cmd1, KS_Control_L,
+ KC(0x0b), KS_Mode_switch, /* Kana */
+ KC(0x0c), KS_Shift_R,
+ KC(0x0d), KS_Shift_L,
+ KC(0x0e), KS_Caps_Lock,
+ KC(0x0f), KS_Cmd2, KS_Meta_L, /* Zenmen */
+ KC(0x10), KS_Cmd_Debugger, KS_Escape,
+ KC(0x11), KS_BackSpace,
+ KC(0x12), KS_Return,
+ KC(0x14), KS_space,
+ KC(0x15), KS_Delete,
+ KC(0x16), KS_Alt_L, /* Henkan */
+ KC(0x17), KS_Alt_R, /* Kakutei */
+ KC(0x18), KS_f11, /* Shokyo */
+ KC(0x19), KS_f12, /* Yobidashi */
+ KC(0x1a), KS_f13, /* Bunsetsu L */
+ KC(0x1b), KS_f14, /* Bunsetsu R */
+ KC(0x1c), KS_KP_Up,
+ KC(0x1d), KS_KP_Left,
+ KC(0x1e), KS_KP_Right,
+ KC(0x1f), KS_KP_Down,
+ /* 0x20, KS_f11, */
+ /* 0x21, KS_f12, */
+ KC(0x22), KS_1, KS_exclam,
+ KC(0x23), KS_2, KS_quotedbl,
+ KC(0x24), KS_3, KS_numbersign,
+ KC(0x25), KS_4, KS_dollar,
+ KC(0x26), KS_5, KS_percent,
+ KC(0x27), KS_6, KS_ampersand,
+ KC(0x28), KS_7, KS_apostrophe,
+ KC(0x29), KS_8, KS_parenleft,
+ KC(0x2a), KS_9, KS_parenright,
+ KC(0x2b), KS_0,
+ KC(0x2c), KS_minus, KS_equal,
+ KC(0x2d), KS_asciicircum, KS_asciitilde,
+ KC(0x2e), KS_backslash, KS_bar,
+
+ /* 0x30, KS_f13, */
+ /* 0x31, KS_f14, */
+ KC(0x32), KS_q,
+ KC(0x33), KS_w,
+ KC(0x34), KS_e,
+ KC(0x35), KS_r,
+ KC(0x36), KS_t,
+ KC(0x37), KS_y,
+ KC(0x38), KS_u,
+ KC(0x39), KS_i,
+ KC(0x3a), KS_o,
+ KC(0x3b), KS_p,
+ KC(0x3c), KS_at, KS_grave,
+ KC(0x3d), KS_bracketleft, KS_braceleft,
+
+ KC(0x42), KS_a,
+ KC(0x43), KS_s,
+ KC(0x44), KS_d,
+ KC(0x45), KS_f,
+ KC(0x46), KS_g,
+ KC(0x47), KS_h,
+ KC(0x48), KS_j,
+ KC(0x49), KS_k,
+ KC(0x4a), KS_l,
+ KC(0x4b), KS_semicolon, KS_plus,
+ KC(0x4c), KS_colon, KS_asterisk,
+ KC(0x4d), KS_bracketright, KS_braceright,
+
+ KC(0x52), KS_z,
+ KC(0x53), KS_x,
+ KC(0x54), KS_c,
+ KC(0x55), KS_v,
+ KC(0x56), KS_b,
+ KC(0x57), KS_n,
+ KC(0x58), KS_m,
+ KC(0x59), KS_comma, KS_less,
+ KC(0x5a), KS_period, KS_greater,
+ KC(0x5b), KS_slash, KS_question,
+ KC(0x5c), KS_underscore,
+
+ KC(0x60), KS_KP_Delete,
+ KC(0x61), KS_KP_Add,
+ KC(0x62), KS_KP_Subtract,
+ KC(0x63), KS_KP_7,
+ KC(0x64), KS_KP_8,
+ KC(0x65), KS_KP_9,
+ KC(0x66), KS_KP_4,
+ KC(0x67), KS_KP_5,
+ KC(0x68), KS_KP_6,
+ KC(0x69), KS_KP_1,
+ KC(0x6a), KS_KP_2,
+ KC(0x6b), KS_KP_3,
+ KC(0x6c), KS_KP_0,
+ KC(0x6d), KS_KP_Decimal,
+ KC(0x6e), KS_KP_Enter,
+
+ KC(0x72), KS_f1,
+ KC(0x73), KS_f2,
+ KC(0x74), KS_f3,
+ KC(0x75), KS_f4,
+ KC(0x76), KS_f5,
+ KC(0x77), KS_f6,
+ KC(0x78), KS_f7,
+ KC(0x79), KS_f8,
+ KC(0x7a), KS_f9,
+ KC(0x7b), KS_f10,
+ KC(0x7c), KS_KP_Multiply,
+ KC(0x7d), KS_KP_Divide,
+ KC(0x7e), KS_KP_Equal,
+ KC(0x7f), KS_KP_Separator,
+};
+
+#define SIZE(map) (sizeof(map)/sizeof(keysym_t))
+
+const struct wscons_keydesc omkbd_keydesctab[] = {
+ { KB_JP, 0, SIZE(omkbd_keydesc_jp), omkbd_keydesc_jp, },
+ { 0, 0, 0, 0 },
+};
Index: src/sys/arch/luna68k/dev/omkbdmap.h
diff -u /dev/null src/sys/arch/luna68k/dev/omkbdmap.h:1.1
--- /dev/null Sun Jul 20 11:14:57 2014
+++ src/sys/arch/luna68k/dev/omkbdmap.h Sun Jul 20 11:14:56 2014
@@ -0,0 +1,23 @@
+/* $NetBSD: omkbdmap.h,v 1.1 2014/07/20 11:14:56 tsutsui Exp $ */
+/* $OpenBSD: omkbdmap.h,v 1.1 2013/05/22 11:35:02 aoyama Exp $ */
+
+/*
+ * Copyright (c) 2013 Kenji Aoyama
+ *
+ * Permission to use, copy, modify, and distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+extern const struct wscons_keydesc omkbd_keydesctab[];
+#ifdef WSDISPLAY_COMPAT_RAWKBD
+extern const uint8_t omkbd_raw[0x80];
+#endif