mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-04 01:24:12 +08:00
097e727b58
The inclusion of linux/arm-smccc.h in acpi_ffh is unnecessary and can be even termed wrong. It is needed in the arm64 architecture callback implementation and probably is the leftover from the missed cleanup of the initial implementation. Signed-off-by: Sudeep Holla <sudeep.holla@arm.com> Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
54 lines
1.4 KiB
C
54 lines
1.4 KiB
C
// SPDX-License-Identifier: GPL-2.0-only
|
|
/*
|
|
* Author: Sudeep Holla <sudeep.holla@arm.com>
|
|
* Copyright 2022 Arm Limited
|
|
*/
|
|
#include <linux/kernel.h>
|
|
#include <linux/acpi.h>
|
|
#include <linux/completion.h>
|
|
#include <linux/idr.h>
|
|
#include <linux/io.h>
|
|
|
|
static struct acpi_ffh_info ffh_ctx;
|
|
|
|
int __weak acpi_ffh_address_space_arch_setup(void *handler_ctxt,
|
|
void **region_ctxt)
|
|
{
|
|
return -EOPNOTSUPP;
|
|
}
|
|
|
|
int __weak acpi_ffh_address_space_arch_handler(acpi_integer *value,
|
|
void *region_context)
|
|
{
|
|
return -EOPNOTSUPP;
|
|
}
|
|
|
|
static acpi_status
|
|
acpi_ffh_address_space_setup(acpi_handle region_handle, u32 function,
|
|
void *handler_context, void **region_context)
|
|
{
|
|
return acpi_ffh_address_space_arch_setup(handler_context,
|
|
region_context);
|
|
}
|
|
|
|
static acpi_status
|
|
acpi_ffh_address_space_handler(u32 function, acpi_physical_address addr,
|
|
u32 bits, acpi_integer *value,
|
|
void *handler_context, void *region_context)
|
|
{
|
|
return acpi_ffh_address_space_arch_handler(value, region_context);
|
|
}
|
|
|
|
void __init acpi_init_ffh(void)
|
|
{
|
|
acpi_status status;
|
|
|
|
status = acpi_install_address_space_handler(ACPI_ROOT_OBJECT,
|
|
ACPI_ADR_SPACE_FIXED_HARDWARE,
|
|
&acpi_ffh_address_space_handler,
|
|
&acpi_ffh_address_space_setup,
|
|
&ffh_ctx);
|
|
if (ACPI_FAILURE(status))
|
|
pr_alert("OperationRegion handler could not be installed\n");
|
|
}
|