提交 1b5fc0de 编写于 作者: G Greg Kurz 提交者: Michael S. Tsirkin

virtio: introduce device specific migration calls

In order to migrate virtio subsections, they should be streamed after
the device itself. We need the device specific code to be called from
the common migration code to achieve this. This patch introduces load
and save methods for this purpose.
Suggested-by: NAndreas Färber <afaerber@suse.de>
Signed-off-by: NGreg Kurz <gkurz@linux.vnet.ibm.com>
Reviewed-by: NAlexander Graf <agraf@suse.de>
Reviewed-by: NMichael S. Tsirkin <mst@redhat.com>
Signed-off-by: NMichael S. Tsirkin <mst@redhat.com>
上级 e38e943a
...@@ -635,7 +635,7 @@ static int virtio_blk_load(QEMUFile *f, void *opaque, int version_id) ...@@ -635,7 +635,7 @@ static int virtio_blk_load(QEMUFile *f, void *opaque, int version_id)
if (version_id != 2) if (version_id != 2)
return -EINVAL; return -EINVAL;
ret = virtio_load(vdev, f); ret = virtio_load(vdev, f, version_id);
if (ret) { if (ret) {
return ret; return ret;
} }
......
...@@ -670,7 +670,7 @@ static int virtio_serial_load(QEMUFile *f, void *opaque, int version_id) ...@@ -670,7 +670,7 @@ static int virtio_serial_load(QEMUFile *f, void *opaque, int version_id)
} }
/* The virtio device */ /* The virtio device */
ret = virtio_load(VIRTIO_DEVICE(s), f); ret = virtio_load(VIRTIO_DEVICE(s), f, version_id);
if (ret) { if (ret) {
return ret; return ret;
} }
......
...@@ -1362,7 +1362,7 @@ static int virtio_net_load(QEMUFile *f, void *opaque, int version_id) ...@@ -1362,7 +1362,7 @@ static int virtio_net_load(QEMUFile *f, void *opaque, int version_id)
if (version_id < 2 || version_id > VIRTIO_NET_VM_VERSION) if (version_id < 2 || version_id > VIRTIO_NET_VM_VERSION)
return -EINVAL; return -EINVAL;
ret = virtio_load(vdev, f); ret = virtio_load(vdev, f, version_id);
if (ret) { if (ret) {
return ret; return ret;
} }
......
...@@ -549,7 +549,7 @@ static int virtio_scsi_load(QEMUFile *f, void *opaque, int version_id) ...@@ -549,7 +549,7 @@ static int virtio_scsi_load(QEMUFile *f, void *opaque, int version_id)
VirtIODevice *vdev = VIRTIO_DEVICE(opaque); VirtIODevice *vdev = VIRTIO_DEVICE(opaque);
int ret; int ret;
ret = virtio_load(vdev, f); ret = virtio_load(vdev, f, version_id);
if (ret) { if (ret) {
return ret; return ret;
} }
......
...@@ -343,7 +343,7 @@ static int virtio_balloon_load(QEMUFile *f, void *opaque, int version_id) ...@@ -343,7 +343,7 @@ static int virtio_balloon_load(QEMUFile *f, void *opaque, int version_id)
if (version_id != 1) if (version_id != 1)
return -EINVAL; return -EINVAL;
ret = virtio_load(vdev, f); ret = virtio_load(vdev, f, version_id);
if (ret) { if (ret) {
return ret; return ret;
} }
......
...@@ -113,7 +113,7 @@ static int virtio_rng_load(QEMUFile *f, void *opaque, int version_id) ...@@ -113,7 +113,7 @@ static int virtio_rng_load(QEMUFile *f, void *opaque, int version_id)
if (version_id != 1) { if (version_id != 1) {
return -EINVAL; return -EINVAL;
} }
virtio_load(vdev, f); virtio_load(vdev, f, version_id);
/* We may have an element ready but couldn't process it due to a quota /* We may have an element ready but couldn't process it due to a quota
* limit. Make sure to try again after live migration when the quota may * limit. Make sure to try again after live migration when the quota may
......
...@@ -843,6 +843,7 @@ void virtio_save(VirtIODevice *vdev, QEMUFile *f) ...@@ -843,6 +843,7 @@ void virtio_save(VirtIODevice *vdev, QEMUFile *f)
{ {
BusState *qbus = qdev_get_parent_bus(DEVICE(vdev)); BusState *qbus = qdev_get_parent_bus(DEVICE(vdev));
VirtioBusClass *k = VIRTIO_BUS_GET_CLASS(qbus); VirtioBusClass *k = VIRTIO_BUS_GET_CLASS(qbus);
VirtioDeviceClass *vdc = VIRTIO_DEVICE_GET_CLASS(vdev);
int i; int i;
if (k->save_config) { if (k->save_config) {
...@@ -877,6 +878,10 @@ void virtio_save(VirtIODevice *vdev, QEMUFile *f) ...@@ -877,6 +878,10 @@ void virtio_save(VirtIODevice *vdev, QEMUFile *f)
k->save_queue(qbus->parent, i, f); k->save_queue(qbus->parent, i, f);
} }
} }
if (vdc->save != NULL) {
vdc->save(vdev, f);
}
} }
int virtio_set_features(VirtIODevice *vdev, uint32_t val) int virtio_set_features(VirtIODevice *vdev, uint32_t val)
...@@ -895,7 +900,7 @@ int virtio_set_features(VirtIODevice *vdev, uint32_t val) ...@@ -895,7 +900,7 @@ int virtio_set_features(VirtIODevice *vdev, uint32_t val)
return bad ? -1 : 0; return bad ? -1 : 0;
} }
int virtio_load(VirtIODevice *vdev, QEMUFile *f) int virtio_load(VirtIODevice *vdev, QEMUFile *f, int version_id)
{ {
int i, ret; int i, ret;
int32_t config_len; int32_t config_len;
...@@ -904,6 +909,7 @@ int virtio_load(VirtIODevice *vdev, QEMUFile *f) ...@@ -904,6 +909,7 @@ int virtio_load(VirtIODevice *vdev, QEMUFile *f)
uint32_t supported_features; uint32_t supported_features;
BusState *qbus = qdev_get_parent_bus(DEVICE(vdev)); BusState *qbus = qdev_get_parent_bus(DEVICE(vdev));
VirtioBusClass *k = VIRTIO_BUS_GET_CLASS(qbus); VirtioBusClass *k = VIRTIO_BUS_GET_CLASS(qbus);
VirtioDeviceClass *vdc = VIRTIO_DEVICE_GET_CLASS(vdev);
if (k->load_config) { if (k->load_config) {
ret = k->load_config(qbus->parent, f); ret = k->load_config(qbus->parent, f);
...@@ -983,6 +989,11 @@ int virtio_load(VirtIODevice *vdev, QEMUFile *f) ...@@ -983,6 +989,11 @@ int virtio_load(VirtIODevice *vdev, QEMUFile *f)
} }
virtio_notify_vector(vdev, VIRTIO_NO_VECTOR); virtio_notify_vector(vdev, VIRTIO_NO_VECTOR);
if (vdc->load != NULL) {
return vdc->load(vdev, f, version_id);
}
return 0; return 0;
} }
......
...@@ -150,6 +150,8 @@ typedef struct VirtioDeviceClass { ...@@ -150,6 +150,8 @@ typedef struct VirtioDeviceClass {
* must mask in frontend instead. * must mask in frontend instead.
*/ */
void (*guest_notifier_mask)(VirtIODevice *vdev, int n, bool mask); void (*guest_notifier_mask)(VirtIODevice *vdev, int n, bool mask);
void (*save)(VirtIODevice *vdev, QEMUFile *f);
int (*load)(VirtIODevice *vdev, QEMUFile *f, int version_id);
} VirtioDeviceClass; } VirtioDeviceClass;
void virtio_init(VirtIODevice *vdev, const char *name, void virtio_init(VirtIODevice *vdev, const char *name,
...@@ -184,7 +186,7 @@ void virtio_notify(VirtIODevice *vdev, VirtQueue *vq); ...@@ -184,7 +186,7 @@ void virtio_notify(VirtIODevice *vdev, VirtQueue *vq);
void virtio_save(VirtIODevice *vdev, QEMUFile *f); void virtio_save(VirtIODevice *vdev, QEMUFile *f);
int virtio_load(VirtIODevice *vdev, QEMUFile *f); int virtio_load(VirtIODevice *vdev, QEMUFile *f, int version_id);
void virtio_notify_config(VirtIODevice *vdev); void virtio_notify_config(VirtIODevice *vdev);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册