xref: /dragonfly/sys/dev/misc/kbd/atkbdc.c (revision a162a738eca94f99d45d88429e86cfd0fbfbe95d)
1 /*
2  * (MPSAFE)
3  *
4  * Copyright (c) 1996-1999
5  * Kazutaka YOKOTA (yokota@zodiac.mech.utsunomiya-u.ac.jp)
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  * 1. Redistributions of source code must retain the above copyright
12  *    notice, this list of conditions and the following disclaimer.
13  * 2. Redistributions in binary form must reproduce the above copyright
14  *    notice, this list of conditions and the following disclaimer in the
15  *    documentation and/or other materials provided with the distribution.
16  * 3. The name of the author may not be used to endorse or promote
17  *    products derived from this software without specific prior written
18  *    permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
21  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
24  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30  * SUCH DAMAGE.
31  *
32  * $FreeBSD: src/sys/dev/kbd/atkbdc.c,v 1.5.2.2 2002/03/31 11:02:02 murray Exp $
33  * from kbdio.c,v 1.13 1998/09/25 11:55:46 yokota Exp
34  */
35 
36 #include "opt_kbd.h"
37 
38 #include <sys/param.h>
39 #include <sys/systm.h>
40 #include <sys/bus.h>
41 #include <sys/kbio.h>
42 #include <sys/kernel.h>
43 #include <sys/malloc.h>
44 #include <sys/rman.h>
45 #include <sys/syslog.h>
46 
47 #include <machine/clock.h>
48 
49 #include <bus/isa/isareg.h>
50 
51 #include "atkbdcreg.h"
52 #include "kbdreg.h"
53 #include "use_atkbdc.h"
54 
55 /* constants */
56 
57 #define MAXKBDC MAX(NATKBDC, 1) /* XXX */
58 
59 /* macros */
60 
61 #ifndef MAX
62 #define MAX(x, y) ((x) > (y) ? (x) : (y))
63 #endif
64 
65 #define nextq(i) (((i) + 1) % KBDQ_BUFSIZE)
66 #define availq(q) ((q)->head != (q)->tail)
67 #if KBDIO_DEBUG >= 2
68 #define emptyq(q) ((q)->tail = (q)->head = (q)->qcount = 0)
69 #else
70 #define emptyq(q) ((q)->tail = (q)->head = 0)
71 #endif
72 
73 #define read_data(k) (bus_space_read_1((k)->iot, (k)->ioh0, 0))
74 #define read_status(k) (bus_space_read_1((k)->iot, (k)->ioh1, 0))
75 #define write_data(k, d) (bus_space_write_1((k)->iot, (k)->ioh0, 0, (d)))
76 #define write_command(k, d) (bus_space_write_1((k)->iot, (k)->ioh1, 0, (d)))
77 
78 /* local variables */
79 
80 /*
81  * We always need at least one copy of the kbdc_softc struct for the
82  * low-level console.  As the low-level console accesses the keyboard
83  * controller before kbdc, and all other devices, is probed, we
84  * statically allocate one entry. XXX
85  */
86 static atkbdc_softc_t default_kbdc;
87 static atkbdc_softc_t *atkbdc_softc[MAXKBDC] = { &default_kbdc };
88 
89 static int verbose = KBDIO_DEBUG;
90 
91 /* function prototypes */
92 
93 static int atkbdc_setup(atkbdc_softc_t *sc, bus_space_tag_t tag,
94     bus_space_handle_t h0, bus_space_handle_t h1);
95 static int addq(kbdkqueue *q, int c);
96 static int removeq(kbdkqueue *q);
97 static int wait_while_controller_busy(atkbdc_softc_t *kbdc);
98 static int wait_for_data(atkbdc_softc_t *kbdc);
99 static int wait_for_kbd_data(atkbdc_softc_t *kbdc);
100 static int wait_for_kbd_ack(atkbdc_softc_t *kbdc);
101 static int wait_for_aux_data(atkbdc_softc_t *kbdc);
102 static int wait_for_aux_ack(atkbdc_softc_t *kbdc);
103 
104 struct atkbdc_quirks {
105           const char *bios_vendor;
106           const char *maker;
107           const char *product;
108           const char *version;
109           int quirk;
110 };
111 
112 /* Old chromebooks running coreboot with i8042 emulation quirks */
113 #define CHROMEBOOK_WORKAROUND                                         \
114           (KBDC_QUIRK_KEEP_ACTIVATED | KBDC_QUIRK_IGNORE_PROBE_RESULT | \
115               KBDC_QUIRK_RESET_AFTER_PROBE | KBDC_QUIRK_SETLEDS_ON_INIT)
116 
117 static struct atkbdc_quirks quirks[] = {
118           /*
119            * Older chromebooks running coreboot have an EC that imperfectly
120            * emulates i8042 w/o fixes to its firmware.  Since we can't probe for
121            * the problem, include all chromebooks by matching 'Google_' in the
122            * bios version string or a maker of either 'Google' or 'GOOGLE'. This
123            * is imperfect, but catches all chromebooks while omitting non-Google
124            * systems from System76 and Purism.
125            */
126           { "coreboot", NULL, NULL, "Google_", CHROMEBOOK_WORKAROUND },
127           { "coreboot", "GOOGLE", NULL, NULL, CHROMEBOOK_WORKAROUND },
128           { "coreboot", "Google", NULL, NULL, CHROMEBOOK_WORKAROUND },
129           /* KBDC hangs on Lenovo X120e and X121e after disabling AUX MUX */
130           { NULL, "LENOVO", NULL, NULL, KBDC_QUIRK_DISABLE_MUX_PROBE },
131 };
132 
133 #define QUIRK_STR_EQUAL(s1, s2) \
134           (s1 == NULL || (s2 != NULL && strcmp(s1, s2) == 0))
135 #define QUIRK_STR_MATCH(s1, s2) \
136           (s1 == NULL || (s2 != NULL && strncmp(s1, s2, strlen(s1)) == 0))
137 
138 static int
atkbdc_getquirks(void)139 atkbdc_getquirks(void)
140 {
141           int i;
142           char *bios_vendor = kgetenv("smbios.bios.vendor");
143           char *maker = kgetenv("smbios.system.maker");
144           char *product = kgetenv("smbios.system.product");
145           char *version = kgetenv("smbios.bios.version");
146           char *reldate = kgetenv("smbios.bios.reldate");
147 
148           for (i = 0; i < nitems(quirks); i++)
149                     if (QUIRK_STR_EQUAL(quirks[i].bios_vendor, bios_vendor) &&
150                         QUIRK_STR_EQUAL(quirks[i].maker, maker) &&
151                         QUIRK_STR_EQUAL(quirks[i].product, product) &&
152                         QUIRK_STR_MATCH(quirks[i].version, version))
153                               return (quirks[i].quirk);
154           /*
155            * Some Chromebooks don't conform to the google comment above so do the
156            * Chromebook workaround for all <= 2018 coreboot systems that have a
157            * 'blank' version.  At least one Acer "Peppy" chromebook has this
158            * issue, with a reldate of 08/13/2014.
159            */
160           if (QUIRK_STR_EQUAL("coreboot", bios_vendor) &&
161               (version != NULL && *version == ' ') &&
162               (reldate != NULL && strlen(reldate) >= 10 &&
163                     strcmp(reldate + 6, "2018") <= 0))
164                     return (CHROMEBOOK_WORKAROUND);
165 
166           return (0);
167 }
168 
169 atkbdc_softc_t *
atkbdc_get_softc(int unit)170 atkbdc_get_softc(int unit)
171 {
172           atkbdc_softc_t *sc;
173 
174           if (unit >= nitems(atkbdc_softc))
175                     return NULL;
176           sc = atkbdc_softc[unit];
177           if (sc == NULL) {
178                     sc = kmalloc(sizeof(*sc), M_DEVBUF, M_WAITOK | M_ZERO);
179                     atkbdc_softc[unit] = sc;
180           }
181           return sc;
182 }
183 
184 int
atkbdc_probe_unit(int unit,struct resource * port0,struct resource * port1)185 atkbdc_probe_unit(int unit, struct resource *port0, struct resource *port1)
186 {
187           if (rman_get_start(port0) <= 0)
188                     return ENXIO;
189           if (rman_get_start(port1) <= 0)
190                     return ENXIO;
191           return 0;
192 }
193 
194 int
atkbdc_attach_unit(int unit,atkbdc_softc_t * sc,struct resource * port0,struct resource * port1)195 atkbdc_attach_unit(int unit, atkbdc_softc_t *sc, struct resource *port0,
196     struct resource *port1)
197 {
198           return atkbdc_setup(sc, rman_get_bustag(port0),
199               rman_get_bushandle(port0), rman_get_bushandle(port1));
200 }
201 
202 extern int acpi_fadt_8042_nolegacy;
203 int kicked_by_syscons = 0;
204 
205 static void
atkbdc_fadt_done(void)206 atkbdc_fadt_done(void)
207 {
208           if (kicked_by_syscons) {
209                     /*
210                      * Configuring all keyboards is fine, because only atkbd
211                      * really does something here, anyway.
212                      */
213                     kbd_configure(KB_CONF_PROBE_ONLY);
214           }
215 }
216 
217 /* After fadt_probe in platform/pc64/acpica/acpi_fadt.c. */
218 SYSINIT(atkbdc_kick, SI_BOOT2_PRESMP, SI_ORDER_THIRD, atkbdc_fadt_done, 0);
219 
220 /* the backdoor to the keyboard controller! XXX */
221 int
atkbdc_configure(void)222 atkbdc_configure(void)
223 {
224           bus_space_tag_t tag;
225           bus_space_handle_t h0;
226           bus_space_handle_t h1;
227           int port0;
228           int port1;
229 #if defined(__x86_64__)
230           int i;
231 #endif
232 
233           kicked_by_syscons = 1;
234           if (acpi_fadt_8042_nolegacy != 0)
235                     return ENXIO;
236 
237           port0 = IO_KBD;
238           resource_int_value("atkbdc", 0, "port", &port0);
239           port1 = IO_KBD + KBD_STATUS_PORT;
240 #if 0
241           resource_int_value("atkbdc", 0, "port", &port0);
242 #endif
243 
244           /* XXX: tag should be passed from the caller */
245 #if defined(__x86_64__)
246           tag = X86_64_BUS_SPACE_IO;
247 #else
248           tag = 0; /* XXX */
249 #endif
250 
251 #if 0 /* notyet */
252           bus_space_map(tag, port0, IO_KBDSIZE, 0, &h0);
253           bus_space_map(tag, port1, IO_KBDSIZE, 0, &h1);
254 #else
255           h0 = (bus_space_handle_t)port0;
256           h1 = (bus_space_handle_t)port1;
257 #endif
258 
259 #if defined(__x86_64__)
260           /*
261            * Check if we really have AT keyboard controller. Poll status
262            * register until we get "all clear" indication. If no such
263            * indication comes, it probably means that there is no AT
264            * keyboard controller present. Give up in such case. Check relies
265            * on the fact that reading from non-existing in/out port returns
266            * 0xff on i386. May or may not be true on other platforms.
267            */
268           for (i = 65536; i != 0; --i) {
269                     if ((bus_space_read_1(tag, h1, 0) & 0x2) == 0)
270                               break;
271                     DELAY(16);
272           }
273           if (i == 0)
274                     return ENXIO;
275 #endif
276 
277           return atkbdc_setup(atkbdc_softc[0], tag, h0, h1);
278 }
279 
280 static int
atkbdc_setup(atkbdc_softc_t * sc,bus_space_tag_t tag,bus_space_handle_t h0,bus_space_handle_t h1)281 atkbdc_setup(atkbdc_softc_t *sc, bus_space_tag_t tag, bus_space_handle_t h0,
282     bus_space_handle_t h1)
283 {
284           u_int64_t tscval[3], read_delay;
285           register_t flags;
286 
287           if (sc->ioh0 == 0) { /* XXX */
288                     sc->command_byte = -1;
289                     sc->command_mask = 0;
290                     sc->lock = FALSE;
291                     sc->kbd.head = sc->kbd.tail = 0;
292                     sc->aux.head = sc->aux.tail = 0;
293                     sc->aux_mux_enabled = FALSE;
294 #if KBDIO_DEBUG >= 2
295                     sc->kbd.call_count = 0;
296                     sc->kbd.qcount = sc->kbd.max_qcount = 0;
297                     sc->aux.call_count = 0;
298                     sc->aux.qcount = sc->aux.max_qcount = 0;
299 #endif
300           }
301           sc->iot = tag;
302           sc->ioh0 = h0;
303           sc->ioh1 = h1;
304           /*
305            * On certain chipsets AT keyboard controller isn't present and is
306            * emulated by BIOS using SMI interrupt. On those chipsets reading
307            * from the status port may be thousand times slower than usually.
308            * Sometimes this emilation is not working properly resulting in
309            * commands timing our and since we assume that inb() operation
310            * takes very little time to complete we need to adjust number of
311            * retries to keep waiting time within a designed limits (100ms).
312            * Measure time it takes to make read_status() call and adjust
313            * number of retries accordingly.
314            */
315           flags = intr_disable();
316           tscval[0] = rdtsc();
317           read_status(sc);
318           tscval[1] = rdtsc();
319           DELAY(1000);
320           tscval[2] = rdtsc();
321           intr_restore(flags);
322           read_delay = tscval[1] - tscval[0];
323           read_delay /= (tscval[2] - tscval[1]) / 1000;
324           sc->retry = 100000 / ((KBDD_DELAYTIME * 2) + read_delay);
325 
326           sc->quirks = atkbdc_getquirks();
327 
328           return 0;
329 }
330 
331 /* open a keyboard controller */
332 KBDC
atkbdc_open(int unit)333 atkbdc_open(int unit)
334 {
335           if (unit <= 0)
336                     unit = 0;
337           if (unit >= MAXKBDC)
338                     return NULL;
339           if ((atkbdc_softc[unit]->port0 != NULL) ||
340               (atkbdc_softc[unit]->ioh0 != 0)) /* XXX */
341                     return (KBDC)atkbdc_softc[unit];
342           return NULL;
343 }
344 
345 /*
346  * I/O access arbitration in `kbdio'
347  *
348  * The `kbdio' module uses a simplistic convention to arbitrate
349  * I/O access to the controller/keyboard/mouse. The convention requires
350  * close cooperation of the calling device driver.
351  *
352  * The device drivers which utilize the `kbdio' module are assumed to
353  * have the following set of routines.
354  *    a. An interrupt handler (the bottom half of the driver).
355  *    b. Timeout routines which may briefly poll the keyboard controller.
356  *    c. Routines outside interrupt context (the top half of the driver).
357  * They should follow the rules below:
358  *    1. The interrupt handler may assume that it always has full access
359  *       to the controller/keyboard/mouse.
360  *    2. The other routines must issue `spltty()' if they wish to
361  *       prevent the interrupt handler from accessing
362  *       the controller/keyboard/mouse.
363  *    3. The timeout routines and the top half routines of the device driver
364  *       arbitrate I/O access by observing the lock flag in `kbdio'.
365  *       The flag is manipulated via `kbdc_lock()'; when one wants to
366  *       perform I/O, call `kbdc_lock(kbdc, TRUE)' and proceed only if
367  *       the call returns with TRUE. Otherwise the caller must back off.
368  *       Call `kbdc_lock(kbdc, FALSE)' when necessary I/O operaion
369  *       is finished. This mechanism does not prevent the interrupt
370  *       handler from being invoked at any time and carrying out I/O.
371  *       Therefore, `spltty()' must be strategically placed in the device
372  *       driver code. Also note that the timeout routine may interrupt
373  *       `kbdc_lock()' called by the top half of the driver, but this
374  *       interruption is OK so long as the timeout routine observes
375  *       rule 4 below.
376  *    4. The interrupt and timeout routines should not extend I/O operation
377  *       across more than one interrupt or timeout; they must complete any
378  *       necessary I/O operation within one invocation of the routine.
379  *       This means that if the timeout routine acquires the lock flag,
380  *       it must reset the flag to FALSE before it returns.
381  */
382 
383 /* set/reset polling lock */
384 int
kbdc_lock(KBDC p,int lock)385 kbdc_lock(KBDC p, int lock)
386 {
387           int prevlock;
388 
389           prevlock = p->lock;
390           p->lock = lock;
391 
392           return (prevlock != lock);
393 }
394 
395 /* check if any data is waiting to be processed */
396 int
kbdc_data_ready(KBDC p)397 kbdc_data_ready(KBDC p)
398 {
399           return (availq(&p->kbd) || availq(&p->aux) ||
400               (read_status(p) & KBDS_ANY_BUFFER_FULL));
401 }
402 
403 /* queuing functions */
404 
405 static int
addq(kbdkqueue * q,int c)406 addq(kbdkqueue *q, int c)
407 {
408           if (nextq(q->tail) != q->head) {
409                     q->q[q->tail] = c;
410                     q->tail = nextq(q->tail);
411 #if KBDIO_DEBUG >= 2
412                     ++q->call_count;
413                     ++q->qcount;
414                     if (q->qcount > q->max_qcount)
415                               q->max_qcount = q->qcount;
416 #endif
417                     return TRUE;
418           }
419           return FALSE;
420 }
421 
422 static int
removeq(kbdkqueue * q)423 removeq(kbdkqueue *q)
424 {
425           int c;
426 
427           if (q->tail != q->head) {
428                     c = q->q[q->head];
429                     q->head = nextq(q->head);
430 #if KBDIO_DEBUG >= 2
431                     --q->qcount;
432 #endif
433                     return c;
434           }
435           return -1;
436 }
437 
438 /*
439  * device I/O routines
440  */
441 static int
wait_while_controller_busy(struct atkbdc_softc * kbdc)442 wait_while_controller_busy(struct atkbdc_softc *kbdc)
443 {
444           /* CPU will stay inside the loop for 100msec at most */
445           TOTALDELAY retry = { .us = 70000, .last_clock = 0 }; /* 70ms */
446           int f;
447           unsigned char c;
448 
449           while ((f = read_status(kbdc)) & KBDS_INPUT_BUFFER_FULL) {
450                     if ((f & KBDS_BUFFER_FULL) == KBDS_KBD_BUFFER_FULL) {
451                               DELAY(KBDD_DELAYTIME);
452                               c = read_data(kbdc);
453                               addq(&kbdc->kbd, c);
454                     } else if ((f & KBDS_BUFFER_FULL) == KBDS_AUX_BUFFER_FULL) {
455                               DELAY(KBDD_DELAYTIME);
456                               c = read_data(kbdc);
457                               addq(&kbdc->aux, c);
458                     }
459                     DELAY(KBDC_DELAYTIME);
460                     if (CHECKTIMEOUT(&retry))
461                               return FALSE;
462           }
463           return TRUE;
464 }
465 
466 /*
467  * wait for any data; whether it's from the controller,
468  * the keyboard, or the aux device.
469  */
470 static int
wait_for_data(struct atkbdc_softc * kbdc)471 wait_for_data(struct atkbdc_softc *kbdc)
472 {
473           /* CPU will stay inside the loop for 200msec at most */
474           TOTALDELAY retry = { 200000, 0 }; /* 200ms */
475           int f;
476 
477           while ((f = read_status(kbdc) & KBDS_ANY_BUFFER_FULL) == 0) {
478                     DELAY(KBDC_DELAYTIME);
479                     if (CHECKTIMEOUT(&retry))
480                               return 0;
481           }
482           DELAY(KBDD_DELAYTIME);
483           return f;
484 }
485 
486 /* wait for data from the keyboard */
487 static int
wait_for_kbd_data(struct atkbdc_softc * kbdc)488 wait_for_kbd_data(struct atkbdc_softc *kbdc)
489 {
490           /* CPU will stay inside the loop for 200msec at most */
491           TOTALDELAY retry = { 200000, 0 }; /* 200ms */
492           int f;
493           unsigned char c;
494 
495           while ((f = read_status(kbdc) & KBDS_BUFFER_FULL) !=
496               KBDS_KBD_BUFFER_FULL) {
497                     if (f == KBDS_AUX_BUFFER_FULL) {
498                               DELAY(KBDD_DELAYTIME);
499                               c = read_data(kbdc);
500                               addq(&kbdc->aux, c);
501                     }
502                     DELAY(KBDC_DELAYTIME);
503                     if (CHECKTIMEOUT(&retry))
504                               return 0;
505           }
506           DELAY(KBDD_DELAYTIME);
507           return f;
508 }
509 
510 /*
511  * wait for an ACK(FAh), RESEND(FEh), or RESET_FAIL(FCh) from the keyboard.
512  * queue anything else.
513  */
514 static int
wait_for_kbd_ack(struct atkbdc_softc * kbdc)515 wait_for_kbd_ack(struct atkbdc_softc *kbdc)
516 {
517           /* CPU will stay inside the loop for 200msec at most */
518           TOTALDELAY retry = { 200000, 0 }; /* 200ms */
519           int f;
520           int b;
521 
522           while (CHECKTIMEOUT(&retry) == 0) {
523                     if ((f = read_status(kbdc)) & KBDS_ANY_BUFFER_FULL) {
524                               DELAY(KBDD_DELAYTIME);
525                               b = read_data(kbdc);
526                               if ((f & KBDS_BUFFER_FULL) == KBDS_KBD_BUFFER_FULL) {
527                                         if ((b == KBD_ACK) || (b == KBD_RESEND) ||
528                                             (b == KBD_RESET_FAIL))
529                                                   return b;
530                                         addq(&kbdc->kbd, b);
531                               } else if ((f & KBDS_BUFFER_FULL) ==
532                                   KBDS_AUX_BUFFER_FULL) {
533                                         addq(&kbdc->aux, b);
534                               }
535                     }
536                     DELAY(KBDC_DELAYTIME);
537           }
538           return -1;
539 }
540 
541 /* wait for data from the aux device */
542 static int
wait_for_aux_data(struct atkbdc_softc * kbdc)543 wait_for_aux_data(struct atkbdc_softc *kbdc)
544 {
545           /* CPU will stay inside the loop for 200msec at most */
546           TOTALDELAY retry = { 200000, 0 }; /* 200ms */
547           int f;
548           unsigned char b;
549 
550           while ((f = read_status(kbdc) & KBDS_BUFFER_FULL) !=
551               KBDS_AUX_BUFFER_FULL) {
552                     if (f == KBDS_KBD_BUFFER_FULL) {
553                               DELAY(KBDD_DELAYTIME);
554                               b = read_data(kbdc);
555                               addq(&kbdc->kbd, b);
556                     }
557                     DELAY(KBDC_DELAYTIME);
558                     if (CHECKTIMEOUT(&retry))
559                               return 0;
560           }
561           DELAY(KBDD_DELAYTIME);
562           return f;
563 }
564 
565 /*
566  * wait for an ACK(FAh), RESEND(FEh), or RESET_FAIL(FCh) from the aux device.
567  * queue anything else.
568  */
569 static int
wait_for_aux_ack(struct atkbdc_softc * kbdc)570 wait_for_aux_ack(struct atkbdc_softc *kbdc)
571 {
572           /* CPU will stay inside the loop for 200msec at most */
573           TOTALDELAY retry = { 200000, 0 }; /* 200ms */
574           int f;
575           int b;
576 
577           while (CHECKTIMEOUT(&retry) == 0) {
578                     if ((f = read_status(kbdc)) & KBDS_ANY_BUFFER_FULL) {
579                               DELAY(KBDD_DELAYTIME);
580                               b = read_data(kbdc);
581                               if ((f & KBDS_BUFFER_FULL) == KBDS_AUX_BUFFER_FULL) {
582                                         if ((b == PSM_ACK) || (b == PSM_RESEND) ||
583                                             (b == PSM_RESET_FAIL))
584                                                   return b;
585                                         addq(&kbdc->aux, b);
586                               } else if ((f & KBDS_BUFFER_FULL) ==
587                                   KBDS_KBD_BUFFER_FULL) {
588                                         addq(&kbdc->kbd, b);
589                               }
590                     }
591                     DELAY(KBDC_DELAYTIME);
592           }
593           return -1;
594 }
595 
596 /*
597  * Returns read-back data or -1 on failure
598  */
599 int
write_controller_w1r1(KBDC p,int c,int d)600 write_controller_w1r1(KBDC p, int c, int d)
601 {
602           if (!write_controller_command(p, c))
603                     return (-1);
604           if (!write_controller_data(p, d))
605                     return (-1);
606           return (read_controller_data(p));
607 }
608 
609 /* write a one byte command to the controller */
610 int
write_controller_command(KBDC p,int c)611 write_controller_command(KBDC p, int c)
612 {
613           if (!wait_while_controller_busy(p))
614                     return FALSE;
615           write_command(p, c);
616           return TRUE;
617 }
618 
619 /* write a one byte data to the controller */
620 int
write_controller_data(KBDC p,int c)621 write_controller_data(KBDC p, int c)
622 {
623           if (!wait_while_controller_busy(p))
624                     return FALSE;
625           write_data(p, c);
626           return TRUE;
627 }
628 
629 /* write a one byte keyboard command */
630 int
write_kbd_command(KBDC p,int c)631 write_kbd_command(KBDC p, int c)
632 {
633           if (!wait_while_controller_busy(p))
634                     return FALSE;
635           write_data(p, c);
636           return TRUE;
637 }
638 
639 /* write a one byte auxiliary device command */
640 int
write_aux_command(KBDC p,int c)641 write_aux_command(KBDC p, int c)
642 {
643           int f;
644 
645           f = aux_mux_is_enabled(p) ? KBDC_WRITE_TO_AUX_MUX + p->aux_mux_port :
646                                             KBDC_WRITE_TO_AUX;
647 
648           if (!write_controller_command(p, f))
649                     return FALSE;
650           return write_controller_data(p, c);
651 }
652 
653 /* send a command to the keyboard and wait for ACK */
654 int
send_kbd_command(KBDC p,int c)655 send_kbd_command(KBDC p, int c)
656 {
657           int retry = KBD_MAXRETRY;
658           int res = -1;
659 
660           while (retry-- > 0) {
661                     if (!write_kbd_command(p, c))
662                               continue;
663                     res = wait_for_kbd_ack(p);
664                     if (res == KBD_ACK)
665                               break;
666           }
667           return res;
668 }
669 
670 /* send a command to the auxiliary device and wait for ACK */
671 int
send_aux_command(KBDC p,int c)672 send_aux_command(KBDC p, int c)
673 {
674           int retry = KBD_MAXRETRY;
675           int res = -1;
676 
677           while (retry-- > 0) {
678                     if (!write_aux_command(p, c))
679                               continue;
680                     /*
681                      * FIXME: XXX
682                      * The aux device may have already sent one or two bytes of
683                      * status data, when a command is received. It will immediately
684                      * stop data transmission, thus, leaving an incomplete data
685                      * packet in our buffer. We have to discard any unprocessed
686                      * data in order to remove such packets. Well, we may remove
687                      * unprocessed, but necessary data byte as well...
688                      */
689                     emptyq(&p->aux);
690                     res = wait_for_aux_ack(p);
691                     if (res == PSM_ACK)
692                               break;
693           }
694           return res;
695 }
696 
697 /* send a command and a data to the keyboard, wait for ACKs */
698 int
send_kbd_command_and_data(KBDC p,int c,int d)699 send_kbd_command_and_data(KBDC p, int c, int d)
700 {
701           int retry;
702           int res = -1;
703 
704           for (retry = KBD_MAXRETRY; retry > 0; --retry) {
705                     if (!write_kbd_command(p, c))
706                               continue;
707                     res = wait_for_kbd_ack(p);
708                     if (res == KBD_ACK)
709                               break;
710                     else if (res != KBD_RESEND)
711                               return res;
712           }
713           if (retry <= 0)
714                     return res;
715 
716           for (retry = KBD_MAXRETRY, res = -1; retry > 0; --retry) {
717                     if (!write_kbd_command(p, d))
718                               continue;
719                     res = wait_for_kbd_ack(p);
720                     if (res != KBD_RESEND)
721                               break;
722           }
723           return res;
724 }
725 
726 /* send a command and a data to the auxiliary device, wait for ACKs */
727 int
send_aux_command_and_data(KBDC p,int c,int d)728 send_aux_command_and_data(KBDC p, int c, int d)
729 {
730           int retry;
731           int res = -1;
732 
733           for (retry = KBD_MAXRETRY; retry > 0; --retry) {
734                     if (!write_aux_command(p, c))
735                               continue;
736                     emptyq(&p->aux);
737                     res = wait_for_aux_ack(p);
738                     if (res == PSM_ACK)
739                               break;
740                     else if (res != PSM_RESEND)
741                               return res;
742           }
743           if (retry <= 0)
744                     return res;
745 
746           for (retry = KBD_MAXRETRY, res = -1; retry > 0; --retry) {
747                     if (!write_aux_command(p, d))
748                               continue;
749                     res = wait_for_aux_ack(p);
750                     if (res != PSM_RESEND)
751                               break;
752           }
753           return res;
754 }
755 
756 /*
757  * read one byte from any source; whether from the controller,
758  * the keyboard, or the aux device
759  */
760 int
read_controller_data(KBDC p)761 read_controller_data(KBDC p)
762 {
763           if (availq(&p->kbd))
764                     return removeq(&p->kbd);
765           if (availq(&p->aux))
766                     return removeq(&p->aux);
767           if (!wait_for_data(p))
768                     return -1; /* timeout */
769           return read_data(p);
770 }
771 
772 #if KBDIO_DEBUG >= 2
773 static int call = 0;
774 #endif
775 
776 /* read one byte from the keyboard */
777 int
read_kbd_data(KBDC p)778 read_kbd_data(KBDC p)
779 {
780           unsigned char b;
781 
782 #if KBDIO_DEBUG >= 2
783           if (++call > 2000) {
784                     call = 0;
785                     log(LOG_DEBUG,
786                         "kbdc: kbd q: %d calls, max %d chars, "
787                         "aux q: %d calls, max %d chars\n",
788                         p->kbd.call_count, p->kbd.max_qcount, p->aux.call_count,
789                         p->aux.max_qcount);
790           }
791 #endif
792 
793           if (availq(&p->kbd))
794                     return removeq(&p->kbd);
795           if (!wait_for_kbd_data(p))
796                     return -1; /* timeout */
797           b = read_data(p);
798           return b;
799 }
800 
801 /* read one byte from the keyboard, but return immediately if
802  * no data is waiting
803  */
804 int
read_kbd_data_no_wait(KBDC p)805 read_kbd_data_no_wait(KBDC p)
806 {
807           int f;
808           unsigned char b;
809 
810 #if KBDIO_DEBUG >= 2
811           if (++call > 2000) {
812                     call = 0;
813                     log(LOG_DEBUG,
814                         "kbdc: kbd q: %d calls, max %d chars, "
815                         "aux q: %d calls, max %d chars\n",
816                         p->kbd.call_count, p->kbd.max_qcount, p->aux.call_count,
817                         p->aux.max_qcount);
818           }
819 #endif
820 
821           if (availq(&p->kbd))
822                     return removeq(&p->kbd);
823           f = read_status(p) & KBDS_BUFFER_FULL;
824           while (f == KBDS_AUX_BUFFER_FULL) {
825                     DELAY(KBDD_DELAYTIME);
826                     b = read_data(p);
827                     addq(&p->aux, b);
828                     f = read_status(p) & KBDS_BUFFER_FULL;
829           }
830           if (f == KBDS_KBD_BUFFER_FULL) {
831                     DELAY(KBDD_DELAYTIME);
832                     b = read_data(p);
833                     return (int)b;
834           }
835           return -1; /* no data */
836 }
837 
838 /* read one byte from the aux device */
839 int
read_aux_data(KBDC p)840 read_aux_data(KBDC p)
841 {
842           unsigned char b;
843           if (availq(&p->aux))
844                     return removeq(&p->aux);
845           if (!wait_for_aux_data(p))
846                     return -1; /* timeout */
847           b = read_data(p);
848           return b;
849 }
850 
851 /* read one byte from the aux device, but return immediately if
852  * no data is waiting
853  */
854 int
read_aux_data_no_wait(KBDC p)855 read_aux_data_no_wait(KBDC p)
856 {
857           unsigned char b;
858           int f;
859 
860           if (availq(&p->aux))
861                     return removeq(&p->aux);
862           f = read_status(p) & KBDS_BUFFER_FULL;
863           while (f == KBDS_KBD_BUFFER_FULL) {
864                     DELAY(KBDD_DELAYTIME);
865                     b = read_data(p);
866                     addq(&p->kbd, b);
867                     f = read_status(p) & KBDS_BUFFER_FULL;
868           }
869           if (f == KBDS_AUX_BUFFER_FULL) {
870                     DELAY(KBDD_DELAYTIME);
871                     b = read_data(p);
872                     return b;
873           }
874           return -1; /* no data */
875 }
876 
877 /* discard data from the keyboard */
878 void
empty_kbd_buffer(KBDC p,int wait)879 empty_kbd_buffer(KBDC p, int wait)
880 {
881           int t;
882           int b;
883           int f;
884 #if KBDIO_DEBUG >= 2
885           int c1 = 0;
886           int c2 = 0;
887 #endif
888           int delta = 2;
889 
890           for (t = wait; t > 0;) {
891                     if ((f = read_status(p)) & KBDS_ANY_BUFFER_FULL) {
892                               DELAY(KBDD_DELAYTIME);
893                               b = read_data(p);
894                               if ((f & KBDS_BUFFER_FULL) == KBDS_AUX_BUFFER_FULL) {
895                                         addq(&p->aux, b);
896 #if KBDIO_DEBUG >= 2
897                                         ++c2;
898                               } else {
899                                         ++c1;
900 #endif
901                               }
902                               t = wait;
903                     } else {
904                               t -= delta;
905                     }
906                     DELAY(delta * 1000);
907           }
908 #if KBDIO_DEBUG >= 2
909           if ((c1 > 0) || (c2 > 0))
910                     log(LOG_DEBUG, "kbdc: %d:%d char read (empty_kbd_buffer)\n", c1,
911                         c2);
912 #endif
913 
914           emptyq(&p->kbd);
915 }
916 
917 /* discard data from the aux device */
918 void
empty_aux_buffer(KBDC p,int wait)919 empty_aux_buffer(KBDC p, int wait)
920 {
921           int t;
922           int b;
923           int f;
924 #if KBDIO_DEBUG >= 2
925           int c1 = 0;
926           int c2 = 0;
927 #endif
928           int delta = 2;
929 
930           for (t = wait; t > 0;) {
931                     if ((f = read_status(p)) & KBDS_ANY_BUFFER_FULL) {
932                               DELAY(KBDD_DELAYTIME);
933                               b = read_data(p);
934                               if ((f & KBDS_BUFFER_FULL) == KBDS_KBD_BUFFER_FULL) {
935                                         addq(&p->kbd, b);
936 #if KBDIO_DEBUG >= 2
937                                         ++c1;
938                               } else {
939                                         ++c2;
940 #endif
941                               }
942                               t = wait;
943                     } else {
944                               t -= delta;
945                     }
946                     DELAY(delta * 1000);
947           }
948 #if KBDIO_DEBUG >= 2
949           if ((c1 > 0) || (c2 > 0))
950                     log(LOG_DEBUG, "kbdc: %d:%d char read (empty_aux_buffer)\n", c1,
951                         c2);
952 #endif
953 
954           emptyq(&p->aux);
955 }
956 
957 /* discard any data from the keyboard or the aux device */
958 void
empty_both_buffers(KBDC p,int wait)959 empty_both_buffers(KBDC p, int wait)
960 {
961           int t;
962           int f;
963           int waited = 0;
964 #if KBDIO_DEBUG >= 2
965           int c1 = 0;
966           int c2 = 0;
967 #endif
968           int delta = 2;
969 
970           for (t = wait; t > 0;) {
971                     if ((f = read_status(p)) & KBDS_ANY_BUFFER_FULL) {
972                               DELAY(KBDD_DELAYTIME);
973                               (void)read_data(p);
974 #if KBDIO_DEBUG >= 2
975                               if ((f & KBDS_BUFFER_FULL) == KBDS_KBD_BUFFER_FULL)
976                                         ++c1;
977                               else
978                                         ++c2;
979 #endif
980                               t = wait;
981                     } else {
982                               t -= delta;
983                     }
984                     /*
985                     * Some systems (Intel/IBM blades) do not have keyboard devices and
986                     * will thus hang in this procedure. Time out after delta seconds to
987                     * avoid this hang -- the keyboard attach will fail later on.
988                     */
989                     waited += (delta * 1000);
990                     if (waited == (delta * 1000000))
991                               return;
992 
993                     DELAY(delta * 1000);
994           }
995 #if KBDIO_DEBUG >= 2
996           if ((c1 > 0) || (c2 > 0))
997                     log(LOG_DEBUG, "kbdc: %d:%d char read (empty_both_buffers)\n",
998                         c1, c2);
999 #endif
1000 
1001           emptyq(&p->kbd);
1002           emptyq(&p->aux);
1003 }
1004 
1005 /* keyboard and mouse device control */
1006 
1007 /* NOTE: enable the keyboard port but disable the keyboard
1008  * interrupt before calling "reset_kbd()".
1009  */
1010 int
reset_kbd(KBDC p)1011 reset_kbd(KBDC p)
1012 {
1013           int retry = KBD_MAXRETRY;
1014           int again = KBD_MAXWAIT;
1015           int c = KBD_RESEND; /* keep the compiler happy */
1016 
1017           while (retry-- > 0) {
1018                     empty_both_buffers(p, 10);
1019                     if (!write_kbd_command(p, KBDC_RESET_KBD))
1020                               continue;
1021                     emptyq(&p->kbd);
1022                     c = read_controller_data(p);
1023                     if (verbose || bootverbose)
1024                               log(LOG_DEBUG, "kbdc: RESET_KBD return code:%04x\n", c);
1025                     if (c == KBD_ACK) /* keyboard has agreed to reset itself... */
1026                               break;
1027           }
1028           if (retry < 0)
1029                     return FALSE;
1030 
1031           while (again-- > 0) {
1032                     /* wait awhile, well, in fact we must wait quite loooooooooooong
1033                      */
1034                     DELAY(KBD_RESETDELAY * 1000);
1035                     c = read_controller_data(p); /* RESET_DONE/RESET_FAIL */
1036                     if (c != -1) /* wait again if the controller is not ready */
1037                               break;
1038           }
1039           if (verbose || bootverbose)
1040                     log(LOG_DEBUG, "kbdc: RESET_KBD status:%04x\n", c);
1041           if (c != KBD_RESET_DONE)
1042                     return FALSE;
1043           return TRUE;
1044 }
1045 
1046 /* NOTE: enable the aux port but disable the aux interrupt
1047  * before calling `reset_aux_dev()'.
1048  */
1049 int
reset_aux_dev(KBDC p)1050 reset_aux_dev(KBDC p)
1051 {
1052           int retry = KBD_MAXRETRY;
1053           int again = KBD_MAXWAIT;
1054           int c = PSM_RESEND; /* keep the compiler happy */
1055 
1056           while (retry-- > 0) {
1057                     empty_both_buffers(p, 10);
1058                     if (!write_aux_command(p, PSMC_RESET_DEV))
1059                               continue;
1060                     emptyq(&p->aux);
1061                     /* NOTE: Compaq Armada laptops require extra delay here. XXX */
1062                     for (again = KBD_MAXWAIT; again > 0; --again) {
1063                               DELAY(KBD_RESETDELAY * 1000);
1064                               c = read_aux_data_no_wait(p);
1065                               if (c != -1)
1066                                         break;
1067                     }
1068                     if (verbose || bootverbose)
1069                               log(LOG_DEBUG, "kbdc: RESET_AUX return code:%04x\n", c);
1070                     if (c == PSM_ACK) /* aux dev is about to reset... */
1071                               break;
1072           }
1073           if (retry < 0)
1074                     return FALSE;
1075 
1076           for (again = KBD_MAXWAIT; again > 0; --again) {
1077                     /* wait awhile, well, quite looooooooooooong */
1078                     DELAY(KBD_RESETDELAY * 1000);
1079                     c = read_aux_data_no_wait(p); /* RESET_DONE/RESET_FAIL */
1080                     if (c != -1) /* wait again if the controller is not ready */
1081                               break;
1082           }
1083           if (verbose || bootverbose)
1084                     log(LOG_DEBUG, "kbdc: RESET_AUX status:%04x\n", c);
1085           if (c != PSM_RESET_DONE) /* reset status */
1086                     return FALSE;
1087 
1088           c = read_aux_data(p); /* device ID */
1089           if (verbose || bootverbose)
1090                     log(LOG_DEBUG, "kbdc: RESET_AUX ID:%04x\n", c);
1091           /* NOTE: we could check the device ID now, but leave it later... */
1092           return TRUE;
1093 }
1094 
1095 /* controller diagnostics and setup */
1096 
1097 int
test_controller(KBDC p)1098 test_controller(KBDC p)
1099 {
1100           int retry = KBD_MAXRETRY;
1101           int again = KBD_MAXWAIT;
1102           int c = KBD_DIAG_FAIL;
1103 
1104           while (retry-- > 0) {
1105                     empty_both_buffers(p, 10);
1106                     if (write_controller_command(p, KBDC_DIAGNOSE))
1107                               break;
1108           }
1109           if (retry < 0)
1110                     return FALSE;
1111 
1112           emptyq(&p->kbd);
1113           while (again-- > 0) {
1114                     /* wait awhile */
1115                     DELAY(KBD_RESETDELAY * 1000);
1116                     c = read_controller_data(p); /* DIAG_DONE/DIAG_FAIL */
1117                     if (c != -1) /* wait again if the controller is not ready */
1118                               break;
1119           }
1120           if (verbose || bootverbose)
1121                     log(LOG_DEBUG, "kbdc: DIAGNOSE status:%04x\n", c);
1122           return (c == KBD_DIAG_DONE);
1123 }
1124 
1125 int
test_kbd_port(KBDC p)1126 test_kbd_port(KBDC p)
1127 {
1128           int retry = KBD_MAXRETRY;
1129           int again = KBD_MAXWAIT;
1130           int c = -1;
1131 
1132           while (retry-- > 0) {
1133                     empty_both_buffers(p, 10);
1134                     if (write_controller_command(p, KBDC_TEST_KBD_PORT))
1135                               break;
1136           }
1137           if (retry < 0)
1138                     return FALSE;
1139 
1140           emptyq(&p->kbd);
1141           while (again-- > 0) {
1142                     c = read_controller_data(p);
1143                     if (c != -1) /* try again if the controller is not ready */
1144                               break;
1145           }
1146           if (verbose || bootverbose)
1147                     log(LOG_DEBUG, "kbdc: TEST_KBD_PORT status:%04x\n", c);
1148           return c;
1149 }
1150 
1151 int
test_aux_port(KBDC p)1152 test_aux_port(KBDC p)
1153 {
1154           int retry = KBD_MAXRETRY;
1155           int again = KBD_MAXWAIT;
1156           int c = -1;
1157 
1158           while (retry-- > 0) {
1159                     empty_both_buffers(p, 10);
1160                     if (write_controller_command(p, KBDC_TEST_AUX_PORT))
1161                               break;
1162           }
1163           if (retry < 0)
1164                     return FALSE;
1165 
1166           emptyq(&p->kbd);
1167           while (again-- > 0) {
1168                     c = read_controller_data(p);
1169                     if (c != -1) /* try again if the controller is not ready */
1170                               break;
1171           }
1172           if (verbose || bootverbose)
1173                     log(LOG_DEBUG, "kbdc: TEST_AUX_PORT status:%04x\n", c);
1174           return c;
1175 }
1176 
1177 int
kbdc_get_device_mask(KBDC p)1178 kbdc_get_device_mask(KBDC p)
1179 {
1180           return p->command_mask;
1181 }
1182 
1183 void
kbdc_set_device_mask(KBDC p,int mask)1184 kbdc_set_device_mask(KBDC p, int mask)
1185 {
1186           p->command_mask = mask &
1187               (((p->quirks & KBDC_QUIRK_KEEP_ACTIVATED) ? 0 :
1188                                                                       KBD_KBD_CONTROL_BITS) |
1189                     KBD_AUX_CONTROL_BITS);
1190 }
1191 
1192 int
get_controller_command_byte(KBDC p)1193 get_controller_command_byte(KBDC p)
1194 {
1195           if (p->command_byte != -1)
1196                     return p->command_byte;
1197           if (!write_controller_command(p, KBDC_GET_COMMAND_BYTE))
1198                     return -1;
1199           emptyq(&p->kbd);
1200           p->command_byte = read_controller_data(p);
1201           return p->command_byte;
1202 }
1203 
1204 int
set_controller_command_byte(KBDC p,int mask,int command)1205 set_controller_command_byte(KBDC p, int mask, int command)
1206 {
1207           if (get_controller_command_byte(p) == -1)
1208                     return FALSE;
1209 
1210           command = (p->command_byte & ~mask) | (command & mask);
1211           if (command & KBD_DISABLE_KBD_PORT) {
1212                     if (!write_controller_command(p, KBDC_DISABLE_KBD_PORT))
1213                               return FALSE;
1214           }
1215           if (!write_controller_command(p, KBDC_SET_COMMAND_BYTE))
1216                     return FALSE;
1217           if (!write_controller_data(p, command))
1218                     return FALSE;
1219           p->command_byte = command;
1220 
1221           if (verbose)
1222                     log(LOG_DEBUG,
1223                         "kbdc: new command byte:%04x (set_controller...)\n",
1224                         command);
1225 
1226           return TRUE;
1227 }
1228 
1229 /*
1230  * Rudimentary support for active PS/2 AUX port multiplexing.
1231  * Only write commands can be routed to a selected AUX port.
1232  * Source port of data processed by read commands is totally ignored.
1233  */
1234 static int
set_aux_mux_state(KBDC p,int enabled)1235 set_aux_mux_state(KBDC p, int enabled)
1236 {
1237           int command, version;
1238 
1239           if (write_controller_command(p, KBDC_FORCE_AUX_OUTPUT) == 0 ||
1240               write_controller_data(p, 0xF0) == 0 ||
1241               read_controller_data(p) != 0xF0)
1242                     return (-1);
1243 
1244           if (write_controller_command(p, KBDC_FORCE_AUX_OUTPUT) == 0 ||
1245               write_controller_data(p, 0x56) == 0 ||
1246               read_controller_data(p) != 0x56)
1247                     return (-1);
1248 
1249           command = enabled ? 0xa4 : 0xa5;
1250           if (write_controller_command(p, KBDC_FORCE_AUX_OUTPUT) == 0 ||
1251               write_controller_data(p, command) == 0 ||
1252               (version = read_controller_data(p)) == command)
1253                     return (-1);
1254 
1255           return (version);
1256 }
1257 
1258 int
set_active_aux_mux_port(KBDC p,int port)1259 set_active_aux_mux_port(KBDC p, int port)
1260 {
1261 
1262           if (!aux_mux_is_enabled(p))
1263                     return (FALSE);
1264 
1265           if (port < 0 || port >= KBDC_AUX_MUX_NUM_PORTS)
1266                     return (FALSE);
1267 
1268           p->aux_mux_port = port;
1269 
1270           return (TRUE);
1271 }
1272 
1273 /* Checks for active multiplexing support and enables it */
1274 int
enable_aux_mux(KBDC p)1275 enable_aux_mux(KBDC p)
1276 {
1277           int version;
1278 
1279           version = set_aux_mux_state(p, TRUE);
1280           if (version >= 0) {
1281                     p->aux_mux_enabled = TRUE;
1282                     set_active_aux_mux_port(p, 0);
1283           }
1284 
1285           return (version);
1286 }
1287 
1288 int
disable_aux_mux(KBDC p)1289 disable_aux_mux(KBDC p)
1290 {
1291 
1292           p->aux_mux_enabled = FALSE;
1293 
1294           return (set_aux_mux_state(p, FALSE));
1295 }
1296 
1297 int
aux_mux_is_enabled(KBDC p)1298 aux_mux_is_enabled(KBDC p)
1299 {
1300 
1301           return (p->aux_mux_enabled);
1302 }
1303