Re: [PATCH] platform/x86: Toshiba WMI Hotkey Driver

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



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



[Index of Archives]     [Linux Kernel Development]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux