Commit 0a1f7f57 authored by Hans de Goede's avatar Hans de Goede

platform/x86: thinkpad_acpi: Move adaptive kbd event handling to tpacpi_driver_event()

Factor out the adaptive kbd non hotkey event handling into
adaptive_keyboard_change_row() and adaptive_keyboard_s_quickview_row()
helpers and move the handling of TP_HKEY_EV_DFR_CHANGE_ROW and
TP_HKEY_EV_DFR_S_QUICKVIEW_ROW to tpacpi_driver_event().

This groups all the handling of hotkey events which do not emit
a key press event together in tpacpi_driver_event().

This also drops the returning of false as known-event value when
adaptive_keyboard_get_mode() / adaptive_keyboard_set_mode() fail.
These functions already log an error on failure, returning false just
leads to an extra messgae being logged about the hkey event being
unknown, which is wrong as the event is not unknown.
Reviewed-by: default avatarMark Pearson <mpearson-lenovo@squebb.ca>
Tested-by: default avatarMark Pearson <mpearson-lenovo@squebb.ca>
Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
Reviewed-by: default avatarIlpo Järvinen <ilpo.jarvinen@linux.intel.com>
Link: https://lore.kernel.org/r/20240424122834.19801-9-hdegoede@redhat.com
parent 33dc2efd
...@@ -3677,51 +3677,51 @@ static int adaptive_keyboard_get_next_mode(int mode) ...@@ -3677,51 +3677,51 @@ static int adaptive_keyboard_get_next_mode(int mode)
return adaptive_keyboard_modes[i]; return adaptive_keyboard_modes[i];
} }
static bool adaptive_keyboard_hotkey_notify_hotkey(const u32 hkey) static void adaptive_keyboard_change_row(void)
{ {
int current_mode = 0; int mode;
int new_mode = 0;
switch (hkey) { if (adaptive_keyboard_mode_is_saved) {
case TP_HKEY_EV_DFR_CHANGE_ROW: mode = adaptive_keyboard_prev_mode;
if (adaptive_keyboard_mode_is_saved) { adaptive_keyboard_mode_is_saved = false;
new_mode = adaptive_keyboard_prev_mode; } else {
adaptive_keyboard_mode_is_saved = false; mode = adaptive_keyboard_get_mode();
} else { if (mode < 0)
current_mode = adaptive_keyboard_get_mode(); return;
if (current_mode < 0) mode = adaptive_keyboard_get_next_mode(mode);
return false; }
new_mode = adaptive_keyboard_get_next_mode(
current_mode);
}
if (adaptive_keyboard_set_mode(new_mode) < 0) adaptive_keyboard_set_mode(mode);
return false; }
return true; static void adaptive_keyboard_s_quickview_row(void)
{
int mode;
case TP_HKEY_EV_DFR_S_QUICKVIEW_ROW: mode = adaptive_keyboard_get_mode();
current_mode = adaptive_keyboard_get_mode(); if (mode < 0)
if (current_mode < 0) return;
return false;
adaptive_keyboard_prev_mode = current_mode; adaptive_keyboard_prev_mode = mode;
adaptive_keyboard_mode_is_saved = true; adaptive_keyboard_mode_is_saved = true;
if (adaptive_keyboard_set_mode (FUNCTION_MODE) < 0) adaptive_keyboard_set_mode(FUNCTION_MODE);
return false; }
return true;
default: static bool adaptive_keyboard_hotkey_notify_hotkey(const u32 hkey)
if (hkey < TP_HKEY_EV_ADAPTIVE_KEY_START || {
hkey > TP_HKEY_EV_ADAPTIVE_KEY_END) { if (tpacpi_driver_event(hkey))
pr_info("Unhandled adaptive keyboard key: 0x%x\n", hkey);
return false;
}
tpacpi_input_send_key(hkey - TP_HKEY_EV_ADAPTIVE_KEY_START +
TP_ACPI_HOTKEYSCAN_ADAPTIVE_START);
return true; return true;
if (hkey < TP_HKEY_EV_ADAPTIVE_KEY_START ||
hkey > TP_HKEY_EV_ADAPTIVE_KEY_END) {
pr_info("Unhandled adaptive keyboard key: 0x%x\n", hkey);
return false;
} }
tpacpi_input_send_key(hkey - TP_HKEY_EV_ADAPTIVE_KEY_START +
TP_ACPI_HOTKEYSCAN_ADAPTIVE_START);
return true;
} }
static bool hotkey_notify_extended_hotkey(const u32 hkey) static bool hotkey_notify_extended_hotkey(const u32 hkey)
...@@ -11117,6 +11117,12 @@ static bool tpacpi_driver_event(const unsigned int hkey_event) ...@@ -11117,6 +11117,12 @@ static bool tpacpi_driver_event(const unsigned int hkey_event)
} }
/* Key events are suppressed by default hotkey_user_mask */ /* Key events are suppressed by default hotkey_user_mask */
return false; return false;
case TP_HKEY_EV_DFR_CHANGE_ROW:
adaptive_keyboard_change_row();
return true;
case TP_HKEY_EV_DFR_S_QUICKVIEW_ROW:
adaptive_keyboard_s_quickview_row();
return true;
case TP_HKEY_EV_THM_CSM_COMPLETED: case TP_HKEY_EV_THM_CSM_COMPLETED:
lapsensor_refresh(); lapsensor_refresh();
/* If we are already accessing DYTC then skip dytc update */ /* If we are already accessing DYTC then skip dytc update */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment