2014-06-02 15:25:16 +02:00
|
|
|
#ifndef QEMU_HW_ACPI_MEMORY_HOTPLUG_H
|
|
|
|
#define QEMU_HW_ACPI_MEMORY_HOTPLUG_H
|
|
|
|
|
|
|
|
#include "hw/qdev-core.h"
|
|
|
|
#include "hw/acpi/acpi.h"
|
2014-06-02 15:25:23 +02:00
|
|
|
#include "migration/vmstate.h"
|
2014-06-02 15:25:16 +02:00
|
|
|
|
|
|
|
#define ACPI_MEMORY_HOTPLUG_STATUS 8
|
|
|
|
|
|
|
|
typedef struct MemStatus {
|
|
|
|
DeviceState *dimm;
|
|
|
|
bool is_enabled;
|
|
|
|
bool is_inserting;
|
|
|
|
uint32_t ost_event;
|
|
|
|
uint32_t ost_status;
|
|
|
|
} MemStatus;
|
|
|
|
|
|
|
|
typedef struct MemHotplugState {
|
2014-06-02 15:25:20 +02:00
|
|
|
bool is_enabled; /* true if memory hotplug is supported */
|
2014-06-02 15:25:16 +02:00
|
|
|
MemoryRegion io;
|
|
|
|
uint32_t selector;
|
|
|
|
uint32_t dev_count;
|
|
|
|
MemStatus *devs;
|
|
|
|
} MemHotplugState;
|
|
|
|
|
|
|
|
void acpi_memory_hotplug_init(MemoryRegion *as, Object *owner,
|
|
|
|
MemHotplugState *state);
|
|
|
|
|
|
|
|
void acpi_memory_plug_cb(ACPIREGS *ar, qemu_irq irq, MemHotplugState *mem_st,
|
|
|
|
DeviceState *dev, Error **errp);
|
2014-06-02 15:25:23 +02:00
|
|
|
|
|
|
|
extern const VMStateDescription vmstate_memory_hotplug;
|
|
|
|
#define VMSTATE_MEMORY_HOTPLUG(memhp, state) \
|
|
|
|
VMSTATE_STRUCT(memhp, state, 1, \
|
|
|
|
vmstate_memory_hotplug, MemHotplugState)
|
|
|
|
|
2014-06-16 19:12:27 +02:00
|
|
|
void acpi_memory_ospm_status(MemHotplugState *mem_st, ACPIOSTInfoList ***list);
|
2014-06-02 15:25:16 +02:00
|
|
|
#endif
|