xref: /qemu/include/hw/acpi/acpi_dev_interface.h (revision aa1b35b975d83a1ee3b5d1a1ae200a59ca44f8d2)
1521b3673SIgor Mammedov #ifndef ACPI_DEV_INTERFACE_H
2521b3673SIgor Mammedov #define ACPI_DEV_INTERFACE_H
3521b3673SIgor Mammedov 
4521b3673SIgor Mammedov #include "qom/object.h"
5ac35f13bSIgor Mammedov #include "hw/boards.h"
6521b3673SIgor Mammedov 
7eaf23bf7SIgor Mammedov /* These values are part of guest ABI, and can not be changed */
8eaf23bf7SIgor Mammedov typedef enum {
9eaf23bf7SIgor Mammedov     ACPI_PCI_HOTPLUG_STATUS = 2,
10eaf23bf7SIgor Mammedov     ACPI_CPU_HOTPLUG_STATUS = 4,
11eaf23bf7SIgor Mammedov     ACPI_MEMORY_HOTPLUG_STATUS = 8,
12b097cc52SXiao Guangrong     ACPI_NVDIMM_HOTPLUG_STATUS = 16,
13d03637bcSBen Warren     ACPI_VMGENID_CHANGE_STATUS = 32,
14eaf23bf7SIgor Mammedov } AcpiEventStatusBits;
15eaf23bf7SIgor Mammedov 
16521b3673SIgor Mammedov #define TYPE_ACPI_DEVICE_IF "acpi-device-interface"
17521b3673SIgor Mammedov 
18521b3673SIgor Mammedov #define ACPI_DEVICE_IF_CLASS(klass) \
19521b3673SIgor Mammedov      OBJECT_CLASS_CHECK(AcpiDeviceIfClass, (klass), \
20521b3673SIgor Mammedov                         TYPE_ACPI_DEVICE_IF)
21521b3673SIgor Mammedov #define ACPI_DEVICE_IF_GET_CLASS(obj) \
22521b3673SIgor Mammedov      OBJECT_GET_CLASS(AcpiDeviceIfClass, (obj), \
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 
28*aa1b35b9SMarc-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  */
48521b3673SIgor Mammedov typedef 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);
57521b3673SIgor Mammedov } AcpiDeviceIfClass;
58521b3673SIgor Mammedov #endif
59