265 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			265 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| /*
 | |
|  * <linux/gpio.h>
 | |
|  *
 | |
|  * This is the LEGACY GPIO bulk include file, including legacy APIs. It is
 | |
|  * used for GPIO drivers still referencing the global GPIO numberspace,
 | |
|  * and should not be included in new code.
 | |
|  *
 | |
|  * If you're implementing a GPIO driver, only include <linux/gpio/driver.h>
 | |
|  * If you're implementing a GPIO consumer, only include <linux/gpio/consumer.h>
 | |
|  */
 | |
| #ifndef __LINUX_GPIO_H
 | |
| #define __LINUX_GPIO_H
 | |
| 
 | |
| #include <linux/errno.h>
 | |
| 
 | |
| /* see Documentation/driver-api/gpio/legacy.rst */
 | |
| 
 | |
| /* make these flag values available regardless of GPIO kconfig options */
 | |
| #define GPIOF_DIR_OUT	(0 << 0)
 | |
| #define GPIOF_DIR_IN	(1 << 0)
 | |
| 
 | |
| #define GPIOF_INIT_LOW	(0 << 1)
 | |
| #define GPIOF_INIT_HIGH	(1 << 1)
 | |
| 
 | |
| #define GPIOF_IN		(GPIOF_DIR_IN)
 | |
| #define GPIOF_OUT_INIT_LOW	(GPIOF_DIR_OUT | GPIOF_INIT_LOW)
 | |
| #define GPIOF_OUT_INIT_HIGH	(GPIOF_DIR_OUT | GPIOF_INIT_HIGH)
 | |
| 
 | |
| /* Gpio pin is active-low */
 | |
| #define GPIOF_ACTIVE_LOW        (1 << 2)
 | |
| 
 | |
| /* Gpio pin is open drain */
 | |
| #define GPIOF_OPEN_DRAIN	(1 << 3)
 | |
| 
 | |
| /* Gpio pin is open source */
 | |
| #define GPIOF_OPEN_SOURCE	(1 << 4)
 | |
| 
 | |
| #define GPIOF_EXPORT		(1 << 5)
 | |
| #define GPIOF_EXPORT_CHANGEABLE	(1 << 6)
 | |
| #define GPIOF_EXPORT_DIR_FIXED	(GPIOF_EXPORT)
 | |
| #define GPIOF_EXPORT_DIR_CHANGEABLE (GPIOF_EXPORT | GPIOF_EXPORT_CHANGEABLE)
 | |
| 
 | |
| /**
 | |
|  * struct gpio - a structure describing a GPIO with configuration
 | |
|  * @gpio:	the GPIO number
 | |
|  * @flags:	GPIO configuration as specified by GPIOF_*
 | |
|  * @label:	a literal description string of this GPIO
 | |
|  */
 | |
| struct gpio {
 | |
| 	unsigned	gpio;
 | |
| 	unsigned long	flags;
 | |
| 	const char	*label;
 | |
| };
 | |
| 
 | |
| #ifdef CONFIG_GPIOLIB
 | |
| 
 | |
| #ifdef CONFIG_ARCH_HAVE_CUSTOM_GPIO_H
 | |
| #include <asm/gpio.h>
 | |
| #else
 | |
| 
 | |
| #include <asm-generic/gpio.h>
 | |
| 
 | |
| static inline int gpio_get_value(unsigned int gpio)
 | |
| {
 | |
| 	return __gpio_get_value(gpio);
 | |
| }
 | |
| 
 | |
| static inline void gpio_set_value(unsigned int gpio, int value)
 | |
| {
 | |
| 	__gpio_set_value(gpio, value);
 | |
| }
 | |
| 
 | |
| static inline int gpio_cansleep(unsigned int gpio)
 | |
| {
 | |
| 	return __gpio_cansleep(gpio);
 | |
| }
 | |
| 
 | |
| static inline int gpio_to_irq(unsigned int gpio)
 | |
| {
 | |
| 	return __gpio_to_irq(gpio);
 | |
| }
 | |
| 
 | |
| static inline int irq_to_gpio(unsigned int irq)
 | |
| {
 | |
| 	return -EINVAL;
 | |
| }
 | |
| 
 | |
| #endif /* ! CONFIG_ARCH_HAVE_CUSTOM_GPIO_H */
 | |
| 
 | |
| /* CONFIG_GPIOLIB: bindings for managed devices that want to request gpios */
 | |
| 
 | |
| struct device;
 | |
| 
 | |
| int devm_gpio_request(struct device *dev, unsigned gpio, const char *label);
 | |
| int devm_gpio_request_one(struct device *dev, unsigned gpio,
 | |
| 			  unsigned long flags, const char *label);
 | |
| void devm_gpio_free(struct device *dev, unsigned int gpio);
 | |
| 
 | |
| #else /* ! CONFIG_GPIOLIB */
 | |
| 
 | |
| #include <linux/kernel.h>
 | |
| #include <linux/types.h>
 | |
| #include <linux/bug.h>
 | |
| #include <linux/pinctrl/pinctrl.h>
 | |
| 
 | |
| struct device;
 | |
| struct gpio_chip;
 | |
| 
 | |
| static inline bool gpio_is_valid(int number)
 | |
| {
 | |
| 	return false;
 | |
| }
 | |
| 
 | |
| static inline int gpio_request(unsigned gpio, const char *label)
 | |
