aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpio/pch_gpio.c
diff options
context:
space:
mode:
authorPeter Tyser <ptyser@xes-inc.com>2011-03-25 11:04:00 -0400
committerGrant Likely <grant.likely@secretlab.ca>2011-03-31 17:17:40 -0400
commit88aab9341a315d81118be6b41c45e4fe32b94bc1 (patch)
tree01c01fa85c4ebc9f732cd006ab41b590f8f2b32b /drivers/gpio/pch_gpio.c
parentba43861277f1858472de4adfc0b28a047484da83 (diff)
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,
105 reg_val |= (1 << nr); 105 reg_val |= (1 << nr);
106 else 106 else
107 reg_val &= ~(1 << nr); 107 reg_val &= ~(1 << nr);
108 iowrite32(reg_val, &chip->reg->po);
108 109
109 mutex_unlock(&chip->lock); 110 mutex_unlock(&chip->lock);
110 111