aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarkus Pargmann <mpa@pengutronix.de>2015-03-24 11:26:18 -0400
committerLinus Walleij <linus.walleij@linaro.org>2015-04-07 09:11:00 -0400
commit16837f9588819c06469e635c04a8135f98ab9ae6 (patch)
tree343e82c48a69093828baf52a82400e780ae9114a
parent0fefcb6876d0d650ac2255c57051b31c48c1b165 (diff)
pinctrl: fsl: imx: Check for 0 config register
0 is used in all pinfunction definitions when a config register is not available, for example imx25-pinfunc.h. If a configuration value is used for such a pinfunction the driver will always write it to the configuration register if it is not -1. For a 0 configuration register the configuration value is written to offset 0x0. This can lead to a crashing/hanging system without any warning message. This patch checks for 0 config register and sets the internal value to -1. If the configuration value is not NO_PADCTL this leads to an error message that applying the configuration failed. Signed-off-by: Markus Pargmann <mpa@pengutronix.de> Acked-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de> Tested-by: Stefan Agner <stefan@agner.ch> Acked-by: Stefan Agner <stefan@agner.ch> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
-rw-r--r--drivers/pinctrl/freescale/pinctrl-imx.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/drivers/pinctrl/freescale/pinctrl-imx.c b/drivers/pinctrl/freescale/pinctrl-imx.c
index 2ee0d9228e63..e261f1cf85c6 100644
--- a/drivers/pinctrl/freescale/pinctrl-imx.c
+++ b/drivers/pinctrl/freescale/pinctrl-imx.c
@@ -542,10 +542,13 @@ static int imx_pinctrl_parse_groups(struct device_node *np,
542 struct imx_pin_reg *pin_reg; 542 struct imx_pin_reg *pin_reg;
543 struct imx_pin *pin = &grp->pins[i]; 543 struct imx_pin *pin = &grp->pins[i];
544 544
545 if (info->flags & SHARE_MUX_CONF_REG) 545 if (info->flags & SHARE_MUX_CONF_REG) {
546 conf_reg = mux_reg; 546 conf_reg = mux_reg;
547 else 547 } else {
548 conf_reg = be32_to_cpu(*list++); 548 conf_reg = be32_to_cpu(*list++);
549 if (!conf_reg)
550 conf_reg = -1;
551 }
549 552
550 pin_id = mux_reg ? mux_reg / 4 : conf_reg / 4; 553 pin_id = mux_reg ? mux_reg / 4 : conf_reg / 4;
551 pin_reg = &info->pin_regs[pin_id]; 554 pin_reg = &info->pin_regs[pin_id];