mirror of
https://github.com/qemu/qemu.git
synced 2025-08-09 10:25:06 +00:00
pc: migrate piix4 & ich9 MemHotplugState
Adds an optional subsection that allows to migrate current state of acpi_memory_hotplug of ACPI PM device. Signed-off-by: Igor Mammedov <imammedo@redhat.com> Acked-by: Peter Crosthwaite <peter.crosthwaite@xilinx.com> Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
This commit is contained in:
parent
1f8621842e
commit
f816a62daa
@ -140,6 +140,23 @@ static int ich9_pm_post_load(void *opaque, int version_id)
|
|||||||
.offset = vmstate_offset_pointer(_state, _field, uint8_t), \
|
.offset = vmstate_offset_pointer(_state, _field, uint8_t), \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool vmstate_test_use_memhp(void *opaque)
|
||||||
|
{
|
||||||
|
ICH9LPCPMRegs *s = opaque;
|
||||||
|
return s->acpi_memory_hotplug.is_enabled;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const VMStateDescription vmstate_memhp_state = {
|
||||||
|
.name = "ich9_pm/memhp",
|
||||||
|
.version_id = 1,
|
||||||
|
.minimum_version_id = 1,
|
||||||
|
.minimum_version_id_old = 1,
|
||||||
|
.fields = (VMStateField[]) {
|
||||||
|
VMSTATE_MEMORY_HOTPLUG(acpi_memory_hotplug, ICH9LPCPMRegs),
|
||||||
|
VMSTATE_END_OF_LIST()
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
const VMStateDescription vmstate_ich9_pm = {
|
const VMStateDescription vmstate_ich9_pm = {
|
||||||
.name = "ich9_pm",
|
.name = "ich9_pm",
|
||||||
.version_id = 1,
|
.version_id = 1,
|
||||||
@ -156,6 +173,13 @@ const VMStateDescription vmstate_ich9_pm = {
|
|||||||
VMSTATE_UINT32(smi_en, ICH9LPCPMRegs),
|
VMSTATE_UINT32(smi_en, ICH9LPCPMRegs),
|
||||||
VMSTATE_UINT32(smi_sts, ICH9LPCPMRegs),
|
VMSTATE_UINT32(smi_sts, ICH9LPCPMRegs),
|
||||||
VMSTATE_END_OF_LIST()
|
VMSTATE_END_OF_LIST()
|
||||||
|
},
|
||||||
|
.subsections = (VMStateSubsection[]) {
|
||||||
|
{
|
||||||
|
.vmsd = &vmstate_memhp_state,
|
||||||
|
.needed = vmstate_test_use_memhp,
|
||||||
|
},
|
||||||
|
VMSTATE_END_OF_LIST()
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -158,3 +158,30 @@ void acpi_memory_plug_cb(ACPIREGS *ar, qemu_irq irq, MemHotplugState *mem_st,
|
|||||||
acpi_update_sci(ar, irq);
|
acpi_update_sci(ar, irq);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const VMStateDescription vmstate_memhp_sts = {
|
||||||
|
.name = "memory hotplug device state",
|
||||||
|
.version_id = 1,
|
||||||
|
.minimum_version_id = 1,
|
||||||
|
.minimum_version_id_old = 1,
|
||||||
|
.fields = (VMStateField[]) {
|
||||||
|
VMSTATE_BOOL(is_enabled, MemStatus),
|
||||||
|
VMSTATE_BOOL(is_inserting, MemStatus),
|
||||||
|
VMSTATE_UINT32(ost_event, MemStatus),
|
||||||
|
VMSTATE_UINT32(ost_status, MemStatus),
|
||||||
|
VMSTATE_END_OF_LIST()
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const VMStateDescription vmstate_memory_hotplug = {
|
||||||
|
.name = "memory hotplug state",
|
||||||
|
.version_id = 1,
|
||||||
|
.minimum_version_id = 1,
|
||||||
|
.minimum_version_id_old = 1,
|
||||||
|
.fields = (VMStateField[]) {
|
||||||
|
VMSTATE_UINT32(selector, MemHotplugState),
|
||||||
|
VMSTATE_STRUCT_VARRAY_POINTER_UINT32(devs, MemHotplugState, dev_count,
|
||||||
|
vmstate_memhp_sts, MemStatus),
|
||||||
|
VMSTATE_END_OF_LIST()
|
||||||
|
}
|
||||||
|
};
|
||||||
|
@ -248,6 +248,23 @@ static bool vmstate_test_no_use_acpi_pci_hotplug(void *opaque, int version_id)
|
|||||||
return !s->use_acpi_pci_hotplug;
|
return !s->use_acpi_pci_hotplug;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool vmstate_test_use_memhp(void *opaque)
|
||||||
|
{
|
||||||
|
PIIX4PMState *s = opaque;
|
||||||
|
return s->acpi_memory_hotplug.is_enabled;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const VMStateDescription vmstate_memhp_state = {
|
||||||
|
.name = "piix4_pm/memhp",
|
||||||
|
.version_id = 1,
|
||||||
|
.minimum_version_id = 1,
|
||||||
|
.minimum_version_id_old = 1,
|
||||||
|
.fields = (VMStateField[]) {
|
||||||
|
VMSTATE_MEMORY_HOTPLUG(acpi_memory_hotplug, PIIX4PMState),
|
||||||
|
VMSTATE_END_OF_LIST()
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
/* qemu-kvm 1.2 uses version 3 but advertised as 2
|
/* qemu-kvm 1.2 uses version 3 but advertised as 2
|
||||||
* To support incoming qemu-kvm 1.2 migration, change version_id
|
* To support incoming qemu-kvm 1.2 migration, change version_id
|
||||||
* and minimum_version_id to 2 below (which breaks migration from
|
* and minimum_version_id to 2 below (which breaks migration from
|
||||||
@ -279,6 +296,13 @@ static const VMStateDescription vmstate_acpi = {
|
|||||||
VMSTATE_PCI_HOTPLUG(acpi_pci_hotplug, PIIX4PMState,
|
VMSTATE_PCI_HOTPLUG(acpi_pci_hotplug, PIIX4PMState,
|
||||||
vmstate_test_use_acpi_pci_hotplug),
|
vmstate_test_use_acpi_pci_hotplug),
|
||||||
VMSTATE_END_OF_LIST()
|
VMSTATE_END_OF_LIST()
|
||||||
|
},
|
||||||
|
.subsections = (VMStateSubsection[]) {
|
||||||
|
{
|
||||||
|
.vmsd = &vmstate_memhp_state,
|
||||||
|
.needed = vmstate_test_use_memhp,
|
||||||
|
},
|
||||||
|
VMSTATE_END_OF_LIST()
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
|
|
||||||
#include "hw/qdev-core.h"
|
#include "hw/qdev-core.h"
|
||||||
#include "hw/acpi/acpi.h"
|
#include "hw/acpi/acpi.h"
|
||||||
|
#include "migration/vmstate.h"
|
||||||
|
|
||||||
#define ACPI_MEMORY_HOTPLUG_STATUS 8
|
#define ACPI_MEMORY_HOTPLUG_STATUS 8
|
||||||
|
|
||||||
@ -27,4 +28,10 @@ void acpi_memory_hotplug_init(MemoryRegion *as, Object *owner,
|
|||||||
|
|
||||||
void acpi_memory_plug_cb(ACPIREGS *ar, qemu_irq irq, MemHotplugState *mem_st,
|
void acpi_memory_plug_cb(ACPIREGS *ar, qemu_irq irq, MemHotplugState *mem_st,
|
||||||
DeviceState *dev, Error **errp);
|
DeviceState *dev, Error **errp);
|
||||||
|
|
||||||
|
extern const VMStateDescription vmstate_memory_hotplug;
|
||||||
|
#define VMSTATE_MEMORY_HOTPLUG(memhp, state) \
|
||||||
|
VMSTATE_STRUCT(memhp, state, 1, \
|
||||||
|
vmstate_memory_hotplug, MemHotplugState)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user