xref: /qemu/include/hw/acpi/acpi_dev_interface.h (revision 27c9188fa0d325e1e9778d627daf9a44813cce47)
1521b3673SIgor Mammedov #ifndef ACPI_DEV_INTERFACE_H
2521b3673SIgor Mammedov #define ACPI_DEV_INTERFACE_H
3521b3673SIgor Mammedov 
4*27c9188fSPhilippe Mathieu-Daudé #include "qapi/qapi-types-acpi.h"
5521b3673SIgor Mammedov #include "qom/object.h"
6ac35f13bSIgor Mammedov #include "hw/boards.h"
7a27bd6c7SMarkus Armbruster #include "hw/qdev-core.h"
8521b3673SIgor Mammedov 
9eaf23bf7SIgor Mammedov /* These values are part of guest ABI, and can not be changed */
10eaf23bf7SIgor Mammedov typedef enum {
11eaf23bf7SIgor Mammedov     ACPI_PCI_HOTPLUG_STATUS = 2,
12eaf23bf7SIgor Mammedov     ACPI_CPU_HOTPLUG_STATUS = 4,
13eaf23bf7SIgor Mammedov     ACPI_MEMORY_HOTPLUG_STATUS = 8,
14b097cc52SXiao Guangrong     ACPI_NVDIMM_HOTPLUG_STATUS = 16,
15d03637bcSBen Warren     ACPI_VMGENID_CHANGE_STATUS = 32,
161962f31bSShameer Kolothum     ACPI_POWER_DOWN_STATUS = 64,
17eaf23bf7SIgor Mammedov } AcpiEventStatusBits;
18eaf23bf7SIgor Mammedov 
19521b3673SIgor Mammedov #define TYPE_ACPI_DEVICE_IF "acpi-device-interface"
20521b3673SIgor Mammedov 
21db1015e9SEduardo Habkost typedef struct AcpiDeviceIfClass AcpiDeviceIfClass;
228110fa1dSEduardo Habkost DECLARE_CLASS_CHECKERS(AcpiDeviceIfClass, ACPI_DEVICE_IF,
23521b3673SIgor Mammedov                        TYPE_ACPI_DEVICE_IF)
24521b3673SIgor Mammedov #define ACPI_DEVICE_IF(obj) \
25521b3673SIgor Mammedov      INTERFACE_CHECK(AcpiDeviceIf, (obj), \
26521b3673SIgor Mammedov                      TYPE_ACPI_DEVICE_IF)
27521b3673SIgor Mammedov 
28aa1b35b9SMarc-André Lureau typedef struct AcpiDeviceIf AcpiDeviceIf;
29521b3673SIgor Mammedov 
30eaf23bf7SIgor Mammedov void acpi_send_event(DeviceState *dev, AcpiEventStatusBits event);
31eaf23bf7SIgor Mammedov 
32521b3673SIgor Mammedov /**
33521b3673SIgor Mammedov  * AcpiDeviceIfClass:
34521b3673SIgor Mammedov  *
35521b3673SIgor Mammedov  * ospm_status: returns status of ACPI device objects, reported
36521b3673SIgor Mammedov  *              via _OST method if device supports it.
37eaf23bf7SIgor Mammedov  * send_event: inject a specified event into guest
38ac35f13bSIgor Mammedov  * madt_cpu: fills @entry with Interrupt Controller Structure
39ac35f13bSIgor Mammedov  *           for CPU indexed by @uid in @apic_ids array,
40ac35f13bSIgor Mammedov  *           returned structure types are:
41ac35f13bSIgor Mammedov  *           0 - Local APIC, 9 - Local x2APIC, 0xB - GICC
42521b3673SIgor Mammedov  *
43521b3673SIgor Mammedov  * Interface is designed for providing unified interface
44521b3673SIgor Mammedov  * to generic ACPI functionality that could be used without
45521b3673SIgor Mammedov  * knowledge about internals of actual device that implements
46521b3673SIgor Mammedov  * ACPI interface.
47521b3673SIgor Mammedov  */
48db1015e9SEduardo Habkost struct AcpiDeviceIfClass {
49521b3673SIgor Mammedov     /* <private> */
50521b3673SIgor Mammedov     InterfaceClass parent_class;
51521b3673SIgor Mammedov 
52521b3673SIgor Mammedov     /* <public> */
53521b3673SIgor Mammedov     void (*ospm_status)(AcpiDeviceIf *adev, ACPIOSTInfoList ***list);
54eaf23bf7SIgor Mammedov     void (*send_event)(AcpiDeviceIf *adev, AcpiEventStatusBits ev);
55ac35f13bSIgor Mammedov     void (*madt_cpu)(AcpiDeviceIf *adev, int uid,
5680e5db30SIgor Mammedov                      const CPUArchIdList *apic_ids, GArray *entry);
57db1015e9SEduardo Habkost };
58521b3673SIgor Mammedov #endif
59