aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDmitry Mastykin <mastichi@gmail.com>2017-12-28 10:19:24 -0500
committerLinus Walleij <linus.walleij@linaro.org>2018-01-30 09:17:14 -0500
commit02e389e63e3523828fc3832f27e0341885f60f6f (patch)
tree9296a8e9f6bf3c41c4e9f5728117daeb0fbae960
parentd3452f1d88311c9af16d709d51dba5ad44afbd1d (diff)
pinctrl: mcp23s08: fix irq setup order
When using mcp23s08 module with gpio-keys, often (50% of boots) it fails to get irq numbers with message: "gpio-keys keys: Unable to get irq number for GPIO 0, error -6". Seems that irqs must be setup before devm_gpiochip_add_data(). Cc: stable@vger.kernel.org Signed-off-by: Dmitry Mastykin <mastichi@gmail.com> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
-rw-r--r--drivers/pinctrl/pinctrl-mcp23s08.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/drivers/pinctrl/pinctrl-mcp23s08.c b/drivers/pinctrl/pinctrl-mcp23s08.c
index 95d548f3ba53..644c5beb05cb 100644
--- a/drivers/pinctrl/pinctrl-mcp23s08.c
+++ b/drivers/pinctrl/pinctrl-mcp23s08.c
@@ -890,16 +890,16 @@ static int mcp23s08_probe_one(struct mcp23s08 *mcp, struct device *dev,
890 goto fail; 890 goto fail;
891 } 891 }
892 892
893 ret = devm_gpiochip_add_data(dev, &mcp->chip, mcp);
894 if (ret < 0)
895 goto fail;
896
897 if (mcp->irq && mcp->irq_controller) { 893 if (mcp->irq && mcp->irq_controller) {
898 ret = mcp23s08_irq_setup(mcp); 894 ret = mcp23s08_irq_setup(mcp);
899 if (ret) 895 if (ret)
900 goto fail; 896 goto fail;
901 } 897 }
902 898
899 ret = devm_gpiochip_add_data(dev, &mcp->chip, mcp);
900 if (ret < 0)
901 goto fail;
902
903 mcp->pinctrl_desc.name = "mcp23xxx-pinctrl"; 903 mcp->pinctrl_desc.name = "mcp23xxx-pinctrl";
904 mcp->pinctrl_desc.pctlops = &mcp_pinctrl_ops; 904 mcp->pinctrl_desc.pctlops = &mcp_pinctrl_ops;
905 mcp->pinctrl_desc.confops = &mcp_pinconf_ops; 905 mcp->pinctrl_desc.confops = &mcp_pinconf_ops;