GPIO fix
authorMatteo Croce <rootkit85@yahoo.it>
Sat, 12 Jan 2008 17:14:15 +0000 (17:14 +0000)
committerMatteo Croce <rootkit85@yahoo.it>
Sat, 12 Jan 2008 17:14:15 +0000 (17:14 +0000)
SVN-Revision: 10180

target/linux/ar7/files/include/asm-mips/ar7/gpio.h

index 7d665ff62dd6115a1f1bd4b8bd2a7995d4380442..00418b586347f194ed5a3b31c0f430f5db72f8aa 100644 (file)
@@ -41,15 +41,14 @@ static inline int gpio_get_value(unsigned gpio)
 
 static inline void gpio_set_value(unsigned gpio, int value)
 {
-       static unsigned addr;
+       static void __iomem *gpio_out;
        unsigned tmp;
 
-       void __iomem *gpio_out =
-               (void __iomem *)KSEG1ADDR(AR7_REGS_GPIO + AR7_GPIO_OUTPUT);
-       if (!addr)
-               addr = readl(gpio_out);
+       if (!gpio_out)
+               gpio_out = (void __iomem *)
+                               KSEG1ADDR(AR7_REGS_GPIO + AR7_GPIO_OUTPUT);
 
-       tmp = addr & ~(1 << gpio);
+       tmp = readl(gpio_out) & ~(1 << gpio);
        if (value)
                tmp |= 1 << gpio;
        writel(tmp, gpio_out);