[PATCH] iommu/exynos: Don't unconditionally steal bus ops
Marek Szyprowski
m.szyprowski at samsung.com
Tue Jan 9 01:59:19 PST 2018
Hi Robin,
On 2018-01-08 20:27, Robin Murphy wrote:
> Removing the early device registration hook overlooked the fact that
> it only ran conditionally on a compatible device being present in the
> DT. With exynos_iommu_init() now running as an unconditional initcall,
> problems arise on non-Exynos systems when other IOMMU drivers find
> themselves unable to install their ops on the platform bus, or at worst
> the Exynos ops get called with someone else's domain and all hell breaks
> loose.
>
> Fix this by delaying the setting of bus ops until an Exynos IOMMU is
> actually found, to replicate the previous order of events.
>
> Fixes: 928055a01b3f ("iommu/exynos: Remove custom platform device registration code")
> Signed-off-by: Robin Murphy <robin.murphy at arm.com>
Right, my fault. However I will prefer to resurrect code added initially
by commit a7b67cd5d9af "iommu/exynos: Play nice in multi-platform builds".
There is no need to do all the things done in the exynos_iommu_init on
non-Exynos platforms.
> ---
> drivers/iommu/exynos-iommu.c | 16 +++++++---------
> 1 file changed, 7 insertions(+), 9 deletions(-)
>
> diff --git a/drivers/iommu/exynos-iommu.c b/drivers/iommu/exynos-iommu.c
> index 6a96a4c42153..e9e756156429 100644
> --- a/drivers/iommu/exynos-iommu.c
> +++ b/drivers/iommu/exynos-iommu.c
> @@ -574,6 +574,12 @@ static int __init exynos_sysmmu_probe(struct platform_device *pdev)
> struct sysmmu_drvdata *data;
> struct resource *res;
>
> + if (platform_bus_type->iommu_ops != &exynos_iommu_ops) {
> + ret = bus_set_iommu(&platform_bus_type, &exynos_iommu_ops);
> + if (ret)
> + return ret;
> + }
> +
> data = devm_kzalloc(dev, sizeof(*data), GFP_KERNEL);
> if (!data)
> return -ENOMEM;
> @@ -1367,16 +1373,8 @@ static int __init exynos_iommu_init(void)
> goto err_zero_lv2;
> }
>
> - ret = bus_set_iommu(&platform_bus_type, &exynos_iommu_ops);
> - if (ret) {
> - pr_err("%s: Failed to register exynos-iommu driver.\n",
> - __func__);
> - goto err_set_iommu;
> - }
> -
> return 0;
> -err_set_iommu:
> - kmem_cache_free(lv2table_kmem_cache, zero_lv2_table);
> +
> err_zero_lv2:
> platform_driver_unregister(&exynos_sysmmu_driver);
> err_reg_driver:
Best regards
--
Marek Szyprowski, PhD
Samsung R&D Institute Poland
More information about the linux-arm-kernel
mailing list