Commit 0960a3cb authored by Rafael J. Wysocki's avatar Rafael J. Wysocki

Merge branches 'acpi-scan', 'acpi-tad', 'acpi-extlog' and 'acpi-misc'

Merge ACPI device enumeration changes, ACPI TAD and extlog drivers
updates, and miscellaneous ACPI-related changes for 6.6-rc1:

 - Defer enumeration of devices with _DEP pointing to IVSC (Wentong Wu).

 - Install SystemCMOS address space handler for ACPI000E (TAD) to meet
   platform firmware expectations on some platforms (Zhang Rui).

 - Fix finding the generic error data in the ACPi extlog driver for
   compatibility with old and new firmware interface versions (Xiaochun
   Lee).

 - Remove assorted unused declarations of functions (Yue Haibing).

 - Move AMBA bus scan handling into arm64 specific directory (Sudeep
   Holla).

* acpi-scan:
  ACPI: scan: Defer enumeration of devices with a _DEP pointing to IVSC device

* acpi-tad:
  ACPI: TAD: Install SystemCMOS address space handler for ACPI000E

* acpi-extlog:
  ACPI: extlog: Fix finding the generic error data for v3 structure

* acpi-misc:
  ACPI: Remove assorted unused declarations of functions
  ACPI: Remove unused extern declaration acpi_paddr_to_node()
  ACPI: Move AMBA bus scan handling into arm64 specific directory
