On Thursday 30 March 2017 07:31 PM, Arnd Bergmann wrote: > On Thu, Mar 30, 2017 at 3:17 PM, Pankaj Dubey <pankaj.dubey@xxxxxxxxxxx> wrote: > >> * register the standard cpu IO areas >> */ >> -static void __init exynos_map_io(void) >> +static int __init exynos_fdt_map_scu(unsigned long node, const char *uname, >> + int depth, void *data) >> { >> - if (soc_is_exynos4()) >> - iotable_init(exynos4_iodesc, ARRAY_SIZE(exynos4_iodesc)); >> + if (!of_flat_dt_is_compatible(node, "samsung,exynos4210") && >> + !of_flat_dt_is_compatible(node, "samsung,exynos4212") && >> + !of_flat_dt_is_compatible(node, "samsung,exynos4412")) >> + return 0; >> + >> + iotable_init(exynos4_iodesc, ARRAY_SIZE(exynos4_iodesc)); >> + return 1; >> } > > This seems really overcomplicated. From what I can tell, this is only needed > to find the SCU address, but there are better ways to do that, either by > looking up the SCU in the DT at the time you actually need it, > or by calling scu_a9_get_base(). Indeed it's complicated and ugly, for the same reason I attempted to clean-up this part for Exynos SoC in patch series [1], which was accepted by Samsung maintainer Krzysztof and later during pull request rejected by ARM maintainers [2] [1]: https://www.spinics.net/lists/arm-kernel/msg540498.html [2]: http://lkml.iu.edu/hypermail/linux/kernel/1612.0/01508.html Given the argument we can't adopt getting base address of SCU completely via DT without breaking OLD dtbs at some point, difficult to simplify these stuffs. Please guide which is the best way to handle such stuffs. In fact I made another attempt [3] to cleanup this SCU related stuffs for other ARM based platforms, but we could not arrive on some consensus at that time. I will try to attempt it again soon. [3]: http://www.spinics.net/lists/arm-kernel/msg542351.html Thanks, Pankaj Dubey > > Arnd > > > -- To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html