Thomas Gleixner | 1a59d1b8 | 2019-05-27 08:55:05 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-or-later */ |
Corentin Chary | e12e6d9 | 2011-02-26 10:20:31 +0100 | [diff] [blame] | 2 | /* |
| 3 | * Asus PC WMI hotkey driver |
| 4 | * |
| 5 | * Copyright(C) 2010 Intel Corporation. |
| 6 | * Copyright(C) 2010-2011 Corentin Chary <corentin.chary@gmail.com> |
| 7 | * |
| 8 | * Portions based on wistron_btns.c: |
| 9 | * Copyright (C) 2005 Miloslav Trmac <mitr@volny.cz> |
| 10 | * Copyright (C) 2005 Bernhard Rosenkraenzer <bero@arklinux.org> |
| 11 | * Copyright (C) 2005 Dmitry Torokhov <dtor@mail.ru> |
Corentin Chary | e12e6d9 | 2011-02-26 10:20:31 +0100 | [diff] [blame] | 12 | */ |
| 13 | |
| 14 | #ifndef _ASUS_WMI_H_ |
| 15 | #define _ASUS_WMI_H_ |
| 16 | |
| 17 | #include <linux/platform_device.h> |
Oleksij Rempel | b564353 | 2016-09-12 17:48:17 +0200 | [diff] [blame] | 18 | #include <linux/i8042.h> |
Corentin Chary | e12e6d9 | 2011-02-26 10:20:31 +0100 | [diff] [blame] | 19 | |
Seth Forshee | c4453f6 | 2011-07-01 11:34:27 +0200 | [diff] [blame] | 20 | #define ASUS_WMI_KEY_IGNORE (-1) |
Corentin Chary | 3ba0302 | 2012-11-29 09:12:38 +0100 | [diff] [blame] | 21 | #define ASUS_WMI_BRN_DOWN 0x20 |
| 22 | #define ASUS_WMI_BRN_UP 0x2f |
Seth Forshee | c4453f6 | 2011-07-01 11:34:27 +0200 | [diff] [blame] | 23 | |
Corentin Chary | e12e6d9 | 2011-02-26 10:20:31 +0100 | [diff] [blame] | 24 | struct module; |
| 25 | struct key_entry; |
| 26 | struct asus_wmi; |
| 27 | |
AceLan Kao | c87992d | 2012-03-20 09:53:08 +0100 | [diff] [blame] | 28 | struct quirk_entry { |
| 29 | bool hotplug_wireless; |
| 30 | bool scalar_panel_brightness; |
AceLan Kao | 6e0044b | 2012-03-20 09:53:09 +0100 | [diff] [blame] | 31 | bool store_backlight_power; |
AceLan Kao | 272c77d | 2012-06-13 09:32:06 +0200 | [diff] [blame] | 32 | bool wmi_backlight_power; |
zino lin | 999d437 | 2016-08-28 16:12:06 +0800 | [diff] [blame] | 33 | bool wmi_backlight_native; |
Hans de Goede | 401fee8 | 2019-06-12 09:02:02 +0200 | [diff] [blame] | 34 | bool wmi_backlight_set_devstate; |
Oleksij Rempel | e9b6151 | 2017-04-28 16:19:49 +0200 | [diff] [blame] | 35 | bool wmi_force_als_set; |
Hans de Goede | 1797d58 | 2020-09-16 16:14:39 +0200 | [diff] [blame] | 36 | bool use_kbd_dock_devid; |
Samuel Čavoj | ea856ec | 2020-10-21 00:09:44 +0200 | [diff] [blame] | 37 | bool use_lid_flip_devid; |
Corentin Chary | 6a2bccc | 2012-03-20 09:53:10 +0100 | [diff] [blame] | 38 | int wapf; |
AceLan Kao | a2a96f0 | 2012-10-03 11:26:31 +0200 | [diff] [blame] | 39 | /* |
| 40 | * For machines with AMD graphic chips, it will send out WMI event |
| 41 | * and ACPI interrupt at the same time while hitting the hotkey. |
| 42 | * To simplify the problem, we just have to ignore the WMI event, |
| 43 | * and let the ACPI interrupt to send out the key event. |
| 44 | */ |
| 45 | int no_display_toggle; |
Kai-Chuan Hsieh | 8023eff | 2016-09-01 23:55:55 +0800 | [diff] [blame] | 46 | u32 xusb2pr; |
Oleksij Rempel | b564353 | 2016-09-12 17:48:17 +0200 | [diff] [blame] | 47 | |
| 48 | bool (*i8042_filter)(unsigned char data, unsigned char str, |
| 49 | struct serio *serio); |
AceLan Kao | c87992d | 2012-03-20 09:53:08 +0100 | [diff] [blame] | 50 | }; |
| 51 | |
Corentin Chary | e12e6d9 | 2011-02-26 10:20:31 +0100 | [diff] [blame] | 52 | struct asus_wmi_driver { |
AceLan Kao | c87992d | 2012-03-20 09:53:08 +0100 | [diff] [blame] | 53 | int brightness; |
AceLan Kao | 6e0044b | 2012-03-20 09:53:09 +0100 | [diff] [blame] | 54 | int panel_power; |
AceLan Kao | a50bd12 | 2012-07-26 17:13:31 +0800 | [diff] [blame] | 55 | int wlan_ctrl_by_user; |
Corentin Chary | e12e6d9 | 2011-02-26 10:20:31 +0100 | [diff] [blame] | 56 | |
| 57 | const char *name; |
| 58 | struct module *owner; |
| 59 | |
| 60 | const char *event_guid; |
| 61 | |
| 62 | const struct key_entry *keymap; |
| 63 | const char *input_name; |
| 64 | const char *input_phys; |
AceLan Kao | c87992d | 2012-03-20 09:53:08 +0100 | [diff] [blame] | 65 | struct quirk_entry *quirks; |
Seth Forshee | c4453f6 | 2011-07-01 11:34:27 +0200 | [diff] [blame] | 66 | /* Returns new code, value, and autorelease values in arguments. |
| 67 | * Return ASUS_WMI_KEY_IGNORE in code if event should be ignored. */ |
| 68 | void (*key_filter) (struct asus_wmi_driver *driver, int *code, |
| 69 | unsigned int *value, bool *autorelease); |
Corentin Chary | e12e6d9 | 2011-02-26 10:20:31 +0100 | [diff] [blame] | 70 | |
| 71 | int (*probe) (struct platform_device *device); |
AceLan Kao | c87992d | 2012-03-20 09:53:08 +0100 | [diff] [blame] | 72 | void (*detect_quirks) (struct asus_wmi_driver *driver); |
Corentin Chary | e12e6d9 | 2011-02-26 10:20:31 +0100 | [diff] [blame] | 73 | |
| 74 | struct platform_driver platform_driver; |
| 75 | struct platform_device *platform_device; |
| 76 | }; |
| 77 | |
| 78 | int asus_wmi_register_driver(struct asus_wmi_driver *driver); |
| 79 | void asus_wmi_unregister_driver(struct asus_wmi_driver *driver); |
| 80 | |
| 81 | #endif /* !_ASUS_WMI_H_ */ |