qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH v3 05/13] vfio/common: Add helper to validate iova/end agains


From: Cédric Le Goater
Subject: Re: [PATCH v3 05/13] vfio/common: Add helper to validate iova/end against hostwin
Date: Mon, 6 Mar 2023 14:24:56 +0100
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.8.0

On 3/4/23 02:43, Joao Martins wrote:
In preparation to be used in device dirty tracking, move the code that
finds the container host DMA window against a iova range.  This avoids
duplication on the common checks across listener callbacks.

Signed-off-by: Joao Martins <joao.m.martins@oracle.com>

Reviewed-by: Cédric Le Goater <clg@redhat.com>

Thanks,

C.

---
  hw/vfio/common.c | 38 ++++++++++++++++++++------------------
  1 file changed, 20 insertions(+), 18 deletions(-)

diff --git a/hw/vfio/common.c b/hw/vfio/common.c
index 151e7f40b73d..80f3a1c44a01 100644
--- a/hw/vfio/common.c
+++ b/hw/vfio/common.c
@@ -903,6 +903,22 @@ static void 
vfio_unregister_ram_discard_listener(VFIOContainer *container,
      g_free(vrdl);
  }
+static VFIOHostDMAWindow *vfio_find_hostwin(VFIOContainer *container,
+                                            hwaddr iova, hwaddr end)
+{
+    VFIOHostDMAWindow *hostwin;
+    bool hostwin_found = false;
+
+    QLIST_FOREACH(hostwin, &container->hostwin_list, hostwin_next) {
+        if (hostwin->min_iova <= iova && end <= hostwin->max_iova) {
+            hostwin_found = true;
+            break;
+        }
+    }
+
+    return hostwin_found ? hostwin : NULL;
+}
+
  static bool vfio_known_safe_misalignment(MemoryRegionSection *section)
  {
      MemoryRegion *mr = section->mr;
@@ -928,7 +944,6 @@ static void vfio_listener_region_add(MemoryListener 
*listener,
      void *vaddr;
      int ret;
      VFIOHostDMAWindow *hostwin;
-    bool hostwin_found;
      Error *err = NULL;
if (vfio_listener_skipped_section(section)) {
@@ -1029,15 +1044,8 @@ static void vfio_listener_region_add(MemoryListener 
*listener,
  #endif
      }
- hostwin_found = false;
-    QLIST_FOREACH(hostwin, &container->hostwin_list, hostwin_next) {
-        if (hostwin->min_iova <= iova && end <= hostwin->max_iova) {
-            hostwin_found = true;
-            break;
-        }
-    }
-
-    if (!hostwin_found) {
+    hostwin = vfio_find_hostwin(container, iova, end);
+    if (!hostwin) {
          error_setg(&err, "Container %p can't map guest IOVA region"
                     " 0x%"HWADDR_PRIx"..0x%"HWADDR_PRIx, container, iova, end);
          goto fail;
@@ -1239,15 +1247,9 @@ static void vfio_listener_region_del(MemoryListener 
*listener,
      if (memory_region_is_ram_device(section->mr)) {
          hwaddr pgmask;
          VFIOHostDMAWindow *hostwin;
-        bool hostwin_found = false;
- QLIST_FOREACH(hostwin, &container->hostwin_list, hostwin_next) {
-            if (hostwin->min_iova <= iova && end <= hostwin->max_iova) {
-                hostwin_found = true;
-                break;
-            }
-        }
-        assert(hostwin_found); /* or region_add() would have failed */
+        hostwin = vfio_find_hostwin(container, iova, end);
+        assert(hostwin); /* or region_add() would have failed */
pgmask = (1ULL << ctz64(hostwin->iova_pgsizes)) - 1;
          try_unmap = !((iova & pgmask) || (int128_get64(llsize) & pgmask));




reply via email to

[Prev in Thread] Current Thread [Next in Thread]