| {
 | |
| 	return -ENOSYS;
 | |
| }
 | |
| 
 | |
| static inline int gpio_request_one(unsigned gpio,
 | |
| 					unsigned long flags, const char *label)
 | |
| {
 | |
| 	return -ENOSYS;
 | |
| }
 | |
| 
 | |
| static inline int gpio_request_array(const struct gpio *array, size_t num)
 | |
| {
 | |
| 	return -ENOSYS;
 | |
| }
 | |
| 
 | |
| static inline void gpio_free(unsigned gpio)
 | |
| {
 | |
| 	might_sleep();
 | |
| 
 | |
| 	/* GPIO can never have been requested */
 | |
| 	WARN_ON(1);
 | |
| }
 | |
| 
 | |
| static inline void gpio_free_array(const struct gpio *array, size_t num)
 | |
| {
 | |
| 	might_sleep();
 | |
| 
 | |
| 	/* GPIO can never have been requested */
 | |
| 	WARN_ON(1);
 | |
| }
 | |
| 
 | |
| static inline int gpio_direction_input(unsigned gpio)
 | |
| {
 | |
| 	return -ENOSYS;
 | |
| }
 | |
| 
 | |
| static inline int gpio_direction_output(unsigned gpio, int value)
 | |
| {
 | |
| 	return -ENOSYS;
 | |
| }
 | |
| 
 | |
| static inline int gpio_set_debounce(unsigned gpio, unsigned debounce)
 | |
| {
 | |
| 	return -ENOSYS;
 | |
| }
 | |
| 
 | |
| static inline int gpio_get_value(unsigned gpio)
 | |
| {
 | |
| 	/* GPIO can never have been requested or set as {in,out}put */
 | |
| 	WARN_ON(1);
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| static inline void gpio_set_value(unsigned gpio, int value)
 | |
| {
 | |
| 	/* GPIO can never have been requested or set as output */
 | |
| 	WARN_ON(1);
 | |
| }
 | |
| 
 | |
| static inline int gpio_cansleep(unsigned gpio)
 | |
| {
 | |
| 	/* GPIO can never have been requested or set as {in,out}put */
 | |
| 	WARN_ON(1);
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| static inline int gpio_get_value_cansleep(unsigned gpio)
 | |
| {
 | |
| 	/* GPIO can never have been requested or set as {in,out}put */
 | |
| 	WARN_ON(1);
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| static inline void gpio_set_value_cansleep(unsigned gpio, int value)
 | |
| {
 | |
| 	/* GPIO can never have been requested or set as output */
 | |
| 	WARN_ON(1);
 | |
| }
 | |
| 
 | |
| static inline int gpio_export(unsigned gpio, bool direction_may_change)
 | |
| {
 | |
| 	/* GPIO can never have been requested or set as {in,out}put */
 | |
| 	WARN_ON(1);
 | |
| 	return -EINVAL;
 | |
| }
 | |
| 
 | |
| static inline int gpio_export_link(struct device *dev, const char *name,
 | |
| 				unsigned gpio)
 | |
| {
 | |
| 	/* GPIO can never have been exported */
 | |
| 	WARN_ON(1);
 | |
| 	return -EINVAL;
 | |
| }
 | |
| 
 | |
| static inline void gpio_unexport(unsigned gpio)
 | |
| {
 | |
| 	/* GPIO can never have been exported */
 | |
| 	WARN_ON(1);
 | |
| }
 | |
| 
 | |
| static inline int gpio_to_irq(unsigned gpio)
 | |
| {
 | |
| 	/* GPIO can never have been requested or set as input */
 | |
| 	WARN_ON(1);
 | |
| 	return -EINVAL;
 | |
| }
 | |
| 
 | |
| static inline int gpiochip_lock_as_irq(struct gpio_chip *chip,
 | |
| 				       unsigned int offset)
 | |
| {
 | |
| 	WARN_ON(1);
 | |
| 	return -EINVAL;
 | |
| }
 | |
| 
 | |
| static inline void gpiochip_unlock_as_irq(struct gpio_chip *chip,
 | |
| 					  unsigned int offset)
 | |
| {
 | |
| 	WARN_ON(1);
 | |
| }
 | |
| 
 | |
| static inline int irq_to_gpio(unsigned irq)
 | |
| {
 | |
| 	/* irq can never have been returned from gpio_to_irq() */
 | |
| 	WARN_ON(1);
 | |
| 	return -EINVAL;
 | |
| }
 | |
| 
 | |
| static inline int devm_gpio_request(struct device *dev, unsigned gpio,
 | |
| 				    const char *label)
 | |
| {
 | |
| 	WARN_ON(1);
 | |
| 	return -EINVAL;
 | |
| }
 | |
| 
 | |
| static inline int devm_gpio_request_one(struct device *dev, unsigned gpio,
 | |
| 					unsigned long flags, const char *label)
 | |
| {
 | |
| 	WARN_ON(1);
 | |
| 	return -EINVAL;
 | |
| }
 | |
| 
 | |
| static inline void devm_gpio_free(struct device *dev, unsigned int gpio)
 | |
| {
 | |
| 	WARN_ON(1);
 | |
| }
 | |
| 
 | |
| #endif /* ! CONFIG_GPIOLIB */
 | |
| 
 | |
| #endif /* __LINUX_GPIO_H */
 | 
