From: Marc-André Lureau <marcandre.lur...@redhat.com> There is no simple way to distinguish when the callback is used for load or save, AFAICT.
Signed-off-by: Marc-André Lureau <marcandre.lur...@redhat.com> --- hw/virtio/virtio.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/hw/virtio/virtio.c b/hw/virtio/virtio.c index 6facd64fbc..8baf9f7ca8 100644 --- a/hw/virtio/virtio.c +++ b/hw/virtio/virtio.c @@ -2502,7 +2502,11 @@ static bool virtio_device_endian_needed(void *opaque) { VirtIODevice *vdev = opaque; - assert(vdev->device_endian != VIRTIO_DEVICE_ENDIAN_UNKNOWN); + /* On load, endian is UNKNOWN. The section might be loaded as required. */ + if (vdev->device_endian == VIRTIO_DEVICE_ENDIAN_UNKNOWN) { + return false; + } + if (!virtio_vdev_has_feature(vdev, VIRTIO_F_VERSION_1)) { return vdev->device_endian != virtio_default_endian(); } -- 2.41.0