abfeec800f
as we have no use for that info. Instead let this function return the keyboard ID and verify at its invocation in sunkbd_configure() that we're talking to a Sun type 4/5/6 keyboard, i.e. a keyboard supported by this driver. - Add an option SUNKBD_EMULATE_ATKBD whose code is based on the respective code in ukbd(4) and like UKBD_EMULATE_ATSCANCODE causes this driver to emit AT keyboard/KB_101 compatible scan codes in K_RAW mode as assumed by kbdmux(4). Unlike UKBD_EMULATE_ATSCANCODE, SUNKBD_EMULATE_ATKBD also triggers the use of AT keyboard maps and thus allows to use the map files in share/syscons/keymaps with this driver at the cost of an additional translation (in ukbd(4) this just is the way of operation). - Implement an option SUNKBD_DFLT_KEYMAP, which like the equivalent options of the other keyboard drivers allows to specify the default in-kernel keyboard map. For obvious reasons this made to only work when also using SUNKBD_EMULATE_ATKBD. - Implement sunkbd_check(), sunkbd_check_char() and sunkbd_clear_state(), which are also required for interoperability with kbdmux(4). - Implement K_CODE mode and FreeBSD keypad compose. - As a minor hack define KBD_DFLT_KEYMAP also in the !SUNKBD_EMULATE_ATKBD case so we can obtain fkey_tab from <dev/kbd/kbdtables.h> rather than having to duplicate it and #ifdef some more code. - Don't use the TX-buffer for writing the two command bytes for setting the keyboard LEDs as this consequently requires a hardware FIFO that is at least two bytes in depth, which the NMOS-variant of the Zilog SCCs doesn't have. Thus use an inlined version of uart_putc() to consecutively write the command bytes (a cleaner approach would be to do this via the soft interrupt handler but that variant wouldn't work while in ddb(4)). [1] - Fix some minor style(9) bugs. PR: 90316 [1] Reviewed by: marcel [1]
69 lines
2.8 KiB
C
69 lines
2.8 KiB
C
/*-
|
|
* Copyright (c) 2002 Jason L. Wright (jason@thought.net)
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
* 3. All advertising materials mentioning features or use of this software
|
|
* must display the following acknowledgement:
|
|
* This product includes software developed by Jason L. Wright
|
|
* 4. The name of the author may not be used to endorse or promote products
|
|
* derived from this software without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
* DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
|
|
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
|
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
|
*
|
|
* Effort sponsored in part by the Defense Advanced Research Projects
|
|
* Agency (DARPA) and Air Force Research Laboratory, Air Force
|
|
* Materiel Command, USAF, under agreement number F30602-01-2-0537.
|
|
*
|
|
* $FreeBSD$
|
|
*/
|
|
|
|
/* keyboard commands (host->kbd) */
|
|
#define SKBD_CMD_RESET 0x01
|
|
#define SKBD_CMD_BELLON 0x02
|
|
#define SKBD_CMD_BELLOFF 0x03
|
|
#define SKBD_CMD_CLICKON 0x0a
|
|
#define SKBD_CMD_CLICKOFF 0x0b
|
|
#define SKBD_CMD_SETLED 0x0e
|
|
#define SKBD_CMD_LAYOUT 0x0f
|
|
|
|
/* keyboard responses (kbd->host) */
|
|
#define SKBD_RSP_RESET_OK 0x04 /* normal reset status for type 4/5/6 */
|
|
#define SKBD_RSP_IDLE 0x7f /* no keys down */
|
|
#define SKBD_RSP_LAYOUT 0xfe /* layout follows */
|
|
#define SKBD_RSP_RESET 0xff /* reset status follows */
|
|
|
|
#define SKBD_LED_NUMLOCK 0x01
|
|
#define SKBD_LED_COMPOSE 0x02
|
|
#define SKBD_LED_SCROLLLOCK 0x04
|
|
#define SKBD_LED_CAPSLOCK 0x08
|
|
|
|
#define SKBD_STATE_RESET 0
|
|
#define SKBD_STATE_LAYOUT 1
|
|
#define SKBD_STATE_GETKEY 2
|
|
|
|
/* keyboard types */
|
|
#define KB_SUN2 2 /* type 2 keyboard */
|
|
#define KB_SUN3 3 /* type 3 keyboard */
|
|
#define KB_SUN4 4 /* type 4/5/6 keyboard */
|
|
|
|
#define SKBD_KEY_RELEASE 0x80
|
|
#define SKBD_KEY_CHAR(c) ((c) & 0x7f)
|