From: Sasha Levin Date: Fri, 27 May 2011 16:18:38 +0000 (+0300) Subject: kvm tools: Use ioeventfd in virtio-blk X-Git-Tag: next-20110824~3^2~249 X-Git-Url: https://git.karo-electronics.de/?a=commitdiff_plain;h=ca7dff1b7a53be43bb3063ebc46e65aec301e381;p=karo-tx-linux.git kvm tools: Use ioeventfd in virtio-blk Use ioeventfds to receive notifications of IO events in virtio-blk. Doing so prevents an exit every time we read/write from/to the virtio disk. Signed-off-by: Sasha Levin Signed-off-by: Pekka Enberg --- diff --git a/tools/kvm/virtio/blk.c b/tools/kvm/virtio/blk.c index a8f9d8c9c885..8d54f5a04879 100644 --- a/tools/kvm/virtio/blk.c +++ b/tools/kvm/virtio/blk.c @@ -10,6 +10,7 @@ #include "kvm/kvm.h" #include "kvm/pci.h" #include "kvm/threadpool.h" +#include "kvm/ioeventfd.h" #include #include @@ -243,11 +244,19 @@ static struct ioport_operations virtio_blk_io_ops = { .io_out = virtio_blk_pci_io_out, }; +static void ioevent_callback(struct kvm *kvm, void *param) +{ + struct blk_dev_job *job = param; + + thread_pool__do_job(job->job_id); +} + void virtio_blk__init(struct kvm *kvm, struct disk_image *disk) { u16 blk_dev_base_addr; - u8 dev, pin, line; + u8 dev, pin, line, i; struct blk_dev *bdev; + struct ioevent ioevent; if (!disk) return; @@ -293,6 +302,20 @@ void virtio_blk__init(struct kvm *kvm, struct disk_image *disk) bdev->pci_hdr.irq_line = line; pci__register(&bdev->pci_hdr, dev); + + for (i = 0; i < NUM_VIRT_QUEUES; i++) { + ioevent = (struct ioevent) { + .io_addr = blk_dev_base_addr + VIRTIO_PCI_QUEUE_NOTIFY, + .io_len = sizeof(u16), + .fn = ioevent_callback, + .datamatch = i, + .fn_ptr = &bdev->jobs[i], + .fn_kvm = kvm, + .fd = eventfd(0, 0), + }; + + ioeventfd__add_event(&ioevent); + } } void virtio_blk__init_all(struct kvm *kvm) @@ -309,6 +332,7 @@ void virtio_blk__delete_all(struct kvm *kvm) struct blk_dev *bdev; bdev = list_first_entry(&bdevs, struct blk_dev, list); + ioeventfd__del_event(bdev->base_addr + VIRTIO_PCI_QUEUE_NOTIFY, 0); list_del(&bdev->list); free(bdev); }