Changeset
hw/virtio/vhost.c | 4 ++++
1 file changed, 4 insertions(+)
Git apply log
Switched to a new branch '1523895458-475479-1-git-send-email-mst@redhat.com'
Applying: vhost: do not verify ring mappings when IOMMU is enabled
To https://github.com/patchew-project/qemu
 * [new tag]         patchew/1523895458-475479-1-git-send-email-mst@redhat.com -> patchew/1523895458-475479-1-git-send-email-mst@redhat.com
Test passed: checkpatch

loading

Test passed: docker-mingw@fedora

loading

Test passed: docker-build@min-glib

loading

Test passed: s390x

loading

[Qemu-devel] [PULL 0/1] vhost: bugfix
Posted by Michael S. Tsirkin, 3 days ago
The following changes since commit 38e83a71d02e026d4a6d0ab1ef9855c4924c2c68:

  Update version for v2.12.0-rc3 release (2018-04-11 19:03:24 +0100)

are available in the git repository at:

  git://git.kernel.org/pub/scm/virt/kvm/mst/qemu.git tags/for_upstream

for you to fetch changes up to aebbdbee559389a9f0d0e56670b9332534b6bb9b:

  vhost: do not verify ring mappings when IOMMU is enabled (2018-04-16 19:11:38 +0300)

----------------------------------------------------------------
vhost: bugfix

This fixes a regression in vhost.

Signed-off-by: Michael S. Tsirkin <mst@redhat.com>

----------------------------------------------------------------
Jason Wang (1):
      vhost: do not verify ring mappings when IOMMU is enabled

 hw/virtio/vhost.c | 4 ++++
 1 file changed, 4 insertions(+)


Re: [Qemu-devel] [PULL 0/1] vhost: bugfix
Posted by Peter Maydell, 2 days ago
On 16 April 2018 at 17:47, Michael S. Tsirkin <mst@redhat.com> wrote:
> The following changes since commit 38e83a71d02e026d4a6d0ab1ef9855c4924c2c68:
>
>   Update version for v2.12.0-rc3 release (2018-04-11 19:03:24 +0100)
>
> are available in the git repository at:
>
>   git://git.kernel.org/pub/scm/virt/kvm/mst/qemu.git tags/for_upstream
>
> for you to fetch changes up to aebbdbee559389a9f0d0e56670b9332534b6bb9b:
>
>   vhost: do not verify ring mappings when IOMMU is enabled (2018-04-16 19:11:38 +0300)
>
> ----------------------------------------------------------------
> vhost: bugfix
>
> This fixes a regression in vhost.
>
> Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
>
> ----------------------------------------------------------------
> Jason Wang (1):
>       vhost: do not verify ring mappings when IOMMU is enabled
>
>  hw/virtio/vhost.c | 4 ++++
>  1 file changed, 4 insertions(+)

Applied, thanks.

-- PMM

[Qemu-devel] [PULL 1/1] vhost: do not verify ring mappings when IOMMU is enabled
Posted by Michael S. Tsirkin, 3 days ago
From: Jason Wang <jasowang@redhat.com>

When IOMMU is enabled, we store virtqueue metadata as iova (though it
may has _phys suffix) and access them through dma helpers. Any
translation failures could be reported by IOMMU.

In this case, trying to validate iova against gpa won't work and will
cause a false error reporting. So this patch bypasses the ring
verification if IOMMU is enabled which is similar to the behavior
before 0ca1fd2d6878 that calls vhost_memory_map() which is a nop when
IOMMU is enabled.

Fixes: 0ca1fd2d6878 ("vhost: Simplify ring verification checks")
Cc: Dr. David Alan Gilbert <dgilbert@redhat.com>
Cc: Igor Mammedov <imammedo@redhat.com>
Cc: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Jason Wang <jasowang@redhat.com>
Reviewed-by: Igor Mammedov <imammedo@redhat.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
---
 hw/virtio/vhost.c | 4 ++++
 1 file changed, 4 insertions(+)

diff --git a/hw/virtio/vhost.c b/hw/virtio/vhost.c
index f51bf57..9d5850a 100644
--- a/hw/virtio/vhost.c
+++ b/hw/virtio/vhost.c
@@ -342,6 +342,10 @@ static int vhost_verify_ring_mappings(struct vhost_dev *dev,
         "used ring"
     };
 
+    if (vhost_dev_has_iommu(dev)) {
+        return 0;
+    }
+
     for (i = 0; i < dev->nvqs; ++i) {
         struct vhost_virtqueue *vq = dev->vqs + i;
 
-- 
MST