mirror of
https://github.com/xemu-project/xemu.git
synced 2025-01-22 11:54:47 +00:00
acpi: introduce TYPE_ACPI_DEVICE_IF interface
... it will be used to abstract generic ACPI bits from device that implements ACPI interface. ACPIOSTInfo type is used for passing-through raw _OST event/status codes reported by guest OS to a management layer. It lets management tools interpret values as specified by ACPI spec if it is interested in it. QEMU doesn't encode these values as enum, since it doesn't need to handle them and it allows interface to scale well without any changes in QEMU while guest OS and management evolves in time. Signed-off-by: Igor Mammedov <imammedo@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Acked-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
This commit is contained in:
parent
6f2e27301d
commit
521b3673ac
@ -1,2 +1,3 @@
|
||||
common-obj-$(CONFIG_ACPI) += core.o piix4.o ich9.o pcihp.o cpu_hotplug.o
|
||||
common-obj-$(CONFIG_ACPI) += memory_hotplug.o
|
||||
common-obj-$(CONFIG_ACPI) += acpi_interface.o
|
||||
|
15
hw/acpi/acpi_interface.c
Normal file
15
hw/acpi/acpi_interface.c
Normal file
@ -0,0 +1,15 @@
|
||||
#include "hw/acpi/acpi_dev_interface.h"
|
||||
#include "qemu/module.h"
|
||||
|
||||
static void register_types(void)
|
||||
{
|
||||
static const TypeInfo acpi_dev_if_info = {
|
||||
.name = TYPE_ACPI_DEVICE_IF,
|
||||
.parent = TYPE_INTERFACE,
|
||||
.class_size = sizeof(AcpiDeviceIfClass),
|
||||
};
|
||||
|
||||
type_register_static(&acpi_dev_if_info);
|
||||
}
|
||||
|
||||
type_init(register_types)
|
43
include/hw/acpi/acpi_dev_interface.h
Normal file
43
include/hw/acpi/acpi_dev_interface.h
Normal file
@ -0,0 +1,43 @@
|
||||
#ifndef ACPI_DEV_INTERFACE_H
|
||||
#define ACPI_DEV_INTERFACE_H
|
||||
|
||||
#include "qom/object.h"
|
||||
#include "qapi-types.h"
|
||||
|
||||
#define TYPE_ACPI_DEVICE_IF "acpi-device-interface"
|
||||
|
||||
#define ACPI_DEVICE_IF_CLASS(klass) \
|
||||
OBJECT_CLASS_CHECK(AcpiDeviceIfClass, (klass), \
|
||||
TYPE_ACPI_DEVICE_IF)
|
||||
#define ACPI_DEVICE_IF_GET_CLASS(obj) \
|
||||
OBJECT_GET_CLASS(AcpiDeviceIfClass, (obj), \
|
||||
TYPE_ACPI_DEVICE_IF)
|
||||
#define ACPI_DEVICE_IF(obj) \
|
||||
INTERFACE_CHECK(AcpiDeviceIf, (obj), \
|
||||
TYPE_ACPI_DEVICE_IF)
|
||||
|
||||
|
||||
typedef struct AcpiDeviceIf {
|
||||
/* <private> */
|
||||
Object Parent;
|
||||
} AcpiDeviceIf;
|
||||
|
||||
/**
|
||||
* AcpiDeviceIfClass:
|
||||
*
|
||||
* ospm_status: returns status of ACPI device objects, reported
|
||||
* via _OST method if device supports it.
|
||||
*
|
||||
* Interface is designed for providing unified interface
|
||||
* to generic ACPI functionality that could be used without
|
||||
* knowledge about internals of actual device that implements
|
||||
* ACPI interface.
|
||||
*/
|
||||
typedef struct AcpiDeviceIfClass {
|
||||
/* <private> */
|
||||
InterfaceClass parent_class;
|
||||
|
||||
/* <public> */
|
||||
void (*ospm_status)(AcpiDeviceIf *adev, ACPIOSTInfoList ***list);
|
||||
} AcpiDeviceIfClass;
|
||||
#endif
|
@ -3245,3 +3245,34 @@
|
||||
# Since: 2.1
|
||||
##
|
||||
{ 'command': 'query-memory-devices', 'returns': ['MemoryDeviceInfo'] }
|
||||
|
||||
## @ACPISlotType
|
||||
#
|
||||
# @DIMM: memory slot
|
||||
#
|
||||
{ 'enum': 'ACPISlotType', 'data': [ 'DIMM' ] }
|
||||
|
||||
## @ACPIOSTInfo
|
||||
#
|
||||
# OSPM Status Indication for a device
|
||||
# For description of possible values of @source and @status fields
|
||||
# see "_OST (OSPM Status Indication)" chapter of ACPI5.0 spec.
|
||||
#
|
||||
# @device: #optional device ID associated with slot
|
||||
#
|
||||
# @slot: slot ID, unique per slot of a given @slot-type
|
||||
#
|
||||
# @slot-type: type of the slot
|
||||
#
|
||||
# @source: an integer containing the source event
|
||||
#
|
||||
# @status: an integer containing the status code
|
||||
#
|
||||
# Since: 2.1
|
||||
##
|
||||
{ 'type': 'ACPIOSTInfo',
|
||||
'data' : { '*device': 'str',
|
||||
'slot': 'str',
|
||||
'slot-type': 'ACPISlotType',
|
||||
'source': 'int',
|
||||
'status': 'int' } }
|
||||
|
Loading…
x
Reference in New Issue
Block a user