diff options
author | Dmitry Mastykin <mastichi@gmail.com> | 2017-12-28 10:19:24 -0500 |
---|---|---|
committer | Linus Walleij <linus.walleij@linaro.org> | 2018-01-30 09:17:14 -0500 |
commit | 02e389e63e3523828fc3832f27e0341885f60f6f (patch) | |
tree | 9296a8e9f6bf3c41c4e9f5728117daeb0fbae960 | |
parent | d3452f1d88311c9af16d709d51dba5ad44afbd1d (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.c | 8 |
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; |