[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH v6 13/19] vfio: Create host IOMMU device instance
From: |
Eric Auger |
Subject: |
Re: [PATCH v6 13/19] vfio: Create host IOMMU device instance |
Date: |
Mon, 3 Jun 2024 14:59:55 +0200 |
User-agent: |
Mozilla Thunderbird |
Hi Zhenzhong,
On 6/3/24 08:10, Zhenzhong Duan wrote:
> Create host IOMMU device instance in vfio_attach_device() and call
> .realize() to initialize it further.
I would squash this with the previous patch
Eric
>
> Suggested-by: Cédric Le Goater <clg@redhat.com>
> Signed-off-by: Zhenzhong Duan <zhenzhong.duan@intel.com>
> ---
> include/hw/vfio/vfio-common.h | 1 +
> hw/vfio/common.c | 16 +++++++++++++++-
> 2 files changed, 16 insertions(+), 1 deletion(-)
>
> diff --git a/include/hw/vfio/vfio-common.h b/include/hw/vfio/vfio-common.h
> index 56d1717211..c0851e83bb 100644
> --- a/include/hw/vfio/vfio-common.h
> +++ b/include/hw/vfio/vfio-common.h
> @@ -127,6 +127,7 @@ typedef struct VFIODevice {
> OnOffAuto pre_copy_dirty_page_tracking;
> bool dirty_pages_supported;
> bool dirty_tracking;
> + HostIOMMUDevice *hiod;
> int devid;
> IOMMUFDBackend *iommufd;
> } VFIODevice;
> diff --git a/hw/vfio/common.c b/hw/vfio/common.c
> index f9619a1dfb..f20a7b5bba 100644
> --- a/hw/vfio/common.c
> +++ b/hw/vfio/common.c
> @@ -1528,6 +1528,7 @@ bool vfio_attach_device(char *name, VFIODevice
> *vbasedev,
> {
> const VFIOIOMMUClass *ops =
> VFIO_IOMMU_CLASS(object_class_by_name(TYPE_VFIO_IOMMU_LEGACY));
> + HostIOMMUDevice *hiod;
>
> if (vbasedev->iommufd) {
> ops =
> VFIO_IOMMU_CLASS(object_class_by_name(TYPE_VFIO_IOMMU_IOMMUFD));
> @@ -1535,7 +1536,19 @@ bool vfio_attach_device(char *name, VFIODevice
> *vbasedev,
>
> assert(ops);
>
> - return ops->attach_device(name, vbasedev, as, errp);
> + if (!ops->attach_device(name, vbasedev, as, errp)) {
> + return false;
> + }
> +
> + hiod = HOST_IOMMU_DEVICE(object_new(ops->hiod_typename));
> + if (!HOST_IOMMU_DEVICE_GET_CLASS(hiod)->realize(hiod, vbasedev, errp)) {
> + object_unref(hiod);
> + ops->detach_device(vbasedev);
> + return false;
> + }
> + vbasedev->hiod = hiod;
> +
> + return true;
> }
>
> void vfio_detach_device(VFIODevice *vbasedev)
> @@ -1543,5 +1556,6 @@ void vfio_detach_device(VFIODevice *vbasedev)
> if (!vbasedev->bcontainer) {
> return;
> }
> + object_unref(vbasedev->hiod);
> vbasedev->bcontainer->ops->detach_device(vbasedev);
> }
- [PATCH v6 11/19] backends/iommufd: Implement HostIOMMUDeviceClass::get_cap() handler, (continued)
- [PATCH v6 11/19] backends/iommufd: Implement HostIOMMUDeviceClass::get_cap() handler, Zhenzhong Duan, 2024/06/03
- Re: [PATCH v6 11/19] backends/iommufd: Implement HostIOMMUDeviceClass::get_cap() handler, Eric Auger, 2024/06/03
- Re: [PATCH v6 11/19] backends/iommufd: Implement HostIOMMUDeviceClass::get_cap() handler, Cédric Le Goater, 2024/06/03
- RE: [PATCH v6 11/19] backends/iommufd: Implement HostIOMMUDeviceClass::get_cap() handler, Duan, Zhenzhong, 2024/06/03
- Re: [PATCH v6 11/19] backends/iommufd: Implement HostIOMMUDeviceClass::get_cap() handler, Eric Auger, 2024/06/04
- RE: [PATCH v6 11/19] backends/iommufd: Implement HostIOMMUDeviceClass::get_cap() handler, Duan, Zhenzhong, 2024/06/04
- Re: [PATCH v6 11/19] backends/iommufd: Implement HostIOMMUDeviceClass::get_cap() handler, Eric Auger, 2024/06/04
[PATCH v6 10/19] vfio/container: Implement HostIOMMUDeviceClass::get_cap() handler, Zhenzhong Duan, 2024/06/03
[PATCH v6 12/19] vfio: Introduce VFIOIOMMUClass::hiod_typename attribute, Zhenzhong Duan, 2024/06/03
[PATCH v6 13/19] vfio: Create host IOMMU device instance, Zhenzhong Duan, 2024/06/03
- Re: [PATCH v6 13/19] vfio: Create host IOMMU device instance,
Eric Auger <=
[PATCH v6 14/19] hw/pci: Introduce helper function pci_device_get_iommu_bus_devfn(), Zhenzhong Duan, 2024/06/03
[PATCH v6 15/19] hw/pci: Introduce pci_device_[set|unset]_iommu_device(), Zhenzhong Duan, 2024/06/03
[PATCH v6 16/19] vfio/pci: Pass HostIOMMUDevice to vIOMMU, Zhenzhong Duan, 2024/06/03
[PATCH v6 18/19] intel_iommu: Implement [set|unset]_iommu_device() callbacks, Zhenzhong Duan, 2024/06/03