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

Reply via email to