aboutsummaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorPaolo Bonzini <pbonzini@redhat.com>2018-10-22 12:37:21 +0200
committerPaolo Bonzini <pbonzini@redhat.com>2019-03-07 17:28:42 +0100
commit6bd4a6d4b867fab1f94f9fe3d1b19d02ac3d684b (patch)
treee393625078c7e5be8fe90ea9836b7959533ce5a4 /tests
parent6ae333f91b99cc4448e6c0af45f38d87bc952c82 (diff)
downloadqemu-6bd4a6d4b867fab1f94f9fe3d1b19d02ac3d684b.zip
qemu-6bd4a6d4b867fab1f94f9fe3d1b19d02ac3d684b.tar.gz
qemu-6bd4a6d4b867fab1f94f9fe3d1b19d02ac3d684b.tar.bz2
tests/libqos: support multiqueue for virtio-net
Initialize the additional virtqueues if they are supported. This is needed to switch vhost-user-test's multiqueue test to the virtio-net qgraph. Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'tests')
-rw-r--r--tests/libqos/virtio-net.c21
-rw-r--r--tests/libqos/virtio-net.h4
-rw-r--r--tests/virtio-net-test.c6
3 files changed, 22 insertions, 9 deletions
diff --git a/tests/libqos/virtio-net.c b/tests/libqos/virtio-net.c
index 3ddfbdc..61c5617 100644
--- a/tests/libqos/virtio-net.c
+++ b/tests/libqos/virtio-net.c
@@ -27,14 +27,19 @@ static QGuestAllocator *alloc;
static void virtio_net_cleanup(QVirtioNet *interface)
{
- qvirtqueue_cleanup(interface->vdev->bus, interface->rx, alloc);
- qvirtqueue_cleanup(interface->vdev->bus, interface->tx, alloc);
+ int i;
+
+ for (i = 0; i < interface->n_queues; i++) {
+ qvirtqueue_cleanup(interface->vdev->bus, interface->queues[i], alloc);
+ }
+ g_free(interface->queues);
}
static void virtio_net_setup(QVirtioNet *interface)
{
QVirtioDevice *vdev = interface->vdev;
uint64_t features;
+ int i;
features = qvirtio_get_features(vdev);
features &= ~(QVIRTIO_F_BAD_FEATURE |
@@ -42,8 +47,16 @@ static void virtio_net_setup(QVirtioNet *interface)
(1u << VIRTIO_RING_F_EVENT_IDX));
qvirtio_set_features(vdev, features);
- interface->rx = qvirtqueue_setup(vdev, alloc, 0);
- interface->tx = qvirtqueue_setup(vdev, alloc, 1);
+ if (features & (1u << VIRTIO_NET_F_MQ)) {
+ interface->n_queues = qvirtio_config_readw(vdev, 8) * 2;
+ } else {
+ interface->n_queues = 2;
+ }
+
+ interface->queues = g_new(QVirtQueue *, interface->n_queues);
+ for (i = 0; i < interface->n_queues; i++) {
+ interface->queues[i] = qvirtqueue_setup(vdev, alloc, i);
+ }
qvirtio_set_driver_ok(vdev);
}
diff --git a/tests/libqos/virtio-net.h b/tests/libqos/virtio-net.h
index e6905cd..28238a1 100644
--- a/tests/libqos/virtio-net.h
+++ b/tests/libqos/virtio-net.h
@@ -26,8 +26,8 @@ typedef struct QVirtioNetDevice QVirtioNetDevice;
struct QVirtioNet {
QVirtioDevice *vdev;
- QVirtQueue *rx;
- QVirtQueue *tx;
+ int n_queues;
+ QVirtQueue **queues;
};
struct QVirtioNetPCI {
diff --git a/tests/virtio-net-test.c b/tests/virtio-net-test.c
index 2d3630c..c58e670 100644
--- a/tests/virtio-net-test.c
+++ b/tests/virtio-net-test.c
@@ -136,8 +136,8 @@ static void send_recv_test(void *obj, void *data, QGuestAllocator *t_alloc)
{
QVirtioNet *net_if = obj;
QVirtioDevice *dev = net_if->vdev;
- QVirtQueue *rx = net_if->rx;
- QVirtQueue *tx = net_if->tx;
+ QVirtQueue *rx = net_if->queues[0];
+ QVirtQueue *tx = net_if->queues[1];
int *sv = data;
rx_test(dev, t_alloc, rx, sv[0]);
@@ -148,7 +148,7 @@ static void stop_cont_test(void *obj, void *data, QGuestAllocator *t_alloc)
{
QVirtioNet *net_if = obj;
QVirtioDevice *dev = net_if->vdev;
- QVirtQueue *rx = net_if->rx;
+ QVirtQueue *rx = net_if->queues[0];
int *sv = data;
rx_stop_cont_test(dev, t_alloc, rx, sv[0]);