diff options
Diffstat (limited to 'include/linux/gpio')
| -rw-r--r-- | include/linux/gpio/consumer.h | 54 | ||||
| -rw-r--r-- | include/linux/gpio/driver.h | 8 | 
2 files changed, 52 insertions, 10 deletions
| diff --git a/include/linux/gpio/consumer.h b/include/linux/gpio/consumer.h index b70af921c614..5215fdba6b9a 100644 --- a/include/linux/gpio/consumer.h +++ b/include/linux/gpio/consumer.h @@ -176,11 +176,15 @@ struct gpio_desc *fwnode_get_named_gpiod(struct fwnode_handle *fwnode,  					 const char *propname, int index,  					 enum gpiod_flags dflags,  					 const char *label); -struct gpio_desc *devm_fwnode_get_index_gpiod_from_child(struct device *dev, -						const char *con_id, int index, -						struct fwnode_handle *child, -						enum gpiod_flags flags, -						const char *label); +struct gpio_desc *fwnode_gpiod_get_index(struct fwnode_handle *fwnode, +					 const char *con_id, int index, +					 enum gpiod_flags flags, +					 const char *label); +struct gpio_desc *devm_fwnode_gpiod_get_index(struct device *dev, +					      struct fwnode_handle *child, +					      const char *con_id, int index, +					      enum gpiod_flags flags, +					      const char *label);  #else /* CONFIG_GPIOLIB */ @@ -532,17 +536,48 @@ struct gpio_desc *fwnode_get_named_gpiod(struct fwnode_handle *fwnode,  }  static inline +struct gpio_desc *fwnode_gpiod_get_index(struct fwnode_handle *fwnode, +					 const char *con_id, int index, +					 enum gpiod_flags flags, +					 const char *label) +{ +	return ERR_PTR(-ENOSYS); +} + +static inline +struct gpio_desc *devm_fwnode_gpiod_get_index(struct device *dev, +					      struct fwnode_handle *fwnode, +					      const char *con_id, int index, +					      enum gpiod_flags flags, +					      const char *label) +{ +	return ERR_PTR(-ENOSYS); +} + +#endif /* CONFIG_GPIOLIB */ + +static inline +struct gpio_desc *devm_fwnode_gpiod_get(struct device *dev, +					struct fwnode_handle *fwnode, +					const char *con_id, +					enum gpiod_flags flags, +					const char *label) +{ +	return devm_fwnode_gpiod_get_index(dev, fwnode, con_id, 0, +					   flags, label); +} + +static inline  struct gpio_desc *devm_fwnode_get_index_gpiod_from_child(struct device *dev,  						const char *con_id, int index,  						struct fwnode_handle *child,  						enum gpiod_flags flags,  						const char *label)  { -	return ERR_PTR(-ENOSYS); +	return devm_fwnode_gpiod_get_index(dev, child, con_id, index, +					   flags, label);  } -#endif /* CONFIG_GPIOLIB */ -  static inline  struct gpio_desc *devm_fwnode_get_gpiod_from_child(struct device *dev,  						   const char *con_id, @@ -550,8 +585,7 @@ struct gpio_desc *devm_fwnode_get_gpiod_from_child(struct device *dev,  						   enum gpiod_flags flags,  						   const char *label)  { -	return devm_fwnode_get_index_gpiod_from_child(dev, con_id, 0, child, -						      flags, label); +	return devm_fwnode_gpiod_get_index(dev, child, con_id, 0, flags, label);  }  #if IS_ENABLED(CONFIG_GPIOLIB) && IS_ENABLED(CONFIG_OF_GPIO) diff --git a/include/linux/gpio/driver.h b/include/linux/gpio/driver.h index 5dd9c982e2cb..e2480ef94c55 100644 --- a/include/linux/gpio/driver.h +++ b/include/linux/gpio/driver.h @@ -22,6 +22,9 @@ enum gpio_lookup_flags;  struct gpio_chip; +#define GPIO_LINE_DIRECTION_IN	1 +#define GPIO_LINE_DIRECTION_OUT	0 +  /**   * struct gpio_irq_chip - GPIO interrupt controller   */ @@ -286,6 +289,9 @@ struct gpio_irq_chip {   *	state (such as pullup/pulldown configuration).   * @init_valid_mask: optional routine to initialize @valid_mask, to be used if   *	not all GPIOs are valid. + * @add_pin_ranges: optional routine to initialize pin ranges, to be used when + *	requires special mapping of the pins that provides GPIO functionality. + *	It is called after adding GPIO chip and before adding IRQ chip.   * @base: identifies the first GPIO number handled by this chip;   *	or, if negative during registration, requests dynamic ID allocation.   *	DEPRECATION: providing anything non-negative and nailing the base @@ -376,6 +382,8 @@ struct gpio_chip {  						   unsigned long *valid_mask,  						   unsigned int ngpios); +	int			(*add_pin_ranges)(struct gpio_chip *chip); +  	int			base;  	u16			ngpio;  	const char		*const *names; | 

