summaryrefslogtreecommitdiffstats
path: root/drivers/gpio
diff options
context:
space:
mode:
authorSascha Hauer <s.hauer@pengutronix.de>2014-02-03 09:52:34 +0100
committerSascha Hauer <s.hauer@pengutronix.de>2014-02-03 09:52:34 +0100
commit3cbd92bf6e96d4274e3a4f6aeceaf51d5406a0a6 (patch)
treec6ef28eff44de2f200294a3b2bd62534431a99af /drivers/gpio
parentf4cece7db55f09069d729d4c915989980694d5c7 (diff)
parentd1e54c4bc2dfa5b2ab178b4fb6457441f0ed6030 (diff)
downloadbarebox-3cbd92bf6e96d4274e3a4f6aeceaf51d5406a0a6.tar.gz
barebox-3cbd92bf6e96d4274e3a4f6aeceaf51d5406a0a6.tar.xz
Merge branch 'for-next/gpio'
Diffstat (limited to 'drivers/gpio')
-rw-r--r--drivers/gpio/gpiolib.c26
1 files changed, 19 insertions, 7 deletions
diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c
index cafef907ef..193c36ca29 100644
--- a/drivers/gpio/gpiolib.c
+++ b/drivers/gpio/gpiolib.c
@@ -50,22 +50,33 @@ int gpio_request(unsigned gpio, const char *label)
struct gpio_info *gi = gpio_to_desc(gpio);
int ret;
- if (!gi)
- return -ENODEV;
+ if (!gi) {
+ ret = -ENODEV;
+ goto done;
+ }
- if (gi->requested)
- return -EBUSY;
+ if (gi->requested) {
+ ret = -EBUSY;
+ goto done;
+ }
+
+ ret = 0;
if (gi->chip->ops->request) {
ret = gi->chip->ops->request(gi->chip, gpio - gi->chip->base);
if (ret)
- return ret;
+ goto done;
}
gi->requested = true;
gi->label = xstrdup(label);
- return 0;
+done:
+ if (ret)
+ pr_err("_gpio_request: gpio-%d (%s) status %d\n",
+ gpio, label ? : "?", ret);
+
+ return ret;
}
void gpio_free(unsigned gpio)
@@ -83,6 +94,7 @@ void gpio_free(unsigned gpio)
gi->requested = false;
free(gi->label);
+ gi->label = NULL;
}
/**
@@ -322,7 +334,7 @@ static int do_gpiolib(int argc, char *argv[])
3, (dir < 0) ? "unk" : ((dir == GPIOF_DIR_IN) ? "in" : "out"),
3, (val < 0) ? "unk" : ((val == 0) ? "lo" : "hi"),
9, gi->requested ? "true" : "false",
- gi->label ? gi->label : "");
+ (gi->requested && gi->label) ? gi->label : "");
}
return 0;