KVM: Calculate available entries in coalesced mmio ring
authorAvi Kivity <avi@redhat.com>
Thu, 4 Jun 2009 15:09:08 +0000 (18:09 +0300)
committerAvi Kivity <avi@redhat.com>
Thu, 10 Sep 2009 05:32:47 +0000 (08:32 +0300)
Instead of checking whether we'll wrap around, calculate how many entries
are available, and check whether we have enough (just one) for the pending
mmio.

By itself, this doesn't change anything, but it paves the way for making
this function lockless.

Signed-off-by: Avi Kivity <avi@redhat.com>
virt/kvm/coalesced_mmio.c

index c4c7ec2f9d300dfffd54badac315b026de7caea6..7549068009994ea1c64d2e7aa98f11b7265e9f98 100644 (file)
@@ -24,7 +24,8 @@ static int coalesced_mmio_in_range(struct kvm_io_device *this,
 {
        struct kvm_coalesced_mmio_dev *dev = to_mmio(this);
        struct kvm_coalesced_mmio_zone *zone;
-       int next;
+       struct kvm_coalesced_mmio_ring *ring;
+       unsigned avail;
        int i;
 
        if (!is_write)
@@ -40,10 +41,9 @@ static int coalesced_mmio_in_range(struct kvm_io_device *this,
         * check if we don't meet the first used entry
         * there is always one unused entry in the buffer
         */
-
-       next = (dev->kvm->coalesced_mmio_ring->last + 1) %
-                                                       KVM_COALESCED_MMIO_MAX;
-       if (next == dev->kvm->coalesced_mmio_ring->first) {
+       ring = dev->kvm->coalesced_mmio_ring;
+       avail = (ring->first - ring->last - 1) % KVM_COALESCED_MMIO_MAX;
+       if (avail < 1) {
                /* full */
                return 0;
        }