summaryrefslogtreecommitdiffstats
path: root/hw/pci-bridge/i82801b11.c
diff options
context:
space:
mode:
authorDr. David Alan Gilbert2016-04-04 17:54:41 +0200
committerMichael S. Tsirkin2016-04-07 18:57:33 +0200
commit3d100d0fa9ee4826425ea1c2a120a0f661d8e739 (patch)
tree4f2fbb410895097eed757d98fb78eea2cad6071f /hw/pci-bridge/i82801b11.c
parentSort the fw_cfg file list (diff)
downloadqemu-3d100d0fa9ee4826425ea1c2a120a0f661d8e739.tar.gz
qemu-3d100d0fa9ee4826425ea1c2a120a0f661d8e739.tar.xz
qemu-3d100d0fa9ee4826425ea1c2a120a0f661d8e739.zip
Migration: Add i82801b11 migration data
The i82801b11 bridge didn't have a vmsd and thus didn't send any migration data, including that of its parent PCIBridge object. The symptom being if the guest used any devices behind the bridge the guest crashed (mostly with various interrupt related issues). Note: This will cause migration from old qemus that used this device to explicitly fail during migration as opposed to the guest crashing. Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com> Suggested-by: Marcel Apfelbaum <marcel@redhat.com> Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
Diffstat (limited to 'hw/pci-bridge/i82801b11.c')
-rw-r--r--hw/pci-bridge/i82801b11.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/hw/pci-bridge/i82801b11.c b/hw/pci-bridge/i82801b11.c
index 5c40708ba8..2404e7ebae 100644
--- a/hw/pci-bridge/i82801b11.c
+++ b/hw/pci-bridge/i82801b11.c
@@ -78,6 +78,14 @@ err_bridge:
return rc;
}
+static const VMStateDescription i82801b11_bridge_dev_vmstate = {
+ .name = "i82801b11_bridge",
+ .fields = (VMStateField[]) {
+ VMSTATE_PCI_DEVICE(parent_obj, PCIBridge),
+ VMSTATE_END_OF_LIST()
+ }
+};
+
static void i82801b11_bridge_class_init(ObjectClass *klass, void *data)
{
PCIDeviceClass *k = PCI_DEVICE_CLASS(klass);
@@ -89,6 +97,7 @@ static void i82801b11_bridge_class_init(ObjectClass *klass, void *data)
k->revision = ICH9_D2P_A2_REVISION;
k->init = i82801b11_bridge_initfn;
k->config_write = pci_bridge_write_config;
+ dc->vmsd = &i82801b11_bridge_dev_vmstate;
set_bit(DEVICE_CATEGORY_BRIDGE, dc->categories);
}