On Friday 11 April 2014 16:09:57 Chanwoo Choi wrote: > On 04/11/2014 03:32 PM, Chanwoo Choi wrote: > >>> > >>> +#if defined(CONFIG_SOC_EXYNOS3250) > >>> +# define soc_is_exynos3250() is_samsung_exynos3250() > >>> +#else > >>> +# define soc_is_exynos3250() 0 > >>> +#endif > >> > >> In general, I think we have too much code littered with soc_is_<foo>() > >> going > >> on, so please try to avoid adding more for this SoC. Especially in cases > >> where > >> you just want to bail out of certain features where we might already have > >> function pointers to control if a function is called or not, such as the > >> firmware interfaces. > >> > > > > Do you prefer dt helper function such as following function instead of new > > soc_is_xx() ? > > - of_machine_is_compatible("samsung,exynos3250") > > > > I think of_machine_is_compatible() is not proper alternative method. > of_machine_is_compatible can be only used if CONFIG_OF is enabled. >
CONFIG_OF is enabled by definition, that wouldn't be a problem. However, of_machine_is_compatible() doesn't solve the problem that Olof mentioned, you still make runtime-decisions based on the SoC ID, which you should not. Instead, the code should be restructured so it doesn't have to know which SoC is being used. If some machines work differently from others, that should be local knowledge within the device driver, and it can use for instance a DT property of the device node that describes the register set the driver is using. Arnd -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/