diff options
author | Robin Murphy <robin.murphy@arm.com> | 2023-11-15 19:25:44 +0100 |
---|---|---|
committer | Joerg Roedel <jroedel@suse.de> | 2023-11-27 10:53:55 +0100 |
commit | a2e7e59a94269484a83386972ca07c22fd188854 (patch) | |
tree | 342d6c7af571cd2c96c740b3b125097c487d92c1 /drivers/rapidio | |
parent | MAINTAINERS: list all Qualcomm IOMMU drivers in the QUALCOMM IOMMU entry (diff) | |
download | linux-a2e7e59a94269484a83386972ca07c22fd188854.tar.xz linux-a2e7e59a94269484a83386972ca07c22fd188854.zip |
iommu: Avoid more races around device probe
It turns out there are more subtle races beyond just the main part of
__iommu_probe_device() itself running in parallel - the dev_iommu_free()
on the way out of an unsuccessful probe can still manage to trip up
concurrent accesses to a device's fwspec. Thus, extend the scope of
iommu_probe_device_lock() to also serialise fwspec creation and initial
retrieval.
Reported-by: Zhenhua Huang <quic_zhenhuah@quicinc.com>
Link: https://lore.kernel.org/linux-iommu/e2e20e1c-6450-4ac5-9804-b0000acdf7de@quicinc.com/
Fixes: 01657bc14a39 ("iommu: Avoid races around device probe")
Signed-off-by: Robin Murphy <robin.murphy@arm.com>
Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Reviewed-by: André Draszik <andre.draszik@linaro.org>
Tested-by: André Draszik <andre.draszik@linaro.org>
Link: https://lore.kernel.org/r/16f433658661d7cadfea51e7c65da95826112a2b.1700071477.git.robin.murphy@arm.com
Cc: stable@vger.kernel.org
Signed-off-by: Joerg Roedel <jroedel@suse.de>
Diffstat (limited to 'drivers/rapidio')
0 files changed, 0 insertions, 0 deletions