diff options
author | Dale Rahn <drahn@cvs.openbsd.org> | 2005-03-15 00:34:26 +0000 |
---|---|---|
committer | Dale Rahn <drahn@cvs.openbsd.org> | 2005-03-15 00:34:26 +0000 |
commit | 5c75918b460da701b6f80cff4089acefc74eeced (patch) | |
tree | 27908cadd617d2213ca0088f82127fae0f14b41d | |
parent | 43a64ca45b364330cf38fdb2b83ccc9167fe994c (diff) |
Restructure the keyboard code so that the keys in rawkey are always sent
as expected. zero both keystate structures, keystate may not be fully
initialized. worked on with uwe.
-rw-r--r-- | sys/arch/zaurus/dev/zaurus_kbd.c | 41 |
1 files changed, 20 insertions, 21 deletions
diff --git a/sys/arch/zaurus/dev/zaurus_kbd.c b/sys/arch/zaurus/dev/zaurus_kbd.c index eaeff76d577..245a4d58504 100644 --- a/sys/arch/zaurus/dev/zaurus_kbd.c +++ b/sys/arch/zaurus/dev/zaurus_kbd.c @@ -1,4 +1,4 @@ -/* $OpenBSD: zaurus_kbd.c,v 1.16 2005/02/23 02:19:32 deraadt Exp $ */ +/* $OpenBSD: zaurus_kbd.c,v 1.17 2005/03/15 00:34:25 drahn Exp $ */ /* * Copyright (c) 2005 Dale Rahn <drahn@openbsd.org> * @@ -199,6 +199,7 @@ zkbd_attach(struct device *parent, struct device *self, void *aux) sc->sc_keystate = malloc(sc->sc_nsense * sc->sc_nstrobe, M_DEVBUF, M_NOWAIT); + bzero(sc->sc_keystate, (sc->sc_nsense * sc->sc_nstrobe)); /* set all the strobe bits */ for (i = 0; i < sc->sc_nstrobe; i++) { @@ -367,17 +368,29 @@ zkbd_poll(void *v) keysdown |= keystate; /* if any keys held */ #ifdef WSDISPLAY_COMPAT_RAWKBD - if (keystate) { - if ((sc->sc_rawkbd) && !( npress >= MAXKEYS-1)) { + if (sc->sc_polling == 0 && sc->sc_rawkbd) { + if ((keystate) || (sc->sc_okeystate[i] != keystate)) { c = sc->sc_xt_keymap[i]; - if (c & 0x80) - sc->sc_rep[npress++] = 0xe0; - sc->sc_rep[npress++] = c & 0x7f; + if (c & 0x80) { + cbuf[ncbuf++] = 0xe0; + } + cbuf[ncbuf] = c & 0x7f; + + if (keystate) { + if (c & 0x80) { + sc->sc_rep[npress++] = 0xe0; + } + sc->sc_rep[npress++] = c & 0x7f; + } else { + cbuf[ncbuf] |= 0x80; + } + ncbuf++; + sc->sc_okeystate[i] = keystate; } } #endif - if (sc->sc_okeystate[i] != keystate) { + if ((!sc->sc_rawkbd) && (sc->sc_okeystate[i] != keystate)) { type = keystate ? WSCONS_EVENT_KEY_DOWN : WSCONS_EVENT_KEY_UP; @@ -390,20 +403,6 @@ zkbd_poll(void *v) if (sc->sc_polling) { sc->sc_pollkey = i; sc->sc_pollUD = type; -#ifdef WSDISPLAY_COMPAT_RAWKBD - } else if (sc->sc_rawkbd) { - - if (npress < sizeof(cbuf)-2) { - c = sc->sc_xt_keymap[i]; - - if (c & 0x80) - cbuf[ncbuf++] = 0xe0; - cbuf[ncbuf] = c & 0x7f; - if (type == WSCONS_EVENT_KEY_UP) - cbuf[ncbuf] |= 0x80; - ncbuf++; - } -#endif } else { wskbd_input(sc->sc_wskbddev, type, i); } |