aboutsummaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/logicvc/logicvc_interface.c
diff options
context:
space:
mode:
authorJason Gunthorpe <[email protected]>2023-06-05 21:59:48 -0300
committerJoerg Roedel <[email protected]>2023-07-14 16:14:16 +0200
commitf188056352bcdcd4bec31c22baa00ba6568f1416 (patch)
treec8f0c5dbfe89dfad99da666d67cb201dec0c0d16 /drivers/gpu/drm/logicvc/logicvc_interface.c
parentfa08280364882c42993dc5d8394c467d76803fdb (diff)
iommu: Avoid locking/unlocking for iommu_probe_device()
Remove the race where a hotplug of a device into an existing group will have the device installed in the group->devices, but not yet attached to the group's current domain. Move the group attachment logic from iommu_probe_device() and put it under the same mutex that updates the group->devices list so everything is atomic under the lock. We retain the two step setup of the default domain for the bus_iommu_probe() case solely so that we have a more complete view of the group when creating the default domain for boot time devices. This is not generally necessary with the current code structure but seems to be supporting some odd corner cases like alias RID's and IOMMU_RESV_DIRECT or driver bugs returning different default_domain types for the same group. During bus_iommu_probe() the group will have a device list but both group->default_domain and group->domain will be NULL. Reviewed-by: Lu Baolu <[email protected]> Reviewed-by: Kevin Tian <[email protected]> Signed-off-by: Jason Gunthorpe <[email protected]> Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Joerg Roedel <[email protected]>
Diffstat (limited to 'drivers/gpu/drm/logicvc/logicvc_interface.c')
0 files changed, 0 insertions, 0 deletions