summaryrefslogtreecommitdiffstats
path: root/tests/libqos/virtio-9p.c
diff options
context:
space:
mode:
authorStefan Hajnoczi2019-10-23 12:04:15 +0200
committerMichael S. Tsirkin2019-10-25 13:46:22 +0200
commitc5bd6d02e6eb6ae868abbcbeb5c3a3be8c5379a5 (patch)
treebee9a761a1a4cddf8a5456d0f6d38a0ff66be3da /tests/libqos/virtio-9p.c
parenttests/virtio-blk-test: set up virtqueue after feature negotiation (diff)
downloadqemu-c5bd6d02e6eb6ae868abbcbeb5c3a3be8c5379a5.tar.gz
qemu-c5bd6d02e6eb6ae868abbcbeb5c3a3be8c5379a5.tar.xz
qemu-c5bd6d02e6eb6ae868abbcbeb5c3a3be8c5379a5.zip
libqos: add missing virtio-9p feature negotiation
VIRTIO Device Initialization requires feature negotiation. The libqos virtio-9p driver lacks feature negotiation and is therefore non-compliant. libqos tests acknowledge all feature bits advertised by the device, except VIRTIO_F_BAD_FEATURE (which devices use to detect broken drivers!) and VIRTIO_RING_F_EVENT_IDX (which is not implemented in libqos and accepting it would break notifications). Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com> Message-Id: <20191023100425.12168-7-stefanha@redhat.com> Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com> Reviewed-by: Thomas Huth" <thuth@redhat.com>
Diffstat (limited to 'tests/libqos/virtio-9p.c')
-rw-r--r--tests/libqos/virtio-9p.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/tests/libqos/virtio-9p.c b/tests/libqos/virtio-9p.c
index 8c9efce3e1..77dbfb62ad 100644
--- a/tests/libqos/virtio-9p.c
+++ b/tests/libqos/virtio-9p.c
@@ -32,6 +32,12 @@ static void virtio_9p_cleanup(QVirtio9P *interface)
static void virtio_9p_setup(QVirtio9P *interface)
{
+ uint64_t features;
+
+ features = qvirtio_get_features(interface->vdev);
+ features &= ~(QVIRTIO_F_BAD_FEATURE | (1ull << VIRTIO_RING_F_EVENT_IDX));
+ qvirtio_set_features(interface->vdev, features);
+
interface->vq = qvirtqueue_setup(interface->vdev, alloc, 0);
qvirtio_set_driver_ok(interface->vdev);
}