a69d682a0b
Some background first: The original XT keyboards used what we call
scancode set #1 today. The PC/AT keyboards introduced scancode set #2,
but for compatibility, its controller translated scancodes back to
set #1 by default. Newer keyboards (maybe all we have to deal with)
also support switching the scancode set.
This means the translation option in the controller and the scancode
set selection in the keyboard have to match. In libpayload, we only
support set #1 scancodes. So we either need the controller's trans-
lation on and set #2 selected in the keyboard, or the controller's
translation off and set #1 selected in the keyboard.
Valid configurations:
* SET #1 + XLATE off
* SET #2 + XLATE on
Both with and without the PC_KEYBOARD_AT_TRANSLATED option, we were
only configuring one of the two settings, leaving room for invalid
configurations. With this change, we try to select scancode set #2
first, which seems to be the most supported one, and configure the
controller's translation accordingly. We try to fall back to set #1
on failure.
We also keep translation disabled during configuration steps to
ensure that the controller doesn't accidentally translate confi-
guration data.
On the coreboot side, we leave the controller's translation at its
default setting, unless DRIVERS_PS2_KEYBOARD is enabled. The latter
enables the translation unconditionally. For QEMU this means that
the option effectively toggles the translation, as QEMU's controller
has it disabled by default. This probably made a lot of earlier
testing inconsistent.
Fixes: commit a95a6bf646
(libpayload/drivers/i8402/kbd: Fix qemu)
The reset introduced there effectively reverted the scancode
selection made before (because 2 is the default). It's unclear
if later changes to the code were only necessary to work
around it.
Change-Id: Iad85af516a7b9f9c0269ff9652ed15ee81700057
Signed-off-by: Nico Huber <nico.h@gmx.de>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/46724
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Angel Pons <th3fanbus@gmail.com>
66 lines
2.7 KiB
C
66 lines
2.7 KiB
C
/*
|
|
*
|
|
* Copyright 2018 Google LLC
|
|
*
|
|
* 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. 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 AND CONTRIBUTORS ``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 OR CONTRIBUTORS 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.
|
|
*/
|
|
|
|
#ifndef __DRIVERS_I8042_I8042_H__
|
|
#define __DRIVERS_I8042_I8042_H__
|
|
|
|
/* Port 0x64 commands */
|
|
#define I8042_CMD_RD_CMD_BYTE 0x20
|
|
#define I8042_CMD_WR_CMD_BYTE 0x60
|
|
#define I8042_CMD_BYTE_XLATE (1 << 6)
|
|
#define I8042_CMD_DIS_AUX 0xa7
|
|
#define I8042_CMD_EN_AUX 0xa8
|
|
#define I8042_CMD_AUX_TEST 0xa9
|
|
#define I8042_CMD_SELF_TEST 0xaa
|
|
#define I8042_SELF_TEST_RSP 0x55
|
|
#define I8042_CMD_KB_TEST 0xab
|
|
#define I8042_CMD_DIAG_DUMP 0xac
|
|
#define I8042_CMD_DIS_KB 0xad
|
|
#define I8042_CMD_EN_KB 0xae
|
|
#define I8042_CMD_RD_INPUT_PORT 0xc0
|
|
#define I8042_CMD_RD_OUTPUT_PORT 0xd0
|
|
#define I8042_CMD_WR_OUTPUT_PORT 0xd1
|
|
#define I8042_CMD_RD_TEST_INPUTS 0xe0
|
|
|
|
/* Port 0x60 keyboard commands */
|
|
#define I8042_KBCMD_SET_MODE_IND 0xed
|
|
#define I8042_MODE_CAPS_LOCK_ON (1 << 2)
|
|
#define I8042_MODE_CAPS_LOCK_OFF (0 << 2)
|
|
#define I8042_MODE_NUM_LOCK_ON (1 << 1)
|
|
#define I8042_MODE_NUM_LOCK_OFF (0 << 1)
|
|
#define I8042_MODE_SCROLL_LOCK_ON (1 << 0)
|
|
#define I8042_MODE_SCROLL_LOCK_OFF (0 << 0)
|
|
#define I8042_KBCMD_SET_SCANCODE 0xf0
|
|
#define I8042_KBCMD_SET_TYPEMATIC 0xf3
|
|
#define I8042_KBCMD_EN 0xf4
|
|
#define I8042_KBCMD_DEFAULT_DIS 0xf5
|
|
#define I8042_KBCMD_SET_DEFAULT 0xf6
|
|
#define I8042_KBCMD_RESEND 0xfe
|
|
#define I8042_KBCMD_RESET 0xff
|
|
|
|
#endif /* __DRIVERS_I8042_I8042_H__ */
|