...@@ -50,7 +50,6 @@ acpi-$(CONFIG_PCI) += acpi_lpss.o ...@@ -50,7 +50,6 @@ 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
acpi-$(CONFIG_ARM_AMBA) += acpi_amba.o
acpi-y += power.o acpi-y += power.o
acpi-y += event.o acpi-y += event.o
acpi-y += evged.o acpi-y += evged.o
......
...@@ -51,12 +51,11 @@ acpi_cmos_rtc_space_handler(u32 function, acpi_physical_address address, ...@@ -51,12 +51,11 @@ acpi_cmos_rtc_space_handler(u32 function, acpi_physical_address address,
return AE_OK; return AE_OK;
} }
static int acpi_install_cmos_rtc_space_handler(struct acpi_device *adev, int acpi_install_cmos_rtc_space_handler(acpi_handle handle)
const struct acpi_device_id *id)
{ {
acpi_status status; acpi_status status;
status = acpi_install_address_space_handler(adev->handle, status = acpi_install_address_space_handler(handle,
ACPI_ADR_SPACE_CMOS, ACPI_ADR_SPACE_CMOS,
&acpi_cmos_rtc_space_handler, &acpi_cmos_rtc_space_handler,
NULL, NULL); NULL, NULL);
...@@ -67,18 +66,30 @@ static int acpi_install_cmos_rtc_space_handler(struct acpi_device *adev, ...@@ -67,18 +66,30 @@ static int acpi_install_cmos_rtc_space_handler(struct acpi_device *adev,
return 1; return 1;
} }
EXPORT_SYMBOL_GPL(acpi_install_cmos_rtc_space_handler);
static void acpi_remove_cmos_rtc_space_handler(struct acpi_device *adev) void acpi_remove_cmos_rtc_space_handler(acpi_handle handle)
{ {
if (ACPI_FAILURE(acpi_remove_address_space_handler(adev->handle, if (ACPI_FAILURE(acpi_remove_address_space_handler(handle,
ACPI_ADR_SPACE_CMOS, &acpi_cmos_rtc_space_handler))) ACPI_ADR_SPACE_CMOS, &acpi_cmos_rtc_space_handler)))
pr_err("Error removing CMOS-RTC region handler\n"); pr_err("Error removing CMOS-RTC region handler\n");
} }
EXPORT_SYMBOL_GPL(acpi_remove_cmos_rtc_space_handler);
static int acpi_cmos_rtc_attach_handler(struct acpi_device *adev, const struct acpi_device_id *id)
{
return acpi_install_cmos_rtc_space_handler(adev->handle);
}
static void acpi_cmos_rtc_detach_handler(struct acpi_device *adev)
{
acpi_remove_cmos_rtc_space_handler(adev->handle);
}
static struct acpi_scan_handler cmos_rtc_handler = { static struct acpi_scan_handler cmos_rtc_handler = {
.ids = acpi_cmos_rtc_ids, .ids = acpi_cmos_rtc_ids,
.attach = acpi_install_cmos_rtc_space_handler, .attach = acpi_cmos_rtc_attach_handler,
.detach = acpi_remove_cmos_rtc_space_handler, .detach = acpi_cmos_rtc_detach_handler,
}; };
void __init acpi_cmos_rtc_init(void) void __init acpi_cmos_rtc_init(void)
......
...@@ -172,7 +172,7 @@ static int extlog_print(struct notifier_block *nb, unsigned long val, ...@@ -172,7 +172,7 @@ static int extlog_print(struct notifier_block *nb, unsigned long val,
fru_text = ""; fru_text = "";
sec_type = (guid_t *)gdata->section_type; sec_type = (guid_t *)gdata->section_type;
if (guid_equal(sec_type, &CPER_SEC_PLATFORM_MEM)) { if (guid_equal(sec_type, &CPER_SEC_PLATFORM_MEM)) {
struct cper_sec_mem_err *mem = (void *)(gdata + 1); struct cper_sec_mem_err *mem = acpi_hest_get_payload(gdata);
if (gdata->error_data_length >= sizeof(*mem)) if (gdata->error_data_length >= sizeof(*mem))
trace_extlog_mem_event(mem, err_seq, fru_id, fru_text, trace_extlog_mem_event(mem, err_seq, fru_id, fru_text,
......
...@@ -557,6 +557,7 @@ static int acpi_tad_disable_timer(struct device *dev, u32 timer_id) ...@@ -557,6 +557,7 @@ static int acpi_tad_disable_timer(struct device *dev, u32 timer_id)
static int acpi_tad_remove(struct platform_device *pdev) static int acpi_tad_remove(struct platform_device *pdev)
{ {
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
acpi_handle handle = ACPI_HANDLE(dev);
struct acpi_tad_driver_data *dd = dev_get_drvdata(dev); struct acpi_tad_driver_data *dd = dev_get_drvdata(dev);
device_init_wakeup(dev, false); device_init_wakeup(dev, false);
...@@ -577,6 +578,7 @@ static int acpi_tad_remove(struct platform_device *pdev) ...@@ -577,6 +578,7 @@ static int acpi_tad_remove(struct platform_device *pdev)
pm_runtime_put_sync(dev); pm_runtime_put_sync(dev);
pm_runtime_disable(dev); pm_runtime_disable(dev);
acpi_remove_cmos_rtc_space_handler(handle);
return 0; return 0;
} }
...@@ -589,6 +591,11 @@ static int acpi_tad_probe(struct platform_device *pdev) ...@@ -589,6 +591,11 @@ static int acpi_tad_probe(struct platform_device *pdev)
unsigned long long caps; unsigned long long caps;
int ret; int ret;
ret = acpi_install_cmos_rtc_space_handler(handle);
if (ret < 0) {
dev_info(dev, "Unable to install space handler\n");
return -ENODEV;
}
/* /*
* Initialization failure messages are mostly about firmware issues, so * Initialization failure messages are mostly about firmware issues, so
* print them at the "info" level. * print them at the "info" level.
...@@ -596,22 +603,27 @@ static int acpi_tad_probe(struct platform_device *pdev) ...@@ -596,22 +603,27 @@ static int acpi_tad_probe(struct platform_device *pdev)
status = acpi_evaluate_integer(handle, "_GCP", NULL, &caps); status = acpi_evaluate_integer(handle, "_GCP", NULL, &caps);
if (ACPI_FAILURE(status)) { if (ACPI_FAILURE(status)) {
dev_info(dev, "Unable to get capabilities\n"); dev_info(dev, "Unable to get capabilities\n");
return -ENODEV; ret = -ENODEV;
goto remove_handler;
} }
if (!(caps & ACPI_TAD_AC_WAKE)) { if (!(caps & ACPI_TAD_AC_WAKE)) {
dev_info(dev, "Unsupported capabilities\n"); dev_info(dev, "Unsupported capabilities\n");
return -ENODEV; ret = -ENODEV;
goto remove_handler;
} }
if (!acpi_has_method(handle, "_PRW")) { if (!acpi_has_method(handle, "_PRW")) {
dev_info(dev, "Missing _PRW\n"); dev_info(dev, "Missing _PRW\n");
return -ENODEV; ret = -ENODEV;
goto remove_handler;
} }
dd = devm_kzalloc(dev, sizeof(*dd), GFP_KERNEL); dd = devm_kzalloc(dev, sizeof(*dd), GFP_KERNEL);
if (!dd) if (!dd) {
return -ENOMEM; ret = -ENOMEM;
goto remove_handler;
}
dd->capabilities = caps; dd->capabilities = caps;
dev_set_drvdata(dev, dd); dev_set_drvdata(dev, dd);
...@@ -653,6 +665,11 @@ static int acpi_tad_probe(struct platform_device *pdev) ...@@ -653,6 +665,11 @@ static int acpi_tad_probe(struct platform_device *pdev)
fail: fail:
acpi_tad_remove(pdev); acpi_tad_remove(pdev);
/* Don't fallthrough because cmos rtc space handler is removed in acpi_tad_remove() */
return ret;
remove_handler:
acpi_remove_cmos_rtc_space_handler(handle);
return ret; return ret;
} }
......
...@@ -3,4 +3,5 @@ obj-$(CONFIG_ACPI_AGDI) += agdi.o ...@@ -3,4 +3,5 @@ obj-$(CONFIG_ACPI_AGDI) += agdi.o
obj-$(CONFIG_ACPI_IORT) += iort.o obj-$(CONFIG_ACPI_IORT) += iort.o
obj-$(CONFIG_ACPI_GTDT) += gtdt.o obj-$(CONFIG_ACPI_GTDT) += gtdt.o
obj-$(CONFIG_ACPI_APMT) += apmt.o obj-$(CONFIG_ACPI_APMT) += apmt.o
obj-$(CONFIG_ARM_AMBA) += amba.o
obj-y += dma.o init.o obj-y += dma.o init.o
...@@ -17,7 +17,7 @@ ...@@ -17,7 +17,7 @@
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/module.h> #include <linux/module.h>
#include "internal.h" #include "init.h"
static const struct acpi_device_id amba_id_list[] = { static const struct acpi_device_id amba_id_list[] = {
{"ARMH0061", 0}, /* PL061 GPIO Device */ {"ARMH0061", 0}, /* PL061 GPIO Device */
......
...@@ -10,4 +10,6 @@ void __init acpi_arm_init(void) ...@@ -10,4 +10,6 @@ void __init acpi_arm_init(void)
acpi_apmt_init(); acpi_apmt_init();
if (IS_ENABLED(CONFIG_ACPI_IORT)) if (IS_ENABLED(CONFIG_ACPI_IORT))
acpi_iort_init(); acpi_iort_init();
if (IS_ENABLED(CONFIG_ARM_AMBA))
acpi_amba_init();
} }
...@@ -4,3 +4,4 @@ ...@@ -4,3 +4,4 @@
void __init acpi_agdi_init(void); void __init acpi_agdi_init(void);
void __init acpi_apmt_init(void); void __init acpi_apmt_init(void);
void __init acpi_iort_init(void); void __init acpi_iort_init(void);
void __init acpi_amba_init(void);
...@@ -28,11 +28,6 @@ void acpi_processor_init(void); ...@@ -28,11 +28,6 @@ void acpi_processor_init(void);
void acpi_platform_init(void); void acpi_platform_init(void);
void acpi_pnp_init(void); void acpi_pnp_init(void);
void acpi_int340x_thermal_init(void); void acpi_int340x_thermal_init(void);
#ifdef CONFIG_ARM_AMBA
void acpi_amba_init(void);
#else
static inline void acpi_amba_init(void) {}
#endif
int acpi_sysfs_init(void); int acpi_sysfs_init(void);
void acpi_gpe_apply_masked_gpes(void); void acpi_gpe_apply_masked_gpes(void);
void acpi_container_init(void); void acpi_container_init(void);
...@@ -128,7 +123,6 @@ int __acpi_device_uevent_modalias(const struct acpi_device *adev, ...@@ -128,7 +123,6 @@ int __acpi_device_uevent_modalias(const struct acpi_device *adev,
/* -------------------------------------------------------------------------- /* --------------------------------------------------------------------------
Power Resource Power Resource
-------------------------------------------------------------------------- */ -------------------------------------------------------------------------- */
int acpi_power_init(void);
void acpi_power_resources_list_free(struct list_head *list); void acpi_power_resources_list_free(struct list_head *list);
int acpi_extract_power_resources(union acpi_object *package, unsigned int start, int acpi_extract_power_resources(union acpi_object *package, unsigned int start,
struct list_head *list); struct list_head *list);
......
...@@ -795,6 +795,9 @@ static const char * const acpi_ignore_dep_ids[] = { ...@@ -795,6 +795,9 @@ static const char * const acpi_ignore_dep_ids[] = {
/* List of HIDs for which we honor deps of matching ACPI devs, when checking _DEP lists. */ /* List of HIDs for which we honor deps of matching ACPI devs, when checking _DEP lists. */
static const char * const acpi_honor_dep_ids[] = { static const char * const acpi_honor_dep_ids[] = {
"INT3472", /* Camera sensor PMIC / clk and regulator info */ "INT3472", /* Camera sensor PMIC / clk and regulator info */
"INTC1059", /* IVSC (TGL) driver must be loaded to allow i2c access to camera sensors */
"INTC1095", /* IVSC (ADL) driver must be loaded to allow i2c access to camera sensors */
"INTC100A", /* IVSC (RPL) driver must be loaded to allow i2c access to camera sensors */
NULL NULL
}; };
...@@ -2616,7 +2619,6 @@ void __init acpi_scan_init(void) ...@@ -2616,7 +2619,6 @@ void __init acpi_scan_init(void)
acpi_watchdog_init(); acpi_watchdog_init();
acpi_pnp_init(); acpi_pnp_init();
acpi_int340x_thermal_init(); acpi_int340x_thermal_init();
acpi_amba_init();
acpi_init_lpit(); acpi_init_lpit();
acpi_scan_add_handler(&generic_device_handler); acpi_scan_add_handler(&generic_device_handler);
......
...@@ -569,8 +569,6 @@ int acpi_match_device_ids(struct acpi_device *device, ...@@ -569,8 +569,6 @@ int acpi_match_device_ids(struct acpi_device *device,
const struct acpi_device_id *ids); const struct acpi_device_id *ids);
void acpi_set_modalias(struct acpi_device *adev, const char *default_id, void acpi_set_modalias(struct acpi_device *adev, const char *default_id,
char *modalias, size_t len); char *modalias, size_t len);
int acpi_create_dir(struct acpi_device *);
void acpi_remove_dir(struct acpi_device *);
static inline bool acpi_device_enumerated(struct acpi_device *adev) static inline bool acpi_device_enumerated(struct acpi_device *adev)
{ {
...@@ -651,6 +649,8 @@ int acpi_disable_wakeup_device_power(struct acpi_device *dev); ...@@ -651,6 +649,8 @@ int acpi_disable_wakeup_device_power(struct acpi_device *dev);
#ifdef CONFIG_X86 #ifdef CONFIG_X86
bool acpi_device_override_status(struct acpi_device *adev, unsigned long long *status); bool acpi_device_override_status(struct acpi_device *adev, unsigned long long *status);
bool acpi_quirk_skip_acpi_ac_and_battery(void); bool acpi_quirk_skip_acpi_ac_and_battery(void);
int acpi_install_cmos_rtc_space_handler(acpi_handle handle);
void acpi_remove_cmos_rtc_space_handler(acpi_handle handle);
#else #else
static inline bool acpi_device_override_status(struct acpi_device *adev, static inline bool acpi_device_override_status(struct acpi_device *adev,
unsigned long long *status) unsigned long long *status)
...@@ -661,6 +661,13 @@ static inline bool acpi_quirk_skip_acpi_ac_and_battery(void) ...@@ -661,6 +661,13 @@ static inline bool acpi_quirk_skip_acpi_ac_and_battery(void)
{ {
return false; return false;
} }
static inline int acpi_install_cmos_rtc_space_handler(acpi_handle handle)
{
return 1;
}
static inline void acpi_remove_cmos_rtc_space_handler(acpi_handle handle)
{
}
#endif #endif
#if IS_ENABLED(CONFIG_X86_ANDROID_TABLETS) #if IS_ENABLED(CONFIG_X86_ANDROID_TABLETS)
......
...@@ -970,8 +970,6 @@ ACPI_EXTERNAL_RETURN_STATUS(acpi_status ...@@ -970,8 +970,6 @@ ACPI_EXTERNAL_RETURN_STATUS(acpi_status
void **data, void **data,
void (*callback)(void *))) void (*callback)(void *)))
void acpi_run_debugger(char *batch_buffer);
void acpi_set_debugger_thread_id(acpi_thread_id thread_id); void acpi_set_debugger_thread_id(acpi_thread_id thread_id);
#endif /* __ACXFACE_H__ */ #endif /* __ACXFACE_H__ */
...@@ -477,8 +477,6 @@ static inline int acpi_get_node(acpi_handle handle) ...@@ -477,8 +477,6 @@ static inline int acpi_get_node(acpi_handle handle)
return 0; return 0;
} }
#endif #endif
extern int acpi_paddr_to_node(u64 start_addr, u64 size);
extern int pnpacpi_disabled; extern int pnpacpi_disabled;
#define PXM_INVAL (-1) #define PXM_INVAL (-1)
......
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