2019-06-04 10:11:33 +02:00
// SPDX-License-Identifier: GPL-2.0-only
2017-04-21 12:47:40 +02:00
/*
* X86 ACPI Utility Functions
*
* Copyright ( C ) 2017 Hans de Goede < hdegoede @ redhat . com >
*
* Based on various non upstream patches to support the CHT Whiskey Cove PMIC :
* Copyright ( C ) 2013 - 2015 Intel Corporation . All rights reserved .
*/
2021-12-30 20:31:19 +01:00
# define pr_fmt(fmt) "ACPI: " fmt
2017-04-21 12:47:40 +02:00
# include <linux/acpi.h>
2017-07-09 21:05:12 +02:00
# include <linux/dmi.h>
2021-12-30 15:17:20 +01:00
# include <linux/platform_device.h>
2017-04-21 12:47:40 +02:00
# include <asm/cpu_device_id.h>
# include <asm/intel-family.h>
# include "../internal.h"
/*
* Some ACPI devices are hidden ( status = = 0x0 ) in recent BIOS - es because
* some recent Windows drivers bind to one device but poke at multiple
* devices at the same time , so the others get hidden .
2017-07-09 21:05:12 +02:00
*
* Some BIOS - es ( temporarily ) hide specific APCI devices to work around Windows
* driver bugs . We use DMI matching to match known cases of this .
*
2021-11-22 18:05:31 +01:00
* Likewise sometimes some not - actually present devices are sometimes
* reported as present , which may cause issues .
2017-04-21 12:47:40 +02:00
*
2021-11-22 18:05:31 +01:00
* We work around this by using the below quirk list to override the status
* reported by the _STA method with a fixed value ( ACPI_STA_DEFAULT or 0 ) .
* Note this MUST only be done for devices where this is safe .
*
* This status overriding is limited to specific CPU ( SoC ) models both to
* avoid potentially causing trouble on other models and because some HIDs
* are re - used on different SoCs for completely different devices .
2017-04-21 12:47:40 +02:00
*/
2021-11-22 18:05:31 +01:00
struct override_status_id {
2017-04-21 12:47:40 +02:00
struct acpi_device_id hid [ 2 ] ;
struct x86_cpu_id cpu_ids [ 2 ] ;
2017-07-09 21:05:12 +02:00
struct dmi_system_id dmi_ids [ 2 ] ; /* Optional */
2017-04-21 12:47:40 +02:00
const char * uid ;
2021-11-22 18:05:32 +01:00
const char * path ;
2021-11-22 18:05:31 +01:00
unsigned long long status ;
2017-04-21 12:47:40 +02:00
} ;
2021-11-22 18:05:32 +01:00
# define ENTRY(status, hid, uid, path, cpu_model, dmi...) { \
2017-04-21 12:47:40 +02:00
{ { hid , } , { } } , \
2021-11-22 18:05:31 +01:00
{ X86_MATCH_INTEL_FAM6_MODEL ( cpu_model , NULL ) , { } } , \
2017-07-09 21:05:12 +02:00
{ { . matches = dmi } , { } } , \
2017-04-21 12:47:40 +02:00
uid , \
2021-11-22 18:05:32 +01:00
path , \
2021-11-22 18:05:31 +01:00
status , \
2017-04-21 12:47:40 +02:00
}
2021-11-22 18:05:31 +01:00
# define PRESENT_ENTRY_HID(hid, uid, cpu_model, dmi...) \
2021-11-22 18:05:32 +01:00
ENTRY ( ACPI_STA_DEFAULT , hid , uid , NULL , cpu_model , dmi )
2021-11-22 18:05:31 +01:00
# define NOT_PRESENT_ENTRY_HID(hid, uid, cpu_model, dmi...) \
2021-11-22 18:05:32 +01:00
ENTRY ( 0 , hid , uid , NULL , cpu_model , dmi )
# define PRESENT_ENTRY_PATH(path, cpu_model, dmi...) \
ENTRY ( ACPI_STA_DEFAULT , " " , NULL , path , cpu_model , dmi )
# define NOT_PRESENT_ENTRY_PATH(path, cpu_model, dmi...) \
ENTRY ( 0 , " " , NULL , path , cpu_model , dmi )
2021-11-22 18:05:31 +01:00
static const struct override_status_id override_status_ids [ ] = {
2017-04-21 12:47:40 +02:00
/*
* Bay / Cherry Trail PWM directly poked by GPU driver in win10 ,
* but Linux uses a separate PWM driver , harmless if not used .
*/
2021-11-22 18:05:31 +01:00
PRESENT_ENTRY_HID ( " 80860F09 " , " 1 " , ATOM_SILVERMONT , { } ) ,
PRESENT_ENTRY_HID ( " 80862288 " , " 1 " , ATOM_AIRMONT , { } ) ,
2019-02-09 13:06:12 +03:00
2021-11-22 18:05:34 +01:00
/* The Xiaomi Mi Pad 2 uses PWM2 for touchkeys backlight control */
PRESENT_ENTRY_HID ( " 80862289 " , " 2 " , ATOM_AIRMONT , {
DMI_MATCH ( DMI_SYS_VENDOR , " Xiaomi Inc " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Mipad2 " ) ,
} ) ,
2017-04-21 12:47:41 +02:00
/*
* The INT0002 device is necessary to clear wakeup interrupt sources
* on Cherry Trail devices , without it we get nobody cared IRQ msgs .
*/
2021-11-22 18:05:31 +01:00
PRESENT_ENTRY_HID ( " INT0002 " , " 1 " , ATOM_AIRMONT , { } ) ,
2017-07-09 21:05:13 +02:00
/*
2018-06-09 18:18:06 -04:00
* On the Dell Venue 11 Pro 7130 and 7139 , the DSDT hides
* the touchscreen ACPI device until a certain time
* after _SB . PCI0 . GFX0 . LCD . LCD1 . _ON gets called has passed
* * and * _STA has been called at least 3 times since .
2017-07-09 21:05:13 +02:00
*/
2021-11-22 18:05:31 +01:00
PRESENT_ENTRY_HID ( " SYNA7500 " , " 1 " , HASWELL_L , {
2017-07-09 21:05:13 +02:00
DMI_MATCH ( DMI_SYS_VENDOR , " Dell Inc. " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Venue 11 Pro 7130 " ) ,
} ) ,
2021-11-22 18:05:31 +01:00
PRESENT_ENTRY_HID ( " SYNA7500 " , " 1 " , HASWELL_L , {
2018-06-09 18:18:06 -04:00
DMI_MATCH ( DMI_SYS_VENDOR , " Dell Inc. " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Venue 11 Pro 7139 " ) ,
} ) ,
2017-07-09 21:05:14 +02:00
/*
2017-10-19 13:23:21 +02:00
* The GPD win BIOS dated 20170221 has disabled the accelerometer , the
2017-07-09 21:05:14 +02:00
* drivers sometimes cause crashes under Windows and this is how the
2021-11-22 18:05:33 +01:00
* manufacturer has solved this : | The DMI match may not seem unique ,
* but it is . In the 67000 + DMI decode dumps from linux - hardware . org
* only 116 have board_vendor set to " AMI Corporation " and of those 116
* only the GPD win and pocket entries ' board_name is " Default string " .
2017-10-19 13:23:21 +02:00
*
* Unfortunately the GPD pocket also uses these strings and its BIOS
* was copy - pasted from the GPD win , so it has a disabled KIOX000A
* node which we should not enable , thus we also check the BIOS date .
2017-07-09 21:05:14 +02:00
*/
2021-11-22 18:05:31 +01:00
PRESENT_ENTRY_HID ( " KIOX000A " , " 1 " , ATOM_AIRMONT , {
2017-10-19 13:23:21 +02:00
DMI_MATCH ( DMI_BOARD_VENDOR , " AMI Corporation " ) ,
DMI_MATCH ( DMI_BOARD_NAME , " Default string " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Default string " ) ,
DMI_MATCH ( DMI_BIOS_DATE , " 02/21/2017 " )
} ) ,
2021-11-22 18:05:31 +01:00
PRESENT_ENTRY_HID ( " KIOX000A " , " 1 " , ATOM_AIRMONT , {
2017-07-09 21:05:14 +02:00
DMI_MATCH ( DMI_BOARD_VENDOR , " AMI Corporation " ) ,
DMI_MATCH ( DMI_BOARD_NAME , " Default string " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Default string " ) ,
DMI_MATCH ( DMI_BIOS_DATE , " 03/20/2017 " )
} ) ,
2021-11-22 18:05:31 +01:00
PRESENT_ENTRY_HID ( " KIOX000A " , " 1 " , ATOM_AIRMONT , {
2017-10-19 13:23:21 +02:00
DMI_MATCH ( DMI_BOARD_VENDOR , " AMI Corporation " ) ,
DMI_MATCH ( DMI_BOARD_NAME , " Default string " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Default string " ) ,
DMI_MATCH ( DMI_BIOS_DATE , " 05/25/2017 " )
} ) ,
2021-11-22 18:05:33 +01:00
/*
* The GPD win / pocket have a PCI wifi card , but its DSDT has the SDIO
* mmc controller enabled and that has a child - device which _PS3
* method sets a GPIO causing the PCI wifi card to turn off .
* See above remark about uniqueness of the DMI match .
*/
NOT_PRESENT_ENTRY_PATH ( " \\ _SB_.PCI0.SDHB.BRC1 " , ATOM_AIRMONT , {
DMI_EXACT_MATCH ( DMI_BOARD_VENDOR , " AMI Corporation " ) ,
DMI_EXACT_MATCH ( DMI_BOARD_NAME , " Default string " ) ,
DMI_EXACT_MATCH ( DMI_BOARD_SERIAL , " Default string " ) ,
DMI_EXACT_MATCH ( DMI_PRODUCT_NAME , " Default string " ) ,
} ) ,
2017-04-21 12:47:40 +02:00
} ;
2021-11-22 18:05:31 +01:00
bool acpi_device_override_status ( struct acpi_device * adev , unsigned long long * status )
2017-04-21 12:47:40 +02:00
{
bool ret = false ;
unsigned int i ;
2021-11-22 18:05:31 +01:00
for ( i = 0 ; i < ARRAY_SIZE ( override_status_ids ) ; i + + ) {
if ( ! x86_match_cpu ( override_status_ids [ i ] . cpu_ids ) )
2017-04-21 12:47:40 +02:00
continue ;
2021-11-22 18:05:31 +01:00
if ( override_status_ids [ i ] . dmi_ids [ 0 ] . matches [ 0 ] . slot & &
! dmi_check_system ( override_status_ids [ i ] . dmi_ids ) )
2017-07-09 21:05:12 +02:00
continue ;
2021-11-22 18:05:32 +01:00
if ( override_status_ids [ i ] . path ) {
struct acpi_buffer path = { ACPI_ALLOCATE_BUFFER , NULL } ;
bool match ;
if ( acpi_get_name ( adev - > handle , ACPI_FULL_PATHNAME , & path ) )
continue ;
match = strcmp ( ( char * ) path . pointer , override_status_ids [ i ] . path ) = = 0 ;
kfree ( path . pointer ) ;
if ( ! match )
continue ;
} else {
if ( acpi_match_device_ids ( adev , override_status_ids [ i ] . hid ) )
continue ;
if ( ! adev - > pnp . unique_id | |
strcmp ( adev - > pnp . unique_id , override_status_ids [ i ] . uid ) )
continue ;
}
2021-11-22 18:05:31 +01:00
* status = override_status_ids [ i ] . status ;
2017-04-21 12:47:40 +02:00
ret = true ;
break ;
}
return ret ;
}
2021-06-09 13:40:18 -05:00
/*
* AMD systems from Renoir and Lucienne * require * that the NVME controller
* is put into D3 over a Modern Standby / suspend - to - idle cycle .
*
* This is " typically " accomplished using the ` StorageD3Enable `
* property in the _DSD that is checked via the ` acpi_storage_d3 ` function
* but this property was introduced after many of these systems launched
* and most OEM systems don ' t have it in their BIOS .
*
* The Microsoft documentation for StorageD3Enable mentioned that Windows has
* a hardcoded allowlist for D3 support , which was used for these platforms .
*
* This allows quirking on Linux in a similar fashion .
*/
static const struct x86_cpu_id storage_d3_cpu_ids [ ] = {
X86_MATCH_VENDOR_FAM_MODEL ( AMD , 23 , 96 , NULL ) , /* Renoir */
X86_MATCH_VENDOR_FAM_MODEL ( AMD , 23 , 104 , NULL ) , /* Lucienne */
{ }
} ;
2022-09-15 13:23:14 -05:00
static const struct dmi_system_id force_storage_d3_dmi [ ] = {
{
/*
* _ADR is ambiguous between GPP1 . DEV0 and GPP1 . NVME
* but . NVME is needed to get StorageD3Enable node
* https : //bugzilla.kernel.org/show_bug.cgi?id=216440
*/
. matches = {
DMI_MATCH ( DMI_SYS_VENDOR , " Dell Inc. " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Inspiron 14 7425 2-in-1 " ) ,
}
} ,
2022-10-14 07:11:36 -05:00
{
. matches = {
DMI_MATCH ( DMI_SYS_VENDOR , " Dell Inc. " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " Inspiron 16 5625 " ) ,
}
} ,
2022-09-15 13:23:14 -05:00
{ }
} ;
2021-06-09 13:40:18 -05:00
bool force_storage_d3 ( void )
{
2022-09-15 13:23:14 -05:00
const struct dmi_system_id * dmi_id = dmi_first_match ( force_storage_d3_dmi ) ;
return dmi_id | | x86_match_cpu ( storage_d3_cpu_ids ) ;
2021-06-09 13:40:18 -05:00
}
2021-12-30 15:17:20 +01:00
/*
* x86 ACPI boards which ship with only Android as their factory image usually
* declare a whole bunch of bogus I2C devices in their ACPI tables and sometimes
* there are issues with serdev devices on these boards too , e . g . the resource
* points to the wrong serdev_controller .
*
* Instantiating I2C / serdev devs for these bogus devs causes various issues ,
* e . g . GPIO / IRQ resource conflicts because sometimes drivers do bind to them .
* The Android x86 kernel fork shipped on these devices has some special code
* to remove the bogus I2C clients ( and AFAICT serdevs are ignored completely ) .
*
* The acpi_quirk_skip_ * _enumeration ( ) functions below are used by the I2C or
* serdev code to skip instantiating any I2C or serdev devs on broken boards .
*
* In case of I2C an exception is made for HIDs on the i2c_acpi_known_good_ids
* list . These are known to always be correct ( and in case of the audio - codecs
* the drivers heavily rely on the codec being enumerated through ACPI ) .
*
* Note these boards typically do actually have I2C and serdev devices ,
* just different ones then the ones described in their DSDT . The devices
* which are actually present are manually instantiated by the
* drivers / platform / x86 / x86 - android - tablets . c kernel module .
*/
# define ACPI_QUIRK_SKIP_I2C_CLIENTS BIT(0)
# define ACPI_QUIRK_UART1_TTY_UART2_SKIP BIT(1)
2021-12-30 20:31:19 +01:00
# define ACPI_QUIRK_SKIP_ACPI_AC_AND_BATTERY BIT(2)
# define ACPI_QUIRK_USE_ACPI_AC_AND_BATTERY BIT(3)
static const struct dmi_system_id acpi_quirk_skip_dmi_ids [ ] = {
/*
* 1. Devices with only the skip / don ' t - skip AC and battery quirks ,
* sorted alphabetically .
*/
{
/* ECS EF20EA, AXP288 PMIC but uses separate fuel-gauge */
. matches = {
DMI_MATCH ( DMI_PRODUCT_NAME , " EF20EA " ) ,
} ,
. driver_data = ( void * ) ACPI_QUIRK_USE_ACPI_AC_AND_BATTERY
} ,
{
/* Lenovo Ideapad Miix 320, AXP288 PMIC, separate fuel-gauge */
. matches = {
DMI_MATCH ( DMI_SYS_VENDOR , " LENOVO " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " 80XF " ) ,
DMI_MATCH ( DMI_PRODUCT_VERSION , " Lenovo MIIX 320-10ICR " ) ,
} ,
. driver_data = ( void * ) ACPI_QUIRK_USE_ACPI_AC_AND_BATTERY
} ,
2021-12-30 15:17:20 +01:00
2021-12-30 20:31:19 +01:00
/*
* 2. Devices which also have the skip i2c / serdev quirks and which
* need the x86 - android - tablets module to properly work .
*/
# if IS_ENABLED(CONFIG_X86_ANDROID_TABLETS)
2021-12-30 15:17:20 +01:00
{
. matches = {
DMI_EXACT_MATCH ( DMI_SYS_VENDOR , " ASUSTeK COMPUTER INC. " ) ,
DMI_EXACT_MATCH ( DMI_PRODUCT_NAME , " ME176C " ) ,
} ,
. driver_data = ( void * ) ( ACPI_QUIRK_SKIP_I2C_CLIENTS |
2021-12-30 20:31:20 +01:00
ACPI_QUIRK_UART1_TTY_UART2_SKIP |
ACPI_QUIRK_SKIP_ACPI_AC_AND_BATTERY ) ,
2021-12-30 15:17:20 +01:00
} ,
{
. matches = {
DMI_MATCH ( DMI_SYS_VENDOR , " ASUSTeK COMPUTER INC. " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " TF103C " ) ,
} ,
2021-12-30 20:31:20 +01:00
. driver_data = ( void * ) ( ACPI_QUIRK_SKIP_I2C_CLIENTS |
ACPI_QUIRK_SKIP_ACPI_AC_AND_BATTERY ) ,
2022-02-23 14:50:31 +01:00
} ,
2022-02-23 14:50:32 +01:00
{
2022-11-27 19:24:03 +01:00
/* Lenovo Yoga Tablet 2 1050F/L */
2022-02-23 14:50:32 +01:00
. matches = {
DMI_MATCH ( DMI_SYS_VENDOR , " Intel Corp. " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " VALLEYVIEW C0 PLATFORM " ) ,
DMI_MATCH ( DMI_BOARD_NAME , " BYT-T FFD8 " ) ,
/* Partial match on beginning of BIOS version */
DMI_MATCH ( DMI_BIOS_VERSION , " BLADE_21 " ) ,
} ,
. driver_data = ( void * ) ( ACPI_QUIRK_SKIP_I2C_CLIENTS |
ACPI_QUIRK_SKIP_ACPI_AC_AND_BATTERY ) ,
} ,
2022-11-27 19:24:03 +01:00
{
/* Lenovo Yoga Tab 3 Pro X90F */
. matches = {
DMI_MATCH ( DMI_SYS_VENDOR , " Intel Corporation " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " CHERRYVIEW D1 PLATFORM " ) ,
DMI_MATCH ( DMI_PRODUCT_VERSION , " Blade3-10A-001 " ) ,
} ,
. driver_data = ( void * ) ( ACPI_QUIRK_SKIP_I2C_CLIENTS |
ACPI_QUIRK_SKIP_ACPI_AC_AND_BATTERY ) ,
} ,
2022-12-08 12:02:02 +01:00
{
/* Medion Lifetab S10346 */
. matches = {
DMI_MATCH ( DMI_BOARD_VENDOR , " AMI Corporation " ) ,
DMI_MATCH ( DMI_BOARD_NAME , " Aptio CRB " ) ,
/* Way too generic, also match on BIOS data */
DMI_MATCH ( DMI_BIOS_DATE , " 10/22/2015 " ) ,
} ,
. driver_data = ( void * ) ( ACPI_QUIRK_SKIP_I2C_CLIENTS |
ACPI_QUIRK_SKIP_ACPI_AC_AND_BATTERY ) ,
} ,
2022-02-23 14:50:31 +01:00
{
/* Nextbook Ares 8 */
. matches = {
DMI_MATCH ( DMI_SYS_VENDOR , " Insyde " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " M890BAP " ) ,
} ,
. driver_data = ( void * ) ( ACPI_QUIRK_SKIP_I2C_CLIENTS |
ACPI_QUIRK_SKIP_ACPI_AC_AND_BATTERY ) ,
2021-12-30 15:17:20 +01:00
} ,
{
/* Whitelabel (sold as various brands) TM800A550L */
. matches = {
DMI_MATCH ( DMI_BOARD_VENDOR , " AMI Corporation " ) ,
DMI_MATCH ( DMI_BOARD_NAME , " Aptio CRB " ) ,
/* Above strings are too generic, also match on BIOS version */
DMI_MATCH ( DMI_BIOS_VERSION , " ZY-8-BI-PX4S70VTR400-X423B-005-D " ) ,
} ,
2021-12-30 20:31:20 +01:00
. driver_data = ( void * ) ( ACPI_QUIRK_SKIP_I2C_CLIENTS |
ACPI_QUIRK_SKIP_ACPI_AC_AND_BATTERY ) ,
2021-12-30 15:17:20 +01:00
} ,
2021-12-30 20:31:19 +01:00
# endif
2021-12-30 15:17:20 +01:00
{ }
} ;
2021-12-30 20:31:19 +01:00
# if IS_ENABLED(CONFIG_X86_ANDROID_TABLETS)
2021-12-30 15:17:20 +01:00
static const struct acpi_device_id i2c_acpi_known_good_ids [ ] = {
{ " 10EC5640 " , 0 } , /* RealTek ALC5640 audio codec */
{ " INT33F4 " , 0 } , /* X-Powers AXP288 PMIC */
{ " INT33FD " , 0 } , /* Intel Crystal Cove PMIC */
2022-11-27 19:24:03 +01:00
{ " INT34D3 " , 0 } , /* Intel Whiskey Cove PMIC */
2021-12-30 15:17:20 +01:00
{ " NPCE69A " , 0 } , /* Asus Transformer keyboard dock */
{ }
} ;
bool acpi_quirk_skip_i2c_client_enumeration ( struct acpi_device * adev )
{
const struct dmi_system_id * dmi_id ;
long quirks ;
2021-12-30 20:31:19 +01:00
dmi_id = dmi_first_match ( acpi_quirk_skip_dmi_ids ) ;
2021-12-30 15:17:20 +01:00
if ( ! dmi_id )
return false ;
quirks = ( unsigned long ) dmi_id - > driver_data ;
if ( ! ( quirks & ACPI_QUIRK_SKIP_I2C_CLIENTS ) )
return false ;
return acpi_match_device_ids ( adev , i2c_acpi_known_good_ids ) ;
}
EXPORT_SYMBOL_GPL ( acpi_quirk_skip_i2c_client_enumeration ) ;
int acpi_quirk_skip_serdev_enumeration ( struct device * controller_parent , bool * skip )
{
struct acpi_device * adev = ACPI_COMPANION ( controller_parent ) ;
const struct dmi_system_id * dmi_id ;
long quirks = 0 ;
2022-09-13 19:31:42 +03:00
u64 uid ;
int ret ;
2021-12-30 15:17:20 +01:00
* skip = false ;
2022-09-13 19:31:42 +03:00
ret = acpi_dev_uid_to_integer ( adev , & uid ) ;
if ( ret )
return 0 ;
/* to not match on PNP enumerated debug UARTs */
if ( ! dev_is_platform ( controller_parent ) )
2021-12-30 15:17:20 +01:00
return 0 ;
2021-12-30 20:31:19 +01:00
dmi_id = dmi_first_match ( acpi_quirk_skip_dmi_ids ) ;
2021-12-30 15:17:20 +01:00
if ( dmi_id )
quirks = ( unsigned long ) dmi_id - > driver_data ;
if ( quirks & ACPI_QUIRK_UART1_TTY_UART2_SKIP ) {
2022-09-13 19:31:42 +03:00
if ( uid = = 1 )
2021-12-30 15:17:20 +01:00
return - ENODEV ; /* Create tty cdev instead of serdev */
2022-09-13 19:31:42 +03:00
if ( uid = = 2 )
2021-12-30 15:17:20 +01:00
* skip = true ;
}
return 0 ;
}
EXPORT_SYMBOL_GPL ( acpi_quirk_skip_serdev_enumeration ) ;
# endif
2021-12-30 20:31:19 +01:00
/* Lists of PMIC ACPI HIDs with an (often better) native charger driver */
static const struct {
const char * hid ;
int hrv ;
} acpi_skip_ac_and_battery_pmic_ids [ ] = {
{ " INT33F4 " , - 1 } , /* X-Powers AXP288 PMIC */
{ " INT34D3 " , 3 } , /* Intel Cherrytrail Whiskey Cove PMIC */
} ;
bool acpi_quirk_skip_acpi_ac_and_battery ( void )
{
const struct dmi_system_id * dmi_id ;
long quirks = 0 ;
int i ;
dmi_id = dmi_first_match ( acpi_quirk_skip_dmi_ids ) ;
if ( dmi_id )
quirks = ( unsigned long ) dmi_id - > driver_data ;
if ( quirks & ACPI_QUIRK_SKIP_ACPI_AC_AND_BATTERY )
return true ;
if ( quirks & ACPI_QUIRK_USE_ACPI_AC_AND_BATTERY )
return false ;
for ( i = 0 ; i < ARRAY_SIZE ( acpi_skip_ac_and_battery_pmic_ids ) ; i + + ) {
if ( acpi_dev_present ( acpi_skip_ac_and_battery_pmic_ids [ i ] . hid , " 1 " ,
acpi_skip_ac_and_battery_pmic_ids [ i ] . hrv ) ) {
pr_info_once ( " found native %s PMIC, skipping ACPI AC and battery devices \n " ,
acpi_skip_ac_and_battery_pmic_ids [ i ] . hid ) ;
return true ;
}
}
return false ;
}
EXPORT_SYMBOL_GPL ( acpi_quirk_skip_acpi_ac_and_battery ) ;