diff options
author | Simon Glass <sjg@chromium.org> | 2015-10-19 03:17:19 (GMT) |
---|---|---|
committer | Simon Glass <sjg@chromium.org> | 2015-11-20 03:13:40 (GMT) |
commit | 31d38ee66dfad4284866267ff0651fa0614dad3c (patch) | |
tree | 52e324ca52b1f401bdbf99f6a029684f7415ef44 /drivers/input | |
parent | 7fe0933c5898e5cce70407184fd458cf3ad9ee32 (diff) | |
download | u-boot-31d38ee66dfad4284866267ff0651fa0614dad3c.tar.xz |
i8042: Use functions to handle register access
At present the register access in kbd_reset() is quite primitive. This makes
it hard to follow.
Create functions to read and write data, both to a single register, and via
the command/data approach.
Signed-off-by: Simon Glass <sjg@chromium.org>
Reviewed-by: Bin Meng <bmeng.cn@gmail.com>
Tested-on: Intel Crown Bay and QEMU
Tested-by: Bin Meng <bmeng.cn@gmail.com>
Diffstat (limited to 'drivers/input')
-rw-r--r-- | drivers/input/i8042.c | 75 |
1 files changed, 44 insertions, 31 deletions
diff --git a/drivers/input/i8042.c b/drivers/input/i8042.c index 7b95b21..dbd4b00 100644 --- a/drivers/input/i8042.c +++ b/drivers/input/i8042.c @@ -446,53 +446,66 @@ static void kbd_conv_char(unsigned char scan_code) return; } -static int kbd_reset(void) +static int kbd_write(int reg, int value) { - u8 config; - - /* controller self test */ - if (kbd_input_empty() == 0) - return -1; - out8(I8042_CMD_REG, CMD_SELF_TEST); - if (kbd_output_full() == 0) - return -1; - if (in8(I8042_DATA_REG) != KBC_TEST_OK) + if (!kbd_input_empty()) return -1; + out8(reg, value); - /* keyboard reset */ - if (kbd_input_empty() == 0) + return 0; +} + +static int kbd_read(int reg) +{ + if (!kbd_output_full()) return -1; - out8(I8042_DATA_REG, CMD_RESET_KBD); - if (kbd_output_full() == 0) + + return in8(reg); +} + +static int kbd_cmd_read(int cmd) +{ + if (kbd_write(I8042_CMD_REG, cmd)) return -1; - if (in8(I8042_DATA_REG) != KBD_ACK) + + return kbd_read(I8042_DATA_REG); +} + +static int kbd_cmd_write(int cmd, int data) +{ + if (kbd_write(I8042_CMD_REG, cmd)) return -1; - if (kbd_output_full() == 0) + + return kbd_write(I8042_DATA_REG, data); +} + +static int kbd_reset(void) +{ + int config; + + /* controller self test */ + if (kbd_cmd_read(CMD_SELF_TEST) != KBC_TEST_OK) return -1; - if (in8(I8042_DATA_REG) != KBD_POR) + + /* keyboard reset */ + if (kbd_write(I8042_DATA_REG, CMD_RESET_KBD) || + kbd_read(I8042_DATA_REG) != KBD_ACK || + kbd_read(I8042_DATA_REG) != KBD_POR) return -1; /* set AT translation and disable irq */ - if (kbd_input_empty() == 0) - return -1; - out8(I8042_CMD_REG, CMD_RD_CONFIG); - if (kbd_output_full() == 0) + config = kbd_cmd_read(CMD_RD_CONFIG); + if (config == -1) return -1; - config = in8(I8042_DATA_REG); + config |= CONFIG_AT_TRANS; config &= ~(CONFIG_KIRQ_EN | CONFIG_MIRQ_EN); - if (kbd_input_empty() == 0) + if (kbd_cmd_write(CMD_WR_CONFIG, config)) return -1; - out8(I8042_CMD_REG, CMD_WR_CONFIG); - if (kbd_input_empty() == 0) - return -1; - out8(I8042_DATA_REG, config); /* enable keyboard */ - if (kbd_input_empty() == 0) - return -1; - out8(I8042_CMD_REG, CMD_KBD_EN); - if (kbd_input_empty() == 0) + if (kbd_write(I8042_CMD_REG, CMD_KBD_EN) || + !kbd_input_empty()) return -1; return 0; |