Commit 246a144e authored by Linus Walleij's avatar Linus Walleij

gpio: vr41xx: fix up errorpath on probe()

The driver was not checking the return value from gpiochip_add()
properly, so add a bail-out check.
Reported-by: default avatarRickard Strandqvist <rickard_strandqvist@spectrumdigital.se>
Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent 7cb5409b
...@@ -515,7 +515,7 @@ static int giu_probe(struct platform_device *pdev) ...@@ -515,7 +515,7 @@ static int giu_probe(struct platform_device *pdev)
struct resource *res; struct resource *res;
unsigned int trigger, i, pin; unsigned int trigger, i, pin;
struct irq_chip *chip; struct irq_chip *chip;
int irq, retval; int irq, ret;
switch (pdev->id) { switch (pdev->id) {
case GPIO_50PINS_PULLUPDOWN: case GPIO_50PINS_PULLUPDOWN:
...@@ -544,7 +544,11 @@ static int giu_probe(struct platform_device *pdev) ...@@ -544,7 +544,11 @@ static int giu_probe(struct platform_device *pdev)
vr41xx_gpio_chip.dev = &pdev->dev; vr41xx_gpio_chip.dev = &pdev->dev;
retval = gpiochip_add(&vr41xx_gpio_chip); ret = gpiochip_add(&vr41xx_gpio_chip);
if (!ret) {
iounmap(giu_base);
return -ENODEV;
}
giu_write(GIUINTENL, 0); giu_write(GIUINTENL, 0);
giu_write(GIUINTENH, 0); giu_write(GIUINTENH, 0);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment