xref: /freebsd/sys/dev/usb/input/ukbd.c (revision 0572ccaa4543b0abef8ef81e384c1d04de9f3da1)
1 #include <sys/cdefs.h>
2 __FBSDID("$FreeBSD$");
3 
4 
5 /*-
6  * Copyright (c) 1998 The NetBSD Foundation, Inc.
7  * All rights reserved.
8  *
9  * This code is derived from software contributed to The NetBSD Foundation
10  * by Lennart Augustsson (lennart@augustsson.net) at
11  * Carlstedt Research & Technology.
12  *
13  * Redistribution and use in source and binary forms, with or without
14  * modification, are permitted provided that the following conditions
15  * are met:
16  * 1. Redistributions of source code must retain the above copyright
17  *    notice, this list of conditions and the following disclaimer.
18  * 2. Redistributions in binary form must reproduce the above copyright
19  *    notice, this list of conditions and the following disclaimer in the
20  *    documentation and/or other materials provided with the distribution.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
23  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
24  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
25  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
26  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
27  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
28  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
29  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
30  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
31  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32  * POSSIBILITY OF SUCH DAMAGE.
33  *
34  */
35 
36 /*
37  * HID spec: http://www.usb.org/developers/devclass_docs/HID1_11.pdf
38  */
39 
40 #include "opt_compat.h"
41 #include "opt_kbd.h"
42 #include "opt_ukbd.h"
43 
44 #include <sys/stdint.h>
45 #include <sys/stddef.h>
46 #include <sys/param.h>
47 #include <sys/queue.h>
48 #include <sys/types.h>
49 #include <sys/systm.h>
50 #include <sys/kernel.h>
51 #include <sys/bus.h>
52 #include <sys/module.h>
53 #include <sys/lock.h>
54 #include <sys/mutex.h>
55 #include <sys/condvar.h>
56 #include <sys/sysctl.h>
57 #include <sys/sx.h>
58 #include <sys/unistd.h>
59 #include <sys/callout.h>
60 #include <sys/malloc.h>
61 #include <sys/priv.h>
62 #include <sys/proc.h>
63 #include <sys/sched.h>
64 #include <sys/kdb.h>
65 
66 #include <dev/usb/usb.h>
67 #include <dev/usb/usbdi.h>
68 #include <dev/usb/usbdi_util.h>
69 #include <dev/usb/usbhid.h>
70 
71 #define	USB_DEBUG_VAR ukbd_debug
72 #include <dev/usb/usb_debug.h>
73 
74 #include <dev/usb/quirk/usb_quirk.h>
75 
76 #include <sys/ioccom.h>
77 #include <sys/filio.h>
78 #include <sys/tty.h>
79 #include <sys/kbio.h>
80 
81 #include <dev/kbd/kbdreg.h>
82 
83 /* the initial key map, accent map and fkey strings */
84 #if defined(UKBD_DFLT_KEYMAP) && !defined(KLD_MODULE)
85 #define	KBD_DFLT_KEYMAP
86 #include "ukbdmap.h"
87 #endif
88 
89 /* the following file must be included after "ukbdmap.h" */
90 #include <dev/kbd/kbdtables.h>
91 
92 #ifdef USB_DEBUG
93 static int ukbd_debug = 0;
94 static int ukbd_no_leds = 0;
95 static int ukbd_pollrate = 0;
96 
97 static SYSCTL_NODE(_hw_usb, OID_AUTO, ukbd, CTLFLAG_RW, 0, "USB keyboard");
98 SYSCTL_INT(_hw_usb_ukbd, OID_AUTO, debug, CTLFLAG_RW | CTLFLAG_TUN,
99     &ukbd_debug, 0, "Debug level");
100 TUNABLE_INT("hw.usb.ukbd.debug", &ukbd_debug);
101 SYSCTL_INT(_hw_usb_ukbd, OID_AUTO, no_leds, CTLFLAG_RW | CTLFLAG_TUN,
102     &ukbd_no_leds, 0, "Disables setting of keyboard leds");
103 TUNABLE_INT("hw.usb.ukbd.no_leds", &ukbd_no_leds);
104 SYSCTL_INT(_hw_usb_ukbd, OID_AUTO, pollrate, CTLFLAG_RW | CTLFLAG_TUN,
105     &ukbd_pollrate, 0, "Force this polling rate, 1-1000Hz");
106 TUNABLE_INT("hw.usb.ukbd.pollrate", &ukbd_pollrate);
107 #endif
108 
109 #define	UKBD_EMULATE_ATSCANCODE	       1
110 #define	UKBD_DRIVER_NAME          "ukbd"
111 #define	UKBD_NMOD                     8	/* units */
112 #define	UKBD_NKEYCODE                 6	/* units */
113 #define	UKBD_IN_BUF_SIZE  (2*(UKBD_NMOD + (2*UKBD_NKEYCODE)))	/* bytes */
114 #define	UKBD_IN_BUF_FULL  (UKBD_IN_BUF_SIZE / 2)	/* bytes */
115 #define	UKBD_NFKEY        (sizeof(fkey_tab)/sizeof(fkey_tab[0]))	/* units */
116 #define	UKBD_BUFFER_SIZE	      64	/* bytes */
117 
118 struct ukbd_data {
119 	uint16_t	modifiers;
120 #define	MOD_CONTROL_L	0x01
121 #define	MOD_CONTROL_R	0x10
122 #define	MOD_SHIFT_L	0x02
123 #define	MOD_SHIFT_R	0x20
124 #define	MOD_ALT_L	0x04
125 #define	MOD_ALT_R	0x40
126 #define	MOD_WIN_L	0x08
127 #define	MOD_WIN_R	0x80
128 /* internal */
129 #define	MOD_EJECT	0x0100
130 #define	MOD_FN		0x0200
131 	uint8_t	keycode[UKBD_NKEYCODE];
132 };
133 
134 enum {
135 	UKBD_INTR_DT,
136 	UKBD_CTRL_LED,
137 	UKBD_N_TRANSFER,
138 };
139 
140 struct ukbd_softc {
141 	keyboard_t sc_kbd;
142 	keymap_t sc_keymap;
143 	accentmap_t sc_accmap;
144 	fkeytab_t sc_fkeymap[UKBD_NFKEY];
145 	struct hid_location sc_loc_apple_eject;
146 	struct hid_location sc_loc_apple_fn;
147 	struct hid_location sc_loc_ctrl_l;
148 	struct hid_location sc_loc_ctrl_r;
149 	struct hid_location sc_loc_shift_l;
150 	struct hid_location sc_loc_shift_r;
151 	struct hid_location sc_loc_alt_l;
152 	struct hid_location sc_loc_alt_r;
153 	struct hid_location sc_loc_win_l;
154 	struct hid_location sc_loc_win_r;
155 	struct hid_location sc_loc_events;
156 	struct hid_location sc_loc_numlock;
157 	struct hid_location sc_loc_capslock;
158 	struct hid_location sc_loc_scrolllock;
159 	struct usb_callout sc_callout;
160 	struct ukbd_data sc_ndata;
161 	struct ukbd_data sc_odata;
162 
163 	struct thread *sc_poll_thread;
164 	struct usb_device *sc_udev;
165 	struct usb_interface *sc_iface;
166 	struct usb_xfer *sc_xfer[UKBD_N_TRANSFER];
167 
168 	uint32_t sc_ntime[UKBD_NKEYCODE];
169 	uint32_t sc_otime[UKBD_NKEYCODE];
170 	uint32_t sc_input[UKBD_IN_BUF_SIZE];	/* input buffer */
171 	uint32_t sc_time_ms;
172 	uint32_t sc_composed_char;	/* composed char code, if non-zero */
173 #ifdef UKBD_EMULATE_ATSCANCODE
174 	uint32_t sc_buffered_char[2];
175 #endif
176 	uint32_t sc_flags;		/* flags */
177 #define	UKBD_FLAG_COMPOSE	0x00000001
178 #define	UKBD_FLAG_POLLING	0x00000002
179 #define	UKBD_FLAG_SET_LEDS	0x00000004
180 #define	UKBD_FLAG_ATTACHED	0x00000010
181 #define	UKBD_FLAG_GONE		0x00000020
182 
183 #define	UKBD_FLAG_HID_MASK	0x003fffc0
184 #define	UKBD_FLAG_APPLE_EJECT	0x00000040
185 #define	UKBD_FLAG_APPLE_FN	0x00000080
186 #define	UKBD_FLAG_APPLE_SWAP	0x00000100
187 #define	UKBD_FLAG_TIMER_RUNNING	0x00000200
188 #define	UKBD_FLAG_CTRL_L	0x00000400
189 #define	UKBD_FLAG_CTRL_R	0x00000800
190 #define	UKBD_FLAG_SHIFT_L	0x00001000
191 #define	UKBD_FLAG_SHIFT_R	0x00002000
192 #define	UKBD_FLAG_ALT_L		0x00004000
193 #define	UKBD_FLAG_ALT_R		0x00008000
194 #define	UKBD_FLAG_WIN_L		0x00010000
195 #define	UKBD_FLAG_WIN_R		0x00020000
196 #define	UKBD_FLAG_EVENTS	0x00040000
197 #define	UKBD_FLAG_NUMLOCK	0x00080000
198 #define	UKBD_FLAG_CAPSLOCK	0x00100000
199 #define	UKBD_FLAG_SCROLLLOCK 	0x00200000
200 
201 	int	sc_mode;		/* input mode (K_XLATE,K_RAW,K_CODE) */
202 	int	sc_state;		/* shift/lock key state */
203 	int	sc_accents;		/* accent key index (> 0) */
204 	int	sc_led_size;
205 	int	sc_kbd_size;
206 
207 	uint16_t sc_inputs;
208 	uint16_t sc_inputhead;
209 	uint16_t sc_inputtail;
210 	uint16_t sc_modifiers;
211 
212 	uint8_t	sc_leds;		/* store for async led requests */
213 	uint8_t	sc_iface_index;
214 	uint8_t	sc_iface_no;
215 	uint8_t sc_id_apple_eject;
216 	uint8_t sc_id_apple_fn;
217 	uint8_t sc_id_ctrl_l;
218 	uint8_t sc_id_ctrl_r;
219 	uint8_t sc_id_shift_l;
220 	uint8_t sc_id_shift_r;
221 	uint8_t sc_id_alt_l;
222 	uint8_t sc_id_alt_r;
223 	uint8_t sc_id_win_l;
224 	uint8_t sc_id_win_r;
225 	uint8_t sc_id_event;
226 	uint8_t sc_id_numlock;
227 	uint8_t sc_id_capslock;
228 	uint8_t sc_id_scrolllock;
229 	uint8_t sc_id_events;
230 	uint8_t sc_kbd_id;
231 
232 	uint8_t sc_buffer[UKBD_BUFFER_SIZE];
233 };
234 
235 #define	KEY_ERROR	  0x01
236 
237 #define	KEY_PRESS	  0
238 #define	KEY_RELEASE	  0x400
239 #define	KEY_INDEX(c)	  ((c) & 0xFF)
240 
241 #define	SCAN_PRESS	  0
242 #define	SCAN_RELEASE	  0x80
243 #define	SCAN_PREFIX_E0	  0x100
244 #define	SCAN_PREFIX_E1	  0x200
245 #define	SCAN_PREFIX_CTL	  0x400
246 #define	SCAN_PREFIX_SHIFT 0x800
247 #define	SCAN_PREFIX	(SCAN_PREFIX_E0  | SCAN_PREFIX_E1 | \
248 			 SCAN_PREFIX_CTL | SCAN_PREFIX_SHIFT)
249 #define	SCAN_CHAR(c)	((c) & 0x7f)
250 
251 #define	UKBD_LOCK()	mtx_lock(&Giant)
252 #define	UKBD_UNLOCK()	mtx_unlock(&Giant)
253 
254 #ifdef	INVARIANTS
255 
256 /*
257  * Assert that the lock is held in all contexts
258  * where the code can be executed.
259  */
260 #define	UKBD_LOCK_ASSERT()	mtx_assert(&Giant, MA_OWNED)
261 
262 /*
263  * Assert that the lock is held in the contexts
264  * where it really has to be so.
265  */
266 #define	UKBD_CTX_LOCK_ASSERT()			 	\
267 	do {						\
268 		if (!kdb_active && panicstr == NULL)	\
269 			mtx_assert(&Giant, MA_OWNED);	\
270 	} while (0)
271 #else
272 
273 #define UKBD_LOCK_ASSERT()	(void)0
274 #define UKBD_CTX_LOCK_ASSERT()	(void)0
275 
276 #endif
277 
278 struct ukbd_mods {
279 	uint32_t mask, key;
280 };
281 
282 static const struct ukbd_mods ukbd_mods[UKBD_NMOD] = {
283 	{MOD_CONTROL_L, 0xe0},
284 	{MOD_CONTROL_R, 0xe4},
285 	{MOD_SHIFT_L, 0xe1},
286 	{MOD_SHIFT_R, 0xe5},
287 	{MOD_ALT_L, 0xe2},
288 	{MOD_ALT_R, 0xe6},
289 	{MOD_WIN_L, 0xe3},
290 	{MOD_WIN_R, 0xe7},
291 };
292 
293 #define	NN 0				/* no translation */
294 /*
295  * Translate USB keycodes to AT keyboard scancodes.
296  */
297 /*
298  * FIXME: Mac USB keyboard generates:
299  * 0x53: keypad NumLock/Clear
300  * 0x66: Power
301  * 0x67: keypad =
302  * 0x68: F13
303  * 0x69: F14
304  * 0x6a: F15
305  */
306 static const uint8_t ukbd_trtab[256] = {
307 	0, 0, 0, 0, 30, 48, 46, 32,	/* 00 - 07 */
308 	18, 33, 34, 35, 23, 36, 37, 38,	/* 08 - 0F */
309 	50, 49, 24, 25, 16, 19, 31, 20,	/* 10 - 17 */
310 	22, 47, 17, 45, 21, 44, 2, 3,	/* 18 - 1F */
311 	4, 5, 6, 7, 8, 9, 10, 11,	/* 20 - 27 */
312 	28, 1, 14, 15, 57, 12, 13, 26,	/* 28 - 2F */
313 	27, 43, 43, 39, 40, 41, 51, 52,	/* 30 - 37 */
314 	53, 58, 59, 60, 61, 62, 63, 64,	/* 38 - 3F */
315 	65, 66, 67, 68, 87, 88, 92, 70,	/* 40 - 47 */
316 	104, 102, 94, 96, 103, 99, 101, 98,	/* 48 - 4F */
317 	97, 100, 95, 69, 91, 55, 74, 78,/* 50 - 57 */
318 	89, 79, 80, 81, 75, 76, 77, 71,	/* 58 - 5F */
319 	72, 73, 82, 83, 86, 107, 122, NN,	/* 60 - 67 */
320 	NN, NN, NN, NN, NN, NN, NN, NN,	/* 68 - 6F */
321 	NN, NN, NN, NN, 115, 108, 111, 113,	/* 70 - 77 */
322 	109, 110, 112, 118, 114, 116, 117, 119,	/* 78 - 7F */
323 	121, 120, NN, NN, NN, NN, NN, 123,	/* 80 - 87 */
324 	124, 125, 126, 127, 128, NN, NN, NN,	/* 88 - 8F */
325 	NN, NN, NN, NN, NN, NN, NN, NN,	/* 90 - 97 */
326 	NN, NN, NN, NN, NN, NN, NN, NN,	/* 98 - 9F */
327 	NN, NN, NN, NN, NN, NN, NN, NN,	/* A0 - A7 */
328 	NN, NN, NN, NN, NN, NN, NN, NN,	/* A8 - AF */
329 	NN, NN, NN, NN, NN, NN, NN, NN,	/* B0 - B7 */
330 	NN, NN, NN, NN, NN, NN, NN, NN,	/* B8 - BF */
331 	NN, NN, NN, NN, NN, NN, NN, NN,	/* C0 - C7 */
332 	NN, NN, NN, NN, NN, NN, NN, NN,	/* C8 - CF */
333 	NN, NN, NN, NN, NN, NN, NN, NN,	/* D0 - D7 */
334 	NN, NN, NN, NN, NN, NN, NN, NN,	/* D8 - DF */
335 	29, 42, 56, 105, 90, 54, 93, 106,	/* E0 - E7 */
336 	NN, NN, NN, NN, NN, NN, NN, NN,	/* E8 - EF */
337 	NN, NN, NN, NN, NN, NN, NN, NN,	/* F0 - F7 */
338 	NN, NN, NN, NN, NN, NN, NN, NN,	/* F8 - FF */
339 };
340 
341 static const uint8_t ukbd_boot_desc[] = {
342 	0x05, 0x01, 0x09, 0x06, 0xa1,
343 	0x01, 0x05, 0x07, 0x19, 0xe0,
344 	0x29, 0xe7, 0x15, 0x00, 0x25,
345 	0x01, 0x75, 0x01, 0x95, 0x08,
346 	0x81, 0x02, 0x95, 0x01, 0x75,
347 	0x08, 0x81, 0x01, 0x95, 0x03,
348 	0x75, 0x01, 0x05, 0x08, 0x19,
349 	0x01, 0x29, 0x03, 0x91, 0x02,
350 	0x95, 0x05, 0x75, 0x01, 0x91,
351 	0x01, 0x95, 0x06, 0x75, 0x08,
352 	0x15, 0x00, 0x26, 0xff, 0x00,
353 	0x05, 0x07, 0x19, 0x00, 0x2a,
354 	0xff, 0x00, 0x81, 0x00, 0xc0
355 };
356 
357 /* prototypes */
358 static void	ukbd_timeout(void *);
359 static void	ukbd_set_leds(struct ukbd_softc *, uint8_t);
360 static int	ukbd_set_typematic(keyboard_t *, int);
361 #ifdef UKBD_EMULATE_ATSCANCODE
362 static int	ukbd_key2scan(struct ukbd_softc *, int, int, int);
363 #endif
364 static uint32_t	ukbd_read_char(keyboard_t *, int);
365 static void	ukbd_clear_state(keyboard_t *);
366 static int	ukbd_ioctl(keyboard_t *, u_long, caddr_t);
367 static int	ukbd_enable(keyboard_t *);
368 static int	ukbd_disable(keyboard_t *);
369 static void	ukbd_interrupt(struct ukbd_softc *);
370 static void	ukbd_event_keyinput(struct ukbd_softc *);
371 
372 static device_probe_t ukbd_probe;
373 static device_attach_t ukbd_attach;
374 static device_detach_t ukbd_detach;
375 static device_resume_t ukbd_resume;
376 
377 static uint8_t
378 ukbd_any_key_pressed(struct ukbd_softc *sc)
379 {
380 	uint8_t i;
381 	uint8_t j;
382 
383 	for (j = i = 0; i < UKBD_NKEYCODE; i++)
384 		j |= sc->sc_odata.keycode[i];
385 
386 	return (j ? 1 : 0);
387 }
388 
389 static void
390 ukbd_start_timer(struct ukbd_softc *sc)
391 {
392 	sc->sc_flags |= UKBD_FLAG_TIMER_RUNNING;
393 	usb_callout_reset(&sc->sc_callout, hz / 40, &ukbd_timeout, sc);
394 }
395 
396 static void
397 ukbd_put_key(struct ukbd_softc *sc, uint32_t key)
398 {
399 
400 	UKBD_CTX_LOCK_ASSERT();
401 
402 	DPRINTF("0x%02x (%d) %s\n", key, key,
403 	    (key & KEY_RELEASE) ? "released" : "pressed");
404 
405 	if (sc->sc_inputs < UKBD_IN_BUF_SIZE) {
406 		sc->sc_input[sc->sc_inputtail] = key;
407 		++(sc->sc_inputs);
408 		++(sc->sc_inputtail);
409 		if (sc->sc_inputtail >= UKBD_IN_BUF_SIZE) {
410 			sc->sc_inputtail = 0;
411 		}
412 	} else {
413 		DPRINTF("input buffer is full\n");
414 	}
415 }
416 
417 static void
418 ukbd_do_poll(struct ukbd_softc *sc, uint8_t wait)
419 {
420 
421 	UKBD_CTX_LOCK_ASSERT();
422 	KASSERT((sc->sc_flags & UKBD_FLAG_POLLING) != 0,
423 	    ("ukbd_do_poll called when not polling\n"));
424 	DPRINTFN(2, "polling\n");
425 
426 	if (!kdb_active && !SCHEDULER_STOPPED()) {
427 		/*
428 		 * In this context the kernel is polling for input,
429 		 * but the USB subsystem works in normal interrupt-driven
430 		 * mode, so we just wait on the USB threads to do the job.
431 		 * Note that we currently hold the Giant, but it's also used
432 		 * as the transfer mtx, so we must release it while waiting.
433 		 */
434 		while (sc->sc_inputs == 0) {
435 			/*
436 			 * Give USB threads a chance to run.  Note that
437 			 * kern_yield performs DROP_GIANT + PICKUP_GIANT.
438 			 */
439 			kern_yield(PRI_UNCHANGED);
440 			if (!wait)
441 				break;
442 		}
443 		return;
444 	}
445 
446 	while (sc->sc_inputs == 0) {
447 
448 		usbd_transfer_poll(sc->sc_xfer, UKBD_N_TRANSFER);
449 
450 		/* Delay-optimised support for repetition of keys */
451 		if (ukbd_any_key_pressed(sc)) {
452 			/* a key is pressed - need timekeeping */
453 			DELAY(1000);
454 
455 			/* 1 millisecond has passed */
456 			sc->sc_time_ms += 1;
457 		}
458 
459 		ukbd_interrupt(sc);
460 
461 		if (!wait)
462 			break;
463 	}
464 }
465 
466 static int32_t
467 ukbd_get_key(struct ukbd_softc *sc, uint8_t wait)
468 {
469 	int32_t c;
470 
471 	UKBD_CTX_LOCK_ASSERT();
472 	KASSERT((!kdb_active && !SCHEDULER_STOPPED())
473 	    || (sc->sc_flags & UKBD_FLAG_POLLING) != 0,
474 	    ("not polling in kdb or panic\n"));
475 
476 	if (sc->sc_inputs == 0 &&
477 	    (sc->sc_flags & UKBD_FLAG_GONE) == 0) {
478 		/* start transfer, if not already started */
479 		usbd_transfer_start(sc->sc_xfer[UKBD_INTR_DT]);
480 	}
481 
482 	if (sc->sc_flags & UKBD_FLAG_POLLING)
483 		ukbd_do_poll(sc, wait);
484 
485 	if (sc->sc_inputs == 0) {
486 		c = -1;
487 	} else {
488 		c = sc->sc_input[sc->sc_inputhead];
489 		--(sc->sc_inputs);
490 		++(sc->sc_inputhead);
491 		if (sc->sc_inputhead >= UKBD_IN_BUF_SIZE) {
492 			sc->sc_inputhead = 0;
493 		}
494 	}
495 	return (c);
496 }
497 
498 static void
499 ukbd_interrupt(struct ukbd_softc *sc)
500 {
501 	uint32_t n_mod;
502 	uint32_t o_mod;
503 	uint32_t now = sc->sc_time_ms;
504 	uint32_t dtime;
505 	uint8_t key;
506 	uint8_t i;
507 	uint8_t j;
508 
509 	UKBD_CTX_LOCK_ASSERT();
510 
511 	if (sc->sc_ndata.keycode[0] == KEY_ERROR)
512 		return;
513 
514 	n_mod = sc->sc_ndata.modifiers;
515 	o_mod = sc->sc_odata.modifiers;
516 	if (n_mod != o_mod) {
517 		for (i = 0; i < UKBD_NMOD; i++) {
518 			if ((n_mod & ukbd_mods[i].mask) !=
519 			    (o_mod & ukbd_mods[i].mask)) {
520 				ukbd_put_key(sc, ukbd_mods[i].key |
521 				    ((n_mod & ukbd_mods[i].mask) ?
522 				    KEY_PRESS : KEY_RELEASE));
523 			}
524 		}
525 	}
526 	/* Check for released keys. */
527 	for (i = 0; i < UKBD_NKEYCODE; i++) {
528 		key = sc->sc_odata.keycode[i];
529 		if (key == 0) {
530 			continue;
531 		}
532 		for (j = 0; j < UKBD_NKEYCODE; j++) {
533 			if (sc->sc_ndata.keycode[j] == 0) {
534 				continue;
535 			}
536 			if (key == sc->sc_ndata.keycode[j]) {
537 				goto rfound;
538 			}
539 		}
540 		ukbd_put_key(sc, key | KEY_RELEASE);
541 rfound:	;
542 	}
543 
544 	/* Check for pressed keys. */
545 	for (i = 0; i < UKBD_NKEYCODE; i++) {
546 		key = sc->sc_ndata.keycode[i];
547 		if (key == 0) {
548 			continue;
549 		}
550 		sc->sc_ntime[i] = now + sc->sc_kbd.kb_delay1;
551 		for (j = 0; j < UKBD_NKEYCODE; j++) {
552 			if (sc->sc_odata.keycode[j] == 0) {
553 				continue;
554 			}
555 			if (key == sc->sc_odata.keycode[j]) {
556 
557 				/* key is still pressed */
558 
559 				sc->sc_ntime[i] = sc->sc_otime[j];
560 				dtime = (sc->sc_otime[j] - now);
561 
562 				if (!(dtime & 0x80000000)) {
563 					/* time has not elapsed */
564 					goto pfound;
565 				}
566 				sc->sc_ntime[i] = now + sc->sc_kbd.kb_delay2;
567 				break;
568 			}
569 		}
570 		ukbd_put_key(sc, key | KEY_PRESS);
571 
572 		/*
573                  * If any other key is presently down, force its repeat to be
574                  * well in the future (100s).  This makes the last key to be
575                  * pressed do the autorepeat.
576                  */
577 		for (j = 0; j != UKBD_NKEYCODE; j++) {
578 			if (j != i)
579 				sc->sc_ntime[j] = now + (100 * 1000);
580 		}
581 pfound:	;
582 	}
583 
584 	sc->sc_odata = sc->sc_ndata;
585 
586 	memcpy(sc->sc_otime, sc->sc_ntime, sizeof(sc->sc_otime));
587 
588 	ukbd_event_keyinput(sc);
589 }
590 
591 static void
592 ukbd_event_keyinput(struct ukbd_softc *sc)
593 {
594 	int c;
595 
596 	UKBD_CTX_LOCK_ASSERT();
597 
598 	if ((sc->sc_flags & UKBD_FLAG_POLLING) != 0)
599 		return;
600 
601 	if (sc->sc_inputs == 0)
602 		return;
603 
604 	if (KBD_IS_ACTIVE(&sc->sc_kbd) &&
605 	    KBD_IS_BUSY(&sc->sc_kbd)) {
606 		/* let the callback function process the input */
607 		(sc->sc_kbd.kb_callback.kc_func) (&sc->sc_kbd, KBDIO_KEYINPUT,
608 		    sc->sc_kbd.kb_callback.kc_arg);
609 	} else {
610 		/* read and discard the input, no one is waiting for it */
611 		do {
612 			c = ukbd_read_char(&sc->sc_kbd, 0);
613 		} while (c != NOKEY);
614 	}
615 }
616 
617 static void
618 ukbd_timeout(void *arg)
619 {
620 	struct ukbd_softc *sc = arg;
621 
622 	UKBD_LOCK_ASSERT();
623 
624 	sc->sc_time_ms += 25;	/* milliseconds */
625 
626 	ukbd_interrupt(sc);
627 
628 	/* Make sure any leftover key events gets read out */
629 	ukbd_event_keyinput(sc);
630 
631 	if (ukbd_any_key_pressed(sc) || (sc->sc_inputs != 0)) {
632 		ukbd_start_timer(sc);
633 	} else {
634 		sc->sc_flags &= ~UKBD_FLAG_TIMER_RUNNING;
635 	}
636 }
637 
638 static uint8_t
639 ukbd_apple_fn(uint8_t keycode) {
640 	switch (keycode) {
641 	case 0x28: return 0x49; /* RETURN -> INSERT */
642 	case 0x2a: return 0x4c; /* BACKSPACE -> DEL */
643 	case 0x50: return 0x4a; /* LEFT ARROW -> HOME */
644 	case 0x4f: return 0x4d; /* RIGHT ARROW -> END */
645 	case 0x52: return 0x4b; /* UP ARROW -> PGUP */
646 	case 0x51: return 0x4e; /* DOWN ARROW -> PGDN */
647 	default: return keycode;
648 	}
649 }
650 
651 static uint8_t
652 ukbd_apple_swap(uint8_t keycode) {
653 	switch (keycode) {
654 	case 0x35: return 0x64;
655 	case 0x64: return 0x35;
656 	default: return keycode;
657 	}
658 }
659 
660 static void
661 ukbd_intr_callback(struct usb_xfer *xfer, usb_error_t error)
662 {
663 	struct ukbd_softc *sc = usbd_xfer_softc(xfer);
664 	struct usb_page_cache *pc;
665 	uint8_t i;
666 	uint8_t offset;
667 	uint8_t id;
668 	int len;
669 
670 	UKBD_LOCK_ASSERT();
671 
672 	usbd_xfer_status(xfer, &len, NULL, NULL, NULL);
673 	pc = usbd_xfer_get_frame(xfer, 0);
674 
675 	switch (USB_GET_STATE(xfer)) {
676 	case USB_ST_TRANSFERRED:
677 		DPRINTF("actlen=%d bytes\n", len);
678 
679 		if (len == 0) {
680 			DPRINTF("zero length data\n");
681 			goto tr_setup;
682 		}
683 
684 		if (sc->sc_kbd_id != 0) {
685 			/* check and remove HID ID byte */
686 			usbd_copy_out(pc, 0, &id, 1);
687 			offset = 1;
688 			len--;
689 			if (len == 0) {
690 				DPRINTF("zero length data\n");
691 				goto tr_setup;
692 			}
693 		} else {
694 			offset = 0;
695 			id = 0;
696 		}
697 
698 		if (len > UKBD_BUFFER_SIZE)
699 			len = UKBD_BUFFER_SIZE;
700 
701 		/* get data */
702 		usbd_copy_out(pc, offset, sc->sc_buffer, len);
703 
704 		/* clear temporary storage */
705 		memset(&sc->sc_ndata, 0, sizeof(sc->sc_ndata));
706 
707 		/* scan through HID data */
708 		if ((sc->sc_flags & UKBD_FLAG_APPLE_EJECT) &&
709 		    (id == sc->sc_id_apple_eject)) {
710 			if (hid_get_data(sc->sc_buffer, len, &sc->sc_loc_apple_eject))
711 				sc->sc_modifiers |= MOD_EJECT;
712 			else
713 				sc->sc_modifiers &= ~MOD_EJECT;
714 		}
715 		if ((sc->sc_flags & UKBD_FLAG_APPLE_FN) &&
716 		    (id == sc->sc_id_apple_fn)) {
717 			if (hid_get_data(sc->sc_buffer, len, &sc->sc_loc_apple_fn))
718 				sc->sc_modifiers |= MOD_FN;
719 			else
720 				sc->sc_modifiers &= ~MOD_FN;
721 		}
722 		if ((sc->sc_flags & UKBD_FLAG_CTRL_L) &&
723 		    (id == sc->sc_id_ctrl_l)) {
724 			if (hid_get_data(sc->sc_buffer, len, &sc->sc_loc_ctrl_l))
725 			  sc->	sc_modifiers |= MOD_CONTROL_L;
726 			else
727 			  sc->	sc_modifiers &= ~MOD_CONTROL_L;
728 		}
729 		if ((sc->sc_flags & UKBD_FLAG_CTRL_R) &&
730 		    (id == sc->sc_id_ctrl_r)) {
731 			if (hid_get_data(sc->sc_buffer, len, &sc->sc_loc_ctrl_r))
732 				sc->sc_modifiers |= MOD_CONTROL_R;
733 			else
734 				sc->sc_modifiers &= ~MOD_CONTROL_R;
735 		}
736 		if ((sc->sc_flags & UKBD_FLAG_SHIFT_L) &&
737 		    (id == sc->sc_id_shift_l)) {
738 			if (hid_get_data(sc->sc_buffer, len, &sc->sc_loc_shift_l))
739 				sc->sc_modifiers |= MOD_SHIFT_L;
740 			else
741 				sc->sc_modifiers &= ~MOD_SHIFT_L;
742 		}
743 		if ((sc->sc_flags & UKBD_FLAG_SHIFT_R) &&
744 		    (id == sc->sc_id_shift_r)) {
745 			if (hid_get_data(sc->sc_buffer, len, &sc->sc_loc_shift_r))
746 				sc->sc_modifiers |= MOD_SHIFT_R;
747 			else
748 				sc->sc_modifiers &= ~MOD_SHIFT_R;
749 		}
750 		if ((sc->sc_flags & UKBD_FLAG_ALT_L) &&
751 		    (id == sc->sc_id_alt_l)) {
752 			if (hid_get_data(sc->sc_buffer, len, &sc->sc_loc_alt_l))
753 				sc->sc_modifiers |= MOD_ALT_L;
754 			else
755 				sc->sc_modifiers &= ~MOD_ALT_L;
756 		}
757 		if ((sc->sc_flags & UKBD_FLAG_ALT_R) &&
758 		    (id == sc->sc_id_alt_r)) {
759 			if (hid_get_data(sc->sc_buffer, len, &sc->sc_loc_alt_r))
760 				sc->sc_modifiers |= MOD_ALT_R;
761 			else
762 				sc->sc_modifiers &= ~MOD_ALT_R;
763 		}
764 		if ((sc->sc_flags & UKBD_FLAG_WIN_L) &&
765 		    (id == sc->sc_id_win_l)) {
766 			if (hid_get_data(sc->sc_buffer, len, &sc->sc_loc_win_l))
767 				sc->sc_modifiers |= MOD_WIN_L;
768 			else
769 				sc->sc_modifiers &= ~MOD_WIN_L;
770 		}
771 		if ((sc->sc_flags & UKBD_FLAG_WIN_R) &&
772 		    (id == sc->sc_id_win_r)) {
773 			if (hid_get_data(sc->sc_buffer, len, &sc->sc_loc_win_r))
774 				sc->sc_modifiers |= MOD_WIN_R;
775 			else
776 				sc->sc_modifiers &= ~MOD_WIN_R;
777 		}
778 
779 		sc->sc_ndata.modifiers = sc->sc_modifiers;
780 
781 		if ((sc->sc_flags & UKBD_FLAG_EVENTS) &&
782 		    (id == sc->sc_id_events)) {
783 			i = sc->sc_loc_events.count;
784 			if (i > UKBD_NKEYCODE)
785 				i = UKBD_NKEYCODE;
786 			if (i > len)
787 				i = len;
788 			while (i--) {
789 				sc->sc_ndata.keycode[i] =
790 				    hid_get_data(sc->sc_buffer + i, len - i,
791 				    &sc->sc_loc_events);
792 			}
793 		}
794 
795 #ifdef USB_DEBUG
796 		DPRINTF("modifiers = 0x%04x\n", (int)sc->sc_modifiers);
797 		for (i = 0; i < UKBD_NKEYCODE; i++) {
798 			if (sc->sc_ndata.keycode[i]) {
799 				DPRINTF("[%d] = 0x%02x\n",
800 				    (int)i, (int)sc->sc_ndata.keycode[i]);
801 			}
802 		}
803 #endif
804 		if (sc->sc_modifiers & MOD_FN) {
805 			for (i = 0; i < UKBD_NKEYCODE; i++) {
806 				sc->sc_ndata.keycode[i] =
807 				    ukbd_apple_fn(sc->sc_ndata.keycode[i]);
808 			}
809 		}
810 
811 		if (sc->sc_flags & UKBD_FLAG_APPLE_SWAP) {
812 			for (i = 0; i < UKBD_NKEYCODE; i++) {
813 				sc->sc_ndata.keycode[i] =
814 				    ukbd_apple_swap(sc->sc_ndata.keycode[i]);
815 			}
816 		}
817 
818 		ukbd_interrupt(sc);
819 
820 		if (!(sc->sc_flags & UKBD_FLAG_TIMER_RUNNING)) {
821 			if (ukbd_any_key_pressed(sc)) {
822 				ukbd_start_timer(sc);
823 			}
824 		}
825 
826 	case USB_ST_SETUP:
827 tr_setup:
828 		if (sc->sc_inputs < UKBD_IN_BUF_FULL) {
829 			usbd_xfer_set_frame_len(xfer, 0, usbd_xfer_max_len(xfer));
830 			usbd_transfer_submit(xfer);
831 		} else {
832 			DPRINTF("input queue is full!\n");
833 		}
834 		break;
835 
836 	default:			/* Error */
837 		DPRINTF("error=%s\n", usbd_errstr(error));
838 
839 		if (error != USB_ERR_CANCELLED) {
840 			/* try to clear stall first */
841 			usbd_xfer_set_stall(xfer);
842 			goto tr_setup;
843 		}
844 		break;
845 	}
846 }
847 
848 static void
849 ukbd_set_leds_callback(struct usb_xfer *xfer, usb_error_t error)
850 {
851 	struct ukbd_softc *sc = usbd_xfer_softc(xfer);
852 	struct usb_device_request req;
853 	struct usb_page_cache *pc;
854 	uint8_t id;
855 	uint8_t any;
856 	int len;
857 
858 	UKBD_LOCK_ASSERT();
859 
860 #ifdef USB_DEBUG
861 	if (ukbd_no_leds)
862 		return;
863 #endif
864 
865 	switch (USB_GET_STATE(xfer)) {
866 	case USB_ST_TRANSFERRED:
867 	case USB_ST_SETUP:
868 		if (!(sc->sc_flags & UKBD_FLAG_SET_LEDS))
869 			break;
870 		sc->sc_flags &= ~UKBD_FLAG_SET_LEDS;
871 
872 		req.bmRequestType = UT_WRITE_CLASS_INTERFACE;
873 		req.bRequest = UR_SET_REPORT;
874 		USETW2(req.wValue, UHID_OUTPUT_REPORT, 0);
875 		req.wIndex[0] = sc->sc_iface_no;
876 		req.wIndex[1] = 0;
877 		req.wLength[1] = 0;
878 
879 		memset(sc->sc_buffer, 0, UKBD_BUFFER_SIZE);
880 
881 		id = 0;
882 		any = 0;
883 
884 		/* Assumption: All led bits must be in the same ID. */
885 
886 		if (sc->sc_flags & UKBD_FLAG_NUMLOCK) {
887 			if (sc->sc_leds & NLKED) {
888 				hid_put_data_unsigned(sc->sc_buffer + 1, UKBD_BUFFER_SIZE - 1,
889 				    &sc->sc_loc_numlock, 1);
890 			}
891 			id = sc->sc_id_numlock;
892 			any = 1;
893 		}
894 
895 		if (sc->sc_flags & UKBD_FLAG_SCROLLLOCK) {
896 			if (sc->sc_leds & SLKED) {
897 				hid_put_data_unsigned(sc->sc_buffer + 1, UKBD_BUFFER_SIZE - 1,
898 				    &sc->sc_loc_scrolllock, 1);
899 			}
900 			id = sc->sc_id_scrolllock;
901 			any = 1;
902 		}
903 
904 		if (sc->sc_flags & UKBD_FLAG_CAPSLOCK) {
905 			if (sc->sc_leds & CLKED) {
906 				hid_put_data_unsigned(sc->sc_buffer + 1, UKBD_BUFFER_SIZE - 1,
907 				    &sc->sc_loc_capslock, 1);
908 			}
909 			id = sc->sc_id_capslock;
910 			any = 1;
911 		}
912 
913 		/* if no leds, nothing to do */
914 		if (!any)
915 			break;
916 
917 		/* range check output report length */
918 		len = sc->sc_led_size;
919 		if (len > (UKBD_BUFFER_SIZE - 1))
920 			len = (UKBD_BUFFER_SIZE - 1);
921 
922 		/* check if we need to prefix an ID byte */
923 		sc->sc_buffer[0] = id;
924 
925 		pc = usbd_xfer_get_frame(xfer, 1);
926 		if (id != 0) {
927 			len++;
928 			usbd_copy_in(pc, 0, sc->sc_buffer, len);
929 		} else {
930 			usbd_copy_in(pc, 0, sc->sc_buffer + 1, len);
931 		}
932 		req.wLength[0] = len;
933 		usbd_xfer_set_frame_len(xfer, 1, len);
934 
935 		DPRINTF("len=%d, id=%d\n", len, id);
936 
937 		/* setup control request last */
938 		pc = usbd_xfer_get_frame(xfer, 0);
939 		usbd_copy_in(pc, 0, &req, sizeof(req));
940 		usbd_xfer_set_frame_len(xfer, 0, sizeof(req));
941 
942 		/* start data transfer */
943 		usbd_xfer_set_frames(xfer, 2);
944 		usbd_transfer_submit(xfer);
945 		break;
946 
947 	default:			/* Error */
948 		DPRINTFN(1, "error=%s\n", usbd_errstr(error));
949 		break;
950 	}
951 }
952 
953 static const struct usb_config ukbd_config[UKBD_N_TRANSFER] = {
954 
955 	[UKBD_INTR_DT] = {
956 		.type = UE_INTERRUPT,
957 		.endpoint = UE_ADDR_ANY,
958 		.direction = UE_DIR_IN,
959 		.flags = {.pipe_bof = 1,.short_xfer_ok = 1,},
960 		.bufsize = 0,	/* use wMaxPacketSize */
961 		.callback = &ukbd_intr_callback,
962 	},
963 
964 	[UKBD_CTRL_LED] = {
965 		.type = UE_CONTROL,
966 		.endpoint = 0x00,	/* Control pipe */
967 		.direction = UE_DIR_ANY,
968 		.bufsize = sizeof(struct usb_device_request) + UKBD_BUFFER_SIZE,
969 		.callback = &ukbd_set_leds_callback,
970 		.timeout = 1000,	/* 1 second */
971 	},
972 };
973 
974 /* A match on these entries will load ukbd */
975 static const STRUCT_USB_HOST_ID __used ukbd_devs[] = {
976 	{USB_IFACE_CLASS(UICLASS_HID),
977 	 USB_IFACE_SUBCLASS(UISUBCLASS_BOOT),
978 	 USB_IFACE_PROTOCOL(UIPROTO_BOOT_KEYBOARD),},
979 };
980 
981 static int
982 ukbd_probe(device_t dev)
983 {
984 	keyboard_switch_t *sw = kbd_get_switch(UKBD_DRIVER_NAME);
985 	struct usb_attach_arg *uaa = device_get_ivars(dev);
986 	void *d_ptr;
987 	int error;
988 	uint16_t d_len;
989 
990 	UKBD_LOCK_ASSERT();
991 	DPRINTFN(11, "\n");
992 
993 	if (sw == NULL) {
994 		return (ENXIO);
995 	}
996 	if (uaa->usb_mode != USB_MODE_HOST) {
997 		return (ENXIO);
998 	}
999 
1000 	if (uaa->info.bInterfaceClass != UICLASS_HID)
1001 		return (ENXIO);
1002 
1003 	if (usb_test_quirk(uaa, UQ_KBD_IGNORE))
1004 		return (ENXIO);
1005 
1006 	if ((uaa->info.bInterfaceSubClass == UISUBCLASS_BOOT) &&
1007 	    (uaa->info.bInterfaceProtocol == UIPROTO_BOOT_KEYBOARD))
1008 		return (BUS_PROBE_DEFAULT);
1009 
1010 	error = usbd_req_get_hid_desc(uaa->device, NULL,
1011 	    &d_ptr, &d_len, M_TEMP, uaa->info.bIfaceIndex);
1012 
1013 	if (error)
1014 		return (ENXIO);
1015 
1016 	if (hid_is_keyboard(d_ptr, d_len)) {
1017 		if (hid_is_mouse(d_ptr, d_len)) {
1018 			/*
1019 			 * NOTE: We currently don't support USB mouse
1020 			 * and USB keyboard on the same USB endpoint.
1021 			 * Let "ums" driver win.
1022 			 */
1023 			error = ENXIO;
1024 		} else {
1025 			error = BUS_PROBE_DEFAULT;
1026 		}
1027 	} else {
1028 		error = ENXIO;
1029 	}
1030 	free(d_ptr, M_TEMP);
1031 	return (error);
1032 }
1033 
1034 static void
1035 ukbd_parse_hid(struct ukbd_softc *sc, const uint8_t *ptr, uint32_t len)
1036 {
1037 	uint32_t flags;
1038 
1039 	/* reset detected bits */
1040 	sc->sc_flags &= ~UKBD_FLAG_HID_MASK;
1041 
1042 	/* check if there is an ID byte */
1043 	sc->sc_kbd_size = hid_report_size(ptr, len,
1044 	    hid_input, &sc->sc_kbd_id);
1045 
1046 	/* investigate if this is an Apple Keyboard */
1047 	if (hid_locate(ptr, len,
1048 	    HID_USAGE2(HUP_CONSUMER, HUG_APPLE_EJECT),
1049 	    hid_input, 0, &sc->sc_loc_apple_eject, &flags,
1050 	    &sc->sc_id_apple_eject)) {
1051 		if (flags & HIO_VARIABLE)
1052 			sc->sc_flags |= UKBD_FLAG_APPLE_EJECT |
1053 			    UKBD_FLAG_APPLE_SWAP;
1054 		DPRINTFN(1, "Found Apple eject-key\n");
1055 	}
1056 	if (hid_locate(ptr, len,
1057 	    HID_USAGE2(0xFFFF, 0x0003),
1058 	    hid_input, 0, &sc->sc_loc_apple_fn, &flags,
1059 	    &sc->sc_id_apple_fn)) {
1060 		if (flags & HIO_VARIABLE)
1061 			sc->sc_flags |= UKBD_FLAG_APPLE_FN;
1062 		DPRINTFN(1, "Found Apple FN-key\n");
1063 	}
1064 	/* figure out some keys */
1065 	if (hid_locate(ptr, len,
1066 	    HID_USAGE2(HUP_KEYBOARD, 0xE0),
1067 	    hid_input, 0, &sc->sc_loc_ctrl_l, &flags,
1068 	    &sc->sc_id_ctrl_l)) {
1069 		if (flags & HIO_VARIABLE)
1070 			sc->sc_flags |= UKBD_FLAG_CTRL_L;
1071 		DPRINTFN(1, "Found left control\n");
1072 	}
1073 	if (hid_locate(ptr, len,
1074 	    HID_USAGE2(HUP_KEYBOARD, 0xE4),
1075 	    hid_input, 0, &sc->sc_loc_ctrl_r, &flags,
1076 	    &sc->sc_id_ctrl_r)) {
1077 		if (flags & HIO_VARIABLE)
1078 			sc->sc_flags |= UKBD_FLAG_CTRL_R;
1079 		DPRINTFN(1, "Found right control\n");
1080 	}
1081 	if (hid_locate(ptr, len,
1082 	    HID_USAGE2(HUP_KEYBOARD, 0xE1),
1083 	    hid_input, 0, &sc->sc_loc_shift_l, &flags,
1084 	    &sc->sc_id_shift_l)) {
1085 		if (flags & HIO_VARIABLE)
1086 			sc->sc_flags |= UKBD_FLAG_SHIFT_L;
1087 		DPRINTFN(1, "Found left shift\n");
1088 	}
1089 	if (hid_locate(ptr, len,
1090 	    HID_USAGE2(HUP_KEYBOARD, 0xE5),
1091 	    hid_input, 0, &sc->sc_loc_shift_r, &flags,
1092 	    &sc->sc_id_shift_r)) {
1093 		if (flags & HIO_VARIABLE)
1094 			sc->sc_flags |= UKBD_FLAG_SHIFT_R;
1095 		DPRINTFN(1, "Found right shift\n");
1096 	}
1097 	if (hid_locate(ptr, len,
1098 	    HID_USAGE2(HUP_KEYBOARD, 0xE2),
1099 	    hid_input, 0, &sc->sc_loc_alt_l, &flags,
1100 	    &sc->sc_id_alt_l)) {
1101 		if (flags & HIO_VARIABLE)
1102 			sc->sc_flags |= UKBD_FLAG_ALT_L;
1103 		DPRINTFN(1, "Found left alt\n");
1104 	}
1105 	if (hid_locate(ptr, len,
1106 	    HID_USAGE2(HUP_KEYBOARD, 0xE6),
1107 	    hid_input, 0, &sc->sc_loc_alt_r, &flags,
1108 	    &sc->sc_id_alt_r)) {
1109 		if (flags & HIO_VARIABLE)
1110 			sc->sc_flags |= UKBD_FLAG_ALT_R;
1111 		DPRINTFN(1, "Found right alt\n");
1112 	}
1113 	if (hid_locate(ptr, len,
1114 	    HID_USAGE2(HUP_KEYBOARD, 0xE3),
1115 	    hid_input, 0, &sc->sc_loc_win_l, &flags,
1116 	    &sc->sc_id_win_l)) {
1117 		if (flags & HIO_VARIABLE)
1118 			sc->sc_flags |= UKBD_FLAG_WIN_L;
1119 		DPRINTFN(1, "Found left GUI\n");
1120 	}
1121 	if (hid_locate(ptr, len,
1122 	    HID_USAGE2(HUP_KEYBOARD, 0xE7),
1123 	    hid_input, 0, &sc->sc_loc_win_r, &flags,
1124 	    &sc->sc_id_win_r)) {
1125 		if (flags & HIO_VARIABLE)
1126 			sc->sc_flags |= UKBD_FLAG_WIN_R;
1127 		DPRINTFN(1, "Found right GUI\n");
1128 	}
1129 	/* figure out event buffer */
1130 	if (hid_locate(ptr, len,
1131 	    HID_USAGE2(HUP_KEYBOARD, 0x00),
1132 	    hid_input, 0, &sc->sc_loc_events, &flags,
1133 	    &sc->sc_id_events)) {
1134 		if (flags & HIO_VARIABLE) {
1135 			DPRINTFN(1, "Ignoring keyboard event control\n");
1136 		} else {
1137 			sc->sc_flags |= UKBD_FLAG_EVENTS;
1138 			DPRINTFN(1, "Found keyboard event array\n");
1139 		}
1140 	}
1141 
1142 	/* figure out leds on keyboard */
1143 	sc->sc_led_size = hid_report_size(ptr, len,
1144 	    hid_output, NULL);
1145 
1146 	if (hid_locate(ptr, len,
1147 	    HID_USAGE2(HUP_LEDS, 0x01),
1148 	    hid_output, 0, &sc->sc_loc_numlock, &flags,
1149 	    &sc->sc_id_numlock)) {
1150 		if (flags & HIO_VARIABLE)
1151 			sc->sc_flags |= UKBD_FLAG_NUMLOCK;
1152 		DPRINTFN(1, "Found keyboard numlock\n");
1153 	}
1154 	if (hid_locate(ptr, len,
1155 	    HID_USAGE2(HUP_LEDS, 0x02),
1156 	    hid_output, 0, &sc->sc_loc_capslock, &flags,
1157 	    &sc->sc_id_capslock)) {
1158 		if (flags & HIO_VARIABLE)
1159 			sc->sc_flags |= UKBD_FLAG_CAPSLOCK;
1160 		DPRINTFN(1, "Found keyboard capslock\n");
1161 	}
1162 	if (hid_locate(ptr, len,
1163 	    HID_USAGE2(HUP_LEDS, 0x03),
1164 	    hid_output, 0, &sc->sc_loc_scrolllock, &flags,
1165 	    &sc->sc_id_scrolllock)) {
1166 		if (flags & HIO_VARIABLE)
1167 			sc->sc_flags |= UKBD_FLAG_SCROLLLOCK;
1168 		DPRINTFN(1, "Found keyboard scrolllock\n");
1169 	}
1170 }
1171 
1172 static int
1173 ukbd_attach(device_t dev)
1174 {
1175 	struct ukbd_softc *sc = device_get_softc(dev);
1176 	struct usb_attach_arg *uaa = device_get_ivars(dev);
1177 	int unit = device_get_unit(dev);
1178 	keyboard_t *kbd = &sc->sc_kbd;
1179 	void *hid_ptr = NULL;
1180 	usb_error_t err;
1181 	uint16_t n;
1182 	uint16_t hid_len;
1183 #ifdef USB_DEBUG
1184 	int rate;
1185 #endif
1186 	UKBD_LOCK_ASSERT();
1187 
1188 	kbd_init_struct(kbd, UKBD_DRIVER_NAME, KB_OTHER, unit, 0, 0, 0);
1189 
1190 	kbd->kb_data = (void *)sc;
1191 
1192 	device_set_usb_desc(dev);
1193 
1194 	sc->sc_udev = uaa->device;
1195 	sc->sc_iface = uaa->iface;
1196 	sc->sc_iface_index = uaa->info.bIfaceIndex;
1197 	sc->sc_iface_no = uaa->info.bIfaceNum;
1198 	sc->sc_mode = K_XLATE;
1199 
1200 	usb_callout_init_mtx(&sc->sc_callout, &Giant, 0);
1201 
1202 	err = usbd_transfer_setup(uaa->device,
1203 	    &uaa->info.bIfaceIndex, sc->sc_xfer, ukbd_config,
1204 	    UKBD_N_TRANSFER, sc, &Giant);
1205 
1206 	if (err) {
1207 		DPRINTF("error=%s\n", usbd_errstr(err));
1208 		goto detach;
1209 	}
1210 	/* setup default keyboard maps */
1211 
1212 	sc->sc_keymap = key_map;
1213 	sc->sc_accmap = accent_map;
1214 	for (n = 0; n < UKBD_NFKEY; n++) {
1215 		sc->sc_fkeymap[n] = fkey_tab[n];
1216 	}
1217 
1218 	kbd_set_maps(kbd, &sc->sc_keymap, &sc->sc_accmap,
1219 	    sc->sc_fkeymap, UKBD_NFKEY);
1220 
1221 	KBD_FOUND_DEVICE(kbd);
1222 
1223 	ukbd_clear_state(kbd);
1224 
1225 	/*
1226 	 * FIXME: set the initial value for lock keys in "sc_state"
1227 	 * according to the BIOS data?
1228 	 */
1229 	KBD_PROBE_DONE(kbd);
1230 
1231 	/* get HID descriptor */
1232 	err = usbd_req_get_hid_desc(uaa->device, NULL, &hid_ptr,
1233 	    &hid_len, M_TEMP, uaa->info.bIfaceIndex);
1234 
1235 	if (err == 0) {
1236 		DPRINTF("Parsing HID descriptor of %d bytes\n",
1237 		    (int)hid_len);
1238 
1239 		ukbd_parse_hid(sc, hid_ptr, hid_len);
1240 
1241 		free(hid_ptr, M_TEMP);
1242 	}
1243 
1244 	/* check if we should use the boot protocol */
1245 	if (usb_test_quirk(uaa, UQ_KBD_BOOTPROTO) ||
1246 	    (err != 0) || (!(sc->sc_flags & UKBD_FLAG_EVENTS))) {
1247 
1248 		DPRINTF("Forcing boot protocol\n");
1249 
1250 		err = usbd_req_set_protocol(sc->sc_udev, NULL,
1251 			sc->sc_iface_index, 0);
1252 
1253 		if (err != 0) {
1254 			DPRINTF("Set protocol error=%s (ignored)\n",
1255 			    usbd_errstr(err));
1256 		}
1257 
1258 		ukbd_parse_hid(sc, ukbd_boot_desc, sizeof(ukbd_boot_desc));
1259 	}
1260 
1261 	/* ignore if SETIDLE fails, hence it is not crucial */
1262 	usbd_req_set_idle(sc->sc_udev, NULL, sc->sc_iface_index, 0, 0);
1263 
1264 	ukbd_ioctl(kbd, KDSETLED, (caddr_t)&sc->sc_state);
1265 
1266 	KBD_INIT_DONE(kbd);
1267 
1268 	if (kbd_register(kbd) < 0) {
1269 		goto detach;
1270 	}
1271 	KBD_CONFIG_DONE(kbd);
1272 
1273 	ukbd_enable(kbd);
1274 
1275 #ifdef KBD_INSTALL_CDEV
1276 	if (kbd_attach(kbd)) {
1277 		goto detach;
1278 	}
1279 #endif
1280 	sc->sc_flags |= UKBD_FLAG_ATTACHED;
1281 
1282 	if (bootverbose) {
1283 		genkbd_diag(kbd, bootverbose);
1284 	}
1285 
1286 #ifdef USB_DEBUG
1287 	/* check for polling rate override */
1288 	rate = ukbd_pollrate;
1289 	if (rate > 0) {
1290 		if (rate > 1000)
1291 			rate = 1;
1292 		else
1293 			rate = 1000 / rate;
1294 
1295 		/* set new polling interval in ms */
1296 		usbd_xfer_set_interval(sc->sc_xfer[UKBD_INTR_DT], rate);
1297 	}
1298 #endif
1299 	/* start the keyboard */
1300 	usbd_transfer_start(sc->sc_xfer[UKBD_INTR_DT]);
1301 
1302 	return (0);			/* success */
1303 
1304 detach:
1305 	ukbd_detach(dev);
1306 	return (ENXIO);			/* error */
1307 }
1308 
1309 static int
1310 ukbd_detach(device_t dev)
1311 {
1312 	struct ukbd_softc *sc = device_get_softc(dev);
1313 	int error;
1314 
1315 	UKBD_LOCK_ASSERT();
1316 
1317 	DPRINTF("\n");
1318 
1319 	sc->sc_flags |= UKBD_FLAG_GONE;
1320 
1321 	usb_callout_stop(&sc->sc_callout);
1322 
1323 	/* kill any stuck keys */
1324 	if (sc->sc_flags & UKBD_FLAG_ATTACHED) {
1325 		/* stop receiving events from the USB keyboard */
1326 		usbd_transfer_stop(sc->sc_xfer[UKBD_INTR_DT]);
1327 
1328 		/* release all leftover keys, if any */
1329 		memset(&sc->sc_ndata, 0, sizeof(sc->sc_ndata));
1330 
1331 		/* process releasing of all keys */
1332 		ukbd_interrupt(sc);
1333 	}
1334 
1335 	ukbd_disable(&sc->sc_kbd);
1336 
1337 #ifdef KBD_INSTALL_CDEV
1338 	if (sc->sc_flags & UKBD_FLAG_ATTACHED) {
1339 		error = kbd_detach(&sc->sc_kbd);
1340 		if (error) {
1341 			/* usb attach cannot return an error */
1342 			device_printf(dev, "WARNING: kbd_detach() "
1343 			    "returned non-zero! (ignored)\n");
1344 		}
1345 	}
1346 #endif
1347 	if (KBD_IS_CONFIGURED(&sc->sc_kbd)) {
1348 		error = kbd_unregister(&sc->sc_kbd);
1349 		if (error) {
1350 			/* usb attach cannot return an error */
1351 			device_printf(dev, "WARNING: kbd_unregister() "
1352 			    "returned non-zero! (ignored)\n");
1353 		}
1354 	}
1355 	sc->sc_kbd.kb_flags = 0;
1356 
1357 	usbd_transfer_unsetup(sc->sc_xfer, UKBD_N_TRANSFER);
1358 
1359 	usb_callout_drain(&sc->sc_callout);
1360 
1361 	DPRINTF("%s: disconnected\n",
1362 	    device_get_nameunit(dev));
1363 
1364 	return (0);
1365 }
1366 
1367 static int
1368 ukbd_resume(device_t dev)
1369 {
1370 	struct ukbd_softc *sc = device_get_softc(dev);
1371 
1372 	UKBD_LOCK_ASSERT();
1373 
1374 	ukbd_clear_state(&sc->sc_kbd);
1375 
1376 	return (0);
1377 }
1378 
1379 /* early keyboard probe, not supported */
1380 static int
1381 ukbd_configure(int flags)
1382 {
1383 	return (0);
1384 }
1385 
1386 /* detect a keyboard, not used */
1387 static int
1388 ukbd__probe(int unit, void *arg, int flags)
1389 {
1390 	return (ENXIO);
1391 }
1392 
1393 /* reset and initialize the device, not used */
1394 static int
1395 ukbd_init(int unit, keyboard_t **kbdp, void *arg, int flags)
1396 {
1397 	return (ENXIO);
1398 }
1399 
1400 /* test the interface to the device, not used */
1401 static int
1402 ukbd_test_if(keyboard_t *kbd)
1403 {
1404 	return (0);
1405 }
1406 
1407 /* finish using this keyboard, not used */
1408 static int
1409 ukbd_term(keyboard_t *kbd)
1410 {
1411 	return (ENXIO);
1412 }
1413 
1414 /* keyboard interrupt routine, not used */
1415 static int
1416 ukbd_intr(keyboard_t *kbd, void *arg)
1417 {
1418 	return (0);
1419 }
1420 
1421 /* lock the access to the keyboard, not used */
1422 static int
1423 ukbd_lock(keyboard_t *kbd, int lock)
1424 {
1425 	return (1);
1426 }
1427 
1428 /*
1429  * Enable the access to the device; until this function is called,
1430  * the client cannot read from the keyboard.
1431  */
1432 static int
1433 ukbd_enable(keyboard_t *kbd)
1434 {
1435 
1436 	UKBD_LOCK();
1437 	KBD_ACTIVATE(kbd);
1438 	UKBD_UNLOCK();
1439 
1440 	return (0);
1441 }
1442 
1443 /* disallow the access to the device */
1444 static int
1445 ukbd_disable(keyboard_t *kbd)
1446 {
1447 
1448 	UKBD_LOCK();
1449 	KBD_DEACTIVATE(kbd);
1450 	UKBD_UNLOCK();
1451 
1452 	return (0);
1453 }
1454 
1455 /* check if data is waiting */
1456 /* Currently unused. */
1457 static int
1458 ukbd_check(keyboard_t *kbd)
1459 {
1460 	struct ukbd_softc *sc = kbd->kb_data;
1461 
1462 	UKBD_CTX_LOCK_ASSERT();
1463 
1464 	if (!KBD_IS_ACTIVE(kbd))
1465 		return (0);
1466 
1467 	if (sc->sc_flags & UKBD_FLAG_POLLING)
1468 		ukbd_do_poll(sc, 0);
1469 
1470 #ifdef UKBD_EMULATE_ATSCANCODE
1471 	if (sc->sc_buffered_char[0]) {
1472 		return (1);
1473 	}
1474 #endif
1475 	if (sc->sc_inputs > 0) {
1476 		return (1);
1477 	}
1478 	return (0);
1479 }
1480 
1481 /* check if char is waiting */
1482 static int
1483 ukbd_check_char_locked(keyboard_t *kbd)
1484 {
1485 	struct ukbd_softc *sc = kbd->kb_data;
1486 
1487 	UKBD_CTX_LOCK_ASSERT();
1488 
1489 	if (!KBD_IS_ACTIVE(kbd))
1490 		return (0);
1491 
1492 	if ((sc->sc_composed_char > 0) &&
1493 	    (!(sc->sc_flags & UKBD_FLAG_COMPOSE))) {
1494 		return (1);
1495 	}
1496 	return (ukbd_check(kbd));
1497 }
1498 
1499 static int
1500 ukbd_check_char(keyboard_t *kbd)
1501 {
1502 	int result;
1503 
1504 	UKBD_LOCK();
1505 	result = ukbd_check_char_locked(kbd);
1506 	UKBD_UNLOCK();
1507 
1508 	return (result);
1509 }
1510 
1511 /* read one byte from the keyboard if it's allowed */
1512 /* Currently unused. */
1513 static int
1514 ukbd_read(keyboard_t *kbd, int wait)
1515 {
1516 	struct ukbd_softc *sc = kbd->kb_data;
1517 	int32_t usbcode;
1518 #ifdef UKBD_EMULATE_ATSCANCODE
1519 	uint32_t keycode;
1520 	uint32_t scancode;
1521 
1522 #endif
1523 
1524 	UKBD_CTX_LOCK_ASSERT();
1525 
1526 	if (!KBD_IS_ACTIVE(kbd))
1527 		return (-1);
1528 
1529 #ifdef UKBD_EMULATE_ATSCANCODE
1530 	if (sc->sc_buffered_char[0]) {
1531 		scancode = sc->sc_buffered_char[0];
1532 		if (scancode & SCAN_PREFIX) {
1533 			sc->sc_buffered_char[0] &= ~SCAN_PREFIX;
1534 			return ((scancode & SCAN_PREFIX_E0) ? 0xe0 : 0xe1);
1535 		}
1536 		sc->sc_buffered_char[0] = sc->sc_buffered_char[1];
1537 		sc->sc_buffered_char[1] = 0;
1538 		return (scancode);
1539 	}
1540 #endif					/* UKBD_EMULATE_ATSCANCODE */
1541 
1542 	/* XXX */
1543 	usbcode = ukbd_get_key(sc, (wait == FALSE) ? 0 : 1);
1544 	if (!KBD_IS_ACTIVE(kbd) || (usbcode == -1))
1545 		return (-1);
1546 
1547 	++(kbd->kb_count);
1548 
1549 #ifdef UKBD_EMULATE_ATSCANCODE
1550 	keycode = ukbd_trtab[KEY_INDEX(usbcode)];
1551 	if (keycode == NN) {
1552 		return -1;
1553 	}
1554 	return (ukbd_key2scan(sc, keycode, sc->sc_ndata.modifiers,
1555 	    (usbcode & KEY_RELEASE)));
1556 #else					/* !UKBD_EMULATE_ATSCANCODE */
1557 	return (usbcode);
1558 #endif					/* UKBD_EMULATE_ATSCANCODE */
1559 }
1560 
1561 /* read char from the keyboard */
1562 static uint32_t
1563 ukbd_read_char_locked(keyboard_t *kbd, int wait)
1564 {
1565 	struct ukbd_softc *sc = kbd->kb_data;
1566 	uint32_t action;
1567 	uint32_t keycode;
1568 	int32_t usbcode;
1569 #ifdef UKBD_EMULATE_ATSCANCODE
1570 	uint32_t scancode;
1571 #endif
1572 
1573 	UKBD_CTX_LOCK_ASSERT();
1574 
1575 	if (!KBD_IS_ACTIVE(kbd))
1576 		return (NOKEY);
1577 
1578 next_code:
1579 
1580 	/* do we have a composed char to return ? */
1581 
1582 	if ((sc->sc_composed_char > 0) &&
1583 	    (!(sc->sc_flags & UKBD_FLAG_COMPOSE))) {
1584 
1585 		action = sc->sc_composed_char;
1586 		sc->sc_composed_char = 0;
1587 
1588 		if (action > 0xFF) {
1589 			goto errkey;
1590 		}
1591 		goto done;
1592 	}
1593 #ifdef UKBD_EMULATE_ATSCANCODE
1594 
1595 	/* do we have a pending raw scan code? */
1596 
1597 	if (sc->sc_mode == K_RAW) {
1598 		scancode = sc->sc_buffered_char[0];
1599 		if (scancode) {
1600 			if (scancode & SCAN_PREFIX) {
1601 				sc->sc_buffered_char[0] = (scancode & ~SCAN_PREFIX);
1602 				return ((scancode & SCAN_PREFIX_E0) ? 0xe0 : 0xe1);
1603 			}
1604 			sc->sc_buffered_char[0] = sc->sc_buffered_char[1];
1605 			sc->sc_buffered_char[1] = 0;
1606 			return (scancode);
1607 		}
1608 	}
1609 #endif					/* UKBD_EMULATE_ATSCANCODE */
1610 
1611 	/* see if there is something in the keyboard port */
1612 	/* XXX */
1613 	usbcode = ukbd_get_key(sc, (wait == FALSE) ? 0 : 1);
1614 	if (usbcode == -1) {
1615 		return (NOKEY);
1616 	}
1617 	++kbd->kb_count;
1618 
1619 #ifdef UKBD_EMULATE_ATSCANCODE
1620 	/* USB key index -> key code -> AT scan code */
1621 	keycode = ukbd_trtab[KEY_INDEX(usbcode)];
1622 	if (keycode == NN) {
1623 		return (NOKEY);
1624 	}
1625 	/* return an AT scan code for the K_RAW mode */
1626 	if (sc->sc_mode == K_RAW) {
1627 		return (ukbd_key2scan(sc, keycode, sc->sc_ndata.modifiers,
1628 		    (usbcode & KEY_RELEASE)));
1629 	}
1630 #else					/* !UKBD_EMULATE_ATSCANCODE */
1631 
1632 	/* return the byte as is for the K_RAW mode */
1633 	if (sc->sc_mode == K_RAW) {
1634 		return (usbcode);
1635 	}
1636 	/* USB key index -> key code */
1637 	keycode = ukbd_trtab[KEY_INDEX(usbcode)];
1638 	if (keycode == NN) {
1639 		return (NOKEY);
1640 	}
1641 #endif					/* UKBD_EMULATE_ATSCANCODE */
1642 
1643 	switch (keycode) {
1644 	case 0x38:			/* left alt (compose key) */
1645 		if (usbcode & KEY_RELEASE) {
1646 			if (sc->sc_flags & UKBD_FLAG_COMPOSE) {
1647 				sc->sc_flags &= ~UKBD_FLAG_COMPOSE;
1648 
1649 				if (sc->sc_composed_char > 0xFF) {
1650 					sc->sc_composed_char = 0;
1651 				}
1652 			}
1653 		} else {
1654 			if (!(sc->sc_flags & UKBD_FLAG_COMPOSE)) {
1655 				sc->sc_flags |= UKBD_FLAG_COMPOSE;
1656 				sc->sc_composed_char = 0;
1657 			}
1658 		}
1659 		break;
1660 		/* XXX: I don't like these... */
1661 	case 0x5c:			/* print screen */
1662 		if (sc->sc_flags & ALTS) {
1663 			keycode = 0x54;	/* sysrq */
1664 		}
1665 		break;
1666 	case 0x68:			/* pause/break */
1667 		if (sc->sc_flags & CTLS) {
1668 			keycode = 0x6c;	/* break */
1669 		}
1670 		break;
1671 	}
1672 
1673 	/* return the key code in the K_CODE mode */
1674 	if (usbcode & KEY_RELEASE) {
1675 		keycode |= SCAN_RELEASE;
1676 	}
1677 	if (sc->sc_mode == K_CODE) {
1678 		return (keycode);
1679 	}
1680 	/* compose a character code */
1681 	if (sc->sc_flags & UKBD_FLAG_COMPOSE) {
1682 		switch (keycode) {
1683 			/* key pressed, process it */
1684 		case 0x47:
1685 		case 0x48:
1686 		case 0x49:		/* keypad 7,8,9 */
1687 			sc->sc_composed_char *= 10;
1688 			sc->sc_composed_char += keycode - 0x40;
1689 			goto check_composed;
1690 
1691 		case 0x4B:
1692 		case 0x4C:
1693 		case 0x4D:		/* keypad 4,5,6 */
1694 			sc->sc_composed_char *= 10;
1695 			sc->sc_composed_char += keycode - 0x47;
1696 			goto check_composed;
1697 
1698 		case 0x4F:
1699 		case 0x50:
1700 		case 0x51:		/* keypad 1,2,3 */
1701 			sc->sc_composed_char *= 10;
1702 			sc->sc_composed_char += keycode - 0x4E;
1703 			goto check_composed;
1704 
1705 		case 0x52:		/* keypad 0 */
1706 			sc->sc_composed_char *= 10;
1707 			goto check_composed;
1708 
1709 			/* key released, no interest here */
1710 		case SCAN_RELEASE | 0x47:
1711 		case SCAN_RELEASE | 0x48:
1712 		case SCAN_RELEASE | 0x49:	/* keypad 7,8,9 */
1713 		case SCAN_RELEASE | 0x4B:
1714 		case SCAN_RELEASE | 0x4C:
1715 		case SCAN_RELEASE | 0x4D:	/* keypad 4,5,6 */
1716 		case SCAN_RELEASE | 0x4F:
1717 		case SCAN_RELEASE | 0x50:
1718 		case SCAN_RELEASE | 0x51:	/* keypad 1,2,3 */
1719 		case SCAN_RELEASE | 0x52:	/* keypad 0 */
1720 			goto next_code;
1721 
1722 		case 0x38:		/* left alt key */
1723 			break;
1724 
1725 		default:
1726 			if (sc->sc_composed_char > 0) {
1727 				sc->sc_flags &= ~UKBD_FLAG_COMPOSE;
1728 				sc->sc_composed_char = 0;
1729 				goto errkey;
1730 			}
1731 			break;
1732 		}
1733 	}
1734 	/* keycode to key action */
1735 	action = genkbd_keyaction(kbd, SCAN_CHAR(keycode),
1736 	    (keycode & SCAN_RELEASE),
1737 	    &sc->sc_state, &sc->sc_accents);
1738 	if (action == NOKEY) {
1739 		goto next_code;
1740 	}
1741 done:
1742 	return (action);
1743 
1744 check_composed:
1745 	if (sc->sc_composed_char <= 0xFF) {
1746 		goto next_code;
1747 	}
1748 errkey:
1749 	return (ERRKEY);
1750 }
1751 
1752 /* Currently wait is always false. */
1753 static uint32_t
1754 ukbd_read_char(keyboard_t *kbd, int wait)
1755 {
1756 	uint32_t keycode;
1757 
1758 	UKBD_LOCK();
1759 	keycode = ukbd_read_char_locked(kbd, wait);
1760 	UKBD_UNLOCK();
1761 
1762 	return (keycode);
1763 }
1764 
1765 /* some useful control functions */
1766 static int
1767 ukbd_ioctl_locked(keyboard_t *kbd, u_long cmd, caddr_t arg)
1768 {
1769 	struct ukbd_softc *sc = kbd->kb_data;
1770 	int i;
1771 #if defined(COMPAT_FREEBSD6) || defined(COMPAT_FREEBSD5) || \
1772     defined(COMPAT_FREEBSD4) || defined(COMPAT_43)
1773 	int ival;
1774 
1775 #endif
1776 
1777 	UKBD_LOCK_ASSERT();
1778 
1779 	switch (cmd) {
1780 	case KDGKBMODE:		/* get keyboard mode */
1781 		*(int *)arg = sc->sc_mode;
1782 		break;
1783 #if defined(COMPAT_FREEBSD6) || defined(COMPAT_FREEBSD5) || \
1784     defined(COMPAT_FREEBSD4) || defined(COMPAT_43)
1785 	case _IO('K', 7):
1786 		ival = IOCPARM_IVAL(arg);
1787 		arg = (caddr_t)&ival;
1788 		/* FALLTHROUGH */
1789 #endif
1790 	case KDSKBMODE:		/* set keyboard mode */
1791 		switch (*(int *)arg) {
1792 		case K_XLATE:
1793 			if (sc->sc_mode != K_XLATE) {
1794 				/* make lock key state and LED state match */
1795 				sc->sc_state &= ~LOCK_MASK;
1796 				sc->sc_state |= KBD_LED_VAL(kbd);
1797 			}
1798 			/* FALLTHROUGH */
1799 		case K_RAW:
1800 		case K_CODE:
1801 			if (sc->sc_mode != *(int *)arg) {
1802 				if ((sc->sc_flags & UKBD_FLAG_POLLING) == 0)
1803 					ukbd_clear_state(kbd);
1804 				sc->sc_mode = *(int *)arg;
1805 			}
1806 			break;
1807 		default:
1808 			return (EINVAL);
1809 		}
1810 		break;
1811 
1812 	case KDGETLED:			/* get keyboard LED */
1813 		*(int *)arg = KBD_LED_VAL(kbd);
1814 		break;
1815 #if defined(COMPAT_FREEBSD6) || defined(COMPAT_FREEBSD5) || \
1816     defined(COMPAT_FREEBSD4) || defined(COMPAT_43)
1817 	case _IO('K', 66):
1818 		ival = IOCPARM_IVAL(arg);
1819 		arg = (caddr_t)&ival;
1820 		/* FALLTHROUGH */
1821 #endif
1822 	case KDSETLED:			/* set keyboard LED */
1823 		/* NOTE: lock key state in "sc_state" won't be changed */
1824 		if (*(int *)arg & ~LOCK_MASK)
1825 			return (EINVAL);
1826 
1827 		i = *(int *)arg;
1828 
1829 		/* replace CAPS LED with ALTGR LED for ALTGR keyboards */
1830 		if (sc->sc_mode == K_XLATE &&
1831 		    kbd->kb_keymap->n_keys > ALTGR_OFFSET) {
1832 			if (i & ALKED)
1833 				i |= CLKED;
1834 			else
1835 				i &= ~CLKED;
1836 		}
1837 		if (KBD_HAS_DEVICE(kbd))
1838 			ukbd_set_leds(sc, i);
1839 
1840 		KBD_LED_VAL(kbd) = *(int *)arg;
1841 		break;
1842 	case KDGKBSTATE:		/* get lock key state */
1843 		*(int *)arg = sc->sc_state & LOCK_MASK;
1844 		break;
1845 #if defined(COMPAT_FREEBSD6) || defined(COMPAT_FREEBSD5) || \
1846     defined(COMPAT_FREEBSD4) || defined(COMPAT_43)
1847 	case _IO('K', 20):
1848 		ival = IOCPARM_IVAL(arg);
1849 		arg = (caddr_t)&ival;
1850 		/* FALLTHROUGH */
1851 #endif
1852 	case KDSKBSTATE:		/* set lock key state */
1853 		if (*(int *)arg & ~LOCK_MASK) {
1854 			return (EINVAL);
1855 		}
1856 		sc->sc_state &= ~LOCK_MASK;
1857 		sc->sc_state |= *(int *)arg;
1858 
1859 		/* set LEDs and quit */
1860 		return (ukbd_ioctl(kbd, KDSETLED, arg));
1861 
1862 	case KDSETREPEAT:		/* set keyboard repeat rate (new
1863 					 * interface) */
1864 		if (!KBD_HAS_DEVICE(kbd)) {
1865 			return (0);
1866 		}
1867 		if (((int *)arg)[1] < 0) {
1868 			return (EINVAL);
1869 		}
1870 		if (((int *)arg)[0] < 0) {
1871 			return (EINVAL);
1872 		}
1873 		if (((int *)arg)[0] < 200)	/* fastest possible value */
1874 			kbd->kb_delay1 = 200;
1875 		else
1876 			kbd->kb_delay1 = ((int *)arg)[0];
1877 		kbd->kb_delay2 = ((int *)arg)[1];
1878 		return (0);
1879 
1880 #if defined(COMPAT_FREEBSD6) || defined(COMPAT_FREEBSD5) || \
1881     defined(COMPAT_FREEBSD4) || defined(COMPAT_43)
1882 	case _IO('K', 67):
1883 		ival = IOCPARM_IVAL(arg);
1884 		arg = (caddr_t)&ival;
1885 		/* FALLTHROUGH */
1886 #endif
1887 	case KDSETRAD:			/* set keyboard repeat rate (old
1888 					 * interface) */
1889 		return (ukbd_set_typematic(kbd, *(int *)arg));
1890 
1891 	case PIO_KEYMAP:		/* set keyboard translation table */
1892 	case OPIO_KEYMAP:		/* set keyboard translation table
1893 					 * (compat) */
1894 	case PIO_KEYMAPENT:		/* set keyboard translation table
1895 					 * entry */
1896 	case PIO_DEADKEYMAP:		/* set accent key translation table */
1897 		sc->sc_accents = 0;
1898 		/* FALLTHROUGH */
1899 	default:
1900 		return (genkbd_commonioctl(kbd, cmd, arg));
1901 	}
1902 
1903 	return (0);
1904 }
1905 
1906 static int
1907 ukbd_ioctl(keyboard_t *kbd, u_long cmd, caddr_t arg)
1908 {
1909 	int result;
1910 
1911 	/*
1912 	 * XXX Check if someone is calling us from a critical section:
1913 	 */
1914 	if (curthread->td_critnest != 0)
1915 		return (EDEADLK);
1916 
1917 	/*
1918 	 * XXX KDGKBSTATE, KDSKBSTATE and KDSETLED can be called from any
1919 	 * context where printf(9) can be called, which among other things
1920 	 * includes interrupt filters and threads with any kinds of locks
1921 	 * already held.  For this reason it would be dangerous to acquire
1922 	 * the Giant here unconditionally.  On the other hand we have to
1923 	 * have it to handle the ioctl.
1924 	 * So we make our best effort to auto-detect whether we can grab
1925 	 * the Giant or not.  Blame syscons(4) for this.
1926 	 */
1927 	switch (cmd) {
1928 	case KDGKBSTATE:
1929 	case KDSKBSTATE:
1930 	case KDSETLED:
1931 		if (!mtx_owned(&Giant) && !SCHEDULER_STOPPED())
1932 			return (EDEADLK);	/* best I could come up with */
1933 		/* FALLTHROUGH */
1934 	default:
1935 		UKBD_LOCK();
1936 		result = ukbd_ioctl_locked(kbd, cmd, arg);
1937 		UKBD_UNLOCK();
1938 		return (result);
1939 	}
1940 }
1941 
1942 
1943 /* clear the internal state of the keyboard */
1944 static void
1945 ukbd_clear_state(keyboard_t *kbd)
1946 {
1947 	struct ukbd_softc *sc = kbd->kb_data;
1948 
1949 	UKBD_CTX_LOCK_ASSERT();
1950 
1951 	sc->sc_flags &= ~(UKBD_FLAG_COMPOSE | UKBD_FLAG_POLLING);
1952 	sc->sc_state &= LOCK_MASK;	/* preserve locking key state */
1953 	sc->sc_accents = 0;
1954 	sc->sc_composed_char = 0;
1955 #ifdef UKBD_EMULATE_ATSCANCODE
1956 	sc->sc_buffered_char[0] = 0;
1957 	sc->sc_buffered_char[1] = 0;
1958 #endif
1959 	memset(&sc->sc_ndata, 0, sizeof(sc->sc_ndata));
1960 	memset(&sc->sc_odata, 0, sizeof(sc->sc_odata));
1961 	memset(&sc->sc_ntime, 0, sizeof(sc->sc_ntime));
1962 	memset(&sc->sc_otime, 0, sizeof(sc->sc_otime));
1963 }
1964 
1965 /* save the internal state, not used */
1966 static int
1967 ukbd_get_state(keyboard_t *kbd, void *buf, size_t len)
1968 {
1969 	return (len == 0) ? 1 : -1;
1970 }
1971 
1972 /* set the internal state, not used */
1973 static int
1974 ukbd_set_state(keyboard_t *kbd, void *buf, size_t len)
1975 {
1976 	return (EINVAL);
1977 }
1978 
1979 static int
1980 ukbd_poll(keyboard_t *kbd, int on)
1981 {
1982 	struct ukbd_softc *sc = kbd->kb_data;
1983 
1984 	UKBD_LOCK();
1985 	if (on) {
1986 		sc->sc_flags |= UKBD_FLAG_POLLING;
1987 		sc->sc_poll_thread = curthread;
1988 	} else {
1989 		sc->sc_flags &= ~UKBD_FLAG_POLLING;
1990 		ukbd_start_timer(sc);	/* start timer */
1991 	}
1992 	UKBD_UNLOCK();
1993 
1994 	return (0);
1995 }
1996 
1997 /* local functions */
1998 
1999 static void
2000 ukbd_set_leds(struct ukbd_softc *sc, uint8_t leds)
2001 {
2002 
2003 	UKBD_LOCK_ASSERT();
2004 	DPRINTF("leds=0x%02x\n", leds);
2005 
2006 	sc->sc_leds = leds;
2007 	sc->sc_flags |= UKBD_FLAG_SET_LEDS;
2008 
2009 	/* start transfer, if not already started */
2010 
2011 	usbd_transfer_start(sc->sc_xfer[UKBD_CTRL_LED]);
2012 }
2013 
2014 static int
2015 ukbd_set_typematic(keyboard_t *kbd, int code)
2016 {
2017 	static const int delays[] = {250, 500, 750, 1000};
2018 	static const int rates[] = {34, 38, 42, 46, 50, 55, 59, 63,
2019 		68, 76, 84, 92, 100, 110, 118, 126,
2020 		136, 152, 168, 184, 200, 220, 236, 252,
2021 	272, 304, 336, 368, 400, 440, 472, 504};
2022 
2023 	if (code & ~0x7f) {
2024 		return (EINVAL);
2025 	}
2026 	kbd->kb_delay1 = delays[(code >> 5) & 3];
2027 	kbd->kb_delay2 = rates[code & 0x1f];
2028 	return (0);
2029 }
2030 
2031 #ifdef UKBD_EMULATE_ATSCANCODE
2032 static int
2033 ukbd_key2scan(struct ukbd_softc *sc, int code, int shift, int up)
2034 {
2035 	static const int scan[] = {
2036 		/* 89 */
2037 		0x11c,	/* Enter */
2038 		/* 90-99 */
2039 		0x11d,	/* Ctrl-R */
2040 		0x135,	/* Divide */
2041 		0x137 | SCAN_PREFIX_SHIFT,	/* PrintScreen */
2042 		0x138,	/* Alt-R */
2043 		0x147,	/* Home */
2044 		0x148,	/* Up */
2045 		0x149,	/* PageUp */
2046 		0x14b,	/* Left */
2047 		0x14d,	/* Right */
2048 		0x14f,	/* End */
2049 		/* 100-109 */
2050 		0x150,	/* Down */
2051 		0x151,	/* PageDown */
2052 		0x152,	/* Insert */
2053 		0x153,	/* Delete */
2054 		0x146,	/* XXX Pause/Break */
2055 		0x15b,	/* Win_L(Super_L) */
2056 		0x15c,	/* Win_R(Super_R) */
2057 		0x15d,	/* Application(Menu) */
2058 
2059 		/* SUN TYPE 6 USB KEYBOARD */
2060 		0x168,	/* Sun Type 6 Help */
2061 		0x15e,	/* Sun Type 6 Stop */
2062 		/* 110 - 119 */
2063 		0x15f,	/* Sun Type 6 Again */
2064 		0x160,	/* Sun Type 6 Props */
2065 		0x161,	/* Sun Type 6 Undo */
2066 		0x162,	/* Sun Type 6 Front */
2067 		0x163,	/* Sun Type 6 Copy */
2068 		0x164,	/* Sun Type 6 Open */
2069 		0x165,	/* Sun Type 6 Paste */
2070 		0x166,	/* Sun Type 6 Find */
2071 		0x167,	/* Sun Type 6 Cut */
2072 		0x125,	/* Sun Type 6 Mute */
2073 		/* 120 - 128 */
2074 		0x11f,	/* Sun Type 6 VolumeDown */
2075 		0x11e,	/* Sun Type 6 VolumeUp */
2076 		0x120,	/* Sun Type 6 PowerDown */
2077 
2078 		/* Japanese 106/109 keyboard */
2079 		0x73,	/* Keyboard Intl' 1 (backslash / underscore) */
2080 		0x70,	/* Keyboard Intl' 2 (Katakana / Hiragana) */
2081 		0x7d,	/* Keyboard Intl' 3 (Yen sign) (Not using in jp106/109) */
2082 		0x79,	/* Keyboard Intl' 4 (Henkan) */
2083 		0x7b,	/* Keyboard Intl' 5 (Muhenkan) */
2084 		0x5c,	/* Keyboard Intl' 6 (Keypad ,) (For PC-9821 layout) */
2085 	};
2086 
2087 	if ((code >= 89) && (code < (int)(89 + (sizeof(scan) / sizeof(scan[0]))))) {
2088 		code = scan[code - 89];
2089 	}
2090 	/* Pause/Break */
2091 	if ((code == 104) && (!(shift & (MOD_CONTROL_L | MOD_CONTROL_R)))) {
2092 		code = (0x45 | SCAN_PREFIX_E1 | SCAN_PREFIX_CTL);
2093 	}
2094 	if (shift & (MOD_SHIFT_L | MOD_SHIFT_R)) {
2095 		code &= ~SCAN_PREFIX_SHIFT;
2096 	}
2097 	code |= (up ? SCAN_RELEASE : SCAN_PRESS);
2098 
2099 	if (code & SCAN_PREFIX) {
2100 		if (code & SCAN_PREFIX_CTL) {
2101 			/* Ctrl */
2102 			sc->sc_buffered_char[0] = (0x1d | (code & SCAN_RELEASE));
2103 			sc->sc_buffered_char[1] = (code & ~SCAN_PREFIX);
2104 		} else if (code & SCAN_PREFIX_SHIFT) {
2105 			/* Shift */
2106 			sc->sc_buffered_char[0] = (0x2a | (code & SCAN_RELEASE));
2107 			sc->sc_buffered_char[1] = (code & ~SCAN_PREFIX_SHIFT);
2108 		} else {
2109 			sc->sc_buffered_char[0] = (code & ~SCAN_PREFIX);
2110 			sc->sc_buffered_char[1] = 0;
2111 		}
2112 		return ((code & SCAN_PREFIX_E0) ? 0xe0 : 0xe1);
2113 	}
2114 	return (code);
2115 
2116 }
2117 
2118 #endif					/* UKBD_EMULATE_ATSCANCODE */
2119 
2120 static keyboard_switch_t ukbdsw = {
2121 	.probe = &ukbd__probe,
2122 	.init = &ukbd_init,
2123 	.term = &ukbd_term,
2124 	.intr = &ukbd_intr,
2125 	.test_if = &ukbd_test_if,
2126 	.enable = &ukbd_enable,
2127 	.disable = &ukbd_disable,
2128 	.read = &ukbd_read,
2129 	.check = &ukbd_check,
2130 	.read_char = &ukbd_read_char,
2131 	.check_char = &ukbd_check_char,
2132 	.ioctl = &ukbd_ioctl,
2133 	.lock = &ukbd_lock,
2134 	.clear_state = &ukbd_clear_state,
2135 	.get_state = &ukbd_get_state,
2136 	.set_state = &ukbd_set_state,
2137 	.get_fkeystr = &genkbd_get_fkeystr,
2138 	.poll = &ukbd_poll,
2139 	.diag = &genkbd_diag,
2140 };
2141 
2142 KEYBOARD_DRIVER(ukbd, ukbdsw, ukbd_configure);
2143 
2144 static int
2145 ukbd_driver_load(module_t mod, int what, void *arg)
2146 {
2147 	switch (what) {
2148 	case MOD_LOAD:
2149 		kbd_add_driver(&ukbd_kbd_driver);
2150 		break;
2151 	case MOD_UNLOAD:
2152 		kbd_delete_driver(&ukbd_kbd_driver);
2153 		break;
2154 	}
2155 	return (0);
2156 }
2157 
2158 static devclass_t ukbd_devclass;
2159 
2160 static device_method_t ukbd_methods[] = {
2161 	DEVMETHOD(device_probe, ukbd_probe),
2162 	DEVMETHOD(device_attach, ukbd_attach),
2163 	DEVMETHOD(device_detach, ukbd_detach),
2164 	DEVMETHOD(device_resume, ukbd_resume),
2165 
2166 	DEVMETHOD_END
2167 };
2168 
2169 static driver_t ukbd_driver = {
2170 	.name = "ukbd",
2171 	.methods = ukbd_methods,
2172 	.size = sizeof(struct ukbd_softc),
2173 };
2174 
2175 DRIVER_MODULE(ukbd, uhub, ukbd_driver, ukbd_devclass, ukbd_driver_load, 0);
2176 MODULE_DEPEND(ukbd, usb, 1, 1, 1);
2177 MODULE_VERSION(ukbd, 1);
2178