source: mainline/uspace/srv/kbd/ctl/pc.c@ 12b6796

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 12b6796 was 12b6796, checked in by Jiri Svoboda <jirik.svoboda@…>, 17 years ago

Tackle scroll lock and cope with lock-key hardware auto-repeat.

  • Property mode set to 100644
File size: 4.2 KB
Line 
1/*
2 * Copyright (c) 2009 Jiri Svoboda
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup kbd_ctl
30 * @ingroup kbd
31 * @{
32 */
33/**
34 * @file
35 * @brief PC keyboard controller driver.
36 */
37
38#include <kbd.h>
39#include <kbd/kbd.h>
40#include <kbd/keycode.h>
41#include <kbd_ctl.h>
42
43enum dec_state {
44 ds_s,
45 ds_e
46};
47
48static enum dec_state ds = ds_s;
49
50static int scanmap_simple[] = {
51
52 [0x29] = KC_BACKTICK,
53
54 [0x02] = KC_1,
55 [0x03] = KC_2,
56 [0x04] = KC_3,
57 [0x05] = KC_4,
58 [0x06] = KC_5,
59 [0x07] = KC_6,
60 [0x08] = KC_7,
61 [0x09] = KC_8,
62 [0x0a] = KC_9,
63 [0x0b] = KC_0,
64
65 [0x0c] = KC_MINUS,
66 [0x0d] = KC_EQUALS,
67 [0x0e] = KC_BACKSPACE,
68
69 [0x0f] = KC_TAB,
70
71 [0x10] = KC_Q,
72 [0x11] = KC_W,
73 [0x12] = KC_E,
74 [0x13] = KC_R,
75 [0x14] = KC_T,
76 [0x15] = KC_Y,
77 [0x16] = KC_U,
78 [0x17] = KC_I,
79 [0x18] = KC_O,
80 [0x19] = KC_P,
81
82 [0x1a] = KC_LBRACKET,
83 [0x1b] = KC_RBRACKET,
84
85 [0x3a] = KC_CAPS_LOCK,
86
87 [0x1e] = KC_A,
88 [0x1f] = KC_S,
89 [0x20] = KC_D,
90 [0x21] = KC_F,
91 [0x22] = KC_G,
92 [0x23] = KC_H,
93 [0x24] = KC_J,
94 [0x25] = KC_K,
95 [0x26] = KC_L,
96
97 [0x27] = KC_SEMICOLON,
98 [0x28] = KC_QUOTE,
99 [0x2b] = KC_BACKSLASH,
100
101 [0x2a] = KC_LSHIFT,
102
103 [0x2c] = KC_Z,
104 [0x2d] = KC_X,
105 [0x2e] = KC_C,
106 [0x2f] = KC_V,
107 [0x30] = KC_B,
108 [0x31] = KC_N,
109 [0x32] = KC_M,
110
111 [0x33] = KC_COMMA,
112 [0x34] = KC_PERIOD,
113 [0x35] = KC_SLASH,
114
115 [0x36] = KC_RSHIFT,
116
117 [0x1d] = KC_LCTRL,
118 [0x38] = KC_LALT,
119 [0x39] = KC_SPACE,
120
121 [0x01] = KC_ESCAPE,
122
123 [0x3b] = KC_F1,
124 [0x3c] = KC_F2,
125 [0x3d] = KC_F3,
126 [0x3e] = KC_F4,
127 [0x3f] = KC_F5,
128 [0x40] = KC_F6,
129 [0x41] = KC_F7,
130
131 [0x42] = KC_F8,
132 [0x43] = KC_F9,
133 [0x44] = KC_F10,
134
135 [0x57] = KC_F11,
136 [0x58] = KC_F12,
137
138 [0x46] = KC_SCROLL_LOCK,
139
140 [0x1c] = KC_ENTER,
141
142 [0x45] = KC_NUM_LOCK,
143 [0x37] = KC_NTIMES,
144 [0x4a] = KC_NMINUS,
145 [0x4e] = KC_NPLUS,
146 [0x47] = KC_N7,
147 [0x48] = KC_N8,
148 [0x49] = KC_N9,
149 [0x4b] = KC_N4,
150 [0x4c] = KC_N5,
151 [0x4d] = KC_N6,
152 [0x4f] = KC_N1,
153 [0x50] = KC_N2,
154 [0x51] = KC_N3,
155 [0x52] = KC_N0,
156 [0x53] = KC_NPERIOD
157};
158
159static int scanmap_e0[] = {
160 [0x38] = KC_RALT,
161 [0x1d] = KC_RSHIFT,
162
163 [0x37] = KC_PRTSCR,
164
165 [0x52] = KC_INSERT,
166 [0x47] = KC_HOME,
167 [0x49] = KC_PAGE_UP,
168
169 [0x53] = KC_DELETE,
170 [0x4f] = KC_END,
171 [0x51] = KC_PAGE_DOWN,
172
173 [0x48] = KC_UP,
174 [0x4b] = KC_LEFT,
175 [0x50] = KC_DOWN,
176 [0x4d] = KC_RIGHT,
177
178 [0x35] = KC_NSLASH,
179 [0x1c] = KC_NENTER
180};
181
182
183void kbd_ctl_parse_scancode(int scancode)
184{
185 kbd_ev_type_t type;
186 unsigned int key;
187 int *map;
188 size_t map_length;
189
190 if (scancode == 0xe0) {
191 ds = ds_e;
192 return;
193 }
194
195 switch (ds) {
196 case ds_s:
197 map = scanmap_simple;
198 map_length = sizeof(scanmap_simple) / sizeof(int);
199 break;
200 case ds_e:
201 map = scanmap_e0;
202 map_length = sizeof(scanmap_e0) / sizeof(int);
203 break;
204 }
205
206 ds = ds_s;
207
208 if (scancode & 0x80) {
209 scancode &= ~0x80;
210 type = KE_RELEASE;
211 } else {
212 type = KE_PRESS;
213 }
214
215 if (scancode < 0 || scancode >= map_length)
216 return;
217
218 key = map[scancode];
219 if (key != 0)
220 kbd_push_ev(type, key);
221}
222
223/**
224 * @}
225 */
Note: See TracBrowser for help on using the repository browser.