summaryrefslogtreecommitdiffstats
path: root/drivers/gpio/pch_gpio.c
diff options
context:
space:
mode:
authorPeter Tyser2011-03-25 16:04:00 +0100
committerGrant Likely2011-03-31 23:17:40 +0200
commit88aab9341a315d81118be6b41c45e4fe32b94bc1 (patch)
tree01c01fa85c4ebc9f732cd006ab41b590f8f2b32b /drivers/gpio/pch_gpio.c
parentgpio/ml_ioh_gpio: Fix output value of ioh_gpio_direction_output() (diff)
downloadkernel-qcow2-linux-88aab9341a315d81118be6b41c45e4fe32b94bc1.tar.gz
kernel-qcow2-linux-88aab9341a315d81118be6b41c45e4fe32b94bc1.tar.xz
kernel-qcow2-linux-88aab9341a315d81118be6b41c45e4fe32b94bc1.zip
gpio/pch_gpio: Fix output value of pch_gpio_direction_output()
The pch_gpio_direction_output() function was missing a write to set the desired output value. The function would properly set the GPIO direction, but not the output value. The value would have to manually be set with a follow up call to pch_gpio_set(). Add the missing write so that pch_gpio_direction_output() sets both the GPIO direction and value. Signed-off-by: Peter Tyser <ptyser@xes-inc.com> Tested-by: Tomoya MORINAGA <tomoya-linux@dsn.okisemi.com> Signed-off-by: Grant Likely <grant.likely@secretlab.ca>
Diffstat (limited to 'drivers/gpio/pch_gpio.c')
-rw-r--r--drivers/gpio/pch_gpio.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/gpio/pch_gpio.c b/drivers/gpio/pch_gpio.c
index 2c6af8705103..f970a5f3585e 100644
--- a/drivers/gpio/pch_gpio.c
+++ b/drivers/gpio/pch_gpio.c
@@ -105,6 +105,7 @@ static int pch_gpio_direction_output(struct gpio_chip *gpio, unsigned nr,
reg_val |= (1 << nr);
else
reg_val &= ~(1 << nr);
+ iowrite32(reg_val, &chip->reg->po);
mutex_unlock(&chip->lock);