diff options
author | Thierry Reding <treding@nvidia.com> | 2014-04-25 11:10:06 -0400 |
---|---|---|
committer | Linus Walleij <linus.walleij@linaro.org> | 2014-05-09 07:48:30 -0400 |
commit | 29a1f2333e07bbbecb920cc78fd035fe8f53207a (patch) | |
tree | b2cb50d4c41ff4d1337cca888da3840f6f0d4d84 /drivers/gpio/gpiolib.c | |
parent | 91329132c909bbeb27699556b98b7f745ddb2ed9 (diff) |
gpio: Add helpers for optional GPIOs
Introduce gpiod_get_optional() and gpiod_get_index_optional() helpers
that make it easier for drivers to handle optional GPIOs.
Currently in order to handle optional GPIOs, a driver needs to special
case error handling for -ENOENT, such as this:
gpio = gpiod_get(dev, "foo");
if (IS_ERR(gpio)) {
if (PTR_ERR(gpio) != -ENOENT)
return PTR_ERR(gpio);
gpio = NULL;
}
if (gpio) {
/* set up GPIO */
}
With these new helpers the above is reduced to:
gpio = gpiod_get_optional(dev, "foo");
if (IS_ERR(gpio))
return PTR_ERR(gpio);
if (gpio) {
/* set up GPIO */
}
While at it, device-managed variants of these functions are also
provided.
Signed-off-by: Thierry Reding <treding@nvidia.com>
Reviewed-by: Alexandre Courbot <acourbot@nvidia.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Diffstat (limited to 'drivers/gpio/gpiolib.c')
-rw-r--r-- | drivers/gpio/gpiolib.c | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c index 4ad110e793c5..d9c9cb4665db 100644 --- a/drivers/gpio/gpiolib.c +++ b/drivers/gpio/gpiolib.c | |||
@@ -2738,6 +2738,22 @@ struct gpio_desc *__must_check gpiod_get(struct device *dev, const char *con_id) | |||
2738 | EXPORT_SYMBOL_GPL(gpiod_get); | 2738 | EXPORT_SYMBOL_GPL(gpiod_get); |
2739 | 2739 | ||
2740 | /** | 2740 | /** |
2741 | * gpiod_get_optional - obtain an optional GPIO for a given GPIO function | ||
2742 | * @dev: GPIO consumer, can be NULL for system-global GPIOs | ||
2743 | * @con_id: function within the GPIO consumer | ||
2744 | * | ||
2745 | * This is equivalent to gpiod_get(), except that when no GPIO was assigned to | ||
2746 | * the requested function it will return NULL. This is convenient for drivers | ||
2747 | * that need to handle optional GPIOs. | ||
2748 | */ | ||
2749 | struct gpio_desc *__must_check gpiod_get_optional(struct device *dev, | ||
2750 | const char *con_id) | ||
2751 | { | ||
2752 | return gpiod_get_index_optional(dev, con_id, 0); | ||
2753 | } | ||
2754 | EXPORT_SYMBOL_GPL(gpiod_get_optional); | ||
2755 | |||
2756 | /** | ||
2741 | * gpiod_get_index - obtain a GPIO from a multi-index GPIO function | 2757 | * gpiod_get_index - obtain a GPIO from a multi-index GPIO function |
2742 | * @dev: GPIO consumer, can be NULL for system-global GPIOs | 2758 | * @dev: GPIO consumer, can be NULL for system-global GPIOs |
2743 | * @con_id: function within the GPIO consumer | 2759 | * @con_id: function within the GPIO consumer |
@@ -2800,6 +2816,33 @@ struct gpio_desc *__must_check gpiod_get_index(struct device *dev, | |||
2800 | EXPORT_SYMBOL_GPL(gpiod_get_index); | 2816 | EXPORT_SYMBOL_GPL(gpiod_get_index); |
2801 | 2817 | ||
2802 | /** | 2818 | /** |
2819 | * gpiod_get_index_optional - obtain an optional GPIO from a multi-index GPIO | ||
2820 | * function | ||
2821 | * @dev: GPIO consumer, can be NULL for system-global GPIOs | ||
2822 | * @con_id: function within the GPIO consumer | ||
2823 | * @index: index of the GPIO to obtain in the consumer | ||
2824 | * | ||
2825 | * This is equivalent to gpiod_get_index(), except that when no GPIO with the | ||
2826 | * specified index was assigned to the requested function it will return NULL. | ||
2827 | * This is convenient for drivers that need to handle optional GPIOs. | ||
2828 | */ | ||
2829 | struct gpio_desc *__must_check gpiod_get_index_optional(struct device *dev, | ||
2830 | const char *con_id, | ||
2831 | unsigned int index) | ||
2832 | { | ||
2833 | struct gpio_desc *desc; | ||
2834 | |||
2835 | desc = gpiod_get_index(dev, con_id, index); | ||
2836 | if (IS_ERR(desc)) { | ||
2837 | if (PTR_ERR(desc) == -ENOENT) | ||
2838 | return NULL; | ||
2839 | } | ||
2840 | |||
2841 | return desc; | ||
2842 | } | ||
2843 | EXPORT_SYMBOL_GPL(gpiod_get_index_optional); | ||
2844 | |||
2845 | /** | ||
2803 | * gpiod_put - dispose of a GPIO descriptor | 2846 | * gpiod_put - dispose of a GPIO descriptor |
2804 | * @desc: GPIO descriptor to dispose of | 2847 | * @desc: GPIO descriptor to dispose of |
2805 | * | 2848 | * |