]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
platform/x86: panasonic-laptop: Add support for programmable buttons
authorJames Harmison <jharmison@redhat.com>
Mon, 9 Sep 2024 11:32:27 +0000 (13:32 +0200)
committerHans de Goede <hdegoede@redhat.com>
Wed, 11 Sep 2024 12:21:28 +0000 (14:21 +0200)
The value returned by "HINF" contains press/release information
in bit 7 and a keycode in bits 0-6.

Change the code to retrieve the keycode to use all 7 keycode bits instead
of only using bits 0-3 and add mappings for the higher keycodes used by
the programmable buttons found on newer panasonic toughbook models.

Tested-by: James Harmison <jharmison@redhat.com>
Signed-off-by: James Harmison <jharmison@redhat.com>
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
Link: https://lore.kernel.org/r/20240909113227.254470-3-hdegoede@redhat.com
drivers/platform/x86/panasonic-laptop.c

index cf845ee1c7b1f0ef4030d7648da3774fbb593136..1c88636649a16d989623bf5964831e7128f8921e 100644 (file)
 
 #include <linux/acpi.h>
 #include <linux/backlight.h>
+#include <linux/bits.h>
 #include <linux/ctype.h>
 #include <linux/i8042.h>
 #include <linux/init.h>
@@ -224,6 +225,17 @@ static const struct key_entry panasonic_keymap[] = {
        { KE_KEY, 8, { KEY_PROG1 } }, /* Change CPU boost */
        { KE_KEY, 9, { KEY_BATTERY } },
        { KE_KEY, 10, { KEY_SUSPEND } },
+       { KE_KEY, 21, { KEY_MACRO1 } },
+       { KE_KEY, 22, { KEY_MACRO2 } },
+       { KE_KEY, 24, { KEY_MACRO3 } },
+       { KE_KEY, 25, { KEY_MACRO4 } },
+       { KE_KEY, 34, { KEY_MACRO5 } },
+       { KE_KEY, 35, { KEY_MACRO6 } },
+       { KE_KEY, 36, { KEY_MACRO7 } },
+       { KE_KEY, 37, { KEY_MACRO8 } },
+       { KE_KEY, 41, { KEY_MACRO9 } },
+       { KE_KEY, 42, { KEY_MACRO10 } },
+       { KE_KEY, 43, { KEY_MACRO11 } },
        { KE_END, 0 }
 };
 
@@ -810,8 +822,8 @@ static void acpi_pcc_generate_keyinput(struct pcc_acpi *pcc)
                return;
        }
 
-       key = result & 0xf;
-       updown = result & 0x80; /* 0x80 == key down; 0x00 = key up */
+       key = result & GENMASK(6, 0);
+       updown = result & BIT(7); /* 0x80 == key down; 0x00 = key up */
 
        /* hack: some firmware sends no key down for sleep / hibernate */
        if (key == 7 || key == 10) {