qemu-devel
[Top][All Lists]
Advanced

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

Re: [PATCH v2 10/10] vfio: Pass HostIOMMUDevice to vIOMMU


From: Cédric Le Goater
Subject: Re: [PATCH v2 10/10] vfio: Pass HostIOMMUDevice to vIOMMU
Date: Mon, 15 Apr 2024 15:37:43 +0200
User-agent: Mozilla Thunderbird

On 4/8/24 10:12, Zhenzhong Duan wrote:
With HostIOMMUDevice passed, vIOMMU can check compatibility with host
IOMMU, call into IOMMUFD specific methods, etc.

Originally-by: Yi Liu <yi.l.liu@intel.com>
Signed-off-by: Nicolin Chen <nicolinc@nvidia.com>
Signed-off-by: Yi Sun <yi.y.sun@linux.intel.com>
Signed-off-by: Zhenzhong Duan <zhenzhong.duan@intel.com>

LGTM, waiting v3.


Thanks,

C.




---
  hw/vfio/pci.c | 20 +++++++++++++++-----
  1 file changed, 15 insertions(+), 5 deletions(-)

diff --git a/hw/vfio/pci.c b/hw/vfio/pci.c
index 64780d1b79..224501a86e 100644
--- a/hw/vfio/pci.c
+++ b/hw/vfio/pci.c
@@ -3111,11 +3111,17 @@ static void vfio_realize(PCIDevice *pdev, Error **errp)
vfio_bars_register(vdev); - ret = vfio_add_capabilities(vdev, errp);
+    ret = pci_device_set_iommu_device(pdev, vbasedev->hiod, errp);
      if (ret) {
+        error_prepend(errp, "Failed to set iommu_device: ");
          goto out_teardown;
      }
+ ret = vfio_add_capabilities(vdev, errp);
+    if (ret) {
+        goto out_unset_idev;
+    }
+
      if (vdev->vga) {
          vfio_vga_quirk_setup(vdev);
      }
@@ -3132,7 +3138,7 @@ static void vfio_realize(PCIDevice *pdev, Error **errp)
              error_setg(errp,
                         "cannot support IGD OpRegion feature on hotplugged "
                         "device");
-            goto out_teardown;
+            goto out_unset_idev;
          }
ret = vfio_get_dev_region_info(vbasedev,
@@ -3141,13 +3147,13 @@ static void vfio_realize(PCIDevice *pdev, Error **errp)
          if (ret) {
              error_setg_errno(errp, -ret,
                               "does not support requested IGD OpRegion 
feature");
-            goto out_teardown;
+            goto out_unset_idev;
          }
ret = vfio_pci_igd_opregion_init(vdev, opregion, errp);
          g_free(opregion);
          if (ret) {
-            goto out_teardown;
+            goto out_unset_idev;
          }
      }
@@ -3233,6 +3239,8 @@ out_deregister:
      if (vdev->intx.mmap_timer) {
          timer_free(vdev->intx.mmap_timer);
      }
+out_unset_idev:
+    pci_device_unset_iommu_device(pdev);
  out_teardown:
      vfio_teardown_msi(vdev);
      vfio_bars_exit(vdev);
@@ -3261,6 +3269,7 @@ static void vfio_instance_finalize(Object *obj)
  static void vfio_exitfn(PCIDevice *pdev)
  {
      VFIOPCIDevice *vdev = VFIO_PCI(pdev);
+    VFIODevice *vbasedev = &vdev->vbasedev;
vfio_unregister_req_notifier(vdev);
      vfio_unregister_err_notifier(vdev);
@@ -3275,7 +3284,8 @@ static void vfio_exitfn(PCIDevice *pdev)
      vfio_teardown_msi(vdev);
      vfio_pci_disable_rp_atomics(vdev);
      vfio_bars_exit(vdev);
-    vfio_migration_exit(&vdev->vbasedev);
+    vfio_migration_exit(vbasedev);
+    pci_device_unset_iommu_device(pdev);
  }
static void vfio_pci_reset(DeviceState *dev)




reply via email to

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