56 lines
1.4 KiB
C
56 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>
|
||
|
|
||
|
#include <linux/arm-smccc.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");
|
||
|
}
|