mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-01 10:13:58 +08:00
ACPI: button: Turn lid_blacklst DMI table into a generic quirk table
Commit 3540c32a9a
("ACPI / button: Add quirks for initial lid state
notification") added 3 different modes to the LID handling code to deal
with various buggy implementations.
Until now users which need one of the 2 non-default modes to get their
HW to work have to pass a kernel commandline option for this.
E.g. https://bugzilla.kernel.org/show_bug.cgi?id=106151 was closed with a
note that the user has to add "button.lid_init_state=open" to the kernel
commandline to get the LID code to not cause undesirable suspends on his
Samsung N210 Plus.
This commit modifies the existing lid_blacklst DMI table so that it can
be used not only to completely disable the LID code on devices where
the ACPI tables are broken beyond repair, but also to select one of the 2
non default LID handling modes on devices where this is necessary.
This will allow us to add quirks to make the LID work OOTB on broken
devices. Getting this working OOTB is esp. important because the typical
breakage is false LID closed reporting, causing undesirable suspends which
basically make the system unusable.
Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
This commit is contained in:
parent
593681e2c7
commit
d7cd08231a
@ -75,18 +75,16 @@ static const struct acpi_device_id button_device_ids[] = {
|
|||||||
};
|
};
|
||||||
MODULE_DEVICE_TABLE(acpi, button_device_ids);
|
MODULE_DEVICE_TABLE(acpi, button_device_ids);
|
||||||
|
|
||||||
/*
|
/* Please keep this list sorted alphabetically by vendor and model */
|
||||||
* Some devices which don't even have a lid in anyway have a broken _LID
|
static const struct dmi_system_id dmi_lid_quirks[] = {
|
||||||
* method (e.g. pointing to a floating gpio pin) causing spurious LID events.
|
|
||||||
*/
|
|
||||||
static const struct dmi_system_id lid_blacklst[] = {
|
|
||||||
{
|
{
|
||||||
/* GP-electronic T701 */
|
/* GP-electronic T701, _LID method points to a floating GPIO */
|
||||||
.matches = {
|
.matches = {
|
||||||
DMI_MATCH(DMI_SYS_VENDOR, "Insyde"),
|
DMI_MATCH(DMI_SYS_VENDOR, "Insyde"),
|
||||||
DMI_MATCH(DMI_PRODUCT_NAME, "T701"),
|
DMI_MATCH(DMI_PRODUCT_NAME, "T701"),
|
||||||
DMI_MATCH(DMI_BIOS_VERSION, "BYT70A.YNCHENG.WIN.007"),
|
DMI_MATCH(DMI_BIOS_VERSION, "BYT70A.YNCHENG.WIN.007"),
|
||||||
},
|
},
|
||||||
|
.driver_data = (void *)(long)ACPI_BUTTON_LID_INIT_DISABLED,
|
||||||
},
|
},
|
||||||
{}
|
{}
|
||||||
};
|
};
|
||||||
@ -128,7 +126,7 @@ struct acpi_button {
|
|||||||
|
|
||||||
static BLOCKING_NOTIFIER_HEAD(acpi_lid_notifier);
|
static BLOCKING_NOTIFIER_HEAD(acpi_lid_notifier);
|
||||||
static struct acpi_device *lid_device;
|
static struct acpi_device *lid_device;
|
||||||
static u8 lid_init_state = ACPI_BUTTON_LID_INIT_METHOD;
|
static long lid_init_state = -1;
|
||||||
|
|
||||||
static unsigned long lid_report_interval __read_mostly = 500;
|
static unsigned long lid_report_interval __read_mostly = 500;
|
||||||
module_param(lid_report_interval, ulong, 0644);
|
module_param(lid_report_interval, ulong, 0644);
|
||||||
@ -483,8 +481,7 @@ static int acpi_button_add(struct acpi_device *device)
|
|||||||
int error;
|
int error;
|
||||||
|
|
||||||
if (!strcmp(hid, ACPI_BUTTON_HID_LID) &&
|
if (!strcmp(hid, ACPI_BUTTON_HID_LID) &&
|
||||||
(dmi_check_system(lid_blacklst) ||
|
lid_init_state == ACPI_BUTTON_LID_INIT_DISABLED)
|
||||||
lid_init_state == ACPI_BUTTON_LID_INIT_DISABLED))
|
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
button = kzalloc(sizeof(struct acpi_button), GFP_KERNEL);
|
button = kzalloc(sizeof(struct acpi_button), GFP_KERNEL);
|
||||||
@ -623,6 +620,16 @@ MODULE_PARM_DESC(lid_init_state, "Behavior for reporting LID initial state");
|
|||||||
|
|
||||||
static int acpi_button_register_driver(struct acpi_driver *driver)
|
static int acpi_button_register_driver(struct acpi_driver *driver)
|
||||||
{
|
{
|
||||||
|
const struct dmi_system_id *dmi_id;
|
||||||
|
|
||||||
|
if (lid_init_state == -1) {
|
||||||
|
dmi_id = dmi_first_match(dmi_lid_quirks);
|
||||||
|
if (dmi_id)
|
||||||
|
lid_init_state = (long)dmi_id->driver_data;
|
||||||
|
else
|
||||||
|
lid_init_state = ACPI_BUTTON_LID_INIT_METHOD;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Modules such as nouveau.ko and i915.ko have a link time dependency
|
* Modules such as nouveau.ko and i915.ko have a link time dependency
|
||||||
* on acpi_lid_open(), and would therefore not be loadable on ACPI
|
* on acpi_lid_open(), and would therefore not be loadable on ACPI
|
||||||
|
Loading…
Reference in New Issue
Block a user