blob: 995c4d8922b12eef963a9cc1cab591ee7b404b1d [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * blacklist.c
3 *
4 * Check to see if the given machine has a known bad ACPI BIOS
5 * or if the BIOS is too old.
Lv Zhenge5f660e2016-05-03 16:49:01 +08006 * Check given machine against acpi_rev_dmi_table[].
Linus Torvalds1da177e2005-04-16 15:20:36 -07007 *
8 * Copyright (C) 2004 Len Brown <len.brown@intel.com>
9 * Copyright (C) 2002 Andy Grover <andrew.grover@intel.com>
10 *
11 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
12 *
13 * This program is free software; you can redistribute it and/or modify
14 * it under the terms of the GNU General Public License as published by
15 * the Free Software Foundation; either version 2 of the License, or (at
16 * your option) any later version.
17 *
18 * This program is distributed in the hope that it will be useful, but
19 * WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
21 * General Public License for more details.
22 *
Linus Torvalds1da177e2005-04-16 15:20:36 -070023 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
24 */
25
Linus Torvalds1da177e2005-04-16 15:20:36 -070026#include <linux/kernel.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070027#include <linux/init.h>
28#include <linux/acpi.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070029#include <linux/dmi.h>
30
Len Browna192a952009-07-28 16:45:54 -040031#include "internal.h"
32
Christoph Hellwig6faadbb2017-09-14 11:59:30 +020033static const struct dmi_system_id acpi_rev_dmi_table[] __initconst;
Len Brownd4b7dc42008-01-23 20:50:56 -050034
Linus Torvalds1da177e2005-04-16 15:20:36 -070035/*
36 * POLICY: If *anything* doesn't work, put it on the blacklist.
37 * If they are critical errors, mark it critical, and abort driver load.
38 */
Toshi Kani5aa59112017-08-23 16:54:43 -060039static struct acpi_platform_list acpi_blacklist[] __initdata = {
Linus Torvalds1da177e2005-04-16 15:20:36 -070040 /* Compaq Presario 1700 */
Alexey Starikovskiyad71860a2007-02-02 19:48:19 +030041 {"PTLTD ", " DSDT ", 0x06040000, ACPI_SIG_DSDT, less_than_or_equal,
Len Brown4be44fc2005-08-05 00:44:28 -040042 "Multiple problems", 1},
Linus Torvalds1da177e2005-04-16 15:20:36 -070043 /* Sony FX120, FX140, FX150? */
Alexey Starikovskiyad71860a2007-02-02 19:48:19 +030044 {"SONY ", "U0 ", 0x20010313, ACPI_SIG_DSDT, less_than_or_equal,
Len Brown4be44fc2005-08-05 00:44:28 -040045 "ACPI driver problem", 1},
Linus Torvalds1da177e2005-04-16 15:20:36 -070046 /* Compaq Presario 800, Insyde BIOS */
Alexey Starikovskiyad71860a2007-02-02 19:48:19 +030047 {"INT440", "SYSFexxx", 0x00001001, ACPI_SIG_DSDT, less_than_or_equal,
Len Brown4be44fc2005-08-05 00:44:28 -040048 "Does not use _REG to protect EC OpRegions", 1},
Linus Torvalds1da177e2005-04-16 15:20:36 -070049 /* IBM 600E - _ADR should return 7, but it returns 1 */
Alexey Starikovskiyad71860a2007-02-02 19:48:19 +030050 {"IBM ", "TP600E ", 0x00000105, ACPI_SIG_DSDT, less_than_or_equal,
Len Brown4be44fc2005-08-05 00:44:28 -040051 "Incorrect _ADR", 1},
Linus Torvalds1da177e2005-04-16 15:20:36 -070052
Toshi Kani5aa59112017-08-23 16:54:43 -060053 { }
Linus Torvalds1da177e2005-04-16 15:20:36 -070054};
55
Len Brown4be44fc2005-08-05 00:44:28 -040056int __init acpi_blacklisted(void)
Linus Torvalds1da177e2005-04-16 15:20:36 -070057{
Toshi Kani5aa59112017-08-23 16:54:43 -060058 int i;
Linus Torvalds1da177e2005-04-16 15:20:36 -070059 int blacklisted = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -070060
Toshi Kani5aa59112017-08-23 16:54:43 -060061 i = acpi_match_platform_list(acpi_blacklist);
62 if (i >= 0) {
63 pr_err(PREFIX "Vendor \"%6.6s\" System \"%8.8s\" Revision 0x%x has a known ACPI BIOS problem.\n",
64 acpi_blacklist[i].oem_id,
65 acpi_blacklist[i].oem_table_id,
66 acpi_blacklist[i].oem_revision);
Linus Torvalds1da177e2005-04-16 15:20:36 -070067
Toshi Kani5aa59112017-08-23 16:54:43 -060068 pr_err(PREFIX "Reason: %s. This is a %s error\n",
69 acpi_blacklist[i].reason,
70 (acpi_blacklist[i].data ?
71 "non-recoverable" : "recoverable"));
Linus Torvalds1da177e2005-04-16 15:20:36 -070072
Toshi Kani5aa59112017-08-23 16:54:43 -060073 blacklisted = acpi_blacklist[i].data;
Linus Torvalds1da177e2005-04-16 15:20:36 -070074 }
75
Lv Zhenge5f660e2016-05-03 16:49:01 +080076 (void)early_acpi_osi_init();
77 dmi_check_system(acpi_rev_dmi_table);
Len Brownd4b7dc42008-01-23 20:50:56 -050078
Linus Torvalds1da177e2005-04-16 15:20:36 -070079 return blacklisted;
80}
Len Brownd4b7dc42008-01-23 20:50:56 -050081#ifdef CONFIG_DMI
Rafael J. Wysocki18d78b62015-07-03 01:06:00 +020082#ifdef CONFIG_ACPI_REV_OVERRIDE_POSSIBLE
83static int __init dmi_enable_rev_override(const struct dmi_system_id *d)
84{
85 printk(KERN_NOTICE PREFIX "DMI detected: %s (force ACPI _REV to 5)\n",
86 d->ident);
87 acpi_rev_override_setup(NULL);
88 return 0;
89}
90#endif
Len Browna1bd4e32008-01-23 21:19:27 -050091
Christoph Hellwig6faadbb2017-09-14 11:59:30 +020092static const struct dmi_system_id acpi_rev_dmi_table[] __initconst = {
Rafael J. Wysocki18d78b62015-07-03 01:06:00 +020093#ifdef CONFIG_ACPI_REV_OVERRIDE_POSSIBLE
94 /*
95 * DELL XPS 13 (2015) switches sound between HDA and I2S
96 * depending on the ACPI _REV callback. If userspace supports
97 * I2S sufficiently (or if you do not care about sound), you
98 * can safely disable this quirk.
99 */
100 {
101 .callback = dmi_enable_rev_override,
102 .ident = "DELL XPS 13 (2015)",
103 .matches = {
104 DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc."),
105 DMI_MATCH(DMI_PRODUCT_NAME, "XPS 13 9343"),
106 },
107 },
Alex Hung9523b9b2016-10-28 11:54:04 -0700108 {
109 .callback = dmi_enable_rev_override,
110 .ident = "DELL Precision 5520",
111 .matches = {
112 DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc."),
113 DMI_MATCH(DMI_PRODUCT_NAME, "Precision 5520"),
114 },
115 },
116 {
117 .callback = dmi_enable_rev_override,
118 .ident = "DELL Precision 3520",
119 .matches = {
120 DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc."),
121 DMI_MATCH(DMI_PRODUCT_NAME, "Precision 3520"),
122 },
123 },
Michael Pobega708f5dc2016-11-11 22:29:14 -0500124 /*
125 * Resolves a quirk with the Dell Latitude 3350 that
126 * causes the ethernet adapter to not function.
127 */
128 {
129 .callback = dmi_enable_rev_override,
130 .ident = "DELL Latitude 3350",
131 .matches = {
132 DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc."),
133 DMI_MATCH(DMI_PRODUCT_NAME, "Latitude 3350"),
134 },
135 },
Kai Heng Feng2cff3192017-04-12 16:12:45 +0800136 {
137 .callback = dmi_enable_rev_override,
138 .ident = "DELL Inspiron 7537",
139 .matches = {
140 DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc."),
141 DMI_MATCH(DMI_PRODUCT_NAME, "Inspiron 7537"),
142 },
143 },
Rafael J. Wysocki18d78b62015-07-03 01:06:00 +0200144#endif
Len Brownd4b7dc42008-01-23 20:50:56 -0500145 {}
146};
147
148#endif /* CONFIG_DMI */