Commit 101b7a97 authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'acpi-6.10-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm

Pull ACPI updates from Rafael Wysocki:
 "These are ACPICA updates coming from the 20240322 release upstream, an
  ACPI DPTF driver update adding new platform support for it, some new
  quirks and some assorted fixes and cleanups.

  Specifics:

   - Add EINJ CXL error types to actbl1.h (Ben Cheatham)

   - Add support for RAS2 table to ACPICA (Shiju Jose)

   - Fix various spelling mistakes in text files and code comments in
     ACPICA (Colin Ian King)

   - Fix spelling and typos in ACPICA (Saket Dumbre)

   - Modify ACPI_OBJECT_COMMON_HEADER (lijun)

   - Add RISC-V RINTC affinity structure support to ACPICA (Haibo Xu)

   - Fix CXL 3.0 structure (RDPAS) in the CEDT table (Hojin Nam)

   - Add missin increment of registered GPE count to ACPICA (Daniil
     Tatianin)

   - Mark new ACPICA release 20240322 (Saket Dumbre)

   - Add support for the AEST V2 table to ACPICA (Ruidong Tian)

   - Disable -Wstringop-truncation for some ACPICA code in the kernel to
     avoid a compiler warning that is not very useful (Arnd Bergmann)

   - Make the kernel indicate support for several ACPI features that are
     in fact supported to the platform firmware through _OSC and fix the
     Generic Initiator Affinity _OSC bit (Armin Wolf)

   - Make the ACPI core set the owner value for ACPI drivers, drop the
     owner setting from a number of drivers and eliminate the owner
     field from struct acpi_driver (Krzysztof Kozlowski)

   - Rearrange fields in several structures to effectively eliminate
     computations from container_of() in some cases (Andy Shevchenko)

   - Do some assorted cleanups of the ACPI device enumeration code (Andy
     Shevchenko)

   - Make the ACPI device enumeration code skip devices with _STA values
     clearly identified by the specification as invalid (Rafael Wysocki)

   - Rework the handling of the NHLT table to simplify and clarify it
     and drop some obsolete pieces (Cezary Rojewski)

   - Add ACPI IRQ override quirks for Asus Vivobook Pro N6506MV,
     TongFang GXxHRXx and GMxHGxx, and XMG APEX 17 M23 (Guenter
     Schafranek, Tamim Khan, Christoffer Sandberg)

   - Add reference to UEFI DSD Guide to the documentation related to the
     ACPI handling of device properties (Sakari Ailus)

   - Fix SRAT lookup of CFMWS ranges with numa_fill_memblks(), remove
     lefover architecture-dependent code from the ACPI NUMA handling
     code and simplify it on top of that (Robert Richter)

   - Add a num-cs device property to specify the number of chip selects
     for Intel Braswell to the ACPI LPSS (Intel SoC) driver and remove a
     nested CONFIG_PM #ifdef from it (Andy Shevchenko)

   - Move three x86-specific ACPI files to the x86 directory (Andy
     Shevchenko)

   - Mark SMO8810 accel on Dell XPS 15 9550 as always present and add a
     PNP_UART1_SKIP quirk for Lenovo Blade2 tablets (Hans de Goede)

   - Move acpi_blacklisted() declaration to asm/acpi.h (Kuppuswamy
     Sathyanarayanan)

   - Add Lunar Lake support to the ACPI DPTF driver (Sumeet Pawnikar)

   - Mark the einj_driver driver's remove callback as __exit because it
     cannot get unbound via sysfs (Uwe Kleine-König)

   - Fix a typo in the ACPI documentation regarding the layout of sysfs
     subdirectory representing the ACPI namespace (John Watts)

   - Make the ACPI pfrut utility print the update_cap field during
     capability query (Chen Yu)

   - Add HAS_IOPORT dependencies to PNP (Niklas Schnelle)"

* tag 'acpi-6.10-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: (72 commits)
  ACPI/NUMA: Squash acpi_numa_memory_affinity_init() into acpi_parse_memory_affinity()
  ACPI/NUMA: Squash acpi_numa_slit_init() into acpi_parse_slit()
  ACPI/NUMA: Remove architecture dependent remainings
  x86/numa: Fix SRAT lookup of CFMWS ranges with numa_fill_memblks()
  ACPI: video: Add backlight=native quirk for Lenovo Slim 7 16ARH7
  ACPI: scan: Avoid enumerating devices with clearly invalid _STA values
  ACPI: Move acpi_blacklisted() declaration to asm/acpi.h
  ACPI: resource: Skip IRQ override on Asus Vivobook Pro N6506MV
  ACPICA: AEST: Add support for the AEST V2 table
  ACPI: tools: pfrut: Print the update_cap field during capability query
  ACPI: property: Add reference to UEFI DSD Guide
  Documentation: firmware-guide: ACPI: Fix namespace typo
  PNP: add HAS_IOPORT dependencies
  ACPI: resource: Do IRQ override on TongFang GXxHRXx and GMxHGxx
  ACPI: resource: Do IRQ override on GMxBGxx (XMG APEX 17 M23)
  ACPICA: Update acpixf.h for new ACPICA release 20240322
  ACPICA: events/evgpeinit: don't forget to increment registered GPE count
  ACPICA: Fix CXL 3.0 structure (RDPAS) in the CEDT table
  ACPICA: SRAT: Add dump and compiler support for RINTC affinity structure
  ACPICA: SRAT: Add RISC-V RINTC affinity structure
  ...
