diff options
-rw-r--r-- | board/spring/usb_charging.c | 3 | ||||
-rw-r--r-- | chip/stm32/keyboard_scan.c | 18 | ||||
-rw-r--r-- | include/keyboard_scan.h | 3 |
3 files changed, 24 insertions, 0 deletions
diff --git a/board/spring/usb_charging.c b/board/spring/usb_charging.c index 464732c593..d7ba332047 100644 --- a/board/spring/usb_charging.c +++ b/board/spring/usb_charging.c @@ -11,6 +11,7 @@ #include "hooks.h" #include "gpio.h" #include "lp5562.h" +#include "keyboard_scan.h" #include "pmu_tpschrome.h" #include "registers.h" #include "smart_battery.h" @@ -420,6 +421,8 @@ static void usb_device_change(int dev_type) else CPRINTF("Unknown]\n"); + keyboard_send_battery_key(); + current_dev_type = dev_type; } diff --git a/chip/stm32/keyboard_scan.c b/chip/stm32/keyboard_scan.c index 8fc92edfb8..d1e46628ea 100644 --- a/chip/stm32/keyboard_scan.c +++ b/chip/stm32/keyboard_scan.c @@ -674,6 +674,24 @@ void keyboard_enable_scanning(int enable) } } +/* Changes to col,row here need to also be reflected in kernel. + * drivers/input/mkbp.c ... see KEY_BATTERY. + */ +#define BATTERY_KEY_COL 0 +#define BATTERY_KEY_ROW 7 +#define BATTERY_KEY_ROW_MASK (1 << BATTERY_KEY_ROW) + +void keyboard_send_battery_key() +{ + mutex_lock(&scanning_enabled); + debounced_state[BATTERY_KEY_COL] ^= BATTERY_KEY_ROW_MASK; + if (kb_fifo_add(debounced_state) == EC_SUCCESS) + board_interrupt_host(1); + else + CPRINTF("dropped battery keystroke\n"); + mutex_unlock(&scanning_enabled); +} + static int command_keyboard_press(int argc, char **argv) { int r, c, p; diff --git a/include/keyboard_scan.h b/include/keyboard_scan.h index 63384b10fb..8bdbd6905c 100644 --- a/include/keyboard_scan.h +++ b/include/keyboard_scan.h @@ -38,4 +38,7 @@ void keyboard_clear_state(void); /* Enables/disables keyboard matrix scan. */ void keyboard_enable_scanning(int enable); +/* Sends KEY_BATTERY keystroke */ +void keyboard_send_battery_key(void); + #endif /* __CROS_EC_KEYBOARD_SCAN_H */ |