diff options
Diffstat (limited to 'include/linux/of_gpio.h')
| -rw-r--r-- | include/linux/of_gpio.h | 79 | 
1 files changed, 70 insertions, 9 deletions
diff --git a/include/linux/of_gpio.h b/include/linux/of_gpio.h index 6598c04dab0..38fc0503601 100644 --- a/include/linux/of_gpio.h +++ b/include/linux/of_gpio.h @@ -18,6 +18,7 @@  #include <linux/kernel.h>  #include <linux/errno.h>  #include <linux/gpio.h> +#include <linux/of.h>  struct device_node; @@ -46,29 +47,32 @@ static inline struct of_mm_gpio_chip *to_of_mm_gpio_chip(struct gpio_chip *gc)  	return container_of(gc, struct of_mm_gpio_chip, gc);  } -extern int of_get_gpio_flags(struct device_node *np, int index, -			     enum of_gpio_flags *flags); -extern unsigned int of_gpio_count(struct device_node *np); +extern int of_get_named_gpio_flags(struct device_node *np, +		const char *list_name, int index, enum of_gpio_flags *flags);  extern int of_mm_gpiochip_add(struct device_node *np,  			      struct of_mm_gpio_chip *mm_gc);  extern void of_gpiochip_add(struct gpio_chip *gc);  extern void of_gpiochip_remove(struct gpio_chip *gc); -extern struct gpio_chip *of_node_to_gpiochip(struct device_node *np); +extern int of_gpio_simple_xlate(struct gpio_chip *gc, +				const struct of_phandle_args *gpiospec, +				u32 *flags);  #else /* CONFIG_OF_GPIO */  /* Drivers may not strictly depend on the GPIO support, so let them link. */ -static inline int of_get_gpio_flags(struct device_node *np, int index, -				    enum of_gpio_flags *flags) +static inline int of_get_named_gpio_flags(struct device_node *np, +		const char *list_name, int index, enum of_gpio_flags *flags)  {  	return -ENOSYS;  } -static inline unsigned int of_gpio_count(struct device_node *np) +static inline int of_gpio_simple_xlate(struct gpio_chip *gc, +				       const struct of_phandle_args *gpiospec, +				       u32 *flags)  { -	return 0; +	return -ENOSYS;  }  static inline void of_gpiochip_add(struct gpio_chip *gc) { } @@ -77,7 +81,64 @@ static inline void of_gpiochip_remove(struct gpio_chip *gc) { }  #endif /* CONFIG_OF_GPIO */  /** - * of_get_gpio - Get a GPIO number to use with GPIO API + * of_gpio_named_count() - Count GPIOs for a device + * @np:		device node to count GPIOs for + * @propname:	property name containing gpio specifier(s) + * + * The function returns the count of GPIOs specified for a node. + * Note that the empty GPIO specifiers count too. Returns either + *   Number of gpios defined in property, + *   -EINVAL for an incorrectly formed gpios property, or + *   -ENOENT for a missing gpios property + * + * Example: + * gpios = <0 + *          &gpio1 1 2 + *          0 + *          &gpio2 3 4>; + * + * The above example defines four GPIOs, two of which are not specified. + * This function will return '4' + */ +static inline int of_gpio_named_count(struct device_node *np, const char* propname) +{ +	return of_count_phandle_with_args(np, propname, "#gpio-cells"); +} + +/** + * of_gpio_count() - Count GPIOs for a device + * @np:		device node to count GPIOs for + * + * Same as of_gpio_named_count, but hard coded to use the 'gpios' property + */ +static inline int of_gpio_count(struct device_node *np) +{ +	return of_gpio_named_count(np, "gpios"); +} + +static inline int of_get_gpio_flags(struct device_node *np, int index, +		      enum of_gpio_flags *flags) +{ +	return of_get_named_gpio_flags(np, "gpios", index, flags); +} + +/** + * of_get_named_gpio() - Get a GPIO number to use with GPIO API + * @np:		device node to get GPIO from + * @propname:	Name of property containing gpio specifier(s) + * @index:	index of the GPIO + * + * Returns GPIO number to use with Linux generic GPIO API, or one of the errno + * value on the error condition. + */ +static inline int of_get_named_gpio(struct device_node *np, +                                   const char *propname, int index) +{ +	return of_get_named_gpio_flags(np, propname, index, NULL); +} + +/** + * of_get_gpio() - Get a GPIO number to use with GPIO API   * @np:		device node to get GPIO from   * @index:	index of the GPIO   *  | 
