Hi Darren, 2015-09-18 15:59 GMT-06:00 Darren Hart <dvhart@xxxxxxxxxxxxx>: > On Wed, Sep 09, 2015 at 11:30:10AM -0600, Azael Avalos wrote: >> Toshiba laptops that feature WMI events for hotkeys were left unsupported >> by the toshiba_acpi driver, however, commit a88bc06e5aec ("toshiba_acpi: >> Avoid registering input device on WMI event laptops") added hardware >> support for such laptops, but the hotkeys are not handled there. >> >> This driver adds support for hotkey monitoring on certain Toshiba laptops >> that manage the hotkeys via WMI events instead of the Toshiba >> Configuration Interface (TCI). >> >> The toshiba_acpi driver and this one can co-exist, as this only takes >> care of hotkeys, while the propper takes care of hardware related stuff. >> >> Currently the driver is under the EXPERIMENTAL flag, as the keymap >> and the notify function are incomplete (due to lack of hardware to test). >> >> Signed-off-by: Azael Avalos <coproscefalo@xxxxxxxxx> > > +Dmitry - Are you interested in being Cc'd on new users of input outside > drivers/input ? > >> --- >> MAINTAINERS | 6 ++ >> drivers/platform/x86/Kconfig | 18 +++++ >> drivers/platform/x86/Makefile | 1 + >> drivers/platform/x86/toshiba-wmi.c | 138 +++++++++++++++++++++++++++++++++++++ >> 4 files changed, 163 insertions(+) >> create mode 100644 drivers/platform/x86/toshiba-wmi.c >> >> diff --git a/MAINTAINERS b/MAINTAINERS >> index 884d398..07f4446 100644 >> --- a/MAINTAINERS >> +++ b/MAINTAINERS >> @@ -10318,6 +10318,12 @@ L: platform-driver-x86@xxxxxxxxxxxxxxx >> S: Maintained >> F: drivers/platform/x86/toshiba_haps.c >> >> +TOSHIBA WMI HOTKEYS DRIVER >> +M: Azael Avalos <coproscefalo@xxxxxxxxx> >> +L: platform-driver-x86@xxxxxxxxxxxxxxx >> +S: Maintained >> +F: drivers/platform/x86/toshiba-wmi.c >> + >> TOSHIBA SMM DRIVER >> M: Jonathan Buzzard <jonathan@xxxxxxxxxxxxxx> >> W: http://www.buzzard.org.uk/toshiba/ >> diff --git a/drivers/platform/x86/Kconfig b/drivers/platform/x86/Kconfig >> index c69bb70..9ae1e89 100644 >> --- a/drivers/platform/x86/Kconfig >> +++ b/drivers/platform/x86/Kconfig >> @@ -700,6 +700,24 @@ config TOSHIBA_HAPS >> If you have a recent Toshiba laptop with a built-in accelerometer >> device, say Y. >> >> +config TOSHIBA_WMI >> + tristate "Toshiba WMI Hotkeys Driver (EXPERIMENTAL)" >> + default n >> + depends on ACPI_WMI >> + depends on INPUT >> + select INPUT_SPARSEKMAP >> + ---help--- >> + This driver adds hotkey monitoring support to some Toshiba models >> + that manage the hotkeys via WMI events. >> + >> + WARNING: This driver is incomplete as it lacks a propper keymap and the >> + *notify function only prints the ACPI event type value. Be warned that >> + you will need to provide some information if you have a Toshiba model >> + with WMI event hotkeys and want to help with the develpment of this >> + driver. >> + >> + If you have a WMI-based hotkeys Toshiba laptop, say Y or M here. >> + >> config ACPI_CMPC >> tristate "CMPC Laptop Extras" >> depends on X86 && ACPI >> diff --git a/drivers/platform/x86/Makefile b/drivers/platform/x86/Makefile >> index ada5128..8f077cb 100644 >> --- a/drivers/platform/x86/Makefile >> +++ b/drivers/platform/x86/Makefile >> @@ -40,6 +40,7 @@ obj-$(CONFIG_ACPI_TOSHIBA) += toshiba_acpi.o >> >> obj-$(CONFIG_TOSHIBA_BT_RFKILL) += toshiba_bluetooth.o >> obj-$(CONFIG_TOSHIBA_HAPS) += toshiba_haps.o >> +obj-$(CONFIG_TOSHIBA_HAPS) += toshiba-wmi.o >> obj-$(CONFIG_INTEL_SCU_IPC) += intel_scu_ipc.o >> obj-$(CONFIG_INTEL_SCU_IPC_UTIL) += intel_scu_ipcutil.o >> obj-$(CONFIG_INTEL_MFLD_THERMAL) += intel_mid_thermal.o >> diff --git a/drivers/platform/x86/toshiba-wmi.c b/drivers/platform/x86/toshiba-wmi.c >> new file mode 100644 >> index 0000000..8cf62a1 >> --- /dev/null >> +++ b/drivers/platform/x86/toshiba-wmi.c >> @@ -0,0 +1,138 @@ >> +/* >> + * toshiba_wmi.c - Toshiba WMI Hotkey Driver >> + * >> + * Copyright (C) 2015 Azael Avalos <coproscefalo@xxxxxxxxx> >> + * >> + * This program is free software; you can redistribute it and/or modify >> + * it under the terms of the GNU General Public License as published by >> + * the Free Software Foundation; either version 2 of the License, or >> + * (at your option) any later version. >> + * >> + * This program is distributed in the hope that it will be useful, >> + * but WITHOUT ANY WARRANTY; without even the implied warranty of >> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the >> + * GNU General Public License for more details. >> + * >> + */ >> + >> +#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt >> + >> +#include <linux/kernel.h> >> +#include <linux/module.h> >> +#include <linux/init.h> >> +#include <linux/types.h> >> +#include <linux/acpi.h> >> +#include <linux/input.h> >> +#include <linux/input/sparse-keymap.h> >> + >> +MODULE_AUTHOR("Azael Avalos"); >> +MODULE_DESCRIPTION("Toshiba WMI Hotkey Driver"); >> +MODULE_LICENSE("GPL"); >> + >> +#define TOSHIBA_WMI_EVENT_GUID "59142400-C6A3-40FA-BADB-8A2652834100" >> + >> +MODULE_ALIAS("wmi:"TOSHIBA_WMI_EVENT_GUID); >> + >> +struct input_dev *toshiba_wmi_input_dev; >> + >> +static const struct key_entry toshiba_wmi_keymap[] __initconst = { >> + /* TODO: Add keymap values once found... */ >> + /*{ KE_KEY, 0x00, { KEY_ } },*/ >> + { KE_END, 0 } >> +}; >> + >> +static void toshiba_wmi_notify(u32 value, void *context) >> +{ >> + struct acpi_buffer response = { ACPI_ALLOCATE_BUFFER, NULL }; >> + union acpi_object *obj; >> + acpi_status status; >> + >> + status = wmi_get_event_data(value, &response); >> + if (ACPI_FAILURE(status)) { >> + pr_err("Bad event status 0x%x\n", status); >> + return; >> + } >> + >> + obj = (union acpi_object *)response.pointer; >> + if (!obj) >> + return; >> + >> + /* TODO: Add propper checks once we have data */ >> + pr_info("Unknown event received, obj type %x\n", obj->type); > > Since this will print all the time, perhaps a pr_dbg is more appropraite here... OK, will change in v2, along with a static warning caught by the build test. > > >> + >> + kfree(response.pointer); >> +} >> + >> +static int __init toshiba_wmi_input_setup(void) >> +{ >> + acpi_status status; >> + int err; >> + >> + toshiba_wmi_input_dev = input_allocate_device(); >> + if (!toshiba_wmi_input_dev) >> + return -ENOMEM; >> + >> + toshiba_wmi_input_dev->name = "Toshiba WMI hotkeys"; >> + toshiba_wmi_input_dev->phys = "wmi/input0"; >> + toshiba_wmi_input_dev->id.bustype = BUS_HOST; >> + >> + err = sparse_keymap_setup(toshiba_wmi_input_dev, >> + toshiba_wmi_keymap, NULL); >> + if (err) >> + goto err_free_dev; >> + >> + status = wmi_install_notify_handler(TOSHIBA_WMI_EVENT_GUID, >> + toshiba_wmi_notify, NULL); >> + if (ACPI_FAILURE(status)) { >> + err = -EIO; >> + goto err_free_keymap; >> + } >> + >> + err = input_register_device(toshiba_wmi_input_dev); >> + if (err) >> + goto err_remove_notifier; >> + >> + return 0; >> + >> + err_remove_notifier: >> + wmi_remove_notify_handler(TOSHIBA_WMI_EVENT_GUID); >> + err_free_keymap: >> + sparse_keymap_free(toshiba_wmi_input_dev); >> + err_free_dev: >> + input_free_device(toshiba_wmi_input_dev); >> + return err; >> +} >> + >> +static void toshiba_wmi_input_destroy(void) >> +{ >> + wmi_remove_notify_handler(TOSHIBA_WMI_EVENT_GUID); >> + sparse_keymap_free(toshiba_wmi_input_dev); >> + input_unregister_device(toshiba_wmi_input_dev); >> +} >> + >> +static int __init toshiba_wmi_init(void) >> +{ >> + int ret; >> + >> + if (!wmi_has_guid(TOSHIBA_WMI_EVENT_GUID)) >> + return -ENODEV; >> + >> + ret = toshiba_wmi_input_setup(); >> + if (ret) { >> + pr_err("Failed to setup input device\n"); >> + return ret; >> + } >> + >> + pr_info("Toshiba WMI Hotkey Driver\n"); >> + >> + return 0; >> +} >> + >> +static void __exit toshiba_wmi_exit(void) >> +{ >> + if (wmi_has_guid(TOSHIBA_WMI_EVENT_GUID)) >> + toshiba_wmi_input_destroy(); >> +} >> + >> +module_init(toshiba_wmi_init); >> +module_exit(toshiba_wmi_exit); >> -- >> 2.5.1 >> >> > > -- > Darren Hart > Intel Open Source Technology Center Cheers Azael -- -- El mundo apesta y vosotros apestais tambien -- -- To unsubscribe from this list: send the line "unsubscribe platform-driver-x86" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html