2019-06-04 11:11:33 +03:00
/* SPDX-License-Identifier: GPL-2.0-only */
2005-04-17 02:20:36 +04:00
# ifndef _I8042_X86IA64IO_H
# define _I8042_X86IA64IO_H
2010-07-08 00:02:16 +04:00
# ifdef CONFIG_X86
# include <asm/x86_init.h>
# endif
2005-04-17 02:20:36 +04:00
/*
* Names .
*/
# define I8042_KBD_PHYS_DESC "isa0060 / serio0"
# define I8042_AUX_PHYS_DESC "isa0060 / serio1"
# define I8042_MUX_PHYS_DESC "isa0060 / serio%d"
/*
* IRQs .
*/
# if defined(__ia64__)
# define I8042_MAP_IRQ(x) isa_irq_to_vector((x))
# else
# define I8042_MAP_IRQ(x) (x)
# endif
# define I8042_KBD_IRQ i8042_kbd_irq
# define I8042_AUX_IRQ i8042_aux_irq
static int i8042_kbd_irq ;
static int i8042_aux_irq ;
/*
* Register numbers .
*/
# define I8042_COMMAND_REG i8042_command_reg
# define I8042_STATUS_REG i8042_command_reg
# define I8042_DATA_REG i8042_data_reg
static int i8042_command_reg = 0x64 ;
static int i8042_data_reg = 0x60 ;
static inline int i8042_read_data ( void )
{
return inb ( I8042_DATA_REG ) ;
}
static inline int i8042_read_status ( void )
{
return inb ( I8042_STATUS_REG ) ;
}
static inline void i8042_write_data ( int val )
{
outb ( val , I8042_DATA_REG ) ;
}
static inline void i8042_write_command ( int val )
{
outb ( val , I8042_COMMAND_REG ) ;
}
2008-05-28 09:10:52 +04:00
# ifdef CONFIG_X86
2005-04-17 02:20:36 +04:00
# include <linux/dmi.h>
2022-06-30 03:38:07 +03:00
# define SERIO_QUIRK_NOKBD BIT(0)
# define SERIO_QUIRK_NOAUX BIT(1)
# define SERIO_QUIRK_NOMUX BIT(2)
# define SERIO_QUIRK_FORCEMUX BIT(3)
# define SERIO_QUIRK_UNLOCK BIT(4)
# define SERIO_QUIRK_PROBE_DEFER BIT(5)
# define SERIO_QUIRK_RESET_ALWAYS BIT(6)
# define SERIO_QUIRK_RESET_NEVER BIT(7)
# define SERIO_QUIRK_DIECT BIT(8)
# define SERIO_QUIRK_DUMBKBD BIT(9)
# define SERIO_QUIRK_NOLOOP BIT(10)
# define SERIO_QUIRK_NOTIMEOUT BIT(11)
# define SERIO_QUIRK_KBDRESET BIT(12)
# define SERIO_QUIRK_DRITEK BIT(13)
# define SERIO_QUIRK_NOPNP BIT(14)
/* Quirk table for different mainboards. Options similar or identical to i8042
* module parameters .
* ORDERING IS IMPORTANT ! The first match will be apllied and the rest ignored .
* This allows entries to overwrite vendor wide quirks on a per device basis .
* Where this is irrelevant , entries are sorted case sensitive by DMI_SYS_VENDOR
* and / or DMI_BOARD_VENDOR to make it easier to avoid dublicate entries .
*/
static const struct dmi_system_id i8042_dmi_quirk_table [ ] __initconst = {
2008-07-19 08:35:43 +04:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " ALIENWARE " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Sentia " ) ,
2008-07-19 08:35:43 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2008-07-19 08:35:43 +04:00
} ,
2009-08-03 20:32:34 +04:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " ASUSTeK COMPUTER INC. " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " X750LN " ) ,
2009-08-03 20:32:34 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2009-08-03 20:32:34 +04:00
} ,
2007-06-12 08:33:27 +04:00
{
2022-06-30 03:38:07 +03:00
/* Asus X450LCP */
2007-06-12 08:33:27 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " ASUSTeK COMPUTER INC. " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " X450LCP " ) ,
2007-06-12 08:33:27 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX | SERIO_QUIRK_RESET_NEVER )
2007-06-12 08:33:27 +04:00
} ,
2014-10-11 22:27:37 +04:00
{
2022-06-30 03:38:07 +03:00
/* ASUS ZenBook UX425UA */
2014-10-11 22:27:37 +04:00
. matches = {
DMI_MATCH ( DMI_SYS_VENDOR , " ASUSTeK COMPUTER INC. " ) ,
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_PRODUCT_NAME , " ZenBook UX425UA " ) ,
2014-10-11 22:27:37 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_PROBE_DEFER | SERIO_QUIRK_RESET_NEVER )
2014-10-11 22:27:37 +04:00
} ,
2005-04-17 02:20:36 +04:00
{
2022-06-30 03:38:07 +03:00
/* ASUS ZenBook UM325UA */
2005-04-17 02:20:36 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " ASUSTeK COMPUTER INC. " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " ZenBook UX325UA_UM325UA " ) ,
2005-04-17 02:20:36 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_PROBE_DEFER | SERIO_QUIRK_RESET_NEVER )
2005-04-17 02:20:36 +04:00
} ,
2022-06-30 03:38:07 +03:00
/*
* On some Asus laptops , just running self tests cause problems .
*/
2005-04-17 02:20:36 +04:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " ASUSTeK COMPUTER INC. " ) ,
DMI_MATCH ( DMI_CHASSIS_TYPE , " 10 " ) , /* Notebook */
2005-04-17 02:20:36 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_NEVER )
2005-04-17 02:20:36 +04:00
} ,
2017-03-07 20:31:29 +03:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " ASUSTeK COMPUTER INC. " ) ,
DMI_MATCH ( DMI_CHASSIS_TYPE , " 31 " ) , /* Convertible Notebook */
2017-03-07 20:31:29 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_NEVER )
2017-03-07 20:31:29 +03:00
} ,
2006-01-06 07:00:38 +03:00
{
2022-06-30 03:38:07 +03:00
/* ASUS P65UP5 - AUX LOOP command does not raise AUX IRQ */
2006-01-06 07:00:38 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_BOARD_VENDOR , " ASUSTeK Computer INC. " ) ,
DMI_MATCH ( DMI_BOARD_NAME , " P/I-P65UP5 " ) ,
DMI_MATCH ( DMI_BOARD_VERSION , " REV 2.X " ) ,
2006-01-06 07:00:38 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2006-01-06 07:00:38 +03:00
} ,
2007-06-12 08:33:32 +04:00
{
2022-06-30 03:38:07 +03:00
/* ASUS G1S */
2007-06-12 08:33:32 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_BOARD_VENDOR , " ASUSTeK Computer Inc. " ) ,
DMI_MATCH ( DMI_BOARD_NAME , " G1S " ) ,
DMI_MATCH ( DMI_BOARD_VERSION , " 1.0 " ) ,
2007-06-12 08:33:32 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2007-06-12 08:33:32 +04:00
} ,
2007-11-21 22:17:38 +03:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire 1360 " ) ,
2007-11-21 22:17:38 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2007-11-21 22:17:38 +03:00
} ,
2008-07-03 19:00:28 +04:00
{
2022-06-30 03:38:07 +03:00
/* Acer Aspire 5710 */
2008-07-03 19:00:28 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire 5710 " ) ,
2008-07-03 19:00:28 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
Input: i8042 - add noloop quirk for Medion Akoya E7225 (MD98857)
Without this the aux port does not get detected, and consequently the touchpad
will not work.
With this patch the touchpad is detected:
$ dmesg | grep -E "(SYN|i8042|serio)"
pnp 00:03: Plug and Play ACPI device, IDs SYN1d22 PNP0f13 (active)
i8042: PNP: PS/2 Controller [PNP0303:PS2K,PNP0f13:PS2M] at 0x60,0x64 irq 1,12
serio: i8042 KBD port at 0x60,0x64 irq 1
serio: i8042 AUX port at 0x60,0x64 irq 12
input: AT Translated Set 2 keyboard as /devices/platform/i8042/serio0/input/input4
psmouse serio1: synaptics: Touchpad model: 1, fw: 8.1, id: 0x1e2b1, caps: 0xd00123/0x840300/0x126800, board id: 2863, fw id: 1473085
input: SynPS/2 Synaptics TouchPad as /devices/platform/i8042/serio1/input/input6
dmidecode excerpt for this laptop is:
Handle 0x0001, DMI type 1, 27 bytes
System Information
Manufacturer: Medion
Product Name: Akoya E7225
Version: 1.0
Cc: stable@vger.kernel.org
Signed-off-by: Jochen Hein <jochen@jochen.org>
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
2015-01-22 23:03:15 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Acer Aspire 7738 */
Input: i8042 - add noloop quirk for Medion Akoya E7225 (MD98857)
Without this the aux port does not get detected, and consequently the touchpad
will not work.
With this patch the touchpad is detected:
$ dmesg | grep -E "(SYN|i8042|serio)"
pnp 00:03: Plug and Play ACPI device, IDs SYN1d22 PNP0f13 (active)
i8042: PNP: PS/2 Controller [PNP0303:PS2K,PNP0f13:PS2M] at 0x60,0x64 irq 1,12
serio: i8042 KBD port at 0x60,0x64 irq 1
serio: i8042 AUX port at 0x60,0x64 irq 12
input: AT Translated Set 2 keyboard as /devices/platform/i8042/serio0/input/input4
psmouse serio1: synaptics: Touchpad model: 1, fw: 8.1, id: 0x1e2b1, caps: 0xd00123/0x840300/0x126800, board id: 2863, fw id: 1473085
input: SynPS/2 Synaptics TouchPad as /devices/platform/i8042/serio1/input/input6
dmidecode excerpt for this laptop is:
Handle 0x0001, DMI type 1, 27 bytes
System Information
Manufacturer: Medion
Product Name: Akoya E7225
Version: 1.0
Cc: stable@vger.kernel.org
Signed-off-by: Jochen Hein <jochen@jochen.org>
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
2015-01-22 23:03:15 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire 7738 " ) ,
Input: i8042 - add noloop quirk for Medion Akoya E7225 (MD98857)
Without this the aux port does not get detected, and consequently the touchpad
will not work.
With this patch the touchpad is detected:
$ dmesg | grep -E "(SYN|i8042|serio)"
pnp 00:03: Plug and Play ACPI device, IDs SYN1d22 PNP0f13 (active)
i8042: PNP: PS/2 Controller [PNP0303:PS2K,PNP0f13:PS2M] at 0x60,0x64 irq 1,12
serio: i8042 KBD port at 0x60,0x64 irq 1
serio: i8042 AUX port at 0x60,0x64 irq 12
input: AT Translated Set 2 keyboard as /devices/platform/i8042/serio0/input/input4
psmouse serio1: synaptics: Touchpad model: 1, fw: 8.1, id: 0x1e2b1, caps: 0xd00123/0x840300/0x126800, board id: 2863, fw id: 1473085
input: SynPS/2 Synaptics TouchPad as /devices/platform/i8042/serio1/input/input6
dmidecode excerpt for this laptop is:
Handle 0x0001, DMI type 1, 27 bytes
System Information
Manufacturer: Medion
Product Name: Akoya E7225
Version: 1.0
Cc: stable@vger.kernel.org
Signed-off-by: Jochen Hein <jochen@jochen.org>
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
2015-01-22 23:03:15 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2008-07-03 19:00:28 +04:00
} ,
2008-10-17 06:00:56 +04:00
{
2022-06-30 03:38:07 +03:00
/* Acer Aspire 5536 */
2008-10-17 06:00:56 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire 5536 " ) ,
DMI_MATCH ( DMI_PRODUCT_VERSION , " 0100 " ) ,
2008-10-17 06:00:56 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2008-10-17 06:00:56 +04:00
} ,
2008-12-20 12:04:51 +03:00
{
2022-06-30 03:38:07 +03:00
/*
* Acer Aspire 5738 z
* Touchpad stops working in mux mode when dis - + re - enabled
* with the touchpad enable / disable toggle hotkey
*/
2008-12-20 12:04:51 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire 5738 " ) ,
2008-12-20 12:04:51 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2008-12-20 12:04:51 +03:00
} ,
2009-12-13 11:34:06 +03:00
{
2022-06-30 03:38:07 +03:00
/* Acer Aspire One 150 */
2009-12-13 11:34:06 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " AOA150 " ) ,
2009-12-13 11:34:06 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2009-12-13 11:34:06 +03:00
} ,
2010-07-19 22:00:52 +04:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire A114-31 " ) ,
2010-07-19 22:00:52 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2010-07-19 22:00:52 +04:00
} ,
2012-08-22 08:57:15 +04:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire A314-31 " ) ,
2012-08-22 08:57:15 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2012-08-22 08:57:15 +04:00
} ,
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire A315-31 " ) ,
2012-08-22 08:57:15 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2012-08-22 08:57:15 +04:00
} ,
2009-04-08 10:53:26 +04:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire ES1-132 " ) ,
2009-04-08 10:53:26 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2009-04-08 10:53:26 +04:00
} ,
2016-12-19 02:26:12 +03:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire ES1-332 " ) ,
2016-12-19 02:26:12 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2016-12-19 02:26:12 +03:00
} ,
2021-01-04 04:59:51 +03:00
{
2020-12-01 09:39:40 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire ES1-432 " ) ,
2020-12-01 09:39:40 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2016-12-19 02:26:12 +03:00
} ,
2014-10-31 19:35:53 +03:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " TravelMate Spin B118-RN " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
/*
* Some Wistron based laptops need us to explicitly enable the ' Dritek
* keyboard extension ' to make their extra keys start generating scancodes .
* Originally , this was just confined to older laptops , but a few Acer laptops
* have turned up in 2007 that also need this again .
*/
2014-10-31 19:35:53 +03:00
{
2022-06-30 03:38:07 +03:00
/* Acer Aspire 5100 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire 5100 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_DRITEK )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Acer Aspire 5610 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire 5610 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_DRITEK )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Acer Aspire 5630 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire 5630 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_DRITEK )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Acer Aspire 5650 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire 5650 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_DRITEK )
2014-10-31 19:35:53 +03:00
} ,
2021-11-03 10:00:19 +03:00
{
2022-06-30 03:38:07 +03:00
/* Acer Aspire 5680 */
2021-11-03 10:00:19 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire 5680 " ) ,
2021-11-03 10:00:19 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_DRITEK )
2021-11-03 10:00:19 +03:00
} ,
2016-01-03 07:39:54 +03:00
{
2022-06-30 03:38:07 +03:00
/* Acer Aspire 5720 */
2016-01-03 07:39:54 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire 5720 " ) ,
2016-01-03 07:39:54 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_DRITEK )
2016-01-03 07:39:54 +03:00
} ,
2014-10-31 19:35:53 +03:00
{
2022-06-30 03:38:07 +03:00
/* Acer Aspire 9110 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Aspire 9110 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_DRITEK )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Acer TravelMate 660 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " TravelMate 660 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_DRITEK )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Acer TravelMate 2490 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " TravelMate 2490 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_DRITEK )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Acer TravelMate 4280 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Acer " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " TravelMate 4280 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_DRITEK )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Amoi M636/A737 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Amoi Electronics CO.,LTD. " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " M636/A737 platform " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2014-10-31 19:35:53 +03:00
} ,
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " ByteSpeed LLC " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " ByteSpeed Laptop C15B " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Compal HEL80I */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " COMPAL " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " HEL80I " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2014-10-31 19:35:53 +03:00
} ,
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Compaq " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " ProLiant " ) ,
DMI_MATCH ( DMI_PRODUCT_VERSION , " 8500 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2014-10-31 19:35:53 +03:00
} ,
2007-09-05 07:18:21 +04:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Compaq " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " ProLiant " ) ,
DMI_MATCH ( DMI_PRODUCT_VERSION , " DL760 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Advent 4211 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " DIXONSXP " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Advent 4211 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Dell Embedded Box PC 3000 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Dell Inc. " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Embedded Box PC 3000 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Dell XPS M1530 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Dell Inc. " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " XPS M1530 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Dell Vostro 1510 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Dell Inc. " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Vostro1510 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Dell Vostro V13 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Dell Inc. " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Vostro V13 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX | SERIO_QUIRK_NOTIMEOUT )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Dell Vostro 1320 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Dell Inc. " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Vostro 1320 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Dell Vostro 1520 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Dell Inc. " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Vostro 1520 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Dell Vostro 1720 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Dell Inc. " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Vostro 1720 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Entroware Proteus */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Entroware " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Proteus " ) ,
DMI_MATCH ( DMI_PRODUCT_VERSION , " EL07R4 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX | SERIO_QUIRK_RESET_ALWAYS )
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
/*
* Some Fujitsu notebooks are having trouble with touchpads if
* active multiplexing mode is activated . Luckily they don ' t have
* external PS / 2 ports so we can safely disable it .
* . . . apparently some Toshibas don ' t like MUX mode either and
* die horrible death on reboot .
*/
2014-10-31 19:35:53 +03:00
{
2022-06-30 03:38:07 +03:00
/* Fujitsu Lifebook P7010/P7010D */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " FUJITSU " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " P7010 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2014-10-31 19:35:53 +03:00
} ,
2020-07-07 04:48:51 +03:00
{
2022-06-30 03:38:07 +03:00
/* Fujitsu Lifebook P5020D */
2020-07-07 04:48:51 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " FUJITSU " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " LifeBook P Series " ) ,
2020-07-07 04:48:51 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2020-07-07 04:48:51 +03:00
} ,
2014-10-31 19:35:53 +03:00
{
2022-06-30 03:38:07 +03:00
/* Fujitsu Lifebook S2000 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " FUJITSU " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " LifeBook S Series " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Fujitsu Lifebook S6230 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " FUJITSU " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " LifeBook S6230 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2014-10-31 19:35:53 +03:00
} ,
2015-01-09 01:53:23 +03:00
{
2022-06-30 03:38:07 +03:00
/* Fujitsu Lifebook T725 laptop */
2015-01-09 01:53:23 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " FUJITSU " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " LIFEBOOK T725 " ) ,
2015-01-09 01:53:23 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX | SERIO_QUIRK_NOTIMEOUT )
2015-01-09 01:53:23 +03:00
} ,
2014-10-31 19:35:53 +03:00
{
2022-06-30 03:38:07 +03:00
/* Fujitsu Lifebook U745 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " FUJITSU " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " LIFEBOOK U745 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Fujitsu T70H */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " FUJITSU " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " FMVLT70H " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Fujitsu A544 laptop */
/* https://bugzilla.redhat.com/show_bug.cgi?id=1111138 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " FUJITSU " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " LIFEBOOK A544 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOTIMEOUT )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Fujitsu AH544 laptop */
/* https://bugzilla.kernel.org/show_bug.cgi?id=69731 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " FUJITSU " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " LIFEBOOK AH544 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOTIMEOUT )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Fujitsu U574 laptop */
/* https://bugzilla.kernel.org/show_bug.cgi?id=69731 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " FUJITSU " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " LIFEBOOK U574 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOTIMEOUT )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Fujitsu UH554 laptop */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " FUJITSU " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " LIFEBOOK UH544 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOTIMEOUT )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Fujitsu Lifebook P7010 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " FUJITSU SIEMENS " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " 0000000000 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Fujitsu-Siemens Lifebook T3010 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " FUJITSU SIEMENS " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " LIFEBOOK T3010 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Fujitsu-Siemens Lifebook E4010 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " FUJITSU SIEMENS " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " LIFEBOOK E4010 " ) ,
2014-10-31 19:35:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2014-10-31 19:35:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Fujitsu-Siemens Amilo Pro 2010 */
2014-10-31 19:35:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " FUJITSU SIEMENS " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " AMILO Pro V2010 " ) ,
2014-09-11 21:10:26 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2014-09-11 21:10:26 +04:00
} ,
2017-03-01 04:14:41 +03:00
{
2022-06-30 03:38:07 +03:00
/* Fujitsu-Siemens Amilo Pro 2030 */
2017-03-01 04:14:41 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " FUJITSU SIEMENS " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " AMILO PRO V2030 " ) ,
2017-03-01 04:14:41 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2017-03-01 04:14:41 +03:00
} ,
2018-07-18 20:24:35 +03:00
{
2022-06-30 03:38:07 +03:00
/* Gigabyte M912 */
2018-07-18 20:24:35 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " GIGABYTE " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " M912 " ) ,
DMI_MATCH ( DMI_PRODUCT_VERSION , " 01 " ) ,
2018-07-18 20:24:35 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2018-07-18 20:24:35 +03:00
} ,
2020-04-01 23:23:06 +03:00
{
2022-06-30 03:38:07 +03:00
/* Gigabyte Spring Peak - defines wrong chassis type */
2020-04-01 23:23:06 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " GIGABYTE " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Spring Peak " ) ,
2020-04-01 23:23:06 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2020-04-01 23:23:06 +03:00
} ,
2020-09-09 02:27:29 +03:00
{
2022-06-30 03:38:07 +03:00
/* Gigabyte T1005 - defines wrong chassis type ("Other") */
2020-09-09 02:27:29 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " GIGABYTE " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " T1005 " ) ,
2020-09-09 02:27:29 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2020-09-09 02:27:29 +03:00
} ,
2018-04-03 20:24:34 +03:00
{
2022-06-30 03:38:07 +03:00
/* Gigabyte T1005M/P - defines wrong chassis type ("Other") */
2018-04-03 20:24:34 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " GIGABYTE " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " T1005M/P " ) ,
2018-04-03 20:24:34 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2018-04-03 20:24:34 +03:00
} ,
2022-06-30 03:38:07 +03:00
/*
* Some laptops need keyboard reset before probing for the trackpad to get
* it detected , initialised & finally work .
*/
2016-10-01 22:07:35 +03:00
{
2022-06-30 03:38:07 +03:00
/* Gigabyte P35 v2 - Elantech touchpad */
2016-10-01 22:07:35 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " GIGABYTE " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " P35V2 " ) ,
2021-02-19 21:37:13 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_KBDRESET )
2016-10-01 22:07:35 +03:00
} ,
2022-06-30 03:38:07 +03:00
{
/* Aorus branded Gigabyte X3 Plus - Elantech touchpad */
2009-04-12 03:50:13 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " GIGABYTE " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " X3 " ) ,
2009-04-12 03:50:13 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_KBDRESET )
2009-04-12 03:50:13 +04:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Gigabyte P34 - Elantech touchpad */
2009-04-12 03:50:13 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " GIGABYTE " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " P34 " ) ,
2009-04-12 03:50:13 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_KBDRESET )
2009-04-12 03:50:13 +04:00
} ,
2009-06-29 09:30:56 +04:00
{
2022-06-30 03:38:07 +03:00
/* Gigabyte P57 - Elantech touchpad */
2009-06-29 09:30:56 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " GIGABYTE " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " P57 " ) ,
2009-06-29 09:30:56 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_KBDRESET )
2009-06-29 09:30:56 +04:00
} ,
2020-12-10 07:24:47 +03:00
{
2022-06-30 03:38:07 +03:00
/* Gericom Bellagio */
2020-12-10 07:24:47 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Gericom " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " N34AS6 " ) ,
2020-12-10 07:24:47 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2020-12-10 07:24:47 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Gigabyte M1022M netbook */
2020-12-10 07:24:47 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_BOARD_VENDOR , " Gigabyte Technology Co.,Ltd. " ) ,
DMI_MATCH ( DMI_BOARD_NAME , " M1022E " ) ,
DMI_MATCH ( DMI_BOARD_VERSION , " 1.02 " ) ,
2020-12-10 07:24:47 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2020-12-10 07:24:47 +03:00
} ,
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Hewlett-Packard " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " HP Pavilion dv9700 " ) ,
DMI_MATCH ( DMI_PRODUCT_VERSION , " Rev 1 " ) ,
2020-12-10 07:24:47 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2020-12-10 07:24:47 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/*
* HP Pavilion DV4017EA -
* errors on MUX ports are reported without raising AUXDATA
* causing " spurious NAK " messages .
*/
2020-12-10 07:24:47 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Hewlett-Packard " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Pavilion dv4000 (EA032EA#ABF) " ) ,
2020-12-10 07:24:47 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2020-12-10 07:24:47 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/*
* HP Pavilion ZT1000 -
* like DV4017EA does not raise AUXERR for errors on MUX ports .
*/
2020-12-10 07:24:47 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Hewlett-Packard " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " HP Pavilion Notebook PC " ) ,
DMI_MATCH ( DMI_PRODUCT_VERSION , " HP Pavilion Notebook ZT1000 " ) ,
2020-12-10 07:24:47 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2020-12-10 07:24:47 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/*
* HP Pavilion DV4270ca -
* like DV4017EA does not raise AUXERR for errors on MUX ports .
*/
2020-12-10 07:24:47 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Hewlett-Packard " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Pavilion dv4000 (EH476UA#ABL) " ) ,
2020-12-10 07:24:47 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2020-12-10 07:24:47 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Newer HP Pavilion dv4 models */
2020-12-10 07:24:47 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Hewlett-Packard " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " HP Pavilion dv4 Notebook PC " ) ,
2020-12-10 07:24:47 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX | SERIO_QUIRK_NOTIMEOUT )
2020-12-10 07:24:47 +03:00
} ,
2009-06-29 09:30:56 +04:00
{
2022-06-30 03:38:07 +03:00
/* IBM 2656 */
2009-06-29 09:30:56 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " IBM " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " 2656 " ) ,
2009-06-29 09:30:56 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2009-06-29 09:30:56 +04:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Avatar AVIU-145A6 */
2009-06-29 09:30:56 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Intel " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " IC4I " ) ,
2009-06-29 09:30:56 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2009-06-29 09:30:56 +04:00
} ,
2010-03-14 09:26:23 +03:00
{
2022-06-30 03:38:07 +03:00
/* Intel MBO Desktop D845PESV */
2010-03-14 09:26:23 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_BOARD_VENDOR , " Intel Corporation " ) ,
DMI_MATCH ( DMI_BOARD_NAME , " D845PESV " ) ,
2010-03-14 09:26:23 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOPNP )
2010-03-14 09:26:23 +03:00
} ,
2009-06-29 09:30:56 +04:00
{
2022-06-30 03:38:07 +03:00
/*
* Intel NUC D54250WYK - does not have i8042 controller but
* declares PS / 2 devices in DSDT .
*/
2009-06-29 09:30:56 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_BOARD_VENDOR , " Intel Corporation " ) ,
DMI_MATCH ( DMI_BOARD_NAME , " D54250WYK " ) ,
2009-06-29 09:30:56 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOPNP )
2009-06-29 09:30:56 +04:00
} ,
2009-12-01 12:14:25 +03:00
{
2022-06-30 03:38:07 +03:00
/* Lenovo 3000 n100 */
2009-12-01 12:14:25 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " LENOVO " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " 076804U " ) ,
2009-12-01 12:14:25 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2009-12-01 12:14:25 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Lenovo XiaoXin Air 12 */
2009-12-01 12:14:25 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " LENOVO " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " 80UN " ) ,
2009-12-01 12:14:25 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2009-12-01 12:14:25 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Lenovo LaVie Z */
2009-12-01 12:14:25 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " LENOVO " ) ,
DMI_MATCH ( DMI_PRODUCT_VERSION , " Lenovo LaVie Z " ) ,
2009-12-01 12:14:25 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2009-12-01 12:14:25 +03:00
} ,
2012-02-03 12:19:07 +04:00
{
/* Lenovo Ideapad U455 */
. matches = {
DMI_MATCH ( DMI_SYS_VENDOR , " LENOVO " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " 20046 " ) ,
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2012-02-03 12:19:07 +04:00
} ,
2018-03-09 02:32:09 +03:00
{
/* Lenovo ThinkPad L460 */
. matches = {
DMI_MATCH ( DMI_SYS_VENDOR , " LENOVO " ) ,
DMI_MATCH ( DMI_PRODUCT_VERSION , " ThinkPad L460 " ) ,
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2017-04-14 01:36:31 +03:00
} ,
2020-04-28 04:07:20 +03:00
{
/* Lenovo ThinkPad Twist S230u */
. matches = {
DMI_MATCH ( DMI_SYS_VENDOR , " LENOVO " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " 33474HU " ) ,
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2020-04-28 04:07:20 +03:00
} ,
2020-09-09 02:27:29 +03:00
{
2022-06-30 03:38:07 +03:00
/* LG Electronics X110 */
2020-09-09 02:27:29 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_BOARD_VENDOR , " LG Electronics Inc. " ) ,
DMI_MATCH ( DMI_BOARD_NAME , " X110 " ) ,
2020-09-09 02:27:29 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2020-09-09 02:27:29 +03:00
} ,
2008-05-28 09:10:52 +04:00
{
2022-06-30 03:38:07 +03:00
/* Medion Akoya Mini E1210 */
2008-05-28 09:10:52 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " MEDION " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " E1210 " ) ,
2008-05-28 09:10:52 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2008-05-28 09:10:52 +04:00
} ,
2014-12-03 02:16:39 +03:00
{
2022-06-30 03:38:07 +03:00
/* Medion Akoya E1222 */
2014-12-03 02:16:39 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " MEDION " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " E122X " ) ,
2014-12-03 02:16:39 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2014-12-03 02:16:39 +03:00
} ,
2009-04-12 03:50:13 +04:00
{
2009-12-04 21:24:19 +03:00
/* MSI Wind U-100 */
2009-04-12 03:50:13 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_BOARD_VENDOR , " MICRO-STAR INTERNATIONAL CO., LTD " ) ,
DMI_MATCH ( DMI_BOARD_NAME , " U-100 " ) ,
2009-09-04 08:45:34 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS | SERIO_QUIRK_NOPNP )
2009-09-04 08:45:34 +04:00
} ,
{
2022-06-30 03:38:07 +03:00
/*
* No data is coming from the touchscreen unless KBC
* is in legacy mode .
*/
/* Panasonic CF-29 */
2009-09-04 08:45:34 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Matsushita " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " CF-29 " ) ,
2009-09-04 08:45:34 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2009-09-04 08:45:34 +04:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Medion Akoya E7225 */
2009-09-04 08:45:34 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Medion " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Akoya E7225 " ) ,
DMI_MATCH ( DMI_PRODUCT_VERSION , " 1.0 " ) ,
2009-09-04 08:45:34 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2009-09-04 08:45:34 +04:00
} ,
2011-01-08 12:37:26 +03:00
{
2022-06-30 03:38:07 +03:00
/* Microsoft Virtual Machine */
2011-01-08 12:37:26 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Microsoft Corporation " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Virtual Machine " ) ,
DMI_MATCH ( DMI_PRODUCT_VERSION , " VS2005R2 " ) ,
2011-01-08 12:37:26 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2011-01-08 12:37:26 +03:00
} ,
2011-11-05 10:59:49 +04:00
{
2022-06-30 03:38:07 +03:00
/* Medion MAM 2070 */
2011-11-05 10:59:49 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Notebook " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " MAM 2070 " ) ,
DMI_MATCH ( DMI_PRODUCT_VERSION , " 5a " ) ,
2011-11-05 10:59:49 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2011-11-05 10:59:49 +04:00
} ,
2014-10-25 01:55:24 +04:00
{
2022-06-30 03:38:07 +03:00
/* TUXEDO BU1406 */
2014-10-25 01:55:24 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Notebook " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " N24_25BU " ) ,
2014-10-25 01:55:24 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2014-10-25 01:55:24 +04:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Clevo P650RS, 650RP6, Sager NP8152-S, and others */
2014-10-25 01:55:24 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Notebook " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " P65xRP " ) ,
2014-10-25 01:55:24 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2014-10-25 01:55:24 +04:00
} ,
2021-11-03 10:00:19 +03:00
{
2022-06-30 03:38:07 +03:00
/* OQO Model 01 */
2021-11-03 10:00:19 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " OQO " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " ZEPTO " ) ,
DMI_MATCH ( DMI_PRODUCT_VERSION , " 00 " ) ,
2021-11-03 10:00:19 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2021-11-03 10:00:19 +03:00
} ,
2014-09-11 00:53:37 +04:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " PEGATRON CORPORATION " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " C15B " ) ,
2014-09-11 00:53:37 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2014-09-11 00:53:37 +04:00
} ,
2017-06-20 05:48:52 +03:00
{
2022-06-30 03:38:07 +03:00
/* Acer Aspire 5 A515 */
2017-06-20 05:48:52 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_BOARD_VENDOR , " PK " ) ,
DMI_MATCH ( DMI_BOARD_NAME , " Grumpy_PK " ) ,
2017-06-20 05:48:52 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOPNP )
2017-06-20 05:48:52 +03:00
} ,
2010-12-28 04:21:45 +03:00
{
2022-06-30 03:38:07 +03:00
/* ULI EV4873 - AUX LOOP does not work properly */
2010-12-28 04:21:45 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " ULI " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " EV4873 " ) ,
DMI_MATCH ( DMI_PRODUCT_VERSION , " 5a " ) ,
2010-12-28 04:21:45 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2010-12-28 04:21:45 +03:00
} ,
2010-01-11 10:59:05 +03:00
{
2022-06-30 03:38:07 +03:00
/*
* Arima - Rioworks HDAMB -
* AUX LOOP command does not raise AUX IRQ
*/
2010-01-11 10:59:05 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_BOARD_VENDOR , " RIOWORKS " ) ,
DMI_MATCH ( DMI_BOARD_NAME , " HDAMB " ) ,
DMI_MATCH ( DMI_BOARD_VERSION , " Rev E " ) ,
2010-01-11 10:59:05 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2010-01-11 10:59:05 +03:00
} ,
2008-01-21 09:04:40 +03:00
{
2022-06-30 03:38:07 +03:00
/* Sharp Actius MM20 */
2008-01-21 09:04:40 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " SHARP " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " PC-MM20 Series " ) ,
2008-01-21 09:04:40 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2008-01-21 09:04:40 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/*
* Sony Vaio FZ - 240 E -
* reset and GET ID commands issued via KBD port are
* sometimes being delivered to AUX3 .
*/
2008-01-21 09:04:40 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Sony Corporation " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " VGN-FZ240E " ) ,
2008-01-21 09:04:40 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2008-01-21 09:04:40 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/*
* Most ( all ? ) VAIOs do not have external PS / 2 ports nor
* they implement active multiplexing properly , and
* MUX discovery usually messes up keyboard / touchpad .
*/
2008-01-21 09:04:40 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Sony Corporation " ) ,
DMI_MATCH ( DMI_BOARD_NAME , " VAIO " ) ,
2008-01-21 09:04:40 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2008-01-21 09:04:40 +03:00
} ,
2008-07-07 16:55:31 +04:00
{
2022-06-30 03:38:07 +03:00
/* Sony Vaio FS-115b */
2008-07-07 16:55:31 +04:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Sony Corporation " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " VGN-FS115B " ) ,
2008-07-07 16:55:31 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2008-07-07 16:55:31 +04:00
} ,
2008-01-31 00:34:12 +03:00
{
2022-06-30 03:38:07 +03:00
/*
* Sony Vaio VGN - CS series require MUX or the touch sensor
* buttons will disturb touchpad operation
*/
2008-01-31 00:34:12 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " Sony Corporation " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " VGN-CS " ) ,
2008-01-31 00:34:12 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_FORCEMUX )
2008-01-31 00:34:12 +03:00
} ,
2008-05-20 21:47:28 +04:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " TOSHIBA " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Satellite P10 " ) ,
2008-05-20 21:47:28 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2008-05-20 21:47:28 +04:00
} ,
2008-01-21 09:04:40 +03:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " TOSHIBA " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " EQUIUM A110 " ) ,
2008-01-21 09:04:40 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2008-01-21 09:04:40 +03:00
} ,
2008-08-06 22:28:43 +04:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " TOSHIBA " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " SATELLITE C850D " ) ,
2008-08-06 22:28:43 +04:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOMUX )
2008-08-06 22:28:43 +04:00
} ,
2015-01-08 03:25:53 +03:00
{
2022-06-30 03:38:07 +03:00
/* Mivvy M310 */
2015-01-08 03:25:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " VIOOO " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " N10 " ) ,
2015-01-08 03:25:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_RESET_ALWAYS )
2015-01-08 03:25:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
/*
* Some laptops need keyboard reset before probing for the trackpad to get
* it detected , initialised & finally work .
*/
{
/* Schenker XMG C504 - Elantech touchpad */
2015-01-08 03:25:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " XMG " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " C504 " ) ,
2015-01-08 03:25:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_KBDRESET )
2015-01-08 03:25:53 +03:00
} ,
{
2022-06-30 03:38:07 +03:00
/* Blue FB5601 */
2015-01-08 03:25:53 +03:00
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_SYS_VENDOR , " blue " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " FB5601 " ) ,
DMI_MATCH ( DMI_PRODUCT_VERSION , " M606 " ) ,
2015-01-08 03:25:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
. driver_data = ( void * ) ( SERIO_QUIRK_NOLOOP )
2015-01-08 03:25:53 +03:00
} ,
2022-06-30 03:38:07 +03:00
{ }
} ;
# ifdef CONFIG_PNP
static const struct dmi_system_id i8042_dmi_laptop_table [ ] __initconst = {
2017-09-15 19:36:16 +03:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_CHASSIS_TYPE , " 8 " ) , /* Portable */
2017-09-15 19:36:16 +03:00
} ,
} ,
2016-10-19 22:04:02 +03:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_CHASSIS_TYPE , " 9 " ) , /* Laptop */
2016-10-19 22:04:02 +03:00
} ,
} ,
2021-11-29 10:21:41 +03:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_CHASSIS_TYPE , " 10 " ) , /* Notebook */
2021-11-29 10:21:41 +03:00
} ,
} ,
2021-12-05 00:17:36 +03:00
{
. matches = {
2022-06-30 03:38:07 +03:00
DMI_MATCH ( DMI_CHASSIS_TYPE , " 14 " ) , /* Sub-Notebook */
2021-12-05 00:17:36 +03:00
} ,
} ,
2021-11-29 10:21:41 +03:00
{ }
} ;
2022-06-30 03:38:07 +03:00
# endif
2021-11-29 10:21:41 +03:00
2008-01-21 09:04:40 +03:00
# endif /* CONFIG_X86 */
2005-04-17 02:20:36 +04:00
# ifdef CONFIG_PNP
# include <linux/pnp.h>
2009-09-10 06:08:16 +04:00
static bool i8042_pnp_kbd_registered ;
2006-03-14 08:12:24 +03:00
static unsigned int i8042_pnp_kbd_devices ;
2009-09-10 06:08:16 +04:00
static bool i8042_pnp_aux_registered ;
2006-03-14 08:12:24 +03:00
static unsigned int i8042_pnp_aux_devices ;
2005-04-17 02:20:36 +04:00
static int i8042_pnp_command_reg ;
static int i8042_pnp_data_reg ;
static int i8042_pnp_kbd_irq ;
static int i8042_pnp_aux_irq ;
static char i8042_pnp_kbd_name [ 32 ] ;
static char i8042_pnp_aux_name [ 32 ] ;
2014-04-20 07:47:35 +04:00
static void i8042_pnp_id_to_string ( struct pnp_id * id , char * dst , int dst_size )
{
strlcpy ( dst , " PNP: " , dst_size ) ;
while ( id ) {
strlcat ( dst , " " , dst_size ) ;
strlcat ( dst , id - > id , dst_size ) ;
id = id - > next ;
}
}
2005-04-17 02:20:36 +04:00
static int i8042_pnp_kbd_probe ( struct pnp_dev * dev , const struct pnp_device_id * did )
{
if ( pnp_port_valid ( dev , 0 ) & & pnp_port_len ( dev , 0 ) = = 1 )
i8042_pnp_data_reg = pnp_port_start ( dev , 0 ) ;
if ( pnp_port_valid ( dev , 1 ) & & pnp_port_len ( dev , 1 ) = = 1 )
i8042_pnp_command_reg = pnp_port_start ( dev , 1 ) ;
if ( pnp_irq_valid ( dev , 0 ) )
i8042_pnp_kbd_irq = pnp_irq ( dev , 0 ) ;
2008-04-18 08:25:18 +04:00
strlcpy ( i8042_pnp_kbd_name , did - > id , sizeof ( i8042_pnp_kbd_name ) ) ;
2005-04-17 02:20:36 +04:00
if ( strlen ( pnp_dev_name ( dev ) ) ) {
2008-04-18 08:25:18 +04:00
strlcat ( i8042_pnp_kbd_name , " : " , sizeof ( i8042_pnp_kbd_name ) ) ;
strlcat ( i8042_pnp_kbd_name , pnp_dev_name ( dev ) , sizeof ( i8042_pnp_kbd_name ) ) ;
2005-04-17 02:20:36 +04:00
}
2014-04-20 07:47:35 +04:00
i8042_pnp_id_to_string ( dev - > id , i8042_kbd_firmware_id ,
sizeof ( i8042_kbd_firmware_id ) ) ;
2020-04-28 03:50:45 +03:00
i8042_kbd_fwnode = dev_fwnode ( & dev - > dev ) ;
2005-04-17 02:20:36 +04:00
2010-03-09 10:42:46 +03:00
/* Keyboard ports are always supposed to be wakeup-enabled */
device_set_wakeup_enable ( & dev - > dev , true ) ;
2006-03-14 08:12:24 +03:00
i8042_pnp_kbd_devices + + ;
2005-04-17 02:20:36 +04:00
return 0 ;
}
static int i8042_pnp_aux_probe ( struct pnp_dev * dev , const struct pnp_device_id * did )
{
if ( pnp_port_valid ( dev , 0 ) & & pnp_port_len ( dev , 0 ) = = 1 )
i8042_pnp_data_reg = pnp_port_start ( dev , 0 ) ;
if ( pnp_port_valid ( dev , 1 ) & & pnp_port_len ( dev , 1 ) = = 1 )
i8042_pnp_command_reg = pnp_port_start ( dev , 1 ) ;
if ( pnp_irq_valid ( dev , 0 ) )
i8042_pnp_aux_irq = pnp_irq ( dev , 0 ) ;
2008-04-18 08:25:18 +04:00
strlcpy ( i8042_pnp_aux_name , did - > id , sizeof ( i8042_pnp_aux_name ) ) ;
2005-04-17 02:20:36 +04:00
if ( strlen ( pnp_dev_name ( dev ) ) ) {
2008-04-18 08:25:18 +04:00
strlcat ( i8042_pnp_aux_name , " : " , sizeof ( i8042_pnp_aux_name ) ) ;
strlcat ( i8042_pnp_aux_name , pnp_dev_name ( dev ) , sizeof ( i8042_pnp_aux_name ) ) ;
2005-04-17 02:20:36 +04:00
}
2014-04-20 07:47:35 +04:00
i8042_pnp_id_to_string ( dev - > id , i8042_aux_firmware_id ,
sizeof ( i8042_aux_firmware_id ) ) ;
2005-04-17 02:20:36 +04:00
2006-03-14 08:12:24 +03:00
i8042_pnp_aux_devices + + ;
2005-04-17 02:20:36 +04:00
return 0 ;
}
2017-08-17 03:43:10 +03:00
static const struct pnp_device_id pnp_kbd_devids [ ] = {
2010-05-19 21:11:13 +04:00
{ . id = " PNP0300 " , . driver_data = 0 } ,
{ . id = " PNP0301 " , . driver_data = 0 } ,
{ . id = " PNP0302 " , . driver_data = 0 } ,
2005-04-17 02:20:36 +04:00
{ . id = " PNP0303 " , . driver_data = 0 } ,
2010-05-19 21:11:13 +04:00
{ . id = " PNP0304 " , . driver_data = 0 } ,
{ . id = " PNP0305 " , . driver_data = 0 } ,
{ . id = " PNP0306 " , . driver_data = 0 } ,
{ . id = " PNP0309 " , . driver_data = 0 } ,
{ . id = " PNP030a " , . driver_data = 0 } ,
2005-04-17 02:20:36 +04:00
{ . id = " PNP030b " , . driver_data = 0 } ,
2010-05-19 21:11:13 +04:00
{ . id = " PNP0320 " , . driver_data = 0 } ,
{ . id = " PNP0343 " , . driver_data = 0 } ,
{ . id = " PNP0344 " , . driver_data = 0 } ,
{ . id = " PNP0345 " , . driver_data = 0 } ,
{ . id = " CPQA0D7 " , . driver_data = 0 } ,
2005-04-17 02:20:36 +04:00
{ . id = " " , } ,
} ;
2013-10-31 11:33:54 +04:00
MODULE_DEVICE_TABLE ( pnp , pnp_kbd_devids ) ;
2005-04-17 02:20:36 +04:00
static struct pnp_driver i8042_pnp_kbd_driver = {
. name = " i8042 kbd " ,
. id_table = pnp_kbd_devids ,
. probe = i8042_pnp_kbd_probe ,
2016-12-13 01:33:37 +03:00
. driver = {
. probe_type = PROBE_FORCE_SYNCHRONOUS ,
. suppress_bind_attrs = true ,
} ,
2005-04-17 02:20:36 +04:00
} ;
2017-08-17 03:43:10 +03:00
static const struct pnp_device_id pnp_aux_devids [ ] = {
2010-05-19 21:11:13 +04:00
{ . id = " AUI0200 " , . driver_data = 0 } ,
2007-04-25 08:40:53 +04:00
{ . id = " FJC6000 " , . driver_data = 0 } ,
{ . id = " FJC6001 " , . driver_data = 0 } ,
2005-04-17 02:20:36 +04:00
{ . id = " PNP0f03 " , . driver_data = 0 } ,
{ . id = " PNP0f0b " , . driver_data = 0 } ,
{ . id = " PNP0f0e " , . driver_data = 0 } ,
{ . id = " PNP0f12 " , . driver_data = 0 } ,
{ . id = " PNP0f13 " , . driver_data = 0 } ,
{ . id = " PNP0f19 " , . driver_data = 0 } ,
{ . id = " PNP0f1c " , . driver_data = 0 } ,
{ . id = " SYN0801 " , . driver_data = 0 } ,
{ . id = " " , } ,
} ;
2013-10-31 11:33:54 +04:00
MODULE_DEVICE_TABLE ( pnp , pnp_aux_devids ) ;
2005-04-17 02:20:36 +04:00
static struct pnp_driver i8042_pnp_aux_driver = {
. name = " i8042 aux " ,
. id_table = pnp_aux_devids ,
. probe = i8042_pnp_aux_probe ,
2016-12-13 01:33:37 +03:00
. driver = {
. probe_type = PROBE_FORCE_SYNCHRONOUS ,
. suppress_bind_attrs = true ,
} ,
2005-04-17 02:20:36 +04:00
} ;
static void i8042_pnp_exit ( void )
{
2005-05-28 11:11:38 +04:00
if ( i8042_pnp_kbd_registered ) {
2009-09-10 06:08:16 +04:00
i8042_pnp_kbd_registered = false ;
2005-04-17 02:20:36 +04:00
pnp_unregister_driver ( & i8042_pnp_kbd_driver ) ;
2005-05-28 11:11:38 +04:00
}
2005-04-17 02:20:36 +04:00
2005-05-28 11:11:38 +04:00
if ( i8042_pnp_aux_registered ) {
2009-09-10 06:08:16 +04:00
i8042_pnp_aux_registered = false ;
2005-04-17 02:20:36 +04:00
pnp_unregister_driver ( & i8042_pnp_aux_driver ) ;
2005-05-28 11:11:38 +04:00
}
2005-04-17 02:20:36 +04:00
}
2005-09-04 10:41:38 +04:00
static int __init i8042_pnp_init ( void )
2005-04-17 02:20:36 +04:00
{
2005-09-04 10:41:51 +04:00
char kbd_irq_str [ 4 ] = { 0 } , aux_irq_str [ 4 ] = { 0 } ;
2009-10-13 08:34:25 +04:00
bool pnp_data_busted = false ;
2006-03-14 08:12:24 +03:00
int err ;
2005-04-17 02:20:36 +04:00
if ( i8042_nopnp ) {
2010-11-30 10:33:07 +03:00
pr_info ( " PNP detection disabled \n " ) ;
2005-04-17 02:20:36 +04:00
return 0 ;
}
2006-03-14 08:12:24 +03:00
err = pnp_register_driver ( & i8042_pnp_kbd_driver ) ;
if ( ! err )
2009-09-10 06:08:16 +04:00
i8042_pnp_kbd_registered = true ;
2005-09-04 10:41:51 +04:00
2006-03-14 08:12:24 +03:00
err = pnp_register_driver ( & i8042_pnp_aux_driver ) ;
if ( ! err )
2009-09-10 06:08:16 +04:00
i8042_pnp_aux_registered = true ;
2005-04-17 02:20:36 +04:00
2006-03-14 08:12:24 +03:00
if ( ! i8042_pnp_kbd_devices & & ! i8042_pnp_aux_devices ) {
2005-04-17 02:20:36 +04:00
i8042_pnp_exit ( ) ;
# if defined(__ia64__)
return - ENODEV ;
# else
2016-12-09 23:57:39 +03:00
pr_info ( " PNP: No PS/2 controller found. \n " ) ;
if ( x86_platform . legacy . i8042 ! =
X86_LEGACY_I8042_EXPECTED_PRESENT )
return - ENODEV ;
pr_info ( " Probing ports directly. \n " ) ;
2005-04-17 02:20:36 +04:00
return 0 ;
# endif
}
2006-03-14 08:12:24 +03:00
if ( i8042_pnp_kbd_devices )
2005-09-04 10:41:51 +04:00
snprintf ( kbd_irq_str , sizeof ( kbd_irq_str ) ,
" %d " , i8042_pnp_kbd_irq ) ;
2006-03-14 08:12:24 +03:00
if ( i8042_pnp_aux_devices )
2005-09-04 10:41:51 +04:00
snprintf ( aux_irq_str , sizeof ( aux_irq_str ) ,
" %d " , i8042_pnp_aux_irq ) ;
2010-11-30 10:33:07 +03:00
pr_info ( " PNP: PS/2 Controller [%s%s%s] at %#x,%#x irq %s%s%s \n " ,
2006-03-14 08:12:24 +03:00
i8042_pnp_kbd_name , ( i8042_pnp_kbd_devices & & i8042_pnp_aux_devices ) ? " , " : " " ,
2005-09-04 10:41:51 +04:00
i8042_pnp_aux_name ,
i8042_pnp_data_reg , i8042_pnp_command_reg ,
2006-03-14 08:12:24 +03:00
kbd_irq_str , ( i8042_pnp_kbd_devices & & i8042_pnp_aux_devices ) ? " , " : " " ,
2005-09-04 10:41:51 +04:00
aux_irq_str ) ;
# if defined(__ia64__)
2006-03-14 08:12:24 +03:00
if ( ! i8042_pnp_kbd_devices )
2009-09-10 06:08:16 +04:00
i8042_nokbd = true ;
2006-03-14 08:12:24 +03:00
if ( ! i8042_pnp_aux_devices )
2009-09-10 06:08:16 +04:00
i8042_noaux = true ;
2005-09-04 10:41:51 +04:00
# endif
2005-04-17 02:20:36 +04:00
if ( ( ( i8042_pnp_data_reg & ~ 0xf ) = = ( i8042_data_reg & ~ 0xf ) & &
2007-07-18 08:38:01 +04:00
i8042_pnp_data_reg ! = i8042_data_reg ) | |
! i8042_pnp_data_reg ) {
2010-11-30 10:33:07 +03:00
pr_warn ( " PNP: PS/2 controller has invalid data port %#x; using default %#x \n " ,
2005-04-17 02:20:36 +04:00
i8042_pnp_data_reg , i8042_data_reg ) ;
i8042_pnp_data_reg = i8042_data_reg ;
2009-09-10 06:08:16 +04:00
pnp_data_busted = true ;
2005-04-17 02:20:36 +04:00
}
if ( ( ( i8042_pnp_command_reg & ~ 0xf ) = = ( i8042_command_reg & ~ 0xf ) & &
2007-07-18 08:38:01 +04:00
i8042_pnp_command_reg ! = i8042_command_reg ) | |
! i8042_pnp_command_reg ) {
2010-11-30 10:33:07 +03:00
pr_warn ( " PNP: PS/2 controller has invalid command port %#x; using default %#x \n " ,
2005-04-17 02:20:36 +04:00
i8042_pnp_command_reg , i8042_command_reg ) ;
i8042_pnp_command_reg = i8042_command_reg ;
2009-09-10 06:08:16 +04:00
pnp_data_busted = true ;
2005-04-17 02:20:36 +04:00
}
2005-09-04 10:42:00 +04:00
if ( ! i8042_nokbd & & ! i8042_pnp_kbd_irq ) {
2010-11-30 10:33:07 +03:00
pr_warn ( " PNP: PS/2 controller doesn't have KBD irq; using default %d \n " ,
i8042_kbd_irq ) ;
2005-04-17 02:20:36 +04:00
i8042_pnp_kbd_irq = i8042_kbd_irq ;
2009-09-10 06:08:16 +04:00
pnp_data_busted = true ;
2005-04-17 02:20:36 +04:00
}
2005-09-04 10:41:51 +04:00
if ( ! i8042_noaux & & ! i8042_pnp_aux_irq ) {
2007-07-18 08:38:01 +04:00
if ( ! pnp_data_busted & & i8042_pnp_kbd_irq ) {
2010-11-30 10:33:07 +03:00
pr_warn ( " PNP: PS/2 appears to have AUX port disabled, "
" if this is incorrect please boot with i8042.nopnp \n " ) ;
2009-09-10 06:08:16 +04:00
i8042_noaux = true ;
2007-07-18 08:38:01 +04:00
} else {
2010-11-30 10:33:07 +03:00
pr_warn ( " PNP: PS/2 controller doesn't have AUX irq; using default %d \n " ,
i8042_aux_irq ) ;
2007-07-18 08:38:01 +04:00
i8042_pnp_aux_irq = i8042_aux_irq ;
}
2005-04-17 02:20:36 +04:00
}
i8042_data_reg = i8042_pnp_data_reg ;
i8042_command_reg = i8042_pnp_command_reg ;
i8042_kbd_irq = i8042_pnp_kbd_irq ;
i8042_aux_irq = i8042_pnp_aux_irq ;
2009-09-04 08:45:34 +04:00
# ifdef CONFIG_X86
i8042_bypass_aux_irq_test = ! pnp_data_busted & &
dmi_check_system ( i8042_dmi_laptop_table ) ;
# endif
2005-04-17 02:20:36 +04:00
return 0 ;
}
2016-12-10 04:59:56 +03:00
# else /* !CONFIG_PNP */
2005-09-04 10:41:38 +04:00
static inline int i8042_pnp_init ( void ) { return 0 ; }
static inline void i8042_pnp_exit ( void ) { }
2016-12-10 04:59:56 +03:00
# endif /* CONFIG_PNP */
2005-04-17 02:20:36 +04:00
2022-06-30 03:38:07 +03:00
# ifdef CONFIG_X86
static void __init i8042_check_quirks ( void )
{
const struct dmi_system_id * device_quirk_info ;
uintptr_t quirks ;
device_quirk_info = dmi_first_match ( i8042_dmi_quirk_table ) ;
if ( ! device_quirk_info )
return ;
quirks = ( uintptr_t ) device_quirk_info - > driver_data ;
if ( quirks & SERIO_QUIRK_NOKBD )
i8042_nokbd = true ;
if ( quirks & SERIO_QUIRK_NOAUX )
i8042_noaux = true ;
if ( quirks & SERIO_QUIRK_NOMUX )
i8042_nomux = true ;
if ( quirks & SERIO_QUIRK_FORCEMUX )
i8042_nomux = false ;
if ( quirks & SERIO_QUIRK_UNLOCK )
i8042_unlock = true ;
if ( quirks & SERIO_QUIRK_PROBE_DEFER )
i8042_probe_defer = true ;
/* Honor module parameter when value is not default */
if ( i8042_reset = = I8042_RESET_DEFAULT ) {
if ( quirks & SERIO_QUIRK_RESET_ALWAYS )
i8042_reset = I8042_RESET_ALWAYS ;
if ( quirks & SERIO_QUIRK_RESET_NEVER )
i8042_reset = I8042_RESET_NEVER ;
}
if ( quirks & SERIO_QUIRK_DIECT )
i8042_direct = true ;
if ( quirks & SERIO_QUIRK_DUMBKBD )
i8042_dumbkbd = true ;
if ( quirks & SERIO_QUIRK_NOLOOP )
i8042_noloop = true ;
if ( quirks & SERIO_QUIRK_NOTIMEOUT )
i8042_notimeout = true ;
if ( quirks & SERIO_QUIRK_KBDRESET )
i8042_kbdreset = true ;
if ( quirks & SERIO_QUIRK_DRITEK )
i8042_dritek = true ;
# ifdef CONFIG_PNP
if ( quirks & SERIO_QUIRK_NOPNP )
i8042_nopnp = true ;
# endif
}
# else
static inline void i8042_check_quirks ( void ) { }
# endif
2005-09-04 10:41:38 +04:00
static int __init i8042_platform_init ( void )
2005-04-17 02:20:36 +04:00
{
2005-09-04 10:41:38 +04:00
int retval ;
2010-07-08 00:02:16 +04:00
# ifdef CONFIG_X86
2012-12-12 01:18:05 +04:00
u8 a20_on = 0xdf ;
2016-12-09 23:57:39 +03:00
/* Just return if platform does not have i8042 controller */
if ( x86_platform . legacy . i8042 = = X86_LEGACY_I8042_PLATFORM_ABSENT )
2010-07-08 00:02:16 +04:00
return - ENODEV ;
# endif
2005-04-17 02:20:36 +04:00
/*
* On ix86 platforms touching the i8042 data register region can do really
* bad things . Because of this the region is always reserved on ix86 boxes .
*
* if ( ! request_region ( I8042_DATA_REG , 16 , " i8042 " ) )
2005-09-04 10:41:38 +04:00
* return - EBUSY ;
2005-04-17 02:20:36 +04:00
*/
i8042_kbd_irq = I8042_MAP_IRQ ( 1 ) ;
i8042_aux_irq = I8042_MAP_IRQ ( 12 ) ;
# if defined(__ia64__)
2022-06-30 03:38:07 +03:00
i8042_reset = I8042_RESET_ALWAYS ;
2005-04-17 02:20:36 +04:00
# endif
2022-06-30 03:38:07 +03:00
i8042_check_quirks ( ) ;
2015-01-08 03:25:53 +03:00
2022-06-30 03:38:07 +03:00
retval = i8042_pnp_init ( ) ;
if ( retval )
return retval ;
2021-11-29 10:21:41 +03:00
2022-06-30 03:38:07 +03:00
# ifdef CONFIG_X86
2012-12-12 01:18:05 +04:00
/*
* A20 was already enabled during early kernel init . But some buggy
* BIOSes ( in MSI Laptops ) require A20 to be enabled using 8042 to
* resume from S3 . So we do it here and hope that nothing breaks .
*/
i8042_command ( & a20_on , 0x10d1 ) ;
i8042_command ( NULL , 0x00ff ) ; /* Null command for SMM firmware */
2008-01-21 09:04:40 +03:00
# endif /* CONFIG_X86 */
2005-09-04 10:41:38 +04:00
return retval ;
2005-04-17 02:20:36 +04:00
}
static inline void i8042_platform_exit ( void )
{
i8042_pnp_exit ( ) ;
}
# endif /* _I8042_X86IA64IO_H */