157087Sakito /*
257087Sakito * Copyright (c) 1992 OMRON Corporation.
3*63199Sbostic * Copyright (c) 1992, 1993
4*63199Sbostic * The Regents of the University of California. All rights reserved.
557087Sakito *
657087Sakito * This code is derived from software contributed to Berkeley by
757087Sakito * OMRON Corporation.
857087Sakito *
957087Sakito * %sccs.include.redist.c%
1057087Sakito *
11*63199Sbostic * @(#)kbd.c 8.1 (Berkeley) 06/10/93
1257087Sakito */
1357087Sakito
1457087Sakito /*
1557087Sakito * kbd.c -- key-code decoding routine
1657087Sakito * by A.Fujita, Dec-12-1992
1757087Sakito */
1857087Sakito
1957087Sakito #include <sys/param.h>
2057087Sakito #include <luna68k/stand/kbdreg.h>
2157087Sakito
2257087Sakito struct kbd_keymap kbd_keymap[] = {
2357087Sakito KC_IGNORE, 0, 0, /* 0 [0x00] */
2457087Sakito KC_IGNORE, 0, 0, /* 1 [0x01] */
2557087Sakito KC_IGNORE, 0, 0, /* 2 [0x02] */
2657087Sakito KC_IGNORE, 0, 0, /* 3 [0x03] */
2757087Sakito KC_IGNORE, 0, 0, /* 4 [0x04] */
2857087Sakito KC_IGNORE, 0, 0, /* 5 [0x05] */
2957087Sakito KC_IGNORE, 0, 0, /* 6 [0x06] */
3057087Sakito KC_IGNORE, 0, 0, /* 7 [0x07] */
3157087Sakito KC_IGNORE, 0, 0, /* 8 [0x08] */
3257087Sakito KC_CODE, 0x09, 0x09, /* 9 [0x09] TAB */
3357087Sakito KC_SHIFT, KS_CTRL, KS_CTRL, /* 10 [0x0A] CTRL */
3457087Sakito KC_IGNORE, 0, 0, /* 11 [0x0B] */
3557087Sakito KC_SHIFT, KS_SHIFT, KS_SHIFT, /* 12 [0x0C] SHIFT */
3657087Sakito KC_SHIFT, KS_SHIFT, KS_SHIFT, /* 13 [0x0D] SHIFT */
3757087Sakito KC_IGNORE, 0, 0, /* 14 [0x0E] */
3857087Sakito KC_SHIFT, KS_META, KS_META, /* 15 [0x0F] META */
3957087Sakito KC_CODE, 0x1B, 0x1B, /* 16 [0x10] ESC */
4057087Sakito KC_CODE, 0x08, 0x08, /* 17 [0x11] BS */
4157087Sakito KC_CODE, 0x0D, 0x0D, /* 18 [0x12] CR */
4257087Sakito KC_IGNORE, 0, 0, /* 19 [0x13] */
4357087Sakito KC_CODE, 0x20, 0x20, /* 20 [0x14] SP */
4457087Sakito KC_CODE, 0x7F, 0x7F, /* 21 [0x15] DEL */
4557087Sakito KC_IGNORE, 0, 0, /* 22 [0x16] */
4657087Sakito KC_IGNORE, 0, 0, /* 23 [0x17] */
4757087Sakito KC_IGNORE, 0, 0, /* 24 [0x18] */
4857087Sakito KC_IGNORE, 0, 0, /* 25 [0x19] */
4957087Sakito KC_IGNORE, 0, 0, /* 26 [0x1A] */
5057087Sakito KC_IGNORE, 0, 0, /* 27 [0x1B] */
5157087Sakito KC_IGNORE, 0, 0, /* 28 [0x1C] */
5257087Sakito KC_IGNORE, 0, 0, /* 29 [0x1D] */
5357087Sakito KC_IGNORE, 0, 0, /* 30 [0x1E] */
5457087Sakito KC_IGNORE, 0, 0, /* 31 [0x1F] */
5557087Sakito KC_IGNORE, 0, 0, /* 32 [0x20] */
5657087Sakito KC_IGNORE, 0, 0, /* 33 [0x21] */
5757087Sakito KC_CODE, 0x31, 0x21, /* 34 [0x22] 1 */
5857087Sakito KC_CODE, 0x32, 0x22, /* 35 [0x23] 2 */
5957087Sakito KC_CODE, 0x33, 0x23, /* 36 [0x24] 3 */
6057087Sakito KC_CODE, 0x34, 0x24, /* 37 [0x25] 4 */
6157087Sakito KC_CODE, 0x35, 0x25, /* 38 [0x26] 5 */
6257087Sakito KC_CODE, 0x36, 0x26, /* 39 [0x27] 6 */
6357087Sakito KC_CODE, 0x37, 0x27, /* 40 [0x28] 7 */
6457087Sakito KC_CODE, 0x38, 0x28, /* 41 [0x29] 8 */
6557087Sakito KC_CODE, 0x39, 0x29, /* 42 [0x2A] 9 */
6657087Sakito KC_CODE, 0x30, 0x30, /* 43 [0x2B] 0 */
6757087Sakito KC_CODE, 0x2D, 0x3D, /* 44 [0x2C] - */
6857087Sakito KC_CODE, 0x5E, 0x7E, /* 45 [0x2D] ^ */
6957087Sakito KC_CODE, 0x5C, 0x7C, /* 46 [0x2E] \ */
7057087Sakito KC_IGNORE, 0, 0, /* 47 [0x2F] */
7157087Sakito KC_IGNORE, 0, 0, /* 48 [0x30] */
7257087Sakito KC_IGNORE, 0, 0, /* 49 [0x31] */
7357087Sakito KC_CODE, 0x71, 0x51, /* 50 [0x32] q */
7457087Sakito KC_CODE, 0x77, 0x57, /* 51 [0x33] w */
7557087Sakito KC_CODE, 0x65, 0x45, /* 52 [0x34] e */
7657087Sakito KC_CODE, 0x72, 0x52, /* 53 [0x35] r */
7757087Sakito KC_CODE, 0x74, 0x54, /* 54 [0x36] t */
7857087Sakito KC_CODE, 0x79, 0x59, /* 55 [0x37] y */
7957087Sakito KC_CODE, 0x75, 0x55, /* 56 [0x38] u */
8057087Sakito KC_CODE, 0x69, 0x49, /* 57 [0x39] i */
8157087Sakito KC_CODE, 0x6F, 0x4F, /* 58 [0x3A] o */
8257087Sakito KC_CODE, 0x70, 0x50, /* 59 [0x3B] p */
8357087Sakito KC_CODE, 0x40, 0x60, /* 60 [0x3C] @ */
8457087Sakito KC_CODE, 0x5B, 0x7B, /* 61 [0x3D] [ */
8557087Sakito KC_IGNORE, 0, 0, /* 62 [0x3E] */
8657087Sakito KC_IGNORE, 0, 0, /* 63 [0x3F] */
8757087Sakito KC_IGNORE, 0, 0, /* 64 [0x40] */
8857087Sakito KC_IGNORE, 0, 0, /* 65 [0x41] */
8957087Sakito KC_CODE, 0x61, 0x41, /* 66 [0x42] a */
9057087Sakito KC_CODE, 0x73, 0x53, /* 67 [0x43] s */
9157087Sakito KC_CODE, 0x64, 0x44, /* 68 [0x44] d */
9257087Sakito KC_CODE, 0x66, 0x46, /* 69 [0x45] f */
9357087Sakito KC_CODE, 0x67, 0x47, /* 70 [0x46] g */
9457087Sakito KC_CODE, 0x68, 0x48, /* 71 [0x47] h */
9557087Sakito KC_CODE, 0x6A, 0x4A, /* 72 [0x48] j */
9657087Sakito KC_CODE, 0x6B, 0x4B, /* 73 [0x49] k */
9757087Sakito KC_CODE, 0x6C, 0x4C, /* 74 [0x4A] l */
9857087Sakito KC_CODE, 0x3B, 0x2B, /* 75 [0x4B] ; */
9957087Sakito KC_CODE, 0x3A, 0x2A, /* 76 [0x4C] : */
10057087Sakito KC_CODE, 0x5D, 0x7D, /* 77 [0x4D] ] */
10157087Sakito KC_IGNORE, 0, 0, /* 78 [0x4E] */
10257087Sakito KC_IGNORE, 0, 0, /* 79 [0x4F] */
10357087Sakito KC_IGNORE, 0, 0, /* 80 [0x50] */
10457087Sakito KC_IGNORE, 0, 0, /* 81 [0x51] */
10557087Sakito KC_CODE, 0x7A, 0x5A, /* 82 [0x52] z */
10657087Sakito KC_CODE, 0x78, 0x58, /* 83 [0x53] x */
10757087Sakito KC_CODE, 0x63, 0x43, /* 84 [0x54] c */
10857087Sakito KC_CODE, 0x76, 0x56, /* 85 [0x55] v */
10957087Sakito KC_CODE, 0x62, 0x42, /* 86 [0x56] b */
11057087Sakito KC_CODE, 0x6E, 0x4E, /* 87 [0x57] n */
11157087Sakito KC_CODE, 0x6D, 0x4D, /* 88 [0x58] m */
11257087Sakito KC_CODE, 0x2C, 0x3C, /* 89 [0x59] , */
11357087Sakito KC_CODE, 0x2E, 0x3E, /* 90 [0x5A] . */
11457087Sakito KC_CODE, 0x2F, 0x3F, /* 91 [0x5B] / */
11557087Sakito KC_CODE, 0x5F, 0x5F, /* 92 [0x5C] _ */
11657087Sakito KC_IGNORE, 0, 0, /* 93 [0x5D] */
11757087Sakito KC_IGNORE, 0, 0, /* 94 [0x5E] */
11857087Sakito KC_IGNORE, 0, 0, /* 95 [0x5F] */
11957087Sakito KC_IGNORE, 0, 0, /* 96 [0x60] */
12057087Sakito KC_IGNORE, 0, 0, /* 97 [0x61] */
12157087Sakito KC_IGNORE, 0, 0, /* 98 [0x62] */
12257087Sakito KC_IGNORE, 0, 0, /* 99 [0x63] */
12357087Sakito KC_IGNORE, 0, 0, /* 100 [0x64] */
12457087Sakito KC_IGNORE, 0, 0, /* 101 [0x65] */
12557087Sakito KC_IGNORE, 0, 0, /* 102 [0x66] */
12657087Sakito KC_IGNORE, 0, 0, /* 103 [0x67] */
12757087Sakito KC_IGNORE, 0, 0, /* 104 [0x68] */
12857087Sakito KC_IGNORE, 0, 0, /* 105 [0x69] */
12957087Sakito KC_IGNORE, 0, 0, /* 106 [0x6A] */
13057087Sakito KC_IGNORE, 0, 0, /* 107 [0x6B] */
13157087Sakito KC_IGNORE, 0, 0, /* 108 [0x6C] */
13257087Sakito KC_IGNORE, 0, 0, /* 109 [0x6D] */
13357087Sakito KC_IGNORE, 0, 0, /* 110 [0x6E] */
13457087Sakito KC_IGNORE, 0, 0, /* 111 [0x6F] */
13557087Sakito KC_IGNORE, 0, 0, /* 112 [0x70] */
13657087Sakito KC_IGNORE, 0, 0, /* 113 [0x71] */
13757087Sakito KC_IGNORE, 0, 0, /* 114 [0x72] */
13857087Sakito KC_IGNORE, 0, 0, /* 115 [0x73] */
13957087Sakito KC_IGNORE, 0, 0, /* 116 [0x74] */
14057087Sakito KC_IGNORE, 0, 0, /* 117 [0x75] */
14157087Sakito KC_IGNORE, 0, 0, /* 118 [0x76] */
14257087Sakito KC_IGNORE, 0, 0, /* 119 [0x77] */
14357087Sakito KC_IGNORE, 0, 0, /* 120 [0x78] */
14457087Sakito KC_IGNORE, 0, 0, /* 121 [0x79] */
14557087Sakito KC_IGNORE, 0, 0, /* 122 [0x7A] */
14657087Sakito KC_IGNORE, 0, 0, /* 123 [0x7B] */
14757087Sakito KC_IGNORE, 0, 0, /* 124 [0x7C] */
14857087Sakito KC_IGNORE, 0, 0, /* 125 [0x7D] */
14957087Sakito KC_IGNORE, 0, 0, /* 126 [0x7E] */
15057087Sakito KC_IGNORE, 0, 0, /* 127 [0x7F] */
15157087Sakito };
15257087Sakito
15357087Sakito int shift_flag = 0;
15457087Sakito int ctrl_flag = 0;
15557087Sakito int meta_flag = 0;
15657087Sakito
kbd_decode(code)15757087Sakito kbd_decode(code)
15857087Sakito register u_char code;
15957087Sakito {
16057617Sakito register unsigned int c, updown = 0;
16157087Sakito
16257087Sakito if (code & 0x80)
16357087Sakito updown = 1;
16457087Sakito
16557087Sakito code &= 0x7F;
16657087Sakito
16757087Sakito c = kbd_keymap[code].km_type;
16857087Sakito
16957617Sakito if (c == KC_IGNORE)
17057617Sakito return(KC_IGNORE);
17157087Sakito
17257617Sakito if ((c == KC_CODE) && updown)
17357617Sakito return(KC_IGNORE);
17457087Sakito
17557617Sakito if (c == KC_SHIFT) {
17657087Sakito switch(kbd_keymap[code].km_code[0]) {
17757617Sakito
17857087Sakito case KS_SHIFT:
17957087Sakito shift_flag = 1 - updown;
18057087Sakito break;
18157087Sakito
18257087Sakito case KS_CTRL:
18357087Sakito ctrl_flag = 1 - updown;
18457087Sakito break;
18557087Sakito
18657087Sakito case KS_META:
18757087Sakito meta_flag = 1 - updown;
18857087Sakito break;
18957087Sakito }
19057087Sakito
19157617Sakito return(KC_IGNORE);
19257087Sakito }
19357087Sakito
19457617Sakito if (shift_flag)
19557617Sakito c = kbd_keymap[code].km_code[1];
19657617Sakito else
19757617Sakito c = kbd_keymap[code].km_code[0];
19857087Sakito
19957617Sakito if (meta_flag)
20057617Sakito c |= 0x80;
20157087Sakito
20257617Sakito if (ctrl_flag)
20357617Sakito c &= 0x1F;
20457617Sakito
20557087Sakito return(c);
20657087Sakito }
207