On 12/02/2024 16:27, Jason Gunthorpe wrote: > On Mon, Feb 12, 2024 at 01:56:37PM +0000, Joao Martins wrote: >> There's generally two modes of operation for IOMMUFD: >> >> * The simple user API which intends to perform relatively simple things >> with IOMMUs e.g. DPDK. It generally creates an IOAS and attach to VFIO >> and mainly performs IOAS_MAP and UNMAP. >> >> * The native IOMMUFD API where you have fine grained control of the >> IOMMU domain and model it accordingly. This is where most new feature >> are being steered to. >> >> For dirty tracking 2) is required, as it needs to ensure that >> the stage-2/parent IOMMU domain will only attach devices >> that support dirty tracking (so far it is all homogeneous in x86, likely >> not the case for smmuv3). Such invariant on dirty tracking provides a >> useful guarantee to VMMs that will refuse incompatible device >> attachments for IOMMU domains. >> >> For dirty tracking such property is enabled/enforced via HWPT_ALLOC, >> which is responsible for creating an IOMMU domain. This is contrast to >> the 'simple API' where the IOMMU domain is created by IOMMUFD >> automatically when it attaches to VFIO (usually referred as autodomains) >> >> To support dirty tracking with the advanced IOMMUFD API, it needs >> similar logic, where IOMMU domains are created and devices attached to >> compatible domains. Essentially mimmicing kernel >> iommufd_device_auto_get_domain(). If this fails (i.e. mdevs) it falls back >> to IOAS attach. >> >> Signed-off-by: Joao Martins <joao.m.mart...@oracle.com> >> --- >> Right now the only alternative to a userspace autodomains implementation >> is to mimmicing all the flags being added to HWPT_ALLOC but into VFIO >> IOAS attach. > > It was my expectation that VMM userspace would implement direct hwpt > support. This is needed in all kinds of cases going forward because > hwpt allocation is not uniform across iommu instances and managing > this in the kernel is only feasible for simpler cases. Dirty tracking > would be one of them. >
/me nods >> +int iommufd_backend_alloc_hwpt(int iommufd, uint32_t dev_id, >> + uint32_t pt_id, uint32_t flags, >> + uint32_t data_type, uint32_t data_len, >> + void *data_ptr, uint32_t *out_hwpt) >> +{ >> + int ret; >> + struct iommu_hwpt_alloc alloc_hwpt = { >> + .size = sizeof(struct iommu_hwpt_alloc), >> + .flags = flags, >> + .dev_id = dev_id, >> + .pt_id = pt_id, >> + .data_type = data_type, >> + .data_len = data_len, >> + .data_uptr = (uint64_t)data_ptr, >> + .__reserved = 0, > > Unless the coding style requirs this it is not necessary to zero in > the __reserved within a bracketed in initializer.. > Ah yes; and no other helper is doing this, so definitely doesn't look code style. I'll remove it. >> +static int iommufd_cdev_autodomains_get(VFIODevice *vbasedev, >> + VFIOIOMMUFDContainer *container, >> + Error **errp) >> +{ >> + int iommufd = vbasedev->iommufd_dev.iommufd->fd; >> + VFIOIOASHwpt *hwpt; >> + Error *err = NULL; >> + int ret = -EINVAL; >> + uint32_t hwpt_id; >> + >> + /* Try to find a domain */ >> + QLIST_FOREACH(hwpt, &container->hwpt_list, next) { >> + ret = iommufd_cdev_attach_ioas_hwpt(vbasedev, hwpt->hwpt_id, &err); >> + if (ret) { >> + /* -EINVAL means the domain is incompatible with the device. */ >> + if (ret == -EINVAL) { > > Please send a kernel kdoc patch to document this.. > Ack > The approach looks good to me > > The nesting patches surely need this too? >From what I understand, yes, but they seem to be able to hid this inside intel-iommu for the parent hwpt allocation somehow. I'll let them comment;