[PATCH V2 4/4] SPEAr3xx: Add pinctrl support for boards

Stephen Warren swarren at wwwdotorg.org
Wed Apr 4 18:32:05 EDT 2012


On 04/04/2012 05:35 AM, Viresh Kumar wrote:
> Signed-off-by: Viresh Kumar <viresh.kumar at st.com>

> +++ b/arch/arm/mach-spear3xx/spear300.c

> +static struct pinctrl_map __initdata spear300_evb_pmx_map[] = {
> +	/* spear3xx per-device maps */
> +	PIN_MAP_MUX_GROUP_HOG_DEFAULT("99000000.pinmux", NULL, "i2c0"),
> +	PIN_MAP_MUX_GROUP_HOG_DEFAULT("99000000.pinmux", NULL, "ssp0"),
> +	PIN_MAP_MUX_GROUP_HOG_DEFAULT("99000000.pinmux", NULL, "mii0"),
> +	PIN_MAP_MUX_GROUP_HOG_DEFAULT("99000000.pinmux", NULL, "uart0"),
> +
> +	/* spear310 per-device maps */
> +	PIN_MAP_MUX_GROUP_HOG_DEFAULT("99000000.pinmux", "clcd_pfmode_grp",
> +			"clcd"),
> +	PIN_MAP_MUX_GROUP_HOG_DEFAULT("99000000.pinmux", "sdhci_4bit_grp",
> +			"sdhci"),
> +	PIN_MAP_MUX_GROUP_HOG_DEFAULT("99000000.pinmux", "gpio1_0_to_3_grp",
> +			"gpio"),
> +	PIN_MAP_MUX_GROUP_HOG_DEFAULT("99000000.pinmux", "gpio1_4_to_7_grp",
> +			"gpio"),
> +};
>
>  static void __init spear300_dt_init(void)
...
> +
> +	if (of_machine_is_compatible("st,spear300-evb")) {
> +		if (pinctrl_register_mappings(spear300_evb_pmx_map,
> +					ARRAY_SIZE(spear300_evb_pmx_map)))
> +			pr_err("Error registering pinmux map\n");
> +	}

It'd be nice to put those mapping tables into device tree from the
start. Hopefully the core pinctrl support for DT will be in linux-next
today/tomorrow.



More information about the linux-arm-kernel mailing list