Revert "virtio: Introduce virtio_add_queue_aio"
This reverts commit 872dd82c83
.
virtio_add_queue_aio is unused.
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
Reviewed-by: Cornelia Huck <cornelia.huck@de.ibm.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
This commit is contained in:
parent
ad07cd69ec
commit
f1ac6a5522
@ -97,7 +97,6 @@ struct VirtQueue
|
|||||||
uint16_t vector;
|
uint16_t vector;
|
||||||
VirtIOHandleOutput handle_output;
|
VirtIOHandleOutput handle_output;
|
||||||
VirtIOHandleOutput handle_aio_output;
|
VirtIOHandleOutput handle_aio_output;
|
||||||
bool use_aio;
|
|
||||||
VirtIODevice *vdev;
|
VirtIODevice *vdev;
|
||||||
EventNotifier guest_notifier;
|
EventNotifier guest_notifier;
|
||||||
EventNotifier host_notifier;
|
EventNotifier host_notifier;
|
||||||
@ -1287,9 +1286,8 @@ void virtio_queue_set_vector(VirtIODevice *vdev, int n, uint16_t vector)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static VirtQueue *virtio_add_queue_internal(VirtIODevice *vdev, int queue_size,
|
VirtQueue *virtio_add_queue(VirtIODevice *vdev, int queue_size,
|
||||||
VirtIOHandleOutput handle_output,
|
VirtIOHandleOutput handle_output)
|
||||||
bool use_aio)
|
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
@ -1306,28 +1304,10 @@ static VirtQueue *virtio_add_queue_internal(VirtIODevice *vdev, int queue_size,
|
|||||||
vdev->vq[i].vring.align = VIRTIO_PCI_VRING_ALIGN;
|
vdev->vq[i].vring.align = VIRTIO_PCI_VRING_ALIGN;
|
||||||
vdev->vq[i].handle_output = handle_output;
|
vdev->vq[i].handle_output = handle_output;
|
||||||
vdev->vq[i].handle_aio_output = NULL;
|
vdev->vq[i].handle_aio_output = NULL;
|
||||||
vdev->vq[i].use_aio = use_aio;
|
|
||||||
|
|
||||||
return &vdev->vq[i];
|
return &vdev->vq[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Add a virt queue and mark AIO.
|
|
||||||
* An AIO queue will use the AioContext based event interface instead of the
|
|
||||||
* default IOHandler and EventNotifier interface.
|
|
||||||
*/
|
|
||||||
VirtQueue *virtio_add_queue_aio(VirtIODevice *vdev, int queue_size,
|
|
||||||
VirtIOHandleOutput handle_output)
|
|
||||||
{
|
|
||||||
return virtio_add_queue_internal(vdev, queue_size, handle_output, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Add a normal virt queue (on the contrary to the AIO version above. */
|
|
||||||
VirtQueue *virtio_add_queue(VirtIODevice *vdev, int queue_size,
|
|
||||||
VirtIOHandleOutput handle_output)
|
|
||||||
{
|
|
||||||
return virtio_add_queue_internal(vdev, queue_size, handle_output, false);
|
|
||||||
}
|
|
||||||
|
|
||||||
void virtio_del_queue(VirtIODevice *vdev, int n)
|
void virtio_del_queue(VirtIODevice *vdev, int n)
|
||||||
{
|
{
|
||||||
if (n < 0 || n >= VIRTIO_QUEUE_MAX) {
|
if (n < 0 || n >= VIRTIO_QUEUE_MAX) {
|
||||||
@ -2073,21 +2053,11 @@ static void virtio_queue_host_notifier_read(EventNotifier *n)
|
|||||||
void virtio_queue_set_host_notifier_fd_handler(VirtQueue *vq, bool assign,
|
void virtio_queue_set_host_notifier_fd_handler(VirtQueue *vq, bool assign,
|
||||||
bool set_handler)
|
bool set_handler)
|
||||||
{
|
{
|
||||||
AioContext *ctx = qemu_get_aio_context();
|
|
||||||
if (assign && set_handler) {
|
if (assign && set_handler) {
|
||||||
if (vq->use_aio) {
|
event_notifier_set_handler(&vq->host_notifier, true,
|
||||||
aio_set_event_notifier(ctx, &vq->host_notifier, true,
|
|
||||||
virtio_queue_host_notifier_read);
|
virtio_queue_host_notifier_read);
|
||||||
} else {
|
|
||||||
event_notifier_set_handler(&vq->host_notifier, true,
|
|
||||||
virtio_queue_host_notifier_read);
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
if (vq->use_aio) {
|
event_notifier_set_handler(&vq->host_notifier, true, NULL);
|
||||||
aio_set_event_notifier(ctx, &vq->host_notifier, true, NULL);
|
|
||||||
} else {
|
|
||||||
event_notifier_set_handler(&vq->host_notifier, true, NULL);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (!assign) {
|
if (!assign) {
|
||||||
/* Test and clear notifier before after disabling event,
|
/* Test and clear notifier before after disabling event,
|
||||||
|
@ -152,9 +152,6 @@ typedef void (*VirtIOHandleOutput)(VirtIODevice *, VirtQueue *);
|
|||||||
VirtQueue *virtio_add_queue(VirtIODevice *vdev, int queue_size,
|
VirtQueue *virtio_add_queue(VirtIODevice *vdev, int queue_size,
|
||||||
VirtIOHandleOutput handle_output);
|
VirtIOHandleOutput handle_output);
|
||||||
|
|
||||||
VirtQueue *virtio_add_queue_aio(VirtIODevice *vdev, int queue_size,
|
|
||||||
VirtIOHandleOutput handle_output);
|
|
||||||
|
|
||||||
void virtio_del_queue(VirtIODevice *vdev, int n);
|
void virtio_del_queue(VirtIODevice *vdev, int n);
|
||||||
|
|
||||||
void *virtqueue_alloc_element(size_t sz, unsigned out_num, unsigned in_num);
|
void *virtqueue_alloc_element(size_t sz, unsigned out_num, unsigned in_num);
|
||||||
|
Loading…
Reference in New Issue
Block a user