[PATCH v1 14/14] iommu/arm-smmu-v3: Add arm_smmu_cache_invalidate_user
Jason Gunthorpe
jgg at nvidia.com
Mon Mar 20 15:19:34 PDT 2023
On Mon, Mar 20, 2023 at 02:22:42PM -0700, Nicolin Chen wrote:
> > > What QEMU does is trapping an SMMU_CMD_CFGI_STE command to send
> > > the host an HWPT alloc ioctl. The former one is based on an SID
> > > or a device, while the latter one is based on ASID.
> > >
> > > So the correct way should be for QEMU to maintain an ASID-based
> > > list, corresponding to the s1ctxptr from STEs, and only send an
> > > alloc ioctl upon a new s1ctxptr/ASID. Meanwhile, at every trap
> > > of SMMU_CMD_CFGI_STE, it calls a separate ioctl to tie a vSID to
> > > a dev_id (and pSID accordingly).
> >
> > It is not ASID, it just s1ctxptr's - de-duplicate them.
>
> SMMU has "ASID" too. And it's one per CD table. It can be also
> seen as one per iommu_domain.
Yes and no, the ASID in ARM is per CDE not per CD table. It is
associated with each TTB0/1 pointer and is effectively the handle for
the IOPTEs.
Every iommu_domain that has a TTB0/1 (ie represents IOPTEs) should
have an ASID.
The "nested" iommu_domains don't represent IOPTEs and don't have ASIDs.
The nested domains are just "shadow STEs".
> > Do something about SMMUv3 not being able to interwork iommu_domains
> > across instances
>
> I don't follow this one. Device instances?
There is some code that makes sure each iommu_domain is hooked to only
one smmu driver instance, IIRC.
> IIUIC, the ioctl for the link of vSID/dev_id should happen at
> the stage when boot boots, while the HWPT alloc ioctl happens
> at CFGI_STE.
Yes
> > > What could be a good prototype of the ioctl? Would it be a VFIO
> > > device one or IOMMUFD one?
> >
> > If we load the vSID table it should be a iommufd one, linked to the
> > ARM SMMUv3 driver and probably take in a pointer to an array of
> > vSID/dev_id pairs. Maybe an add/remove type of operation.
>
> Will try some solution.
It is only necessary if you want to do batching
For non-batching the SID invalidation should be done differently with
a device_id input instead. That is a bit tricky to organize as you
want iommufd to get back a 'struct device *' from the ID.
Jason
More information about the linux-arm-kernel
mailing list