iommu: Avoid more races around device probe
authorRobin Murphy <robin.murphy@arm.com>
Wed, 15 Nov 2023 18:25:44 +0000 (18:25 +0000)
committerJoerg Roedel <jroedel@suse.de>
Mon, 27 Nov 2023 09:53:55 +0000 (10:53 +0100)
commita2e7e59a94269484a83386972ca07c22fd188854
tree342d6c7af571cd2c96c740b3b125097c487d92c1
parenta99583e2aff64baf27b04b7d3a0341a52bf8e047
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>
drivers/acpi/scan.c
drivers/iommu/iommu.c
drivers/iommu/of_iommu.c
include/linux/iommu.h