1521b3673SIgor Mammedov #ifndef ACPI_DEV_INTERFACE_H 2521b3673SIgor Mammedov #define ACPI_DEV_INTERFACE_H 3521b3673SIgor Mammedov 42ae16a6aSMarkus Armbruster #include "qapi/qapi-types-misc.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 21*db1015e9SEduardo Habkost typedef struct AcpiDeviceIfClass AcpiDeviceIfClass; 22521b3673SIgor Mammedov #define ACPI_DEVICE_IF_CLASS(klass) \ 23521b3673SIgor Mammedov OBJECT_CLASS_CHECK(AcpiDeviceIfClass, (klass), \ 24521b3673SIgor Mammedov TYPE_ACPI_DEVICE_IF) 25521b3673SIgor Mammedov #define ACPI_DEVICE_IF_GET_CLASS(obj) \ 26521b3673SIgor Mammedov OBJECT_GET_CLASS(AcpiDeviceIfClass, (obj), \ 27521b3673SIgor Mammedov TYPE_ACPI_DEVICE_IF) 28521b3673SIgor Mammedov #define ACPI_DEVICE_IF(obj) \ 29521b3673SIgor Mammedov INTERFACE_CHECK(AcpiDeviceIf, (obj), \ 30521b3673SIgor Mammedov TYPE_ACPI_DEVICE_IF) 31521b3673SIgor Mammedov 32aa1b35b9SMarc-André Lureau typedef struct AcpiDeviceIf AcpiDeviceIf; 33521b3673SIgor Mammedov 34eaf23bf7SIgor Mammedov void acpi_send_event(DeviceState *dev, AcpiEventStatusBits event); 35eaf23bf7SIgor Mammedov 36521b3673SIgor Mammedov /** 37521b3673SIgor Mammedov * AcpiDeviceIfClass: 38521b3673SIgor Mammedov * 39521b3673SIgor Mammedov * ospm_status: returns status of ACPI device objects, reported 40521b3673SIgor Mammedov * via _OST method if device supports it. 41eaf23bf7SIgor Mammedov * send_event: inject a specified event into guest 42ac35f13bSIgor Mammedov * madt_cpu: fills @entry with Interrupt Controller Structure 43ac35f13bSIgor Mammedov * for CPU indexed by @uid in @apic_ids array, 44ac35f13bSIgor Mammedov * returned structure types are: 45ac35f13bSIgor Mammedov * 0 - Local APIC, 9 - Local x2APIC, 0xB - GICC 46521b3673SIgor Mammedov * 47521b3673SIgor Mammedov * Interface is designed for providing unified interface 48521b3673SIgor Mammedov * to generic ACPI functionality that could be used without 49521b3673SIgor Mammedov * knowledge about internals of actual device that implements 50521b3673SIgor Mammedov * ACPI interface. 51521b3673SIgor Mammedov */ 52*db1015e9SEduardo Habkost struct AcpiDeviceIfClass { 53521b3673SIgor Mammedov /* <private> */ 54521b3673SIgor Mammedov InterfaceClass parent_class; 55521b3673SIgor Mammedov 56521b3673SIgor Mammedov /* <public> */ 57521b3673SIgor Mammedov void (*ospm_status)(AcpiDeviceIf *adev, ACPIOSTInfoList ***list); 58eaf23bf7SIgor Mammedov void (*send_event)(AcpiDeviceIf *adev, AcpiEventStatusBits ev); 59ac35f13bSIgor Mammedov void (*madt_cpu)(AcpiDeviceIf *adev, int uid, 6080e5db30SIgor Mammedov const CPUArchIdList *apic_ids, GArray *entry); 61*db1015e9SEduardo Habkost }; 62521b3673SIgor Mammedov #endif 63