gpio: mb86s70: Revert "Return error if requesting an already assigned gpio"
authorArd Biesheuvel <ard.biesheuvel@linaro.org>
Fri, 27 Oct 2017 20:21:48 +0000 (21:21 +0100)
committerLinus Walleij <linus.walleij@linaro.org>
Tue, 31 Oct 2017 12:13:34 +0000 (13:13 +0100)
Commit fd9c963c5661 ("gpio: mb86s70: Return error if requesting an
already assigned gpio") adds code that infers from the state of the
GPIO Pin Function Register (PFR) whether a GPIO has been assigned
already. This assumes that the pin functions are set to 'peripheral'
when the driver is loaded, which is not guaranteed. Also, the GPIO
layer is perfectly capable of keeping track of which GPIOs have been
assigned already, so we shouldn't need this check in the first place.

This reverts commit fd9c963c5661af3403e77e312c0d9941773b6c1b.

Cc: Axel Lin <axel.lin@ingics.com>
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Acked-by: Axel Lin <axel.lin@ingics.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/gpio/gpio-mb86s7x.c

index b140806bded3fed47fff52bc99979abf7a7bbebc..3134c0d2bfe4bfe25b09bef301316f7dae639a8e 100644 (file)
@@ -53,11 +53,6 @@ static int mb86s70_gpio_request(struct gpio_chip *gc, unsigned gpio)
        spin_lock_irqsave(&gchip->lock, flags);
 
        val = readl(gchip->base + PFR(gpio));
-       if (!(val & OFFSET(gpio))) {
-               spin_unlock_irqrestore(&gchip->lock, flags);
-               return -EINVAL;
-       }
-
        val &= ~OFFSET(gpio);
        writel(val, gchip->base + PFR(gpio));