mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-18 02:46:06 +00:00
793582ff47
- Update the ACPICA code in the kernel to upstream revision 20230331 including the following changes: * Delete bogus node_array array of pointers from AEST table (Jessica Clarke). * Add support for trace buffer extension in GICC to the ACPI MADT parser (Xiongfeng Wang). * Add missing macro ACPI_FUNCTION_TRACE() for acpi_ns_repair_HID() (Xiongfeng Wang). * Add missing tables to astable (Pedro Falcato). * Add support for 64 bit loong_arch compilation to ACPICA (Huacai Chen). * Add support for ASPT table in disassembler to ACPICA (Jeremi Piotrowski). * Add support for Arm's MPAM ACPI table version 2 (Hesham Almatary). * Update all copyrights/signons in ACPICA to 2023 (Bob Moore). * Add support for ClockInput resource (v6.5) (Niyas Sait). * Add RISC-V INTC interrupt controller definition to the list of supported interrupt controllers for MADT (Sunil V L). * Add structure definitions for the RISC-V RHCT ACPI table (Sunil V L). * Address several cases in which the ACPICA code might lead to undefined behavior (Tamir Duberstein). * Make ACPICA code support flexible arrays properly (Kees Cook). * Check null return of ACPI_ALLOCATE_ZEROED in acpi_db_display_objects() (void0red). * Add os specific support for Zephyr RTOS to ACPICA (Najumon). * Update version to 20230331 (Bob Moore). - Fix evaluating the _PDC ACPI control method when running as Xen dom0 (Roger Pau Monne). - Use platform devices to load ACPI PPC and PCC drivers (Petr Pavlu). - Check for null return of devm_kzalloc() in fch_misc_setup() (Kang Chen). - Log a message if enable_irq_wake() fails for the ACPI SCI (Simon Gaiser). - Initialize the correct IOMMU fwspec while parsing ACPI VIOT (Jean-Philippe Brucker). - Amend indentation and prefix error messages with FW_BUG in the ACPI SPCR parsing code (Andy Shevchenko). - Enable ACPI sysfs support for CCEL records (Kuppuswamy Sathyanarayanan). - Make the APEI error injection code warn on invalid arguments when explicitly indicated by platform (Shuai Xue). - Add CXL error types to the error injection code in APEI (Tony Luck). - Refactor acpi_data_prop_read_single() (Andy Shevchenko). - Fix two issues in the ACPI SBS driver (Armin Wolf). - Replace ternary operator with min_t() in the generic ACPI thermal zone driver (Jiangshan Yi). - Ensure that ACPI notify handlers are not running after removal and clean up code in acpi_sb_notify() (Rafael Wysocki). - Remove register_backlight_delay module option and code and remove quirks for false-positive backlight control support advertised on desktop boards (Hans de Goede). - Replace irqdomain.h include with struct declarations in ACPI headers and update several pieces of code previously including of.h implicitly through those headers (Rob Herring). - Fix acpi_evaluate_dsm_typed() redefinition error (Kiran K). - Update the pm_profile sysfs attribute documentation (Rafael Wysocki). - Add 80862289 ACPI _HID for second PWM controller on Cherry Trail to the ACPI driver for Intel SoCs (Hans de Goede). -----BEGIN PGP SIGNATURE----- iQJGBAABCAAwFiEE4fcc61cGeeHD/fCwgsRv/nhiVHEFAmRGvLQSHHJqd0Byand5 c29ja2kubmV0AAoJEILEb/54YlRxoV4P/jxWGAdldtgXORR58lKGbSs6lx/0Y+SF iI7qK88NcbcbWS+a3PqRrisNkjN17rjzajfp28Ue2CXFxzwTViyw6KYELbPJ6N/h /3prem++jKgf7qiueDJG/AyO8N2+Z+yciubhxdMiK1+c1dZM2ycwSyBzJgYocpXn fH+YFPhxE7c8Z8doBrTOZjRuU4SIEKCmxo3c5BbCuyVZkbqCRdQMIDCiBJgLTmbo z4pu9OFhAamB8Cth2QFfRbZWqmuY71Gt54+c4ITPPV2ALlLUYODyHZoSISBJULp3 k0lU/hMCD+i1WRwv+Bb6of7pJPM4Lqp+wOirAtiiibjE9LRxVTNyOUAHLXbx+t2V PN8JKVJVCLaZO6TRELgFIL4nh4aBdOtr4BuaLnClZho9bG68jEkc8grnOZYhFYtM 66BuJBW30rwwGY4N5VSZGzFFR7l2qaHIOSHdq681bxQ3e6erFEeIc5jQVEOKgCqd XWdELVkqf3CnCX0lgonj+AgoeCqOpYdrNcWqMsJ+6OyQRoFhLFltDSPeJm9gHGO7 X+qCQru4ZgEDKexWKpGgH9x8AllDKbh/ApyyumXgsQOsRocVdoNaf+yCBlaaDyqu UYif6hgFYnIxF2Fg1r/POgHDXFobE4iUTHcUU1V2QhuByc4PkN9ljKsHeC2FgVUz JityWRiMABNv =O61K -----END PGP SIGNATURE----- Merge tag 'acpi-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm Pull ACPI updates from Rafael Wysocki: "These update the ACPICA code in the kernel to upstream revision 20230331, fix the ACPI SBS driver and the evaluation of the _PDC method on Xen dom0 in the ACPI processor driver, update the ACPI driver for Intel SoCs and clean up code in multiple places. Specifics: - Update the ACPICA code in the kernel to upstream revision 20230331 including the following changes: * Delete bogus node_array array of pointers from AEST table (Jessica Clarke) * Add support for trace buffer extension in GICC to the ACPI MADT parser (Xiongfeng Wang) * Add missing macro ACPI_FUNCTION_TRACE() for acpi_ns_repair_HID() (Xiongfeng Wang) * Add missing tables to astable (Pedro Falcato) * Add support for 64 bit loong_arch compilation to ACPICA (Huacai Chen) * Add support for ASPT table in disassembler to ACPICA (Jeremi Piotrowski) * Add support for Arm's MPAM ACPI table version 2 (Hesham Almatary) * Update all copyrights/signons in ACPICA to 2023 (Bob Moore) * Add support for ClockInput resource (v6.5) (Niyas Sait) * Add RISC-V INTC interrupt controller definition to the list of supported interrupt controllers for MADT (Sunil V L) * Add structure definitions for the RISC-V RHCT ACPI table (Sunil V L) * Address several cases in which the ACPICA code might lead to undefined behavior (Tamir Duberstein) * Make ACPICA code support flexible arrays properly (Kees Cook) * Check null return of ACPI_ALLOCATE_ZEROED in acpi_db_display_objects() (void0red) * Add os specific support for Zephyr RTOS to ACPICA (Najumon) * Update version to 20230331 (Bob Moore) - Fix evaluating the _PDC ACPI control method when running as Xen dom0 (Roger Pau Monne) - Use platform devices to load ACPI PPC and PCC drivers (Petr Pavlu) - Check for null return of devm_kzalloc() in fch_misc_setup() (Kang Chen) - Log a message if enable_irq_wake() fails for the ACPI SCI (Simon Gaiser) - Initialize the correct IOMMU fwspec while parsing ACPI VIOT (Jean-Philippe Brucker) - Amend indentation and prefix error messages with FW_BUG in the ACPI SPCR parsing code (Andy Shevchenko) - Enable ACPI sysfs support for CCEL records (Kuppuswamy Sathyanarayanan) - Make the APEI error injection code warn on invalid arguments when explicitly indicated by platform (Shuai Xue) - Add CXL error types to the error injection code in APEI (Tony Luck) - Refactor acpi_data_prop_read_single() (Andy Shevchenko) - Fix two issues in the ACPI SBS driver (Armin Wolf) - Replace ternary operator with min_t() in the generic ACPI thermal zone driver (Jiangshan Yi) - Ensure that ACPI notify handlers are not running after removal and clean up code in acpi_sb_notify() (Rafael Wysocki) - Remove register_backlight_delay module option and code and remove quirks for false-positive backlight control support advertised on desktop boards (Hans de Goede) - Replace irqdomain.h include with struct declarations in ACPI headers and update several pieces of code previously including of.h implicitly through those headers (Rob Herring) - Fix acpi_evaluate_dsm_typed() redefinition error (Kiran K) - Update the pm_profile sysfs attribute documentation (Rafael Wysocki) - Add 80862289 ACPI _HID for second PWM controller on Cherry Trail to the ACPI driver for Intel SoCs (Hans de Goede)" * tag 'acpi-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: (64 commits) ACPI: LPSS: Add 80862289 ACPI _HID for second PWM controller on Cherry Trail ACPI: bus: Ensure that notify handlers are not running after removal ACPI: bus: Add missing braces to acpi_sb_notify() ACPI: video: Remove desktops without backlight DMI quirks ACPI: video: Remove register_backlight_delay module option and code ACPI: Replace irqdomain.h include with struct declarations fpga: lattice-sysconfig-spi: Add explicit include for of.h tpm: atmel: Add explicit include for of.h virtio-mmio: Add explicit include for of.h pata: ixp4xx: Add explicit include for of.h ata: pata_macio: Add explicit include of irqdomain.h serial: 8250_tegra: Add explicit include for of.h net: rfkill-gpio: Add explicit include for of.h staging: iio: resolver: ad2s1210: Add explicit include for of.h iio: adc: ad7292: Add explicit include for of.h ACPICA: Update version to 20230331 ACPICA: add os specific support for Zephyr RTOS ACPICA: ACPICA: check null return of ACPI_ALLOCATE_ZEROED in acpi_db_display_objects ACPICA: acpi_resource_irq: Replace 1-element arrays with flexible array ACPICA: acpi_madt_oem_data: Fix flexible array member definition ...
242 lines
7.7 KiB
C
242 lines
7.7 KiB
C
// SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0
|
|
/******************************************************************************
|
|
*
|
|
* Module Name: utglobal - Global variables for the ACPI subsystem
|
|
*
|
|
* Copyright (C) 2000 - 2023, Intel Corp.
|
|
*
|
|
*****************************************************************************/
|
|
|
|
#define EXPORT_ACPI_INTERFACES
|
|
#define DEFINE_ACPI_GLOBALS
|
|
|
|
#include <acpi/acpi.h>
|
|
#include "accommon.h"
|
|
|
|
#define _COMPONENT ACPI_UTILITIES
|
|
ACPI_MODULE_NAME("utglobal")
|
|
|
|
/*******************************************************************************
|
|
*
|
|
* Static global variable initialization.
|
|
*
|
|
******************************************************************************/
|
|
/* Various state name strings */
|
|
const char *acpi_gbl_sleep_state_names[ACPI_S_STATE_COUNT] = {
|
|
"\\_S0_",
|
|
"\\_S1_",
|
|
"\\_S2_",
|
|
"\\_S3_",
|
|
"\\_S4_",
|
|
"\\_S5_"
|
|
};
|
|
|
|
const char *acpi_gbl_lowest_dstate_names[ACPI_NUM_sx_w_METHODS] = {
|
|
"_S0W",
|
|
"_S1W",
|
|
"_S2W",
|
|
"_S3W",
|
|
"_S4W"
|
|
};
|
|
|
|
const char *acpi_gbl_highest_dstate_names[ACPI_NUM_sx_d_METHODS] = {
|
|
"_S1D",
|
|
"_S2D",
|
|
"_S3D",
|
|
"_S4D"
|
|
};
|
|
|
|
/* Hex-to-ascii */
|
|
|
|
const char acpi_gbl_lower_hex_digits[] = "0123456789abcdef";
|
|
const char acpi_gbl_upper_hex_digits[] = "0123456789ABCDEF";
|
|
|
|
/*******************************************************************************
|
|
*
|
|
* Namespace globals
|
|
*
|
|
******************************************************************************/
|
|
/*
|
|
* Predefined ACPI Names (Built-in to the Interpreter)
|
|
*
|
|
* NOTES:
|
|
* 1) _SB_ is defined to be a device to allow \_SB_._INI to be run
|
|
* during the initialization sequence.
|
|
* 2) _TZ_ is defined to be a thermal zone in order to allow ASL code to
|
|
* perform a Notify() operation on it. 09/2010: Changed to type Device.
|
|
* This still allows notifies, but does not confuse host code that
|
|
* searches for valid thermal_zone objects.
|
|
*/
|
|
const struct acpi_predefined_names acpi_gbl_pre_defined_names[] = {
|
|
{"_GPE", ACPI_TYPE_LOCAL_SCOPE, NULL},
|
|
{"_PR_", ACPI_TYPE_LOCAL_SCOPE, NULL},
|
|
{"_SB_", ACPI_TYPE_DEVICE, NULL},
|
|
{"_SI_", ACPI_TYPE_LOCAL_SCOPE, NULL},
|
|
{"_TZ_", ACPI_TYPE_DEVICE, NULL},
|
|
/*
|
|
* March, 2015:
|
|
* The _REV object is in the process of being deprecated, because
|
|
* other ACPI implementations permanently return 2. Thus, it
|
|
* has little or no value. Return 2 for compatibility with
|
|
* other ACPI implementations.
|
|
*/
|
|
{"_REV", ACPI_TYPE_INTEGER, ACPI_CAST_PTR(char, 2)},
|
|
{"_OS_", ACPI_TYPE_STRING, ACPI_OS_NAME},
|
|
{"_GL_", ACPI_TYPE_MUTEX, ACPI_CAST_PTR(char, 1)},
|
|
{"_OSI", ACPI_TYPE_METHOD, ACPI_CAST_PTR(char, 1)},
|
|
|
|
/* Table terminator */
|
|
|
|
{NULL, ACPI_TYPE_ANY, NULL}
|
|
};
|
|
|
|
#if (!ACPI_REDUCED_HARDWARE)
|
|
/******************************************************************************
|
|
*
|
|
* Event and Hardware globals
|
|
*
|
|
******************************************************************************/
|
|
|
|
struct acpi_bit_register_info acpi_gbl_bit_register_info[ACPI_NUM_BITREG] = {
|
|
/* Name Parent Register Register Bit Position Register Bit Mask */
|
|
|
|
/* ACPI_BITREG_TIMER_STATUS */ {ACPI_REGISTER_PM1_STATUS,
|
|
ACPI_BITPOSITION_TIMER_STATUS,
|
|
ACPI_BITMASK_TIMER_STATUS},
|
|
/* ACPI_BITREG_BUS_MASTER_STATUS */ {ACPI_REGISTER_PM1_STATUS,
|
|
ACPI_BITPOSITION_BUS_MASTER_STATUS,
|
|
ACPI_BITMASK_BUS_MASTER_STATUS},
|
|
/* ACPI_BITREG_GLOBAL_LOCK_STATUS */ {ACPI_REGISTER_PM1_STATUS,
|
|
ACPI_BITPOSITION_GLOBAL_LOCK_STATUS,
|
|
ACPI_BITMASK_GLOBAL_LOCK_STATUS},
|
|
/* ACPI_BITREG_POWER_BUTTON_STATUS */ {ACPI_REGISTER_PM1_STATUS,
|
|
ACPI_BITPOSITION_POWER_BUTTON_STATUS,
|
|
ACPI_BITMASK_POWER_BUTTON_STATUS},
|
|
/* ACPI_BITREG_SLEEP_BUTTON_STATUS */ {ACPI_REGISTER_PM1_STATUS,
|
|
ACPI_BITPOSITION_SLEEP_BUTTON_STATUS,
|
|
ACPI_BITMASK_SLEEP_BUTTON_STATUS},
|
|
/* ACPI_BITREG_RT_CLOCK_STATUS */ {ACPI_REGISTER_PM1_STATUS,
|
|
ACPI_BITPOSITION_RT_CLOCK_STATUS,
|
|
ACPI_BITMASK_RT_CLOCK_STATUS},
|
|
/* ACPI_BITREG_WAKE_STATUS */ {ACPI_REGISTER_PM1_STATUS,
|
|
ACPI_BITPOSITION_WAKE_STATUS,
|
|
ACPI_BITMASK_WAKE_STATUS},
|
|
/* ACPI_BITREG_PCIEXP_WAKE_STATUS */ {ACPI_REGISTER_PM1_STATUS,
|
|
ACPI_BITPOSITION_PCIEXP_WAKE_STATUS,
|
|
ACPI_BITMASK_PCIEXP_WAKE_STATUS},
|
|
|
|
/* ACPI_BITREG_TIMER_ENABLE */ {ACPI_REGISTER_PM1_ENABLE,
|
|
ACPI_BITPOSITION_TIMER_ENABLE,
|
|
ACPI_BITMASK_TIMER_ENABLE},
|
|
/* ACPI_BITREG_GLOBAL_LOCK_ENABLE */ {ACPI_REGISTER_PM1_ENABLE,
|
|
ACPI_BITPOSITION_GLOBAL_LOCK_ENABLE,
|
|
ACPI_BITMASK_GLOBAL_LOCK_ENABLE},
|
|
/* ACPI_BITREG_POWER_BUTTON_ENABLE */ {ACPI_REGISTER_PM1_ENABLE,
|
|
ACPI_BITPOSITION_POWER_BUTTON_ENABLE,
|
|
ACPI_BITMASK_POWER_BUTTON_ENABLE},
|
|
/* ACPI_BITREG_SLEEP_BUTTON_ENABLE */ {ACPI_REGISTER_PM1_ENABLE,
|
|
ACPI_BITPOSITION_SLEEP_BUTTON_ENABLE,
|
|
ACPI_BITMASK_SLEEP_BUTTON_ENABLE},
|
|
/* ACPI_BITREG_RT_CLOCK_ENABLE */ {ACPI_REGISTER_PM1_ENABLE,
|
|
ACPI_BITPOSITION_RT_CLOCK_ENABLE,
|
|
ACPI_BITMASK_RT_CLOCK_ENABLE},
|
|
/* ACPI_BITREG_PCIEXP_WAKE_DISABLE */ {ACPI_REGISTER_PM1_ENABLE,
|
|
ACPI_BITPOSITION_PCIEXP_WAKE_DISABLE,
|
|
ACPI_BITMASK_PCIEXP_WAKE_DISABLE},
|
|
|
|
/* ACPI_BITREG_SCI_ENABLE */ {ACPI_REGISTER_PM1_CONTROL,
|
|
ACPI_BITPOSITION_SCI_ENABLE,
|
|
ACPI_BITMASK_SCI_ENABLE},
|
|
/* ACPI_BITREG_BUS_MASTER_RLD */ {ACPI_REGISTER_PM1_CONTROL,
|
|
ACPI_BITPOSITION_BUS_MASTER_RLD,
|
|
ACPI_BITMASK_BUS_MASTER_RLD},
|
|
/* ACPI_BITREG_GLOBAL_LOCK_RELEASE */ {ACPI_REGISTER_PM1_CONTROL,
|
|
ACPI_BITPOSITION_GLOBAL_LOCK_RELEASE,
|
|
ACPI_BITMASK_GLOBAL_LOCK_RELEASE},
|
|
/* ACPI_BITREG_SLEEP_TYPE */ {ACPI_REGISTER_PM1_CONTROL,
|
|
ACPI_BITPOSITION_SLEEP_TYPE,
|
|
ACPI_BITMASK_SLEEP_TYPE},
|
|
/* ACPI_BITREG_SLEEP_ENABLE */ {ACPI_REGISTER_PM1_CONTROL,
|
|
ACPI_BITPOSITION_SLEEP_ENABLE,
|
|
ACPI_BITMASK_SLEEP_ENABLE},
|
|
|
|
/* ACPI_BITREG_ARB_DIS */ {ACPI_REGISTER_PM2_CONTROL,
|
|
ACPI_BITPOSITION_ARB_DISABLE,
|
|
ACPI_BITMASK_ARB_DISABLE}
|
|
};
|
|
|
|
struct acpi_fixed_event_info acpi_gbl_fixed_event_info[ACPI_NUM_FIXED_EVENTS] = {
|
|
/* ACPI_EVENT_PMTIMER */ {ACPI_BITREG_TIMER_STATUS,
|
|
ACPI_BITREG_TIMER_ENABLE,
|
|
ACPI_BITMASK_TIMER_STATUS,
|
|
ACPI_BITMASK_TIMER_ENABLE},
|
|
/* ACPI_EVENT_GLOBAL */ {ACPI_BITREG_GLOBAL_LOCK_STATUS,
|
|
ACPI_BITREG_GLOBAL_LOCK_ENABLE,
|
|
ACPI_BITMASK_GLOBAL_LOCK_STATUS,
|
|
ACPI_BITMASK_GLOBAL_LOCK_ENABLE},
|
|
/* ACPI_EVENT_POWER_BUTTON */ {ACPI_BITREG_POWER_BUTTON_STATUS,
|
|
ACPI_BITREG_POWER_BUTTON_ENABLE,
|
|
ACPI_BITMASK_POWER_BUTTON_STATUS,
|
|
ACPI_BITMASK_POWER_BUTTON_ENABLE},
|
|
/* ACPI_EVENT_SLEEP_BUTTON */ {ACPI_BITREG_SLEEP_BUTTON_STATUS,
|
|
ACPI_BITREG_SLEEP_BUTTON_ENABLE,
|
|
ACPI_BITMASK_SLEEP_BUTTON_STATUS,
|
|
ACPI_BITMASK_SLEEP_BUTTON_ENABLE},
|
|
/* ACPI_EVENT_RTC */ {ACPI_BITREG_RT_CLOCK_STATUS,
|
|
ACPI_BITREG_RT_CLOCK_ENABLE,
|
|
ACPI_BITMASK_RT_CLOCK_STATUS,
|
|
ACPI_BITMASK_RT_CLOCK_ENABLE},
|
|
};
|
|
#endif /* !ACPI_REDUCED_HARDWARE */
|
|
|
|
#if defined (ACPI_DISASSEMBLER) || defined (ACPI_ASL_COMPILER)
|
|
|
|
/* to_pld macro: compile/disassemble strings */
|
|
|
|
const char *acpi_gbl_pld_panel_list[] = {
|
|
"TOP",
|
|
"BOTTOM",
|
|
"LEFT",
|
|
"RIGHT",
|
|
"FRONT",
|
|
"BACK",
|
|
"UNKNOWN",
|
|
NULL
|
|
};
|
|
|
|
const char *acpi_gbl_pld_vertical_position_list[] = {
|
|
"UPPER",
|
|
"CENTER",
|
|
"LOWER",
|
|
NULL
|
|
};
|
|
|
|
const char *acpi_gbl_pld_horizontal_position_list[] = {
|
|
"LEFT",
|
|
"CENTER",
|
|
"RIGHT",
|
|
NULL
|
|
};
|
|
|
|
const char *acpi_gbl_pld_shape_list[] = {
|
|
"ROUND",
|
|
"OVAL",
|
|
"SQUARE",
|
|
"VERTICALRECTANGLE",
|
|
"HORIZONTALRECTANGLE",
|
|
"VERTICALTRAPEZOID",
|
|
"HORIZONTALTRAPEZOID",
|
|
"UNKNOWN",
|
|
"CHAMFERED",
|
|
NULL
|
|
};
|
|
#endif
|
|
|
|
/* Public globals */
|
|
|
|
ACPI_EXPORT_SYMBOL(acpi_gbl_FADT)
|
|
ACPI_EXPORT_SYMBOL(acpi_dbg_level)
|
|
ACPI_EXPORT_SYMBOL(acpi_dbg_layer)
|
|
ACPI_EXPORT_SYMBOL(acpi_gpe_count)
|
|
ACPI_EXPORT_SYMBOL(acpi_current_gpe_count)
|