mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-01 06:43:53 -06:00
acpi: add interface to build device specific AML
There is already ISADeviceClass::build_aml() callback which builds device specific AML blob for some ISA devices. To extend the same idea to other devices, add TYPE_ACPI_DEV_AML_IF Interface that will provide a more generic callback which will be used not only for ISA but other devices. It will allow get rid of some data-mining and ad-hoc AML building, by asking device(s) to generate its own AML blob like it's done for ISA devices. Signed-off-by: Igor Mammedov <imammedo@redhat.com> Acked-by: Gerd Hoffmann <kraxel@redhat.com> Message-Id: <20220608135340.3304695-2-imammedo@redhat.com> Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
This commit is contained in:
parent
6d940eff47
commit
23609e47c0
3 changed files with 49 additions and 1 deletions
40
include/hw/acpi/acpi_aml_interface.h
Normal file
40
include/hw/acpi/acpi_aml_interface.h
Normal file
|
@ -0,0 +1,40 @@
|
|||
#ifndef ACPI_AML_INTERFACE_H
|
||||
#define ACPI_AML_INTERFACE_H
|
||||
|
||||
#include "qom/object.h"
|
||||
#include "hw/acpi/aml-build.h"
|
||||
|
||||
#define TYPE_ACPI_DEV_AML_IF "acpi-dev-aml-interface"
|
||||
typedef struct AcpiDevAmlIfClass AcpiDevAmlIfClass;
|
||||
DECLARE_CLASS_CHECKERS(AcpiDevAmlIfClass, ACPI_DEV_AML_IF, TYPE_ACPI_DEV_AML_IF)
|
||||
#define ACPI_DEV_AML_IF(obj) \
|
||||
INTERFACE_CHECK(AcpiDevAmlIf, (obj), TYPE_ACPI_DEV_AML_IF)
|
||||
|
||||
typedef struct AcpiDevAmlIf AcpiDevAmlIf;
|
||||
typedef void (*dev_aml_fn)(AcpiDevAmlIf *adev, Aml *scope);
|
||||
|
||||
/**
|
||||
* AcpiDevAmlIfClass:
|
||||
*
|
||||
* build_dev_aml: adds device specific AML blob to provided scope
|
||||
*
|
||||
* Interface is designed for providing generic callback that builds device
|
||||
* specific AML blob.
|
||||
*/
|
||||
struct AcpiDevAmlIfClass {
|
||||
/* <private> */
|
||||
InterfaceClass parent_class;
|
||||
|
||||
/* <public> */
|
||||
dev_aml_fn build_dev_aml;
|
||||
};
|
||||
|
||||
static inline void call_dev_aml_func(DeviceState *dev, Aml *scope)
|
||||
{
|
||||
if (object_dynamic_cast(OBJECT(dev), TYPE_ACPI_DEV_AML_IF)) {
|
||||
AcpiDevAmlIfClass *klass = ACPI_DEV_AML_IF_GET_CLASS(dev);
|
||||
klass->build_dev_aml(ACPI_DEV_AML_IF(dev), scope);
|
||||
}
|
||||
}
|
||||
|
||||
#endif
|
Loading…
Add table
Add a link
Reference in a new issue