Skip to content

Commit eda1a94

Browse files
jgunthorpejoergroedel
authored andcommitted
iommu: Mark dev_iommu_priv_set() with a lockdep
A perfect driver would only call dev_iommu_priv_set() from its probe callback. We've made it functionally correct to call it from the of_xlate by adding a lock around that call. lockdep assert that iommu_probe_device_lock is held to discourage misuse. Exclude PPC kernels with CONFIG_FSL_PAMU turned on because FSL_PAMU uses a global static for its priv and abuses priv for its domain. Remove the pointless stores of NULL, all these are on paths where the core code will free dev->iommu after the op returns. Reviewed-by: Lu Baolu <baolu.lu@linux.intel.com> Reviewed-by: Jerry Snitselaar <jsnitsel@redhat.com> Tested-by: Hector Martin <marcan@marcan.st> Signed-off-by: Jason Gunthorpe <jgg@nvidia.com> Link: https://lore.kernel.org/r/5-v2-16e4def25ebb+820-iommu_fwspec_p1_jgg@nvidia.com Signed-off-by: Joerg Roedel <jroedel@suse.de>
1 parent 64945d1 commit eda1a94

8 files changed

Lines changed: 10 additions & 12 deletions

File tree

drivers/iommu/amd/iommu.c

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -551,8 +551,6 @@ static void amd_iommu_uninit_device(struct device *dev)
551551
if (dev_data->domain)
552552
detach_device(dev);
553553

554-
dev_iommu_priv_set(dev, NULL);
555-
556554
/*
557555
* We keep dev_data around for unplugged devices and reuse it when the
558556
* device is re-plugged - not doing so would introduce a ton of races.

drivers/iommu/apple-dart.c

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -740,7 +740,6 @@ static void apple_dart_release_device(struct device *dev)
740740
{
741741
struct apple_dart_master_cfg *cfg = dev_iommu_priv_get(dev);
742742

743-
dev_iommu_priv_set(dev, NULL);
744743
kfree(cfg);
745744
}
746745

drivers/iommu/arm/arm-smmu-v3/arm-smmu-v3.c

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2695,7 +2695,6 @@ static struct iommu_device *arm_smmu_probe_device(struct device *dev)
26952695

26962696
err_free_master:
26972697
kfree(master);
2698-
dev_iommu_priv_set(dev, NULL);
26992698
return ERR_PTR(ret);
27002699
}
27012700

drivers/iommu/arm/arm-smmu/arm-smmu.c

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1420,7 +1420,6 @@ static void arm_smmu_release_device(struct device *dev)
14201420

14211421
arm_smmu_rpm_put(cfg->smmu);
14221422

1423-
dev_iommu_priv_set(dev, NULL);
14241423
kfree(cfg);
14251424
}
14261425

drivers/iommu/intel/iommu.c

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -4461,7 +4461,6 @@ static struct iommu_device *intel_iommu_probe_device(struct device *dev)
44614461
ret = intel_pasid_alloc_table(dev);
44624462
if (ret) {
44634463
dev_err(dev, "PASID table allocation failed\n");
4464-
dev_iommu_priv_set(dev, NULL);
44654464
kfree(info);
44664465
return ERR_PTR(ret);
44674466
}
@@ -4479,7 +4478,6 @@ static void intel_iommu_release_device(struct device *dev)
44794478
dmar_remove_one_dev_info(dev);
44804479
intel_pasid_free_table(dev);
44814480
intel_iommu_debugfs_remove_dev(info);
4482-
dev_iommu_priv_set(dev, NULL);
44834481
kfree(info);
44844482
set_dma_ops(dev, NULL);
44854483
}

drivers/iommu/iommu.c

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -387,6 +387,15 @@ static u32 dev_iommu_get_max_pasids(struct device *dev)
387387
return min_t(u32, max_pasids, dev->iommu->iommu_dev->max_pasids);
388388
}
389389

390+
void dev_iommu_priv_set(struct device *dev, void *priv)
391+
{
392+
/* FSL_PAMU does something weird */
393+
if (!IS_ENABLED(CONFIG_FSL_PAMU))
394+
lockdep_assert_held(&iommu_probe_device_lock);
395+
dev->iommu->priv = priv;
396+
}
397+
EXPORT_SYMBOL_GPL(dev_iommu_priv_set);
398+
390399
/*
391400
* Init the dev->iommu and dev->iommu_group in the struct device and get the
392401
* driver probed

drivers/iommu/omap-iommu.c

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1719,7 +1719,6 @@ static void omap_iommu_release_device(struct device *dev)
17191719
if (!dev->of_node || !arch_data)
17201720
return;
17211721

1722-
dev_iommu_priv_set(dev, NULL);
17231722
kfree(arch_data);
17241723

17251724
}

include/linux/iommu.h

Lines changed: 1 addition & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -850,10 +850,7 @@ static inline void *dev_iommu_priv_get(struct device *dev)
850850
return NULL;
851851
}
852852

853-
static inline void dev_iommu_priv_set(struct device *dev, void *priv)
854-
{
855-
dev->iommu->priv = priv;
856-
}
853+
void dev_iommu_priv_set(struct device *dev, void *priv);
857854

858855
extern struct mutex iommu_probe_device_lock;
859856
int iommu_probe_device(struct device *dev);

0 commit comments

Comments
 (0)