gpio: tegra: read output value when gpio is set in direction_out
authorLaxman Dewangan <ldewangan@nvidia.com>
Fri, 9 Nov 2012 06:04:20 +0000 (11:34 +0530)
committerLinus Walleij <linus.walleij@linaro.org>
Sat, 17 Nov 2012 20:14:04 +0000 (21:14 +0100)
Read the output value when gpio is set for the output mode for
gpio_get_value(). Reading input value in direction out does not
give correct value.

Signed-off-by: Laxman Dewangan <ldewangan@nvidia.com>
Acked-by: Stephen Warren <swarren@nvidia.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/gpio/gpio-tegra.c

index cfd9b72..5389be8 100644 (file)
@@ -134,6 +134,11 @@ static void tegra_gpio_set(struct gpio_chip *chip, unsigned offset, int value)
 
 static int tegra_gpio_get(struct gpio_chip *chip, unsigned offset)
 {
+       /* If gpio is in output mode then read from the out value */
+       if ((tegra_gpio_readl(GPIO_OE(offset)) >> GPIO_BIT(offset)) & 1)
+               return (tegra_gpio_readl(GPIO_OUT(offset)) >>
+                               GPIO_BIT(offset)) & 0x1;
+
        return (tegra_gpio_readl(GPIO_IN(offset)) >> GPIO_BIT(offset)) & 0x1;
 }