parents 0c181b1d e573d27e
...@@ -15,7 +15,7 @@ ACPI Device Tree - Representation of ACPI Namespace ...@@ -15,7 +15,7 @@ ACPI Device Tree - Representation of ACPI Namespace
Abstract Abstract
======== ========
The Linux ACPI subsystem converts ACPI namespace objects into a Linux The Linux ACPI subsystem converts ACPI namespace objects into a Linux
device tree under the /sys/devices/LNXSYSTEM:00 and updates it upon device tree under the /sys/devices/LNXSYSTM:00 and updates it upon
receiving ACPI hotplug notification events. For each device object receiving ACPI hotplug notification events. For each device object
in this hierarchy there is a corresponding symbolic link in the in this hierarchy there is a corresponding symbolic link in the
/sys/bus/acpi/devices. /sys/bus/acpi/devices.
...@@ -326,7 +326,7 @@ example ACPI namespace illustrated in Figure 2 with the addition of ...@@ -326,7 +326,7 @@ example ACPI namespace illustrated in Figure 2 with the addition of
fixed PWR_BUTTON/SLP_BUTTON devices is shown below:: fixed PWR_BUTTON/SLP_BUTTON devices is shown below::
+--------------+---+-----------------+ +--------------+---+-----------------+
| LNXSYSTEM:00 | \ | acpi:LNXSYSTEM: | | LNXSYSTM:00 | \ | acpi:LNXSYSTM: |
+--------------+---+-----------------+ +--------------+---+-----------------+
| |
| +-------------+-----+----------------+ | +-------------+-----+----------------+
......
...@@ -56,6 +56,8 @@ static inline void disable_acpi(void) ...@@ -56,6 +56,8 @@ static inline void disable_acpi(void)
extern int acpi_gsi_to_irq(u32 gsi, unsigned int *irq); extern int acpi_gsi_to_irq(u32 gsi, unsigned int *irq);
extern int acpi_blacklisted(void);
static inline void acpi_noirq_set(void) { acpi_noirq = 1; } static inline void acpi_noirq_set(void) { acpi_noirq = 1; }
static inline void acpi_disable_pci(void) static inline void acpi_disable_pci(void)
{ {
......
...@@ -37,8 +37,6 @@ extern int phys_to_target_node(phys_addr_t start); ...@@ -37,8 +37,6 @@ extern int phys_to_target_node(phys_addr_t start);
#define phys_to_target_node phys_to_target_node #define phys_to_target_node phys_to_target_node
extern int memory_add_physaddr_to_nid(u64 start); extern int memory_add_physaddr_to_nid(u64 start);
#define memory_add_physaddr_to_nid memory_add_physaddr_to_nid #define memory_add_physaddr_to_nid memory_add_physaddr_to_nid
extern int numa_fill_memblks(u64 start, u64 end);
#define numa_fill_memblks numa_fill_memblks
#endif #endif
#endif /* __ASSEMBLY__ */ #endif /* __ASSEMBLY__ */
......
...@@ -929,6 +929,8 @@ int memory_add_physaddr_to_nid(u64 start) ...@@ -929,6 +929,8 @@ int memory_add_physaddr_to_nid(u64 start)
} }
EXPORT_SYMBOL_GPL(memory_add_physaddr_to_nid); EXPORT_SYMBOL_GPL(memory_add_physaddr_to_nid);
#endif
static int __init cmp_memblk(const void *a, const void *b) static int __init cmp_memblk(const void *a, const void *b)
{ {
const struct numa_memblk *ma = *(const struct numa_memblk **)a; const struct numa_memblk *ma = *(const struct numa_memblk **)a;
...@@ -1001,5 +1003,3 @@ int __init numa_fill_memblks(u64 start, u64 end) ...@@ -1001,5 +1003,3 @@ int __init numa_fill_memblks(u64 start, u64 end)
} }
return 0; return 0;
} }
#endif
...@@ -469,6 +469,9 @@ config ACPI_REDUCED_HARDWARE_ONLY ...@@ -469,6 +469,9 @@ config ACPI_REDUCED_HARDWARE_ONLY
If you are unsure what to do, do not enable this option. If you are unsure what to do, do not enable this option.
config ACPI_NHLT
bool
source "drivers/acpi/nfit/Kconfig" source "drivers/acpi/nfit/Kconfig"
source "drivers/acpi/numa/Kconfig" source "drivers/acpi/numa/Kconfig"
source "drivers/acpi/apei/Kconfig" source "drivers/acpi/apei/Kconfig"
......
...@@ -14,7 +14,6 @@ tables.o: $(src)/../../include/$(CONFIG_ACPI_CUSTOM_DSDT_FILE) ; ...@@ -14,7 +14,6 @@ tables.o: $(src)/../../include/$(CONFIG_ACPI_CUSTOM_DSDT_FILE) ;
endif endif
obj-$(CONFIG_ACPI) += tables.o obj-$(CONFIG_ACPI) += tables.o
obj-$(CONFIG_X86) += blacklist.o
# #
# ACPI Core Subsystem (Interpreter) # ACPI Core Subsystem (Interpreter)
...@@ -46,7 +45,6 @@ acpi-y += ec.o ...@@ -46,7 +45,6 @@ acpi-y += ec.o
acpi-$(CONFIG_ACPI_DOCK) += dock.o acpi-$(CONFIG_ACPI_DOCK) += dock.o
acpi-$(CONFIG_PCI) += pci_root.o pci_link.o pci_irq.o acpi-$(CONFIG_PCI) += pci_root.o pci_link.o pci_irq.o
obj-$(CONFIG_ACPI_MCFG) += pci_mcfg.o obj-$(CONFIG_ACPI_MCFG) += pci_mcfg.o
acpi-$(CONFIG_PCI) += acpi_lpss.o
acpi-y += acpi_apd.o acpi-y += acpi_apd.o
acpi-y += acpi_platform.o acpi-y += acpi_platform.o
acpi-y += acpi_pnp.o acpi-y += acpi_pnp.o
...@@ -55,10 +53,6 @@ acpi-y += event.o ...@@ -55,10 +53,6 @@ acpi-y += event.o
acpi-y += evged.o acpi-y += evged.o
acpi-y += sysfs.o acpi-y += sysfs.o
acpi-y += property.o acpi-y += property.o
acpi-$(CONFIG_X86) += acpi_cmos_rtc.o
acpi-$(CONFIG_X86) += x86/apple.o
acpi-$(CONFIG_X86) += x86/utils.o
acpi-$(CONFIG_X86) += x86/s2idle.o
acpi-$(CONFIG_DEBUG_FS) += debugfs.o acpi-$(CONFIG_DEBUG_FS) += debugfs.o
acpi-y += acpi_lpat.o acpi-y += acpi_lpat.o
acpi-$(CONFIG_ACPI_FPDT) += acpi_fpdt.o acpi-$(CONFIG_ACPI_FPDT) += acpi_fpdt.o
...@@ -93,6 +87,7 @@ obj-$(CONFIG_ACPI_THERMAL_LIB) += thermal_lib.o ...@@ -93,6 +87,7 @@ obj-$(CONFIG_ACPI_THERMAL_LIB) += thermal_lib.o
obj-$(CONFIG_ACPI_THERMAL) += thermal.o obj-$(CONFIG_ACPI_THERMAL) += thermal.o
obj-$(CONFIG_ACPI_PLATFORM_PROFILE) += platform_profile.o obj-$(CONFIG_ACPI_PLATFORM_PROFILE) += platform_profile.o
obj-$(CONFIG_ACPI_NFIT) += nfit/ obj-$(CONFIG_ACPI_NFIT) += nfit/
obj-$(CONFIG_ACPI_NHLT) += nhlt.o
obj-$(CONFIG_ACPI_NUMA) += numa/ obj-$(CONFIG_ACPI_NUMA) += numa/
obj-$(CONFIG_ACPI) += acpi_memhotplug.o obj-$(CONFIG_ACPI) += acpi_memhotplug.o
obj-$(CONFIG_ACPI_HOTPLUG_IOAPIC) += ioapic.o obj-$(CONFIG_ACPI_HOTPLUG_IOAPIC) += ioapic.o
...@@ -132,3 +127,4 @@ obj-$(CONFIG_ARM64) += arm64/ ...@@ -132,3 +127,4 @@ obj-$(CONFIG_ARM64) += arm64/
obj-$(CONFIG_ACPI_VIOT) += viot.o obj-$(CONFIG_ACPI_VIOT) += viot.o
obj-$(CONFIG_RISCV) += riscv/ obj-$(CONFIG_RISCV) += riscv/
obj-$(CONFIG_X86) += x86/
...@@ -5,6 +5,7 @@ ...@@ -5,6 +5,7 @@
ccflags-y := -D_LINUX -DBUILDING_ACPICA ccflags-y := -D_LINUX -DBUILDING_ACPICA
ccflags-$(CONFIG_ACPI_DEBUG) += -DACPI_DEBUG_OUTPUT ccflags-$(CONFIG_ACPI_DEBUG) += -DACPI_DEBUG_OUTPUT
CFLAGS_tbfind.o += $(call cc-disable-warning, stringop-truncation)
# use acpi.o to put all files here into acpi.o modparam namespace # use acpi.o to put all files here into acpi.o modparam namespace
obj-y += acpi.o obj-y += acpi.o
......
...@@ -547,7 +547,7 @@ struct acpi_field_info { ...@@ -547,7 +547,7 @@ struct acpi_field_info {
struct acpi_ged_handler_info { struct acpi_ged_handler_info {
struct acpi_ged_handler_info *next; struct acpi_ged_handler_info *next;
u32 int_id; /* The interrupt ID that triggers the execution ofthe evt_method. */ u32 int_id; /* The interrupt ID that triggers the execution of the evt_method. */
struct acpi_namespace_node *evt_method; /* The _EVT method to be executed when an interrupt with ID = int_ID is received */ struct acpi_namespace_node *evt_method; /* The _EVT method to be executed when an interrupt with ID = int_ID is received */
}; };
......
...@@ -48,7 +48,7 @@ ...@@ -48,7 +48,7 @@
u8 descriptor_type; /* To differentiate various internal objs */\ u8 descriptor_type; /* To differentiate various internal objs */\
u8 type; /* acpi_object_type */\ u8 type; /* acpi_object_type */\
u16 reference_count; /* For object deletion management */\ u16 reference_count; /* For object deletion management */\
u8 flags; u8 flags
/* /*
* Note: There are 3 bytes available here before the * Note: There are 3 bytes available here before the
* next natural alignment boundary (for both 32/64 cases) * next natural alignment boundary (for both 32/64 cases)
...@@ -71,10 +71,12 @@ ...@@ -71,10 +71,12 @@
*****************************************************************************/ *****************************************************************************/
struct acpi_object_common { struct acpi_object_common {
ACPI_OBJECT_COMMON_HEADER}; ACPI_OBJECT_COMMON_HEADER;
};
struct acpi_object_integer { struct acpi_object_integer {
ACPI_OBJECT_COMMON_HEADER u8 fill[3]; /* Prevent warning on some compilers */ ACPI_OBJECT_COMMON_HEADER;
u8 fill[3]; /* Prevent warning on some compilers */
u64 value; u64 value;
}; };
...@@ -86,23 +88,26 @@ struct acpi_object_integer { ...@@ -86,23 +88,26 @@ struct acpi_object_integer {
*/ */
#define ACPI_COMMON_BUFFER_INFO(_type) \ #define ACPI_COMMON_BUFFER_INFO(_type) \
_type *pointer; \ _type *pointer; \
u32 length; u32 length
/* Null terminated, ASCII characters only */ /* Null terminated, ASCII characters only */
struct acpi_object_string { struct acpi_object_string {
ACPI_OBJECT_COMMON_HEADER ACPI_COMMON_BUFFER_INFO(char) /* String in AML stream or allocated string */ ACPI_OBJECT_COMMON_HEADER;
ACPI_COMMON_BUFFER_INFO(char); /* String in AML stream or allocated string */
}; };
struct acpi_object_buffer { struct acpi_object_buffer {
ACPI_OBJECT_COMMON_HEADER ACPI_COMMON_BUFFER_INFO(u8) /* Buffer in AML stream or allocated buffer */ ACPI_OBJECT_COMMON_HEADER;
ACPI_COMMON_BUFFER_INFO(u8); /* Buffer in AML stream or allocated buffer */
u32 aml_length; u32 aml_length;
u8 *aml_start; u8 *aml_start;
struct acpi_namespace_node *node; /* Link back to parent node */ struct acpi_namespace_node *node; /* Link back to parent node */
}; };
struct acpi_object_package { struct acpi_object_package {
ACPI_OBJECT_COMMON_HEADER struct acpi_namespace_node *node; /* Link back to parent node */ ACPI_OBJECT_COMMON_HEADER;
struct acpi_namespace_node *node; /* Link back to parent node */
union acpi_operand_object **elements; /* Array of pointers to acpi_objects */ union acpi_operand_object **elements; /* Array of pointers to acpi_objects */
u8 *aml_start; u8 *aml_start;
u32 aml_length; u32 aml_length;
...@@ -116,11 +121,13 @@ struct acpi_object_package { ...@@ -116,11 +121,13 @@ struct acpi_object_package {
*****************************************************************************/ *****************************************************************************/
struct acpi_object_event { struct acpi_object_event {
ACPI_OBJECT_COMMON_HEADER acpi_semaphore os_semaphore; /* Actual OS synchronization object */ ACPI_OBJECT_COMMON_HEADER;
acpi_semaphore os_semaphore; /* Actual OS synchronization object */
}; };
struct acpi_object_mutex { struct acpi_object_mutex {
ACPI_OBJECT_COMMON_HEADER u8 sync_level; /* 0-15, specified in Mutex() call */ ACPI_OBJECT_COMMON_HEADER;
u8 sync_level; /* 0-15, specified in Mutex() call */
u16 acquisition_depth; /* Allow multiple Acquires, same thread */ u16 acquisition_depth; /* Allow multiple Acquires, same thread */
acpi_mutex os_mutex; /* Actual OS synchronization object */ acpi_mutex os_mutex; /* Actual OS synchronization object */
acpi_thread_id thread_id; /* Current owner of the mutex */ acpi_thread_id thread_id; /* Current owner of the mutex */
...@@ -132,7 +139,8 @@ struct acpi_object_mutex { ...@@ -132,7 +139,8 @@ struct acpi_object_mutex {
}; };
struct acpi_object_region { struct acpi_object_region {
ACPI_OBJECT_COMMON_HEADER u8 space_id; ACPI_OBJECT_COMMON_HEADER;
u8 space_id;
struct acpi_namespace_node *node; /* Containing namespace node */ struct acpi_namespace_node *node; /* Containing namespace node */
union acpi_operand_object *handler; /* Handler for region access */ union acpi_operand_object *handler; /* Handler for region access */
union acpi_operand_object *next; union acpi_operand_object *next;
...@@ -142,7 +150,8 @@ struct acpi_object_region { ...@@ -142,7 +150,8 @@ struct acpi_object_region {
}; };
struct acpi_object_method { struct acpi_object_method {
ACPI_OBJECT_COMMON_HEADER u8 info_flags; ACPI_OBJECT_COMMON_HEADER;
u8 info_flags;
u8 param_count; u8 param_count;
u8 sync_level; u8 sync_level;
union acpi_operand_object *mutex; union acpi_operand_object *mutex;
...@@ -178,33 +187,43 @@ struct acpi_object_method { ...@@ -178,33 +187,43 @@ struct acpi_object_method {
*/ */
#define ACPI_COMMON_NOTIFY_INFO \ #define ACPI_COMMON_NOTIFY_INFO \
union acpi_operand_object *notify_list[2]; /* Handlers for system/device notifies */\ union acpi_operand_object *notify_list[2]; /* Handlers for system/device notifies */\
union acpi_operand_object *handler; /* Handler for Address space */ union acpi_operand_object *handler /* Handler for Address space */
/* COMMON NOTIFY for POWER, PROCESSOR, DEVICE, and THERMAL */ /* COMMON NOTIFY for POWER, PROCESSOR, DEVICE, and THERMAL */
struct acpi_object_notify_common { struct acpi_object_notify_common {
ACPI_OBJECT_COMMON_HEADER ACPI_COMMON_NOTIFY_INFO}; ACPI_OBJECT_COMMON_HEADER;
ACPI_COMMON_NOTIFY_INFO;
};
struct acpi_object_device { struct acpi_object_device {
ACPI_OBJECT_COMMON_HEADER ACPI_OBJECT_COMMON_HEADER;
ACPI_COMMON_NOTIFY_INFO struct acpi_gpe_block_info *gpe_block; ACPI_COMMON_NOTIFY_INFO;
struct acpi_gpe_block_info *gpe_block;
}; };
struct acpi_object_power_resource { struct acpi_object_power_resource {
ACPI_OBJECT_COMMON_HEADER ACPI_COMMON_NOTIFY_INFO u32 system_level; ACPI_OBJECT_COMMON_HEADER;
ACPI_COMMON_NOTIFY_INFO;
u32 system_level;
u32 resource_order; u32 resource_order;
}; };
struct acpi_object_processor { struct acpi_object_processor {
ACPI_OBJECT_COMMON_HEADER ACPI_OBJECT_COMMON_HEADER;
/* The next two fields take advantage of the 3-byte space before NOTIFY_INFO */ /* The next two fields take advantage of the 3-byte space before NOTIFY_INFO */
u8 proc_id; u8 proc_id;
u8 length; u8 length;
ACPI_COMMON_NOTIFY_INFO acpi_io_address address; ACPI_COMMON_NOTIFY_INFO;
acpi_io_address address;
}; };
struct acpi_object_thermal_zone { struct acpi_object_thermal_zone {
ACPI_OBJECT_COMMON_HEADER ACPI_COMMON_NOTIFY_INFO}; ACPI_OBJECT_COMMON_HEADER;
ACPI_COMMON_NOTIFY_INFO;
};
/****************************************************************************** /******************************************************************************
* *
...@@ -226,17 +245,21 @@ ACPI_OBJECT_COMMON_HEADER ACPI_COMMON_NOTIFY_INFO}; ...@@ -226,17 +245,21 @@ ACPI_OBJECT_COMMON_HEADER ACPI_COMMON_NOTIFY_INFO};
u32 base_byte_offset; /* Byte offset within containing object */\ u32 base_byte_offset; /* Byte offset within containing object */\
u32 value; /* Value to store into the Bank or Index register */\ u32 value; /* Value to store into the Bank or Index register */\
u8 start_field_bit_offset;/* Bit offset within first field datum (0-63) */\ u8 start_field_bit_offset;/* Bit offset within first field datum (0-63) */\
u8 access_length; /* For serial regions/fields */ u8 access_length /* For serial regions/fields */
/* COMMON FIELD (for BUFFER, REGION, BANK, and INDEX fields) */ /* COMMON FIELD (for BUFFER, REGION, BANK, and INDEX fields) */
struct acpi_object_field_common { struct acpi_object_field_common {
ACPI_OBJECT_COMMON_HEADER ACPI_COMMON_FIELD_INFO union acpi_operand_object *region_obj; /* Parent Operation Region object (REGION/BANK fields only) */ ACPI_OBJECT_COMMON_HEADER;
ACPI_COMMON_FIELD_INFO;
union acpi_operand_object *region_obj; /* Parent Operation Region object (REGION/BANK fields only) */
}; };
struct acpi_object_region_field { struct acpi_object_region_field {
ACPI_OBJECT_COMMON_HEADER ACPI_COMMON_FIELD_INFO u16 resource_length; ACPI_OBJECT_COMMON_HEADER;
ACPI_COMMON_FIELD_INFO;
u16 resource_length;
union acpi_operand_object *region_obj; /* Containing op_region object */ union acpi_operand_object *region_obj; /* Containing op_region object */
u8 *resource_buffer; /* resource_template for serial regions/fields */ u8 *resource_buffer; /* resource_template for serial regions/fields */
u16 pin_number_index; /* Index relative to previous Connection/Template */ u16 pin_number_index; /* Index relative to previous Connection/Template */
...@@ -244,12 +267,16 @@ struct acpi_object_region_field { ...@@ -244,12 +267,16 @@ struct acpi_object_region_field {
}; };
struct acpi_object_bank_field { struct acpi_object_bank_field {
ACPI_OBJECT_COMMON_HEADER ACPI_COMMON_FIELD_INFO union acpi_operand_object *region_obj; /* Containing op_region object */ ACPI_OBJECT_COMMON_HEADER;
ACPI_COMMON_FIELD_INFO;
union acpi_operand_object *region_obj; /* Containing op_region object */
union acpi_operand_object *bank_obj; /* bank_select Register object */ union acpi_operand_object *bank_obj; /* bank_select Register object */
}; };
struct acpi_object_index_field { struct acpi_object_index_field {
ACPI_OBJECT_COMMON_HEADER ACPI_COMMON_FIELD_INFO ACPI_OBJECT_COMMON_HEADER;
ACPI_COMMON_FIELD_INFO;
/* /*
* No "RegionObj" pointer needed since the Index and Data registers * No "RegionObj" pointer needed since the Index and Data registers
* are each field definitions unto themselves. * are each field definitions unto themselves.
...@@ -261,7 +288,9 @@ struct acpi_object_index_field { ...@@ -261,7 +288,9 @@ struct acpi_object_index_field {
/* The buffer_field is different in that it is part of a Buffer, not an op_region */ /* The buffer_field is different in that it is part of a Buffer, not an op_region */
struct acpi_object_buffer_field { struct acpi_object_buffer_field {
ACPI_OBJECT_COMMON_HEADER ACPI_COMMON_FIELD_INFO u8 is_create_field; /* Special case for objects created by create_field() */ ACPI_OBJECT_COMMON_HEADER;
ACPI_COMMON_FIELD_INFO;
u8 is_create_field; /* Special case for objects created by create_field() */
union acpi_operand_object *buffer_obj; /* Containing Buffer object */ union acpi_operand_object *buffer_obj; /* Containing Buffer object */
}; };
...@@ -272,7 +301,8 @@ struct acpi_object_buffer_field { ...@@ -272,7 +301,8 @@ struct acpi_object_buffer_field {
*****************************************************************************/ *****************************************************************************/
struct acpi_object_notify_handler { struct acpi_object_notify_handler {
ACPI_OBJECT_COMMON_HEADER struct acpi_namespace_node *node; /* Parent device */ ACPI_OBJECT_COMMON_HEADER;
struct acpi_namespace_node *node; /* Parent device */
u32 handler_type; /* Type: Device/System/Both */ u32 handler_type; /* Type: Device/System/Both */
acpi_notify_handler handler; /* Handler address */ acpi_notify_handler handler; /* Handler address */
void *context; void *context;
...@@ -280,7 +310,8 @@ struct acpi_object_notify_handler { ...@@ -280,7 +310,8 @@ struct acpi_object_notify_handler {
}; };
struct acpi_object_addr_handler { struct acpi_object_addr_handler {
ACPI_OBJECT_COMMON_HEADER u8 space_id; ACPI_OBJECT_COMMON_HEADER;
u8 space_id;
u8 handler_flags; u8 handler_flags;
acpi_adr_space_handler handler; acpi_adr_space_handler handler;
struct acpi_namespace_node *node; /* Parent device */ struct acpi_namespace_node *node; /* Parent device */
...@@ -307,7 +338,8 @@ struct acpi_object_addr_handler { ...@@ -307,7 +338,8 @@ struct acpi_object_addr_handler {
* The Reference.Class differentiates these types. * The Reference.Class differentiates these types.
*/ */
struct acpi_object_reference { struct acpi_object_reference {
ACPI_OBJECT_COMMON_HEADER u8 class; /* Reference Class */ ACPI_OBJECT_COMMON_HEADER;
u8 class; /* Reference Class */
u8 target_type; /* Used for Index Op */ u8 target_type; /* Used for Index Op */
u8 resolved; /* Reference has been resolved to a value */ u8 resolved; /* Reference has been resolved to a value */
void *object; /* name_op=>HANDLE to obj, index_op=>union acpi_operand_object */ void *object; /* name_op=>HANDLE to obj, index_op=>union acpi_operand_object */
...@@ -340,7 +372,8 @@ typedef enum { ...@@ -340,7 +372,8 @@ typedef enum {
* Currently: Region and field_unit types * Currently: Region and field_unit types
*/ */
struct acpi_object_extra { struct acpi_object_extra {
ACPI_OBJECT_COMMON_HEADER struct acpi_namespace_node *method_REG; /* _REG method for this region (if any) */ ACPI_OBJECT_COMMON_HEADER;
struct acpi_namespace_node *method_REG; /* _REG method for this region (if any) */
struct acpi_namespace_node *scope_node; struct acpi_namespace_node *scope_node;
void *region_context; /* Region-specific data */ void *region_context; /* Region-specific data */
u8 *aml_start; u8 *aml_start;
...@@ -350,14 +383,16 @@ struct acpi_object_extra { ...@@ -350,14 +383,16 @@ struct acpi_object_extra {
/* Additional data that can be attached to namespace nodes */ /* Additional data that can be attached to namespace nodes */
struct acpi_object_data { struct acpi_object_data {
ACPI_OBJECT_COMMON_HEADER acpi_object_handler handler; ACPI_OBJECT_COMMON_HEADER;
acpi_object_handler handler;
void *pointer; void *pointer;
}; };
/* Structure used when objects are cached for reuse */ /* Structure used when objects are cached for reuse */
struct acpi_object_cache_list { struct acpi_object_cache_list {
ACPI_OBJECT_COMMON_HEADER union acpi_operand_object *next; /* Link for object cache and internal lists */ ACPI_OBJECT_COMMON_HEADER;
union acpi_operand_object *next; /* Link for object cache and internal lists */
}; };
/****************************************************************************** /******************************************************************************
......
...@@ -413,6 +413,7 @@ acpi_ev_match_gpe_method(acpi_handle obj_handle, ...@@ -413,6 +413,7 @@ acpi_ev_match_gpe_method(acpi_handle obj_handle,
gpe_event_info->flags &= ~(ACPI_GPE_DISPATCH_MASK); gpe_event_info->flags &= ~(ACPI_GPE_DISPATCH_MASK);
gpe_event_info->flags |= (u8)(type | ACPI_GPE_DISPATCH_METHOD); gpe_event_info->flags |= (u8)(type | ACPI_GPE_DISPATCH_METHOD);
gpe_event_info->dispatch.method_node = method_node; gpe_event_info->dispatch.method_node = method_node;
walk_info->count++;
ACPI_DEBUG_PRINT((ACPI_DB_LOAD, ACPI_DEBUG_PRINT((ACPI_DB_LOAD,
"Registered GPE method %s as GPE number 0x%.2X\n", "Registered GPE method %s as GPE number 0x%.2X\n",
......
...@@ -62,7 +62,12 @@ void acpi_ut_track_stack_ptr(void) ...@@ -62,7 +62,12 @@ void acpi_ut_track_stack_ptr(void)
acpi_size current_sp; acpi_size current_sp;
if (&current_sp < acpi_gbl_lowest_stack_pointer) { if (&current_sp < acpi_gbl_lowest_stack_pointer) {
#pragma GCC diagnostic push
#if defined(__GNUC__) && __GNUC__ >= 12
#pragma GCC diagnostic ignored "-Wdangling-pointer="
#endif
acpi_gbl_lowest_stack_pointer = &current_sp; acpi_gbl_lowest_stack_pointer = &current_sp;
#pragma GCC diagnostic pop
} }
if (acpi_gbl_nesting_level > acpi_gbl_deepest_nesting) { if (acpi_gbl_nesting_level > acpi_gbl_deepest_nesting) {
......
...@@ -851,7 +851,7 @@ static int __init einj_probe(struct platform_device *pdev) ...@@ -851,7 +851,7 @@ static int __init einj_probe(struct platform_device *pdev)
return rc; return rc;
} }
static void einj_remove(struct platform_device *pdev) static void __exit einj_remove(struct platform_device *pdev)
{ {
struct apei_exec_context ctx; struct apei_exec_context ctx;
...@@ -873,8 +873,14 @@ static void einj_remove(struct platform_device *pdev) ...@@ -873,8 +873,14 @@ static void einj_remove(struct platform_device *pdev)
} }
static struct platform_device *einj_dev; static struct platform_device *einj_dev;
static struct platform_driver einj_driver = { /*
.remove_new = einj_remove, * einj_remove() lives in .exit.text. For drivers registered via
* platform_driver_probe() this is ok because they cannot get unbound at
* runtime. So mark the driver struct with __refdata to prevent modpost
* triggering a section mismatch warning.
*/
static struct platform_driver einj_driver __refdata = {
.remove_new = __exit_p(einj_remove),
.driver = { .driver = {
.name = "acpi-einj", .name = "acpi-einj",
}, },
......
...@@ -112,6 +112,17 @@ int acpi_bus_get_status(struct acpi_device *device) ...@@ -112,6 +112,17 @@ int acpi_bus_get_status(struct acpi_device *device)
if (ACPI_FAILURE(status)) if (ACPI_FAILURE(status))
return -ENODEV; return -ENODEV;
if (!device->status.present && device->status.enabled) {
pr_info(FW_BUG "Device [%s] status [%08x]: not present and enabled\n",
device->pnp.bus_id, (u32)sta);
device->status.enabled = 0;
/*
* The status is clearly invalid, so clear the functional bit as
* well to avoid attempting to use the device.
*/
device->status.functional = 0;
}
acpi_set_device_status(device, sta); acpi_set_device_status(device, sta);
if (device->status.functional && !device->status.present) { if (device->status.functional && !device->status.present) {
...@@ -316,9 +327,14 @@ static void acpi_bus_osc_negotiate_platform_control(void) ...@@ -316,9 +327,14 @@ static void acpi_bus_osc_negotiate_platform_control(void)
capbuf[OSC_SUPPORT_DWORD] |= OSC_SB_PAD_SUPPORT; capbuf[OSC_SUPPORT_DWORD] |= OSC_SB_PAD_SUPPORT;
if (IS_ENABLED(CONFIG_ACPI_PROCESSOR)) if (IS_ENABLED(CONFIG_ACPI_PROCESSOR))
capbuf[OSC_SUPPORT_DWORD] |= OSC_SB_PPC_OST_SUPPORT; capbuf[OSC_SUPPORT_DWORD] |= OSC_SB_PPC_OST_SUPPORT;
if (IS_ENABLED(CONFIG_ACPI_THERMAL))
capbuf[OSC_SUPPORT_DWORD] |= OSC_SB_FAST_THERMAL_SAMPLING_SUPPORT;
capbuf[OSC_SUPPORT_DWORD] |= OSC_SB_HOTPLUG_OST_SUPPORT; capbuf[OSC_SUPPORT_DWORD] |= OSC_SB_HOTPLUG_OST_SUPPORT;
capbuf[OSC_SUPPORT_DWORD] |= OSC_SB_PCLPI_SUPPORT; capbuf[OSC_SUPPORT_DWORD] |= OSC_SB_PCLPI_SUPPORT;
capbuf[OSC_SUPPORT_DWORD] |= OSC_SB_OVER_16_PSTATES_SUPPORT;
capbuf[OSC_SUPPORT_DWORD] |= OSC_SB_GED_SUPPORT;
capbuf[OSC_SUPPORT_DWORD] |= OSC_SB_IRQ_RESOURCE_SOURCE_SUPPORT;
if (IS_ENABLED(CONFIG_ACPI_PRMT)) if (IS_ENABLED(CONFIG_ACPI_PRMT))
capbuf[OSC_SUPPORT_DWORD] |= OSC_SB_PRM_SUPPORT; capbuf[OSC_SUPPORT_DWORD] |= OSC_SB_PRM_SUPPORT;
if (IS_ENABLED(CONFIG_ACPI_FFH)) if (IS_ENABLED(CONFIG_ACPI_FFH))
...@@ -990,25 +1006,26 @@ EXPORT_SYMBOL_GPL(acpi_driver_match_device); ...@@ -990,25 +1006,26 @@ EXPORT_SYMBOL_GPL(acpi_driver_match_device);
-------------------------------------------------------------------------- */ -------------------------------------------------------------------------- */
/** /**
* acpi_bus_register_driver - register a driver with the ACPI bus * __acpi_bus_register_driver - register a driver with the ACPI bus
* @driver: driver being registered * @driver: driver being registered
* @owner: owning module/driver
* *
* Registers a driver with the ACPI bus. Searches the namespace for all * Registers a driver with the ACPI bus. Searches the namespace for all
* devices that match the driver's criteria and binds. Returns zero for * devices that match the driver's criteria and binds. Returns zero for
* success or a negative error status for failure. * success or a negative error status for failure.
*/ */
int acpi_bus_register_driver(struct acpi_driver *driver) int __acpi_bus_register_driver(struct acpi_driver *driver, struct module *owner)
{ {
if (acpi_disabled) if (acpi_disabled)
return -ENODEV; return -ENODEV;
driver->drv.name = driver->name; driver->drv.name = driver->name;
driver->drv.bus = &acpi_bus_type; driver->drv.bus = &acpi_bus_type;
driver->drv.owner = driver->owner; driver->drv.owner = owner;
return driver_register(&driver->drv); return driver_register(&driver->drv);
} }
EXPORT_SYMBOL(acpi_bus_register_driver); EXPORT_SYMBOL(__acpi_bus_register_driver);
/** /**
* acpi_bus_unregister_driver - unregisters a driver with the ACPI bus * acpi_bus_unregister_driver - unregisters a driver with the ACPI bus
......
...@@ -88,43 +88,29 @@ static void dock_hotplug_event(struct dock_dependent_device *dd, u32 event, ...@@ -88,43 +88,29 @@ static void dock_hotplug_event(struct dock_dependent_device *dd, u32 event,
enum dock_callback_type cb_type) enum dock_callback_type cb_type)
{ {
struct acpi_device *adev = dd->adev; struct acpi_device *adev = dd->adev;
acpi_hp_fixup fixup = NULL;
acpi_hp_uevent uevent = NULL;
acpi_hp_notify notify = NULL;
acpi_lock_hp_context(); acpi_lock_hp_context();
if (!adev->hp) if (adev->hp) {
goto out; if (cb_type == DOCK_CALL_FIXUP)
if (cb_type == DOCK_CALL_FIXUP) {
void (*fixup)(struct acpi_device *);
fixup = adev->hp->fixup; fixup = adev->hp->fixup;
if (fixup) { else if (cb_type == DOCK_CALL_UEVENT)
acpi_unlock_hp_context();
fixup(adev);
return;
}
} else if (cb_type == DOCK_CALL_UEVENT) {
void (*uevent)(struct acpi_device *, u32);
uevent = adev->hp->uevent; uevent = adev->hp->uevent;
if (uevent) { else
acpi_unlock_hp_context();
uevent(adev, event);
return;
}
} else {
int (*notify)(struct acpi_device *, u32);
notify = adev->hp->notify; notify = adev->hp->notify;
if (notify) {
acpi_unlock_hp_context();
notify(adev, event);
return;
}
} }
out:
acpi_unlock_hp_context(); acpi_unlock_hp_context();
if (fixup)
fixup(adev);
else if (uevent)
uevent(adev, event);
else if (notify)
notify(adev, event);
} }
static struct dock_station *find_dock_station(acpi_handle handle) static struct dock_station *find_dock_station(acpi_handle handle)
......
...@@ -150,6 +150,7 @@ static const struct acpi_device_id pch_fivr_device_ids[] = { ...@@ -150,6 +150,7 @@ static const struct acpi_device_id pch_fivr_device_ids[] = {
{"INTC1045", 0}, {"INTC1045", 0},
{"INTC1049", 0}, {"INTC1049", 0},
{"INTC1064", 0}, {"INTC1064", 0},
{"INTC106B", 0},
{"INTC10A3", 0}, {"INTC10A3", 0},
{"", 0}, {"", 0},
}; };
......
...@@ -232,6 +232,8 @@ static const struct acpi_device_id int3407_device_ids[] = { ...@@ -232,6 +232,8 @@ static const struct acpi_device_id int3407_device_ids[] = {
{"INTC1061", 0}, {"INTC1061", 0},
{"INTC1065", 0}, {"INTC1065", 0},
{"INTC1066", 0}, {"INTC1066", 0},
{"INTC106C", 0},
{"INTC106D", 0},
{"INTC10A4", 0}, {"INTC10A4", 0},
{"INTC10A5", 0}, {"INTC10A5", 0},
{"", 0}, {"", 0},
......
...@@ -43,6 +43,12 @@ static const struct acpi_device_id int340x_thermal_device_ids[] = { ...@@ -43,6 +43,12 @@ static const struct acpi_device_id int340x_thermal_device_ids[] = {
{"INTC1064"}, {"INTC1064"},
{"INTC1065"}, {"INTC1065"},
{"INTC1066"}, {"INTC1066"},
{"INTC1068"},
{"INTC1069"},
{"INTC106A"},
{"INTC106B"},
{"INTC106C"},
{"INTC106D"},
{"INTC10A0"}, {"INTC10A0"},
{"INTC10A1"}, {"INTC10A1"},
{"INTC10A2"}, {"INTC10A2"},
......
...@@ -15,6 +15,7 @@ ...@@ -15,6 +15,7 @@
{"INTC1044", }, /* Fan for Tiger Lake generation */ \ {"INTC1044", }, /* Fan for Tiger Lake generation */ \
{"INTC1048", }, /* Fan for Alder Lake generation */ \ {"INTC1048", }, /* Fan for Alder Lake generation */ \
{"INTC1063", }, /* Fan for Meteor Lake generation */ \ {"INTC1063", }, /* Fan for Meteor Lake generation */ \
{"INTC106A", }, /* Fan for Lunar Lake generation */ \
{"INTC10A2", }, /* Fan for Raptor Lake generation */ \ {"INTC10A2", }, /* Fan for Raptor Lake generation */ \
{"PNP0C0B", } /* Generic ACPI fan */ {"PNP0C0B", } /* Generic ACPI fan */
......
...@@ -69,7 +69,8 @@ void acpi_debugfs_init(void); ...@@ -69,7 +69,8 @@ void acpi_debugfs_init(void);
#else #else
static inline void acpi_debugfs_init(void) { return; } static inline void acpi_debugfs_init(void) { return; }
#endif #endif
#ifdef CONFIG_PCI
#if defined(CONFIG_X86) && defined(CONFIG_PCI)
void acpi_lpss_init(void); void acpi_lpss_init(void);
#else #else
static inline void acpi_lpss_init(void) {} static inline void acpi_lpss_init(void) {}
......
// SPDX-License-Identifier: GPL-2.0-only
/*
* Copyright(c) 2023-2024 Intel Corporation
*
* Authors: Cezary Rojewski <cezary.rojewski@intel.com>
* Amadeusz Slawinski <amadeuszx.slawinski@linux.intel.com>
*/
#define pr_fmt(fmt) "ACPI: NHLT: " fmt
#include <linux/acpi.h>
#include <linux/errno.h>
#include <linux/export.h>
#include <linux/minmax.h>
#include <linux/printk.h>
#include <linux/types.h>
#include <acpi/nhlt.h>
static struct acpi_table_nhlt *acpi_gbl_nhlt;
static struct acpi_table_nhlt empty_nhlt = {
.header = {
.signature = ACPI_SIG_NHLT,
},
};
/**
* acpi_nhlt_get_gbl_table - Retrieve a pointer to the first NHLT table.
*
* If there is no NHLT in the system, acpi_gbl_nhlt will instead point to an
* empty table.
*
* Return: ACPI status code of the operation.
*/
acpi_status acpi_nhlt_get_gbl_table(void)
{
acpi_status status;
status = acpi_get_table(ACPI_SIG_NHLT, 0, (struct acpi_table_header **)(&acpi_gbl_nhlt));
if (!acpi_gbl_nhlt)
acpi_gbl_nhlt = &empty_nhlt;
return status;
}
EXPORT_SYMBOL_GPL(acpi_nhlt_get_gbl_table);
/**
* acpi_nhlt_put_gbl_table - Release the global NHLT table.
*/
void acpi_nhlt_put_gbl_table(void)
{
acpi_put_table((struct acpi_table_header *)acpi_gbl_nhlt);
}
EXPORT_SYMBOL_GPL(acpi_nhlt_put_gbl_table);
/**
* acpi_nhlt_endpoint_match - Verify if an endpoint matches criteria.
* @ep: the endpoint to check.
* @link_type: the hardware link type, e.g.: PDM or SSP.
* @dev_type: the device type.
* @dir: stream direction.
* @bus_id: the ID of virtual bus hosting the endpoint.
*
* Either of @link_type, @dev_type, @dir or @bus_id may be set to a negative
* value to ignore the parameter when matching.
*
* Return: %true if endpoint matches specified criteria or %false otherwise.
*/
bool acpi_nhlt_endpoint_match(const struct acpi_nhlt_endpoint *ep,
int link_type, int dev_type, int dir, int bus_id)
{
return ep &&
(link_type < 0 || ep->link_type == link_type) &&
(dev_type < 0 || ep->device_type == dev_type) &&
(bus_id < 0 || ep->virtual_bus_id == bus_id) &&
(dir < 0 || ep->direction == dir);
}
EXPORT_SYMBOL_GPL(acpi_nhlt_endpoint_match);
/**
* acpi_nhlt_tb_find_endpoint - Search a NHLT table for an endpoint.
* @tb: the table to search.
* @link_type: the hardware link type, e.g.: PDM or SSP.
* @dev_type: the device type.
* @dir: stream direction.
* @bus_id: the ID of virtual bus hosting the endpoint.
*
* Either of @link_type, @dev_type, @dir or @bus_id may be set to a negative
* value to ignore the parameter during the search.
*
* Return: A pointer to endpoint matching the criteria, %NULL if not found or
* an ERR_PTR() otherwise.
*/
struct acpi_nhlt_endpoint *
acpi_nhlt_tb_find_endpoint(const struct acpi_table_nhlt *tb,
int link_type, int dev_type, int dir, int bus_id)
{
struct acpi_nhlt_endpoint *ep;
for_each_nhlt_endpoint(tb, ep)
if (acpi_nhlt_endpoint_match(ep, link_type, dev_type, dir, bus_id))
return ep;
return NULL;
}
EXPORT_SYMBOL_GPL(acpi_nhlt_tb_find_endpoint);
/**
* acpi_nhlt_find_endpoint - Search all NHLT tables for an endpoint.
* @link_type: the hardware link type, e.g.: PDM or SSP.
* @dev_type: the device type.
* @dir: stream direction.
* @bus_id: the ID of virtual bus hosting the endpoint.
*
* Either of @link_type, @dev_type, @dir or @bus_id may be set to a negative
* value to ignore the parameter during the search.
*
* Return: A pointer to endpoint matching the criteria, %NULL if not found or
* an ERR_PTR() otherwise.
*/
struct acpi_nhlt_endpoint *
acpi_nhlt_find_endpoint(int link_type, int dev_type, int dir, int bus_id)
{
/* TODO: Currently limited to table of index 0. */
return acpi_nhlt_tb_find_endpoint(acpi_gbl_nhlt, link_type, dev_type, dir, bus_id);
}
EXPORT_SYMBOL_GPL(acpi_nhlt_find_endpoint);
/**
* acpi_nhlt_endpoint_find_fmtcfg - Search endpoint's formats configuration space
* for a specific format.
* @ep: the endpoint to search.
* @ch: number of channels.
* @rate: samples per second.
* @vbps: valid bits per sample.
* @bps: bits per sample.
*
* Return: A pointer to format matching the criteria, %NULL if not found or
* an ERR_PTR() otherwise.
*/
struct acpi_nhlt_format_config *
acpi_nhlt_endpoint_find_fmtcfg(const struct acpi_nhlt_endpoint *ep,
u16 ch, u32 rate, u16 vbps, u16 bps)
{
struct acpi_nhlt_wave_formatext *wav;
struct acpi_nhlt_format_config *fmt;
for_each_nhlt_endpoint_fmtcfg(ep, fmt) {
wav = &fmt->format;
if (wav->valid_bits_per_sample == vbps &&
wav->samples_per_sec == rate &&
wav->bits_per_sample == bps &&
wav->channel_count == ch)
return fmt;
}
return NULL;
}
EXPORT_SYMBOL_GPL(acpi_nhlt_endpoint_find_fmtcfg);
/**
* acpi_nhlt_tb_find_fmtcfg - Search a NHLT table for a specific format.
* @tb: the table to search.
* @link_type: the hardware link type, e.g.: PDM or SSP.
* @dev_type: the device type.
* @dir: stream direction.
* @bus_id: the ID of virtual bus hosting the endpoint.
*
* @ch: number of channels.
* @rate: samples per second.
* @vbps: valid bits per sample.
* @bps: bits per sample.
*
* Either of @link_type, @dev_type, @dir or @bus_id may be set to a negative
* value to ignore the parameter during the search.
*
* Return: A pointer to format matching the criteria, %NULL if not found or
* an ERR_PTR() otherwise.
*/
struct acpi_nhlt_format_config *
acpi_nhlt_tb_find_fmtcfg(const struct acpi_table_nhlt *tb,
int link_type, int dev_type, int dir, int bus_id,
u16 ch, u32 rate, u16 vbps, u16 bps)
{
struct acpi_nhlt_format_config *fmt;
struct acpi_nhlt_endpoint *ep;
for_each_nhlt_endpoint(tb, ep) {
if (!acpi_nhlt_endpoint_match(ep, link_type, dev_type, dir, bus_id))
continue;
fmt = acpi_nhlt_endpoint_find_fmtcfg(ep, ch, rate, vbps, bps);
if (fmt)
return fmt;
}
return NULL;
}
EXPORT_SYMBOL_GPL(acpi_nhlt_tb_find_fmtcfg);
/**
* acpi_nhlt_find_fmtcfg - Search all NHLT tables for a specific format.
* @link_type: the hardware link type, e.g.: PDM or SSP.
* @dev_type: the device type.
* @dir: stream direction.
* @bus_id: the ID of virtual bus hosting the endpoint.
*
* @ch: number of channels.
* @rate: samples per second.
* @vbps: valid bits per sample.
* @bps: bits per sample.
*
* Either of @link_type, @dev_type, @dir or @bus_id may be set to a negative
* value to ignore the parameter during the search.
*
* Return: A pointer to format matching the criteria, %NULL if not found or
* an ERR_PTR() otherwise.
*/
struct acpi_nhlt_format_config *
acpi_nhlt_find_fmtcfg(int link_type, int dev_type, int dir, int bus_id,
u16 ch, u32 rate, u16 vbps, u16 bps)
{
/* TODO: Currently limited to table of index 0. */
return acpi_nhlt_tb_find_fmtcfg(acpi_gbl_nhlt, link_type, dev_type, dir, bus_id,
ch, rate, vbps, bps);
}
EXPORT_SYMBOL_GPL(acpi_nhlt_find_fmtcfg);
static bool acpi_nhlt_config_is_micdevice(struct acpi_nhlt_config *cfg)
{
return cfg->capabilities_size >= sizeof(struct acpi_nhlt_micdevice_config);
}
static bool acpi_nhlt_config_is_vendor_micdevice(struct acpi_nhlt_config *cfg)
{
struct acpi_nhlt_vendor_micdevice_config *devcfg = __acpi_nhlt_config_caps(cfg);
return cfg->capabilities_size >= sizeof(*devcfg) &&
cfg->capabilities_size == struct_size(devcfg, mics, devcfg->mics_count);
}
/**
* acpi_nhlt_endpoint_mic_count - Retrieve number of digital microphones for a PDM endpoint.
* @ep: the endpoint to return microphones count for.
*
* Return: A number of microphones or an error code if an invalid endpoint is provided.
*/
int acpi_nhlt_endpoint_mic_count(const struct acpi_nhlt_endpoint *ep)
{
union acpi_nhlt_device_config *devcfg;
struct acpi_nhlt_format_config *fmt;
struct acpi_nhlt_config *cfg;
u16 max_ch = 0;
if (!ep || ep->link_type != ACPI_NHLT_LINKTYPE_PDM)
return -EINVAL;
/* Find max number of channels based on formats configuration. */
for_each_nhlt_endpoint_fmtcfg(ep, fmt)
max_ch = max(fmt->format.channel_count, max_ch);
cfg = __acpi_nhlt_endpoint_config(ep);
devcfg = __acpi_nhlt_config_caps(cfg);
/* If @ep is not a mic array, fallback to channels count. */
if (!acpi_nhlt_config_is_micdevice(cfg) ||
devcfg->gen.config_type != ACPI_NHLT_CONFIGTYPE_MICARRAY)
return max_ch;
switch (devcfg->mic.array_type) {
case ACPI_NHLT_ARRAYTYPE_LINEAR2_SMALL:
case ACPI_NHLT_ARRAYTYPE_LINEAR2_BIG:
return 2;
case ACPI_NHLT_ARRAYTYPE_LINEAR4_GEO1:
case ACPI_NHLT_ARRAYTYPE_PLANAR4_LSHAPED:
case ACPI_NHLT_ARRAYTYPE_LINEAR4_GEO2:
return 4;
case ACPI_NHLT_ARRAYTYPE_VENDOR:
if (!acpi_nhlt_config_is_vendor_micdevice(cfg))
return -EINVAL;
return devcfg->vendor_mic.mics_count;
default:
pr_warn("undefined mic array type: %#x\n", devcfg->mic.array_type);
return max_ch;
}
}
EXPORT_SYMBOL_GPL(acpi_nhlt_endpoint_mic_count);
...@@ -208,16 +208,26 @@ int __init srat_disabled(void) ...@@ -208,16 +208,26 @@ int __init srat_disabled(void)
return acpi_numa < 0; return acpi_numa < 0;
} }
#if defined(CONFIG_X86) || defined(CONFIG_ARM64) || defined(CONFIG_LOONGARCH) __weak int __init numa_fill_memblks(u64 start, u64 end)
{
return NUMA_NO_MEMBLK;
}
/* /*
* Callback for SLIT parsing. pxm_to_node() returns NUMA_NO_NODE for * Callback for SLIT parsing. pxm_to_node() returns NUMA_NO_NODE for
* I/O localities since SRAT does not list them. I/O localities are * I/O localities since SRAT does not list them. I/O localities are
* not supported at this point. * not supported at this point.
*/ */
void __init acpi_numa_slit_init(struct acpi_table_slit *slit) static int __init acpi_parse_slit(struct acpi_table_header *table)
{ {
struct acpi_table_slit *slit = (struct acpi_table_slit *)table;
int i, j; int i, j;
if (!slit_valid(slit)) {
pr_info("SLIT table looks invalid. Not used.\n");
return -EINVAL;
}
for (i = 0; i < slit->locality_count; i++) { for (i = 0; i < slit->locality_count; i++) {
const int from_node = pxm_to_node(i); const int from_node = pxm_to_node(i);
...@@ -234,28 +244,34 @@ void __init acpi_numa_slit_init(struct acpi_table_slit *slit) ...@@ -234,28 +244,34 @@ void __init acpi_numa_slit_init(struct acpi_table_slit *slit)
slit->entry[slit->locality_count * i + j]); slit->entry[slit->locality_count * i + j]);
} }
} }
return 0;
} }
/* static int parsed_numa_memblks __initdata;
* Default callback for parsing of the Proximity Domain <-> Memory
* Area mappings static int __init
*/ acpi_parse_memory_affinity(union acpi_subtable_headers *header,
int __init const unsigned long table_end)
acpi_numa_memory_affinity_init(struct acpi_srat_mem_affinity *ma)
{ {
struct acpi_srat_mem_affinity *ma;
u64 start, end; u64 start, end;
u32 hotpluggable; u32 hotpluggable;
int node, pxm; int node, pxm;
ma = (struct acpi_srat_mem_affinity *)header;
acpi_table_print_srat_entry(&header->common);
if (srat_disabled()) if (srat_disabled())
goto out_err; return 0;
if (ma->header.length < sizeof(struct acpi_srat_mem_affinity)) { if (ma->header.length < sizeof(struct acpi_srat_mem_affinity)) {
pr_err("SRAT: Unexpected header length: %d\n", pr_err("SRAT: Unexpected header length: %d\n",
ma->header.length); ma->header.length);
goto out_err_bad_srat; goto out_err_bad_srat;
} }
if ((ma->flags & ACPI_SRAT_MEM_ENABLED) == 0) if ((ma->flags & ACPI_SRAT_MEM_ENABLED) == 0)
goto out_err; return 0;
hotpluggable = IS_ENABLED(CONFIG_MEMORY_HOTPLUG) && hotpluggable = IS_ENABLED(CONFIG_MEMORY_HOTPLUG) &&
(ma->flags & ACPI_SRAT_MEM_HOT_PLUGGABLE); (ma->flags & ACPI_SRAT_MEM_HOT_PLUGGABLE);
...@@ -293,11 +309,15 @@ acpi_numa_memory_affinity_init(struct acpi_srat_mem_affinity *ma) ...@@ -293,11 +309,15 @@ acpi_numa_memory_affinity_init(struct acpi_srat_mem_affinity *ma)
max_possible_pfn = max(max_possible_pfn, PFN_UP(end - 1)); max_possible_pfn = max(max_possible_pfn, PFN_UP(end - 1));
parsed_numa_memblks++;
return 0; return 0;
out_err_bad_srat: out_err_bad_srat:
/* Just disable SRAT, but do not fail and ignore errors. */
bad_srat(); bad_srat();
out_err:
return -EINVAL; return 0;
} }
static int __init acpi_parse_cfmws(union acpi_subtable_headers *header, static int __init acpi_parse_cfmws(union acpi_subtable_headers *header,
...@@ -340,26 +360,6 @@ static int __init acpi_parse_cfmws(union acpi_subtable_headers *header, ...@@ -340,26 +360,6 @@ static int __init acpi_parse_cfmws(union acpi_subtable_headers *header,
(*fake_pxm)++; (*fake_pxm)++;
return 0; return 0;
} }
#else
static int __init acpi_parse_cfmws(union acpi_subtable_headers *header,
void *arg, const unsigned long table_end)
{
return 0;
}
#endif /* defined(CONFIG_X86) || defined (CONFIG_ARM64) */
static int __init acpi_parse_slit(struct acpi_table_header *table)
{
struct acpi_table_slit *slit = (struct acpi_table_slit *)table;
if (!slit_valid(slit)) {
pr_info("SLIT table looks invalid. Not used.\n");
return -EINVAL;
}
acpi_numa_slit_init(slit);
return 0;
}
void __init __weak void __init __weak
acpi_numa_x2apic_affinity_init(struct acpi_srat_x2apic_cpu_affinity *pa) acpi_numa_x2apic_affinity_init(struct acpi_srat_x2apic_cpu_affinity *pa)
...@@ -450,24 +450,6 @@ acpi_parse_gi_affinity(union acpi_subtable_headers *header, ...@@ -450,24 +450,6 @@ acpi_parse_gi_affinity(union acpi_subtable_headers *header,
} }
#endif /* defined(CONFIG_X86) || defined (CONFIG_ARM64) */ #endif /* defined(CONFIG_X86) || defined (CONFIG_ARM64) */
static int __initdata parsed_numa_memblks;
static int __init
acpi_parse_memory_affinity(union acpi_subtable_headers * header,
const unsigned long end)
{
struct acpi_srat_mem_affinity *memory_affinity;
memory_affinity = (struct acpi_srat_mem_affinity *)header;
acpi_table_print_srat_entry(&header->common);
/* let architecture-dependent part to do it */
if (!acpi_numa_memory_affinity_init(memory_affinity))
parsed_numa_memblks++;
return 0;
}
static int __init acpi_parse_srat(struct acpi_table_header *table) static int __init acpi_parse_srat(struct acpi_table_header *table)
{ {
struct acpi_table_srat *srat = (struct acpi_table_srat *)table; struct acpi_table_srat *srat = (struct acpi_table_srat *)table;
......
...@@ -31,9 +31,14 @@ static int acpi_data_get_property_array(const struct acpi_device_data *data, ...@@ -31,9 +31,14 @@ static int acpi_data_get_property_array(const struct acpi_device_data *data,
* not defined without a warning. For instance if any of the properties * not defined without a warning. For instance if any of the properties
* from different GUID appear in a property list of another, it will be * from different GUID appear in a property list of another, it will be
* accepted by the kernel. Firmware validation tools should catch these. * accepted by the kernel. Firmware validation tools should catch these.
*
* References:
*
* [1] UEFI DSD Guide.
* https://github.com/UEFI/DSD-Guide/blob/main/src/dsd-guide.adoc
*/ */
static const guid_t prp_guids[] = { static const guid_t prp_guids[] = {
/* ACPI _DSD device properties GUID: daffd814-6eba-4d8c-8a91-bc9bbf4aa301 */ /* ACPI _DSD device properties GUID [1]: daffd814-6eba-4d8c-8a91-bc9bbf4aa301 */
GUID_INIT(0xdaffd814, 0x6eba, 0x4d8c, GUID_INIT(0xdaffd814, 0x6eba, 0x4d8c,
0x8a, 0x91, 0xbc, 0x9b, 0xbf, 0x4a, 0xa3, 0x01), 0x8a, 0x91, 0xbc, 0x9b, 0xbf, 0x4a, 0xa3, 0x01),
/* Hotplug in D3 GUID: 6211e2c0-58a3-4af3-90e1-927a4e0c55a4 */ /* Hotplug in D3 GUID: 6211e2c0-58a3-4af3-90e1-927a4e0c55a4 */
...@@ -53,12 +58,12 @@ static const guid_t prp_guids[] = { ...@@ -53,12 +58,12 @@ static const guid_t prp_guids[] = {
0xa5, 0x61, 0x99, 0xa5, 0x18, 0x97, 0x62, 0xd0), 0xa5, 0x61, 0x99, 0xa5, 0x18, 0x97, 0x62, 0xd0),
}; };
/* ACPI _DSD data subnodes GUID: dbb8e3e6-5886-4ba6-8795-1319f52a966b */ /* ACPI _DSD data subnodes GUID [1]: dbb8e3e6-5886-4ba6-8795-1319f52a966b */
static const guid_t ads_guid = static const guid_t ads_guid =
GUID_INIT(0xdbb8e3e6, 0x5886, 0x4ba6, GUID_INIT(0xdbb8e3e6, 0x5886, 0x4ba6,
0x87, 0x95, 0x13, 0x19, 0xf5, 0x2a, 0x96, 0x6b); 0x87, 0x95, 0x13, 0x19, 0xf5, 0x2a, 0x96, 0x6b);
/* ACPI _DSD data buffer GUID: edb12dd0-363d-4085-a3d2-49522ca160c4 */ /* ACPI _DSD data buffer GUID [1]: edb12dd0-363d-4085-a3d2-49522ca160c4 */
static const guid_t buffer_prop_guid = static const guid_t buffer_prop_guid =
GUID_INIT(0xedb12dd0, 0x363d, 0x4085, GUID_INIT(0xedb12dd0, 0x363d, 0x4085,
0xa3, 0xd2, 0x49, 0x52, 0x2c, 0xa1, 0x60, 0xc4); 0xa3, 0xd2, 0x49, 0x52, 0x2c, 0xa1, 0x60, 0xc4);
......
...@@ -517,6 +517,13 @@ static const struct dmi_system_id irq1_level_low_skip_override[] = { ...@@ -517,6 +517,13 @@ static const struct dmi_system_id irq1_level_low_skip_override[] = {
DMI_MATCH(DMI_BOARD_NAME, "E1504GAB"), DMI_MATCH(DMI_BOARD_NAME, "E1504GAB"),
}, },
}, },
{
/* Asus Vivobook Pro N6506MV */
.matches = {
DMI_MATCH(DMI_SYS_VENDOR, "ASUSTeK COMPUTER INC."),
DMI_MATCH(DMI_BOARD_NAME, "N6506MV"),
},
},
{ {
/* LG Electronics 17U70P */ /* LG Electronics 17U70P */
.matches = { .matches = {
...@@ -533,6 +540,12 @@ static const struct dmi_system_id irq1_level_low_skip_override[] = { ...@@ -533,6 +540,12 @@ static const struct dmi_system_id irq1_level_low_skip_override[] = {
* to have a working keyboard. * to have a working keyboard.
*/ */
static const struct dmi_system_id irq1_edge_low_force_override[] = { static const struct dmi_system_id irq1_edge_low_force_override[] = {
{
/* XMG APEX 17 (M23) */
.matches = {
DMI_MATCH(DMI_BOARD_NAME, "GMxBGxx"),
},
},
{ {
/* TongFang GMxRGxx/XMG CORE 15 (M22)/TUXEDO Stellaris 15 Gen4 AMD */ /* TongFang GMxRGxx/XMG CORE 15 (M22)/TUXEDO Stellaris 15 Gen4 AMD */
.matches = { .matches = {
...@@ -630,6 +643,18 @@ static const struct dmi_system_id irq1_edge_low_force_override[] = { ...@@ -630,6 +643,18 @@ static const struct dmi_system_id irq1_edge_low_force_override[] = {
DMI_MATCH(DMI_BOARD_NAME, "X565"), DMI_MATCH(DMI_BOARD_NAME, "X565"),
}, },
}, },
{
/* TongFang GXxHRXx/TUXEDO InfinityBook Pro Gen9 AMD */
.matches = {
DMI_MATCH(DMI_BOARD_NAME, "GXxHRXx"),
},
},
{
/* TongFang GMxHGxx/TUXEDO Stellaris Slim Gen1 AMD */
.matches = {
DMI_MATCH(DMI_BOARD_NAME, "GMxHGxx"),
},
},
{ } { }
}; };
......
...@@ -73,8 +73,7 @@ void acpi_unlock_hp_context(void) ...@@ -73,8 +73,7 @@ void acpi_unlock_hp_context(void)
void acpi_initialize_hp_context(struct acpi_device *adev, void acpi_initialize_hp_context(struct acpi_device *adev,
struct acpi_hotplug_context *hp, struct acpi_hotplug_context *hp,
int (*notify)(struct acpi_device *, u32), acpi_hp_notify notify, acpi_hp_uevent uevent)
void (*uevent)(struct acpi_device *, u32))
{ {
acpi_lock_hp_context(); acpi_lock_hp_context();
hp->notify = notify; hp->notify = notify;
...@@ -428,7 +427,7 @@ void acpi_device_hotplug(struct acpi_device *adev, u32 src) ...@@ -428,7 +427,7 @@ void acpi_device_hotplug(struct acpi_device *adev, u32 src)
} else if (adev->flags.hotplug_notify) { } else if (adev->flags.hotplug_notify) {
error = acpi_generic_hotplug_event(adev, src); error = acpi_generic_hotplug_event(adev, src);
} else { } else {
int (*notify)(struct acpi_device *, u32); acpi_hp_notify notify;
acpi_lock_hp_context(); acpi_lock_hp_context();
notify = adev->hp ? adev->hp->notify : NULL; notify = adev->hp ? adev->hp->notify : NULL;
...@@ -1298,10 +1297,10 @@ const char *acpi_device_hid(struct acpi_device *device) ...@@ -1298,10 +1297,10 @@ const char *acpi_device_hid(struct acpi_device *device)
{ {
struct acpi_hardware_id *hid; struct acpi_hardware_id *hid;
if (list_empty(&device->pnp.ids)) hid = list_first_entry_or_null(&device->pnp.ids, struct acpi_hardware_id, list);
if (!hid)
return dummy_hid; return dummy_hid;
hid = list_first_entry(&device->pnp.ids, struct acpi_hardware_id, list);
return hid->id; return hid->id;
} }
EXPORT_SYMBOL(acpi_device_hid); EXPORT_SYMBOL(acpi_device_hid);
...@@ -1581,12 +1580,13 @@ int acpi_iommu_fwspec_init(struct device *dev, u32 id, ...@@ -1581,12 +1580,13 @@ int acpi_iommu_fwspec_init(struct device *dev, u32 id,
struct fwnode_handle *fwnode, struct fwnode_handle *fwnode,
const struct iommu_ops *ops) const struct iommu_ops *ops)
{ {
int ret = iommu_fwspec_init(dev, fwnode, ops); int ret;
if (!ret)
ret = iommu_fwspec_add_ids(dev, &id, 1);
ret = iommu_fwspec_init(dev, fwnode, ops);
if (ret)
return ret; return ret;
return iommu_fwspec_add_ids(dev, &id, 1);
} }
static inline const struct iommu_ops *acpi_iommu_fwspec_ops(struct device *dev) static inline const struct iommu_ops *acpi_iommu_fwspec_ops(struct device *dev)
...@@ -1625,12 +1625,11 @@ static int acpi_iommu_configure_id(struct device *dev, const u32 *id_in) ...@@ -1625,12 +1625,11 @@ static int acpi_iommu_configure_id(struct device *dev, const u32 *id_in)
if (!err && dev->bus) if (!err && dev->bus)
err = iommu_probe_device(dev); err = iommu_probe_device(dev);
/* Ignore all other errors apart from EPROBE_DEFER */ if (err == -EPROBE_DEFER)
if (err == -EPROBE_DEFER) {
return err; return err;
} else if (err) { if (err) {
dev_dbg(dev, "Adding to IOMMU failed: %d\n", err); dev_dbg(dev, "Adding to IOMMU failed: %d\n", err);
return -ENODEV; return err;
} }
if (!acpi_iommu_fwspec_ops(dev)) if (!acpi_iommu_fwspec_ops(dev))
return -ENODEV; return -ENODEV;
...@@ -1671,13 +1670,14 @@ int acpi_dma_configure_id(struct device *dev, enum dev_dma_attr attr, ...@@ -1671,13 +1670,14 @@ int acpi_dma_configure_id(struct device *dev, enum dev_dma_attr attr,
acpi_arch_dma_setup(dev); acpi_arch_dma_setup(dev);
/* Ignore all other errors apart from EPROBE_DEFER */
ret = acpi_iommu_configure_id(dev, input_id); ret = acpi_iommu_configure_id(dev, input_id);
if (ret == -EPROBE_DEFER) if (ret == -EPROBE_DEFER)
return -EPROBE_DEFER; return -EPROBE_DEFER;
/* /*
* Historically this routine doesn't fail driver probing due to errors * Historically this routine doesn't fail driver probing due to errors
* in acpi_iommu_configure_id() * in acpi_iommu_configure_id().
*/ */
arch_setup_dma_ops(dev, 0, U64_MAX, attr == DEV_DMA_COHERENT); arch_setup_dma_ops(dev, 0, U64_MAX, attr == DEV_DMA_COHERENT);
...@@ -1962,7 +1962,7 @@ bool acpi_device_is_present(const struct acpi_device *adev) ...@@ -1962,7 +1962,7 @@ bool acpi_device_is_present(const struct acpi_device *adev)
bool acpi_device_is_enabled(const struct acpi_device *adev) bool acpi_device_is_enabled(const struct acpi_device *adev)
{ {
return adev->status.present && adev->status.enabled; return adev->status.enabled;
} }
static bool acpi_scan_handler_matching(struct acpi_scan_handler *handler, static bool acpi_scan_handler_matching(struct acpi_scan_handler *handler,
......
...@@ -497,6 +497,14 @@ static const struct dmi_system_id video_detect_dmi_table[] = { ...@@ -497,6 +497,14 @@ static const struct dmi_system_id video_detect_dmi_table[] = {
DMI_MATCH(DMI_PRODUCT_NAME, "82BK"), DMI_MATCH(DMI_PRODUCT_NAME, "82BK"),
}, },
}, },
{
.callback = video_detect_force_native,
/* Lenovo Slim 7 16ARH7 */
.matches = {
DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"),
DMI_MATCH(DMI_PRODUCT_NAME, "82UX"),
},
},
{ {
.callback = video_detect_force_native, .callback = video_detect_force_native,
/* Lenovo ThinkPad X131e (3371 AMD version) */ /* Lenovo ThinkPad X131e (3371 AMD version) */
......
obj-$(CONFIG_ACPI) += acpi-x86.o
acpi-x86-y += apple.o
acpi-x86-y += cmos_rtc.o
acpi-x86-$(CONFIG_PCI) += lpss.o
acpi-x86-y += s2idle.o
acpi-x86-y += utils.o
obj-$(CONFIG_X86) += blacklist.o
...@@ -17,7 +17,7 @@ ...@@ -17,7 +17,7 @@
#include <linux/acpi.h> #include <linux/acpi.h>
#include <linux/dmi.h> #include <linux/dmi.h>
#include "internal.h" #include "../internal.h"
#ifdef CONFIG_DMI #ifdef CONFIG_DMI
static const struct dmi_system_id acpi_rev_dmi_table[] __initconst; static const struct dmi_system_id acpi_rev_dmi_table[] __initconst;
......
...@@ -15,7 +15,7 @@ ...@@ -15,7 +15,7 @@
#include <linux/module.h> #include <linux/module.h>
#include <linux/mc146818rtc.h> #include <linux/mc146818rtc.h>
#include "internal.h" #include "../internal.h"
static const struct acpi_device_id acpi_cmos_rtc_ids[] = { static const struct acpi_device_id acpi_cmos_rtc_ids[] = {
{ "PNP0B00" }, { "PNP0B00" },
......
...@@ -25,7 +25,7 @@ ...@@ -25,7 +25,7 @@
#include <linux/suspend.h> #include <linux/suspend.h>
#include <linux/delay.h> #include <linux/delay.h>
#include "internal.h" #include "../internal.h"
#ifdef CONFIG_X86_INTEL_LPSS #ifdef CONFIG_X86_INTEL_LPSS
...@@ -325,6 +325,7 @@ static const struct lpss_device_desc bsw_i2c_dev_desc = { ...@@ -325,6 +325,7 @@ static const struct lpss_device_desc bsw_i2c_dev_desc = {
static const struct property_entry bsw_spi_properties[] = { static const struct property_entry bsw_spi_properties[] = {
PROPERTY_ENTRY_U32("intel,spi-pxa2xx-type", LPSS_BSW_SSP), PROPERTY_ENTRY_U32("intel,spi-pxa2xx-type", LPSS_BSW_SSP),
PROPERTY_ENTRY_U32("num-cs", 2),
{ } { }
}; };
...@@ -886,10 +887,8 @@ static int acpi_lpss_activate(struct device *dev) ...@@ -886,10 +887,8 @@ static int acpi_lpss_activate(struct device *dev)
if (pdata->dev_desc->flags & (LPSS_SAVE_CTX | LPSS_SAVE_CTX_ONCE)) if (pdata->dev_desc->flags & (LPSS_SAVE_CTX | LPSS_SAVE_CTX_ONCE))
lpss_deassert_reset(pdata); lpss_deassert_reset(pdata);
#ifdef CONFIG_PM
if (pdata->dev_desc->flags & LPSS_SAVE_CTX_ONCE) if (pdata->dev_desc->flags & LPSS_SAVE_CTX_ONCE)
acpi_lpss_save_ctx(dev, pdata); acpi_lpss_save_ctx(dev, pdata);
#endif
return 0; return 0;
} }
......
...@@ -100,6 +100,15 @@ static const struct override_status_id override_status_ids[] = { ...@@ -100,6 +100,15 @@ static const struct override_status_id override_status_ids[] = {
DMI_MATCH(DMI_PRODUCT_NAME, "Venue 11 Pro 7139"), DMI_MATCH(DMI_PRODUCT_NAME, "Venue 11 Pro 7139"),
}), }),
/*
* The Dell XPS 15 9550 has a SMO8110 accelerometer /
* HDD freefall sensor which is wrongly marked as not present.
*/
PRESENT_ENTRY_HID("SMO8810", "1", SKYLAKE, {
DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc."),
DMI_MATCH(DMI_PRODUCT_NAME, "XPS 15 9550"),
}),
/* /*
* The GPD win BIOS dated 20170221 has disabled the accelerometer, the * The GPD win BIOS dated 20170221 has disabled the accelerometer, the
* drivers sometimes cause crashes under Windows and this is how the * drivers sometimes cause crashes under Windows and this is how the
...@@ -260,9 +269,10 @@ bool force_storage_d3(void) ...@@ -260,9 +269,10 @@ bool force_storage_d3(void)
#define ACPI_QUIRK_SKIP_I2C_CLIENTS BIT(0) #define ACPI_QUIRK_SKIP_I2C_CLIENTS BIT(0)
#define ACPI_QUIRK_UART1_SKIP BIT(1) #define ACPI_QUIRK_UART1_SKIP BIT(1)
#define ACPI_QUIRK_UART1_TTY_UART2_SKIP BIT(2) #define ACPI_QUIRK_UART1_TTY_UART2_SKIP BIT(2)
#define ACPI_QUIRK_SKIP_ACPI_AC_AND_BATTERY BIT(3) #define ACPI_QUIRK_PNP_UART1_SKIP BIT(3)
#define ACPI_QUIRK_USE_ACPI_AC_AND_BATTERY BIT(4) #define ACPI_QUIRK_SKIP_ACPI_AC_AND_BATTERY BIT(4)
#define ACPI_QUIRK_SKIP_GPIO_EVENT_HANDLERS BIT(5) #define ACPI_QUIRK_USE_ACPI_AC_AND_BATTERY BIT(5)
#define ACPI_QUIRK_SKIP_GPIO_EVENT_HANDLERS BIT(6)
static const struct dmi_system_id acpi_quirk_skip_dmi_ids[] = { static const struct dmi_system_id acpi_quirk_skip_dmi_ids[] = {
/* /*
...@@ -342,6 +352,7 @@ static const struct dmi_system_id acpi_quirk_skip_dmi_ids[] = { ...@@ -342,6 +352,7 @@ static const struct dmi_system_id acpi_quirk_skip_dmi_ids[] = {
DMI_MATCH(DMI_BIOS_VERSION, "BLADE_21"), DMI_MATCH(DMI_BIOS_VERSION, "BLADE_21"),
}, },
.driver_data = (void *)(ACPI_QUIRK_SKIP_I2C_CLIENTS | .driver_data = (void *)(ACPI_QUIRK_SKIP_I2C_CLIENTS |
ACPI_QUIRK_PNP_UART1_SKIP |
ACPI_QUIRK_SKIP_ACPI_AC_AND_BATTERY), ACPI_QUIRK_SKIP_ACPI_AC_AND_BATTERY),
}, },
{ {
...@@ -440,14 +451,18 @@ static int acpi_dmi_skip_serdev_enumeration(struct device *controller_parent, bo ...@@ -440,14 +451,18 @@ static int acpi_dmi_skip_serdev_enumeration(struct device *controller_parent, bo
if (ret) if (ret)
return 0; return 0;
/* to not match on PNP enumerated debug UARTs */
if (!dev_is_platform(controller_parent))
return 0;
dmi_id = dmi_first_match(acpi_quirk_skip_dmi_ids); dmi_id = dmi_first_match(acpi_quirk_skip_dmi_ids);
if (dmi_id) if (dmi_id)
quirks = (unsigned long)dmi_id->driver_data; quirks = (unsigned long)dmi_id->driver_data;
if (!dev_is_platform(controller_parent)) {
/* PNP enumerated UARTs */
if ((quirks & ACPI_QUIRK_PNP_UART1_SKIP) && uid == 1)
*skip = true;
return 0;
}
if ((quirks & ACPI_QUIRK_UART1_SKIP) && uid == 1) if ((quirks & ACPI_QUIRK_UART1_SKIP) && uid == 1)
*skip = true; *skip = true;
......
...@@ -127,7 +127,6 @@ MODULE_DEVICE_TABLE(acpi, atlas_device_ids); ...@@ -127,7 +127,6 @@ MODULE_DEVICE_TABLE(acpi, atlas_device_ids);
static struct acpi_driver atlas_acpi_driver = { static struct acpi_driver atlas_acpi_driver = {
.name = ACPI_ATLAS_NAME, .name = ACPI_ATLAS_NAME,
.class = ACPI_ATLAS_CLASS, .class = ACPI_ATLAS_CLASS,
.owner = THIS_MODULE,
.ids = atlas_device_ids, .ids = atlas_device_ids,
.ops = { .ops = {
.add = atlas_acpi_button_add, .add = atlas_acpi_button_add,
......
...@@ -156,7 +156,6 @@ static void fjes_acpi_remove(struct acpi_device *device) ...@@ -156,7 +156,6 @@ static void fjes_acpi_remove(struct acpi_device *device)
static struct acpi_driver fjes_acpi_driver = { static struct acpi_driver fjes_acpi_driver = {
.name = DRV_NAME, .name = DRV_NAME,
.class = DRV_NAME, .class = DRV_NAME,
.owner = THIS_MODULE,
.ids = fjes_acpi_ids, .ids = fjes_acpi_ids,
.ops = { .ops = {
.add = fjes_acpi_add, .add = fjes_acpi_add,
......
...@@ -523,7 +523,6 @@ static struct acpi_driver event_driver = { ...@@ -523,7 +523,6 @@ static struct acpi_driver event_driver = {
.notify = event_device_notify, .notify = event_device_notify,
.remove = event_device_remove, .remove = event_device_remove,
}, },
.owner = THIS_MODULE,
}; };
static int __init event_module_init(void) static int __init event_module_init(void)
......
...@@ -1925,7 +1925,6 @@ MODULE_DEVICE_TABLE(acpi, asus_device_ids); ...@@ -1925,7 +1925,6 @@ MODULE_DEVICE_TABLE(acpi, asus_device_ids);
static struct acpi_driver asus_acpi_driver = { static struct acpi_driver asus_acpi_driver = {
.name = ASUS_LAPTOP_NAME, .name = ASUS_LAPTOP_NAME,
.class = ASUS_LAPTOP_CLASS, .class = ASUS_LAPTOP_CLASS,
.owner = THIS_MODULE,
.ids = asus_device_ids, .ids = asus_device_ids,
.flags = ACPI_DRIVER_ALL_NOTIFY_EVENTS, .flags = ACPI_DRIVER_ALL_NOTIFY_EVENTS,
.ops = { .ops = {
......
...@@ -434,7 +434,6 @@ static const struct acpi_device_id cmpc_accel_device_ids_v4[] = { ...@@ -434,7 +434,6 @@ static const struct acpi_device_id cmpc_accel_device_ids_v4[] = {
}; };
static struct acpi_driver cmpc_accel_acpi_driver_v4 = { static struct acpi_driver cmpc_accel_acpi_driver_v4 = {
.owner = THIS_MODULE,
.name = "cmpc_accel_v4", .name = "cmpc_accel_v4",
.class = "cmpc_accel_v4", .class = "cmpc_accel_v4",
.ids = cmpc_accel_device_ids_v4, .ids = cmpc_accel_device_ids_v4,
...@@ -660,7 +659,6 @@ static const struct acpi_device_id cmpc_accel_device_ids[] = { ...@@ -660,7 +659,6 @@ static const struct acpi_device_id cmpc_accel_device_ids[] = {
}; };
static struct acpi_driver cmpc_accel_acpi_driver = { static struct acpi_driver cmpc_accel_acpi_driver = {
.owner = THIS_MODULE,
.name = "cmpc_accel", .name = "cmpc_accel",
.class = "cmpc_accel", .class = "cmpc_accel",
.ids = cmpc_accel_device_ids, .ids = cmpc_accel_device_ids,
...@@ -754,7 +752,6 @@ static const struct acpi_device_id cmpc_tablet_device_ids[] = { ...@@ -754,7 +752,6 @@ static const struct acpi_device_id cmpc_tablet_device_ids[] = {
}; };
static struct acpi_driver cmpc_tablet_acpi_driver = { static struct acpi_driver cmpc_tablet_acpi_driver = {
.owner = THIS_MODULE,
.name = "cmpc_tablet", .name = "cmpc_tablet",
.class = "cmpc_tablet", .class = "cmpc_tablet",
.ids = cmpc_tablet_device_ids, .ids = cmpc_tablet_device_ids,
...@@ -996,7 +993,6 @@ static const struct acpi_device_id cmpc_ipml_device_ids[] = { ...@@ -996,7 +993,6 @@ static const struct acpi_device_id cmpc_ipml_device_ids[] = {
}; };
static struct acpi_driver cmpc_ipml_acpi_driver = { static struct acpi_driver cmpc_ipml_acpi_driver = {
.owner = THIS_MODULE,
.name = "cmpc", .name = "cmpc",
.class = "cmpc", .class = "cmpc",
.ids = cmpc_ipml_device_ids, .ids = cmpc_ipml_device_ids,
...@@ -1064,7 +1060,6 @@ static const struct acpi_device_id cmpc_keys_device_ids[] = { ...@@ -1064,7 +1060,6 @@ static const struct acpi_device_id cmpc_keys_device_ids[] = {
}; };
static struct acpi_driver cmpc_keys_acpi_driver = { static struct acpi_driver cmpc_keys_acpi_driver = {
.owner = THIS_MODULE,
.name = "cmpc_keys", .name = "cmpc_keys",
.class = "cmpc_keys", .class = "cmpc_keys",
.ids = cmpc_keys_device_ids, .ids = cmpc_keys_device_ids,
......
...@@ -295,7 +295,6 @@ static struct acpi_driver rbtn_driver = { ...@@ -295,7 +295,6 @@ static struct acpi_driver rbtn_driver = {
.remove = rbtn_remove, .remove = rbtn_remove,
.notify = rbtn_notify, .notify = rbtn_notify,
}, },
.owner = THIS_MODULE,
}; };
......
...@@ -1463,7 +1463,6 @@ MODULE_DEVICE_TABLE(acpi, eeepc_device_ids); ...@@ -1463,7 +1463,6 @@ MODULE_DEVICE_TABLE(acpi, eeepc_device_ids);
static struct acpi_driver eeepc_acpi_driver = { static struct acpi_driver eeepc_acpi_driver = {
.name = EEEPC_LAPTOP_NAME, .name = EEEPC_LAPTOP_NAME,
.class = EEEPC_ACPI_CLASS, .class = EEEPC_ACPI_CLASS,
.owner = THIS_MODULE,
.ids = eeepc_device_ids, .ids = eeepc_device_ids,
.flags = ACPI_DRIVER_ALL_NOTIFY_EVENTS, .flags = ACPI_DRIVER_ALL_NOTIFY_EVENTS,
.ops = { .ops = {
......
...@@ -125,7 +125,6 @@ static const struct acpi_device_id irst_ids[] = { ...@@ -125,7 +125,6 @@ static const struct acpi_device_id irst_ids[] = {
}; };
static struct acpi_driver irst_driver = { static struct acpi_driver irst_driver = {
.owner = THIS_MODULE,
.name = "intel_rapid_start", .name = "intel_rapid_start",
.class = "intel_rapid_start", .class = "intel_rapid_start",
.ids = irst_ids, .ids = irst_ids,
......
...@@ -32,7 +32,6 @@ static const struct acpi_device_id smartconnect_ids[] = { ...@@ -32,7 +32,6 @@ static const struct acpi_device_id smartconnect_ids[] = {
MODULE_DEVICE_TABLE(acpi, smartconnect_ids); MODULE_DEVICE_TABLE(acpi, smartconnect_ids);
static struct acpi_driver smartconnect_driver = { static struct acpi_driver smartconnect_driver = {
.owner = THIS_MODULE,
.name = "intel_smart_connect", .name = "intel_smart_connect",
.class = "intel_smart_connect", .class = "intel_smart_connect",
.ids = smartconnect_ids, .ids = smartconnect_ids,
......
...@@ -790,7 +790,6 @@ static struct acpi_driver acpi_driver = { ...@@ -790,7 +790,6 @@ static struct acpi_driver acpi_driver = {
.remove = acpi_remove, .remove = acpi_remove,
.notify = acpi_notify, .notify = acpi_notify,
}, },
.owner = THIS_MODULE,
}; };
static int __init acpi_init(void) static int __init acpi_init(void)
......
...@@ -3303,7 +3303,6 @@ static struct acpi_driver sony_nc_driver = { ...@@ -3303,7 +3303,6 @@ static struct acpi_driver sony_nc_driver = {
.name = SONY_NC_DRIVER_NAME, .name = SONY_NC_DRIVER_NAME,
.class = SONY_NC_CLASS, .class = SONY_NC_CLASS,
.ids = sony_nc_device_ids, .ids = sony_nc_device_ids,
.owner = THIS_MODULE,
.ops = { .ops = {
.add = sony_nc_add, .add = sony_nc_add,
.remove = sony_nc_remove, .remove = sony_nc_remove,
...@@ -4844,7 +4843,6 @@ static struct acpi_driver sony_pic_driver = { ...@@ -4844,7 +4843,6 @@ static struct acpi_driver sony_pic_driver = {
.name = SONY_PIC_DRIVER_NAME, .name = SONY_PIC_DRIVER_NAME,
.class = SONY_PIC_CLASS, .class = SONY_PIC_CLASS,
.ids = sony_pic_device_ids, .ids = sony_pic_device_ids,
.owner = THIS_MODULE,
.ops = { .ops = {
.add = sony_pic_add, .add = sony_pic_add,
.remove = sony_pic_remove, .remove = sony_pic_remove,
......
...@@ -3583,7 +3583,6 @@ static SIMPLE_DEV_PM_OPS(toshiba_acpi_pm, ...@@ -3583,7 +3583,6 @@ static SIMPLE_DEV_PM_OPS(toshiba_acpi_pm,
static struct acpi_driver toshiba_acpi_driver = { static struct acpi_driver toshiba_acpi_driver = {
.name = "Toshiba ACPI driver", .name = "Toshiba ACPI driver",
.owner = THIS_MODULE,
.ids = toshiba_device_ids, .ids = toshiba_device_ids,
.flags = ACPI_DRIVER_ALL_NOTIFY_EVENTS, .flags = ACPI_DRIVER_ALL_NOTIFY_EVENTS,
.ops = { .ops = {
......
...@@ -59,7 +59,6 @@ static struct acpi_driver toshiba_bt_rfkill_driver = { ...@@ -59,7 +59,6 @@ static struct acpi_driver toshiba_bt_rfkill_driver = {
.remove = toshiba_bt_rfkill_remove, .remove = toshiba_bt_rfkill_remove,
.notify = toshiba_bt_rfkill_notify, .notify = toshiba_bt_rfkill_notify,
}, },
.owner = THIS_MODULE,
.drv.pm = &toshiba_bt_pm, .drv.pm = &toshiba_bt_pm,
}; };
......
...@@ -251,7 +251,6 @@ MODULE_DEVICE_TABLE(acpi, haps_device_ids); ...@@ -251,7 +251,6 @@ MODULE_DEVICE_TABLE(acpi, haps_device_ids);
static struct acpi_driver toshiba_haps_driver = { static struct acpi_driver toshiba_haps_driver = {
.name = "Toshiba HAPS", .name = "Toshiba HAPS",
.owner = THIS_MODULE,
.ids = haps_device_ids, .ids = haps_device_ids,
.flags = ACPI_DRIVER_ALL_NOTIFY_EVENTS, .flags = ACPI_DRIVER_ALL_NOTIFY_EVENTS,
.ops = { .ops = {
......
...@@ -110,7 +110,6 @@ static void wl_remove(struct acpi_device *device) ...@@ -110,7 +110,6 @@ static void wl_remove(struct acpi_device *device)
static struct acpi_driver wl_driver = { static struct acpi_driver wl_driver = {
.name = "wireless-hotkey", .name = "wireless-hotkey",
.owner = THIS_MODULE,
.ids = wl_ids, .ids = wl_ids,
.ops = { .ops = {
.add = wl_add, .add = wl_add,
......
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
# #
config ISAPNP config ISAPNP
bool "ISA Plug and Play support" bool "ISA Plug and Play support"
depends on ISA || COMPILE_TEST depends on ISA || (HAS_IOPORT && COMPILE_TEST)
help help
Say Y here if you would like support for ISA Plug and Play devices. Say Y here if you would like support for ISA Plug and Play devices.
Some information is in <file:Documentation/userspace-api/isapnp.rst>. Some information is in <file:Documentation/userspace-api/isapnp.rst>.
......
...@@ -120,7 +120,6 @@ static struct acpi_driver ptp_vmw_acpi_driver = { ...@@ -120,7 +120,6 @@ static struct acpi_driver ptp_vmw_acpi_driver = {
.add = ptp_vmw_acpi_add, .add = ptp_vmw_acpi_add,
.remove = ptp_vmw_acpi_remove .remove = ptp_vmw_acpi_remove
}, },
.owner = THIS_MODULE
}; };
static int __init ptp_vmw_init(void) static int __init ptp_vmw_init(void)
......
...@@ -705,6 +705,7 @@ static const struct acpi_device_id int3400_thermal_match[] = { ...@@ -705,6 +705,7 @@ static const struct acpi_device_id int3400_thermal_match[] = {
{"INTC1040", 0}, {"INTC1040", 0},
{"INTC1041", 0}, {"INTC1041", 0},
{"INTC1042", 0}, {"INTC1042", 0},
{"INTC1068", 0},
{"INTC10A0", 0}, {"INTC10A0", 0},
{} {}
}; };
......
...@@ -284,6 +284,7 @@ static const struct acpi_device_id int3403_device_ids[] = { ...@@ -284,6 +284,7 @@ static const struct acpi_device_id int3403_device_ids[] = {
{"INTC1043", 0}, {"INTC1043", 0},
{"INTC1046", 0}, {"INTC1046", 0},
{"INTC1062", 0}, {"INTC1062", 0},
{"INTC1069", 0},
{"INTC10A1", 0}, {"INTC10A1", 0},
{"", 0}, {"", 0},
}; };
......
...@@ -86,7 +86,6 @@ static const struct acpi_device_id vmgenid_ids[] = { ...@@ -86,7 +86,6 @@ static const struct acpi_device_id vmgenid_ids[] = {
static struct acpi_driver vmgenid_driver = { static struct acpi_driver vmgenid_driver = {
.name = "vmgenid", .name = "vmgenid",
.ids = vmgenid_ids, .ids = vmgenid_ids,
.owner = THIS_MODULE,
.ops = { .ops = {
.add = vmgenid_add, .add = vmgenid_add,
.notify = vmgenid_notify .notify = vmgenid_notify
......
...@@ -9,8 +9,13 @@ ...@@ -9,8 +9,13 @@
#ifndef __ACPI_BUS_H__ #ifndef __ACPI_BUS_H__
#define __ACPI_BUS_H__ #define __ACPI_BUS_H__
#include <linux/completion.h>
#include <linux/container_of.h>
#include <linux/device.h> #include <linux/device.h>
#include <linux/kobject.h>
#include <linux/mutex.h>
#include <linux/property.h> #include <linux/property.h>
#include <linux/types.h>
struct acpi_handle_list { struct acpi_handle_list {
u32 count; u32 count;
...@@ -124,8 +129,8 @@ static inline struct acpi_hotplug_profile *to_acpi_hotplug_profile( ...@@ -124,8 +129,8 @@ static inline struct acpi_hotplug_profile *to_acpi_hotplug_profile(
} }
struct acpi_scan_handler { struct acpi_scan_handler {
const struct acpi_device_id *ids;
struct list_head list_node; struct list_head list_node;
const struct acpi_device_id *ids;
bool (*match)(const char *idstr, const struct acpi_device_id **matchid); bool (*match)(const char *idstr, const struct acpi_device_id **matchid);
int (*attach)(struct acpi_device *dev, const struct acpi_device_id *id); int (*attach)(struct acpi_device *dev, const struct acpi_device_id *id);
void (*detach)(struct acpi_device *dev); void (*detach)(struct acpi_device *dev);
...@@ -139,11 +144,15 @@ struct acpi_scan_handler { ...@@ -139,11 +144,15 @@ struct acpi_scan_handler {
* -------------------- * --------------------
*/ */
typedef int (*acpi_hp_notify) (struct acpi_device *, u32);
typedef void (*acpi_hp_uevent) (struct acpi_device *, u32);
typedef void (*acpi_hp_fixup) (struct acpi_device *);
struct acpi_hotplug_context { struct acpi_hotplug_context {
struct acpi_device *self; struct acpi_device *self;
int (*notify)(struct acpi_device *, u32); acpi_hp_notify notify;
void (*uevent)(struct acpi_device *, u32); acpi_hp_uevent uevent;
void (*fixup)(struct acpi_device *); acpi_hp_fixup fixup;
}; };
/* /*
...@@ -170,7 +179,6 @@ struct acpi_driver { ...@@ -170,7 +179,6 @@ struct acpi_driver {
unsigned int flags; unsigned int flags;
struct acpi_device_ops ops; struct acpi_device_ops ops;
struct device_driver drv; struct device_driver drv;
struct module *owner;
}; };
/* /*
...@@ -269,6 +277,7 @@ struct acpi_device_power_flags { ...@@ -269,6 +277,7 @@ struct acpi_device_power_flags {
}; };
struct acpi_device_power_state { struct acpi_device_power_state {
struct list_head resources; /* Power resources referenced */
struct { struct {
u8 valid:1; u8 valid:1;
u8 explicit_set:1; /* _PSx present? */ u8 explicit_set:1; /* _PSx present? */
...@@ -276,7 +285,6 @@ struct acpi_device_power_state { ...@@ -276,7 +285,6 @@ struct acpi_device_power_state {
} flags; } flags;
int power; /* % Power (compared to D0) */ int power; /* % Power (compared to D0) */
int latency; /* Dx->D0 time (microseconds) */ int latency; /* Dx->D0 time (microseconds) */
struct list_head resources; /* Power resources referenced */
}; };
struct acpi_device_power { struct acpi_device_power {
...@@ -342,16 +350,16 @@ struct acpi_device_wakeup { ...@@ -342,16 +350,16 @@ struct acpi_device_wakeup {
}; };
struct acpi_device_physical_node { struct acpi_device_physical_node {
unsigned int node_id;
struct list_head node; struct list_head node;
struct device *dev; struct device *dev;
unsigned int node_id;
bool put_online:1; bool put_online:1;
}; };
struct acpi_device_properties { struct acpi_device_properties {
struct list_head list;
const guid_t *guid; const guid_t *guid;
union acpi_object *properties; union acpi_object *properties;
struct list_head list;
void **bufs; void **bufs;
}; };
...@@ -488,12 +496,12 @@ struct acpi_device { ...@@ -488,12 +496,12 @@ struct acpi_device {
/* Non-device subnode */ /* Non-device subnode */
struct acpi_data_node { struct acpi_data_node {
struct list_head sibling;
const char *name; const char *name;
acpi_handle handle; acpi_handle handle;
struct fwnode_handle fwnode; struct fwnode_handle fwnode;
struct fwnode_handle *parent; struct fwnode_handle *parent;
struct acpi_device_data data; struct acpi_device_data data;
struct list_head sibling;
struct kobject kobj; struct kobject kobj;
struct completion kobj_done; struct completion kobj_done;
}; };
...@@ -578,8 +586,7 @@ static inline void acpi_set_hp_context(struct acpi_device *adev, ...@@ -578,8 +586,7 @@ static inline void acpi_set_hp_context(struct acpi_device *adev,
void acpi_initialize_hp_context(struct acpi_device *adev, void acpi_initialize_hp_context(struct acpi_device *adev,
struct acpi_hotplug_context *hp, struct acpi_hotplug_context *hp,
int (*notify)(struct acpi_device *, u32), acpi_hp_notify notify, acpi_hp_uevent uevent);
void (*uevent)(struct acpi_device *, u32));
/* acpi_device.dev.bus == &acpi_bus_type */ /* acpi_device.dev.bus == &acpi_bus_type */
extern const struct bus_type acpi_bus_type; extern const struct bus_type acpi_bus_type;
...@@ -656,7 +663,12 @@ void acpi_scan_lock_release(void); ...@@ -656,7 +663,12 @@ void acpi_scan_lock_release(void);
void acpi_lock_hp_context(void); void acpi_lock_hp_context(void);
void acpi_unlock_hp_context(void); void acpi_unlock_hp_context(void);
int acpi_scan_add_handler(struct acpi_scan_handler *handler); int acpi_scan_add_handler(struct acpi_scan_handler *handler);
int acpi_bus_register_driver(struct acpi_driver *driver); /*
* use a macro to avoid include chaining to get THIS_MODULE
*/
#define acpi_bus_register_driver(drv) \
__acpi_bus_register_driver(drv, THIS_MODULE)
int __acpi_bus_register_driver(struct acpi_driver *driver, struct module *owner);
void acpi_bus_unregister_driver(struct acpi_driver *driver); void acpi_bus_unregister_driver(struct acpi_driver *driver);
int acpi_bus_scan(acpi_handle handle); int acpi_bus_scan(acpi_handle handle);
void acpi_bus_trim(struct acpi_device *start); void acpi_bus_trim(struct acpi_device *start);
......
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
/* Current ACPICA subsystem version in YYYYMMDD format */ /* Current ACPICA subsystem version in YYYYMMDD format */
#define ACPI_CA_VERSION 0x20230628 #define ACPI_CA_VERSION 0x20240322
#include <acpi/acconfig.h> #include <acpi/acconfig.h>
#include <acpi/actypes.h> #include <acpi/actypes.h>
......
...@@ -571,8 +571,6 @@ struct acpi_cedt_cxims { ...@@ -571,8 +571,6 @@ struct acpi_cedt_cxims {
struct acpi_cedt_rdpas { struct acpi_cedt_rdpas {
struct acpi_cedt_header header; struct acpi_cedt_header header;
u8 reserved1;
u16 length;
u16 segment; u16 segment;
u16 bdf; u16 bdf;
u8 protocol; u8 protocol;
...@@ -1096,6 +1094,12 @@ enum acpi_einj_command_status { ...@@ -1096,6 +1094,12 @@ enum acpi_einj_command_status {
#define ACPI_EINJ_PLATFORM_CORRECTABLE (1<<9) #define ACPI_EINJ_PLATFORM_CORRECTABLE (1<<9)
#define ACPI_EINJ_PLATFORM_UNCORRECTABLE (1<<10) #define ACPI_EINJ_PLATFORM_UNCORRECTABLE (1<<10)
#define ACPI_EINJ_PLATFORM_FATAL (1<<11) #define ACPI_EINJ_PLATFORM_FATAL (1<<11)
#define ACPI_EINJ_CXL_CACHE_CORRECTABLE (1<<12)
#define ACPI_EINJ_CXL_CACHE_UNCORRECTABLE (1<<13)
#define ACPI_EINJ_CXL_CACHE_FATAL (1<<14)
#define ACPI_EINJ_CXL_MEM_CORRECTABLE (1<<15)
#define ACPI_EINJ_CXL_MEM_UNCORRECTABLE (1<<16)
#define ACPI_EINJ_CXL_MEM_FATAL (1<<17)
#define ACPI_EINJ_VENDOR_DEFINED (1<<31) #define ACPI_EINJ_VENDOR_DEFINED (1<<31)
/******************************************************************************* /*******************************************************************************
......
This diff is collapsed.
...@@ -192,7 +192,8 @@ enum acpi_srat_type { ...@@ -192,7 +192,8 @@ enum acpi_srat_type {
ACPI_SRAT_TYPE_GIC_ITS_AFFINITY = 4, /* ACPI 6.2 */ ACPI_SRAT_TYPE_GIC_ITS_AFFINITY = 4, /* ACPI 6.2 */
ACPI_SRAT_TYPE_GENERIC_AFFINITY = 5, /* ACPI 6.3 */ ACPI_SRAT_TYPE_GENERIC_AFFINITY = 5, /* ACPI 6.3 */
ACPI_SRAT_TYPE_GENERIC_PORT_AFFINITY = 6, /* ACPI 6.4 */ ACPI_SRAT_TYPE_GENERIC_PORT_AFFINITY = 6, /* ACPI 6.4 */
ACPI_SRAT_TYPE_RESERVED = 7 /* 7 and greater are reserved */ ACPI_SRAT_TYPE_RINTC_AFFINITY = 7, /* ACPI 6.6 */
ACPI_SRAT_TYPE_RESERVED = 8 /* 8 and greater are reserved */
}; };
/* /*
...@@ -296,6 +297,21 @@ struct acpi_srat_generic_affinity { ...@@ -296,6 +297,21 @@ struct acpi_srat_generic_affinity {
#define ACPI_SRAT_GENERIC_AFFINITY_ENABLED (1) /* 00: Use affinity structure */ #define ACPI_SRAT_GENERIC_AFFINITY_ENABLED (1) /* 00: Use affinity structure */
#define ACPI_SRAT_ARCHITECTURAL_TRANSACTIONS (1<<1) /* ACPI 6.4 */ #define ACPI_SRAT_ARCHITECTURAL_TRANSACTIONS (1<<1) /* ACPI 6.4 */
/* 7: RINTC Affinity Structure(ACPI 6.6) */
struct acpi_srat_rintc_affinity {
struct acpi_subtable_header header;
u16 reserved;
u32 proximity_domain;
u32 acpi_processor_uid;
u32 flags;
u32 clock_domain;
};
/* Flags for struct acpi_srat_rintc_affinity */
#define ACPI_SRAT_RINTC_ENABLED (1) /* 00: Use affinity structure */
/******************************************************************************* /*******************************************************************************
* *
* STAO - Status Override Table (_STA override) - ACPI 6.0 * STAO - Status Override Table (_STA override) - ACPI 6.0
......
/* SPDX-License-Identifier: GPL-2.0-only */
/*
* Copyright(c) 2023-2024 Intel Corporation
*
* Authors: Cezary Rojewski <cezary.rojewski@intel.com>
* Amadeusz Slawinski <amadeuszx.slawinski@linux.intel.com>
*/
#ifndef __ACPI_NHLT_H__
#define __ACPI_NHLT_H__
#include <linux/acpi.h>
#include <linux/kconfig.h>
#include <linux/overflow.h>
#include <linux/types.h>
#define __acpi_nhlt_endpoint_config(ep) ((void *)((ep) + 1))
#define __acpi_nhlt_config_caps(cfg) ((void *)((cfg) + 1))
/**
* acpi_nhlt_endpoint_fmtscfg - Get the formats configuration space.
* @ep: the endpoint to retrieve the space for.
*
* Return: A pointer to the formats configuration space.
*/
static inline struct acpi_nhlt_formats_config *
acpi_nhlt_endpoint_fmtscfg(const struct acpi_nhlt_endpoint *ep)
{
struct acpi_nhlt_config *cfg = __acpi_nhlt_endpoint_config(ep);
return (struct acpi_nhlt_formats_config *)((u8 *)(cfg + 1) + cfg->capabilities_size);
}
#define __acpi_nhlt_first_endpoint(tb) \
((void *)(tb + 1))
#define __acpi_nhlt_next_endpoint(ep) \
((void *)((u8 *)(ep) + (ep)->length))
#define __acpi_nhlt_get_endpoint(tb, ep, i) \
((i) ? __acpi_nhlt_next_endpoint(ep) : __acpi_nhlt_first_endpoint(tb))
#define __acpi_nhlt_first_fmtcfg(fmts) \
((void *)(fmts + 1))
#define __acpi_nhlt_next_fmtcfg(fmt) \
((void *)((u8 *)((fmt) + 1) + (fmt)->config.capabilities_size))
#define __acpi_nhlt_get_fmtcfg(fmts, fmt, i) \
((i) ? __acpi_nhlt_next_fmtcfg(fmt) : __acpi_nhlt_first_fmtcfg(fmts))
/*
* The for_each_nhlt_*() macros rely on an iterator to deal with the
* variable length of each endpoint structure and the possible presence
* of an OED-Config used by Windows only.
*/
/**
* for_each_nhlt_endpoint - Iterate over endpoints in a NHLT table.
* @tb: the pointer to a NHLT table.
* @ep: the pointer to endpoint to use as loop cursor.
*/
#define for_each_nhlt_endpoint(tb, ep) \
for (unsigned int __i = 0; \
__i < (tb)->endpoints_count && \
(ep = __acpi_nhlt_get_endpoint(tb, ep, __i)); \
__i++)
/**
* for_each_nhlt_fmtcfg - Iterate over format configurations.
* @fmts: the pointer to formats configuration space.
* @fmt: the pointer to format to use as loop cursor.
*/
#define for_each_nhlt_fmtcfg(fmts, fmt) \
for (unsigned int __i = 0; \
__i < (fmts)->formats_count && \
(fmt = __acpi_nhlt_get_fmtcfg(fmts, fmt, __i)); \
__i++)
/**
* for_each_nhlt_endpoint_fmtcfg - Iterate over format configurations in an endpoint.
* @ep: the pointer to an endpoint.
* @fmt: the pointer to format to use as loop cursor.
*/
#define for_each_nhlt_endpoint_fmtcfg(ep, fmt) \
for_each_nhlt_fmtcfg(acpi_nhlt_endpoint_fmtscfg(ep), fmt)
#if IS_ENABLED(CONFIG_ACPI_NHLT)
/*
* System-wide pointer to the first NHLT table.
*
* A sound driver may utilize acpi_nhlt_get/put_gbl_table() on its
* initialization and removal respectively to avoid excessive mapping
* and unmapping of the memory occupied by the table between streaming
* operations.
*/
acpi_status acpi_nhlt_get_gbl_table(void);
void acpi_nhlt_put_gbl_table(void);
bool acpi_nhlt_endpoint_match(const struct acpi_nhlt_endpoint *ep,
int link_type, int dev_type, int dir, int bus_id);
struct acpi_nhlt_endpoint *
acpi_nhlt_tb_find_endpoint(const struct acpi_table_nhlt *tb,
int link_type, int dev_type, int dir, int bus_id);
struct acpi_nhlt_endpoint *
acpi_nhlt_find_endpoint(int link_type, int dev_type, int dir, int bus_id);
struct acpi_nhlt_format_config *
acpi_nhlt_endpoint_find_fmtcfg(const struct acpi_nhlt_endpoint *ep,
u16 ch, u32 rate, u16 vbps, u16 bps);
struct acpi_nhlt_format_config *
acpi_nhlt_tb_find_fmtcfg(const struct acpi_table_nhlt *tb,
int link_type, int dev_type, int dir, int bus_id,
u16 ch, u32 rate, u16 vpbs, u16 bps);
struct acpi_nhlt_format_config *
acpi_nhlt_find_fmtcfg(int link_type, int dev_type, int dir, int bus_id,
u16 ch, u32 rate, u16 vpbs, u16 bps);
int acpi_nhlt_endpoint_mic_count(const struct acpi_nhlt_endpoint *ep);
#else /* !CONFIG_ACPI_NHLT */
static inline acpi_status acpi_nhlt_get_gbl_table(void)
{
return AE_NOT_FOUND;
}
static inline void acpi_nhlt_put_gbl_table(void)
{
}
static inline bool
acpi_nhlt_endpoint_match(const struct acpi_nhlt_endpoint *ep,
int link_type, int dev_type, int dir, int bus_id)
{
return false;
}
static inline struct acpi_nhlt_endpoint *
acpi_nhlt_tb_find_endpoint(const struct acpi_table_nhlt *tb,
int link_type, int dev_type, int dir, int bus_id)
{
return NULL;
}
static inline struct acpi_nhlt_format_config *
acpi_nhlt_endpoint_find_fmtcfg(const struct acpi_nhlt_endpoint *ep,
u16 ch, u32 rate, u16 vbps, u16 bps)
{
return NULL;
}
static inline struct acpi_nhlt_format_config *
acpi_nhlt_tb_find_fmtcfg(const struct acpi_table_nhlt *tb,
int link_type, int dev_type, int dir, int bus_id,
u16 ch, u32 rate, u16 vpbs, u16 bps)
{
return NULL;
}
static inline int acpi_nhlt_endpoint_mic_count(const struct acpi_nhlt_endpoint *ep)
{
return 0;
}
static inline struct acpi_nhlt_endpoint *
acpi_nhlt_find_endpoint(int link_type, int dev_type, int dir, int bus_id)
{
return NULL;
}
static inline struct acpi_nhlt_format_config *
acpi_nhlt_find_fmtcfg(int link_type, int dev_type, int dir, int bus_id,
u16 ch, u32 rate, u16 vpbs, u16 bps)
{
return NULL;
}
#endif /* CONFIG_ACPI_NHLT */
#endif /* __ACPI_NHLT_H__ */
...@@ -242,9 +242,6 @@ static inline bool acpi_gicc_is_usable(struct acpi_madt_generic_interrupt *gicc) ...@@ -242,9 +242,6 @@ static inline bool acpi_gicc_is_usable(struct acpi_madt_generic_interrupt *gicc)
return gicc->flags & ACPI_MADT_ENABLED; return gicc->flags & ACPI_MADT_ENABLED;
} }
/* the following numa functions are architecture-dependent */
void acpi_numa_slit_init (struct acpi_table_slit *slit);
#if defined(CONFIG_X86) || defined(CONFIG_LOONGARCH) #if defined(CONFIG_X86) || defined(CONFIG_LOONGARCH)
void acpi_numa_processor_affinity_init (struct acpi_srat_cpu_affinity *pa); void acpi_numa_processor_affinity_init (struct acpi_srat_cpu_affinity *pa);
#else #else
...@@ -267,8 +264,6 @@ static inline void ...@@ -267,8 +264,6 @@ static inline void
acpi_numa_gicc_affinity_init(struct acpi_srat_gicc_affinity *pa) { } acpi_numa_gicc_affinity_init(struct acpi_srat_gicc_affinity *pa) { }
#endif #endif
int acpi_numa_memory_affinity_init (struct acpi_srat_mem_affinity *ma);
#ifndef PHYS_CPUID_INVALID #ifndef PHYS_CPUID_INVALID
typedef u32 phys_cpuid_t; typedef u32 phys_cpuid_t;
#define PHYS_CPUID_INVALID (phys_cpuid_t)(-1) #define PHYS_CPUID_INVALID (phys_cpuid_t)(-1)
...@@ -421,7 +416,7 @@ extern char *wmi_get_acpi_device_uid(const char *guid); ...@@ -421,7 +416,7 @@ extern char *wmi_get_acpi_device_uid(const char *guid);
extern char acpi_video_backlight_string[]; extern char acpi_video_backlight_string[];
extern long acpi_is_video_device(acpi_handle handle); extern long acpi_is_video_device(acpi_handle handle);
extern int acpi_blacklisted(void);
extern void acpi_osi_setup(char *str); extern void acpi_osi_setup(char *str);
extern bool acpi_osi_is_win8(void); extern bool acpi_osi_is_win8(void);
...@@ -573,9 +568,13 @@ acpi_status acpi_run_osc(acpi_handle handle, struct acpi_osc_context *context); ...@@ -573,9 +568,13 @@ acpi_status acpi_run_osc(acpi_handle handle, struct acpi_osc_context *context);
#define OSC_SB_CPCV2_SUPPORT 0x00000040 #define OSC_SB_CPCV2_SUPPORT 0x00000040
#define OSC_SB_PCLPI_SUPPORT 0x00000080 #define OSC_SB_PCLPI_SUPPORT 0x00000080
#define OSC_SB_OSLPI_SUPPORT 0x00000100 #define OSC_SB_OSLPI_SUPPORT 0x00000100
#define OSC_SB_FAST_THERMAL_SAMPLING_SUPPORT 0x00000200
#define OSC_SB_OVER_16_PSTATES_SUPPORT 0x00000400
#define OSC_SB_GED_SUPPORT 0x00000800
#define OSC_SB_CPC_DIVERSE_HIGH_SUPPORT 0x00001000 #define OSC_SB_CPC_DIVERSE_HIGH_SUPPORT 0x00001000
#define OSC_SB_GENERIC_INITIATOR_SUPPORT 0x00002000 #define OSC_SB_IRQ_RESOURCE_SOURCE_SUPPORT 0x00002000
#define OSC_SB_CPC_FLEXIBLE_ADR_SPACE 0x00004000 #define OSC_SB_CPC_FLEXIBLE_ADR_SPACE 0x00004000
#define OSC_SB_GENERIC_INITIATOR_SUPPORT 0x00020000
#define OSC_SB_NATIVE_USB4_SUPPORT 0x00040000 #define OSC_SB_NATIVE_USB4_SUPPORT 0x00040000
#define OSC_SB_PRM_SUPPORT 0x00200000 #define OSC_SB_PRM_SUPPORT 0x00200000
#define OSC_SB_FFH_OPR_SUPPORT 0x00400000 #define OSC_SB_FFH_OPR_SUPPORT 0x00400000
......
...@@ -36,12 +36,7 @@ int memory_add_physaddr_to_nid(u64 start); ...@@ -36,12 +36,7 @@ int memory_add_physaddr_to_nid(u64 start);
int phys_to_target_node(u64 start); int phys_to_target_node(u64 start);
#endif #endif
#ifndef numa_fill_memblks int numa_fill_memblks(u64 start, u64 end);
static inline int __init numa_fill_memblks(u64 start, u64 end)
{
return NUMA_NO_MEMBLK;
}
#endif
#else /* !CONFIG_NUMA */ #else /* !CONFIG_NUMA */
static inline int numa_nearest_node(int node, unsigned int state) static inline int numa_nearest_node(int node, unsigned int state)
......
...@@ -174,6 +174,8 @@ void print_cap(struct pfru_update_cap_info *cap) ...@@ -174,6 +174,8 @@ void print_cap(struct pfru_update_cap_info *cap)
exit(1); exit(1);
} }
printf("update capability:%d\n", cap->update_cap);
uuid_unparse(cap->code_type, uuid); uuid_unparse(cap->code_type, uuid);
printf("code injection image type:%s\n", uuid); printf("code injection image type:%s\n", uuid);
printf("fw_version:%d\n", cap->fw_version); printf("fw_version:%d\n", cap->fw_version);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment