summaryrefslogtreecommitdiff
path: root/drivers/platform/x86/asus-nb-wmi.c
diff options
context:
space:
mode:
authorHans de Goede <hdegoede@redhat.com>2022-08-24 18:11:45 +0300
committerHans de Goede <hdegoede@redhat.com>2022-08-25 17:23:53 +0300
commit1ea0d3b46798afc35c3185f6058b8bc08525d56c (patch)
tree2a1588ecacef5fcf8ff912901d35440bc0323c69 /drivers/platform/x86/asus-nb-wmi.c
parentc98dc61ee08f833e68337700546e120e2edac7c9 (diff)
downloadlinux-1ea0d3b46798afc35c3185f6058b8bc08525d56c.tar.xz
platform/x86: asus-wmi: Simplify tablet-mode-switch handling
Simplify tablet-mode-switch handling: 1. The code is the same for all variants, the only difference is the dev_id and notify event code. Store the dev_id + code in struct asus_wmi and unify the handling 2. Make the new unified asus_wmi_tablet_mode_get_state() check dev_id has been set and make it a no-op when not set. This allows calling it unconditionally at resume/restore time 3. Simplify the tablet_mode_sw module-param handling, this also allows selecting the new lid-flip-rog type through the module-param. Cc: Luke D. Jones <luke@ljones.dev> Signed-off-by: Hans de Goede <hdegoede@redhat.com> Link: https://lore.kernel.org/r/20220824151145.1448010-2-hdegoede@redhat.com
Diffstat (limited to 'drivers/platform/x86/asus-nb-wmi.c')
-rw-r--r--drivers/platform/x86/asus-nb-wmi.c13
1 files changed, 2 insertions, 11 deletions
diff --git a/drivers/platform/x86/asus-nb-wmi.c b/drivers/platform/x86/asus-nb-wmi.c
index d9e7cf6e4a0e..cb8af61d684c 100644
--- a/drivers/platform/x86/asus-nb-wmi.c
+++ b/drivers/platform/x86/asus-nb-wmi.c
@@ -504,17 +504,8 @@ static void asus_nb_wmi_quirks(struct asus_wmi_driver *driver)
else
wapf = quirks->wapf;
- switch (tablet_mode_sw) {
- case 0:
- quirks->tablet_switch_mode = asus_wmi_no_tablet_switch;
- break;
- case 1:
- quirks->tablet_switch_mode = asus_wmi_kbd_dock_devid;
- break;
- case 2:
- quirks->tablet_switch_mode = asus_wmi_lid_flip_devid;
- break;
- }
+ if (tablet_mode_sw != -1)
+ quirks->tablet_switch_mode = tablet_mode_sw;
if (quirks->i8042_filter) {
ret = i8042_install_filter(quirks->i8042_filter);