aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>2018-10-12 06:55:47 -0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2018-10-12 06:55:47 -0400
commitef0e75a47c4ad518aa3c91bb6a86a329b890f263 (patch)
tree6277c5ffe503dcef640ff0d2f3d8ada800985bc6
parenta291ab2d40e97a5ae0c07bf62f04ad7c438f66d0 (diff)
parentf259f896f2348f0302f6f88d4382378cf9d23a7e (diff)
Merge tag 'pinctrl-v4.19-5' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl
Linus writes: "pin control fix for v4.19: A single pin control fix for v4.19: - Interrupt setup in the MCP23S08 driver." * tag 'pinctrl-v4.19-5' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl: pinctrl: mcp23s08: fix irq and irqchip setup order
-rw-r--r--drivers/pinctrl/pinctrl-mcp23s08.c13
1 files changed, 12 insertions, 1 deletions
diff --git a/drivers/pinctrl/pinctrl-mcp23s08.c b/drivers/pinctrl/pinctrl-mcp23s08.c
index 4a8a8efadefa..cf73a403d22d 100644
--- a/drivers/pinctrl/pinctrl-mcp23s08.c
+++ b/drivers/pinctrl/pinctrl-mcp23s08.c
@@ -636,6 +636,14 @@ static int mcp23s08_irq_setup(struct mcp23s08 *mcp)
636 return err; 636 return err;
637 } 637 }
638 638
639 return 0;
640}
641
642static int mcp23s08_irqchip_setup(struct mcp23s08 *mcp)
643{
644 struct gpio_chip *chip = &mcp->chip;
645 int err;
646
639 err = gpiochip_irqchip_add_nested(chip, 647 err = gpiochip_irqchip_add_nested(chip,
640 &mcp23s08_irq_chip, 648 &mcp23s08_irq_chip,
641 0, 649 0,
@@ -912,7 +920,7 @@ static int mcp23s08_probe_one(struct mcp23s08 *mcp, struct device *dev,
912 } 920 }
913 921
914 if (mcp->irq && mcp->irq_controller) { 922 if (mcp->irq && mcp->irq_controller) {
915 ret = mcp23s08_irq_setup(mcp); 923 ret = mcp23s08_irqchip_setup(mcp);
916 if (ret) 924 if (ret)
917 goto fail; 925 goto fail;
918 } 926 }
@@ -944,6 +952,9 @@ static int mcp23s08_probe_one(struct mcp23s08 *mcp, struct device *dev,
944 goto fail; 952 goto fail;
945 } 953 }
946 954
955 if (mcp->irq)
956 ret = mcp23s08_irq_setup(mcp);
957
947fail: 958fail:
948 if (ret < 0) 959 if (ret < 0)
949 dev_dbg(dev, "can't setup chip %d, --> %d\n", addr, ret); 960 dev_dbg(dev, "can't setup chip %d, --> %d\n", addr, ret);