diff options
author | nbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2008-04-20 16:32:28 +0000 |
---|---|---|
committer | nbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2008-04-20 16:32:28 +0000 |
commit | 3f8ac58c32e617088b98a583d71edbf9d6729c1c (patch) | |
tree | a2d45ecc5f26a739135a681cb482b2ccc8ba3a4e /target/linux/rb532 | |
parent | b153f66ff2419758c0a7cc3b2fd2901e7de459b7 (diff) |
fix gpio on rb532 - fixes the cf driver
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@10888 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux/rb532')
-rw-r--r-- | target/linux/rb532/files/arch/mips/rb500/gpio.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/target/linux/rb532/files/arch/mips/rb500/gpio.c b/target/linux/rb532/files/arch/mips/rb500/gpio.c index f7c417355a..6c92a8fe56 100644 --- a/target/linux/rb532/files/arch/mips/rb500/gpio.c +++ b/target/linux/rb532/files/arch/mips/rb500/gpio.c @@ -43,7 +43,7 @@ static volatile unsigned char *devCtl3Base; static unsigned char latchU5State; -static spinlock_t clu5Lock; +static spinlock_t clu5Lock = SPIN_LOCK_UNLOCKED; struct rb500_gpio_reg __iomem *rb500_gpio_reg0; EXPORT_SYMBOL(rb500_gpio_reg0); @@ -116,7 +116,7 @@ EXPORT_SYMBOL(rb500_gpio_set_value); int rb500_gpio_direction_input(unsigned gpio) { - writel(readl(&rb500_gpio_reg0->gpiocfg) | (1 << gpio), (void *)&rb500_gpio_reg0->gpiocfg); + writel(readl(&rb500_gpio_reg0->gpiocfg) & ~(1 << gpio), (void *)&rb500_gpio_reg0->gpiocfg); return 0; } @@ -125,7 +125,7 @@ EXPORT_SYMBOL(rb500_gpio_direction_input); int rb500_gpio_direction_output(unsigned gpio, int value) { gpio_set_value(gpio, value); - writel(readl(&rb500_gpio_reg0->gpiocfg) & ~(1 << gpio), (void *)&rb500_gpio_reg0->gpiocfg); + writel(readl(&rb500_gpio_reg0->gpiocfg) | (1 << gpio), (void *)&rb500_gpio_reg0->gpiocfg); return 0; } |