]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
iommu/msm: Claim bus ops on probe
authorRobin Murphy <robin.murphy@arm.com>
Tue, 9 Jan 2018 16:17:25 +0000 (16:17 +0000)
committerJoerg Roedel <jroedel@suse.de>
Wed, 17 Jan 2018 14:25:49 +0000 (15:25 +0100)
Since the MSM IOMMU driver now probes via DT exclusively rather than
platform data, dependent masters should be deferred until the IOMMU
itself is ready. Thus we can do away with the early initialisation
hook to unconditionally claim the bus ops, and instead do that only
once an IOMMU is actually probed. Furthermore, this should also make
the driver safe for multiplatform kernels on non-MSM SoCs.

Reviewed-by: Sricharan R <sricharan@codeaurora.org>
Signed-off-by: Robin Murphy <robin.murphy@arm.com>
Signed-off-by: Joerg Roedel <jroedel@suse.de>
drivers/iommu/msm_iommu.c

index 04f4d51ffacb1e50ae3f87f04fd3b23306f7b55b..dda1ce87a0704f4666556b3cfcb9710fa7c36d24 100644 (file)
@@ -823,6 +823,8 @@ static int msm_iommu_probe(struct platform_device *pdev)
                goto fail;
        }
 
+       bus_set_iommu(&platform_bus_type, &msm_iommu_ops);
+
        pr_info("device mapped at %p, irq %d with %d ctx banks\n",
                iommu->base, iommu->irq, iommu->ncb);
 
@@ -875,19 +877,7 @@ static void __exit msm_iommu_driver_exit(void)
 subsys_initcall(msm_iommu_driver_init);
 module_exit(msm_iommu_driver_exit);
 
-static int __init msm_iommu_init(void)
-{
-       bus_set_iommu(&platform_bus_type, &msm_iommu_ops);
-       return 0;
-}
-
-static int __init msm_iommu_of_setup(struct device_node *np)
-{
-       msm_iommu_init();
-       return 0;
-}
-
-IOMMU_OF_DECLARE(msm_iommu_of, "qcom,apq8064-iommu", msm_iommu_of_setup);
+IOMMU_OF_DECLARE(msm_iommu_of, "qcom,apq8064-iommu", NULL);
 
 MODULE_LICENSE("GPL v2");
 MODULE_AUTHOR("Stepan Moskovchenko <stepanm@codeaurora.org>");