Re: [PATCH RFC v1 1/2] iommu: Introduce iommu_dev_reset_prepare() and iommu_dev_reset_done()
From: Robin Murphy
Date: Tue Jun 10 2025 - 10:44:43 EST
On 2025-06-10 2:04 pm, Jason Gunthorpe wrote:
On Tue, Jun 10, 2025 at 12:07:00AM -0700, Nicolin Chen wrote:
On Tue, Jun 10, 2025 at 12:26:07PM +0800, Baolu Lu wrote:
On 6/10/25 02:45, Nicolin Chen wrote:
+ ops = dev_iommu_ops(dev);
Should this be protected by group->mutext?
Not seemingly, but should require the iommu_probe_device_lock I
think.
group and ops are not permitted to change while a driver is attached..
IIRC the FLR code in PCI doesn't always ensure that (due to the sysfs
paths), so yeah, this looks troubled. iommu_probe_device_lock perhaps
would fix it.
No, iommu_probe_device_lock is for protecting access to dev->iommu in
the probe path until the device is definitively assigned to a group (or
not). Fundamentally it defends against multiple sources triggering a
probe of the same device in parallel - once the device *is* probed it is
no longer relevant, and the group mutex is the right thing to protect
all subsequent operations.
Also I'm still working towards getting rid of iommu_probe_device_lock as
soon as I can because it's horrid... I now have most of a plan for
making it safe to rely on device_lock() for probe, which should nicely
solve the dev->driver races as well.
Thanks,
Robin.