|  | #ifndef __LINUX_GPIO_H | 
|  | #define __LINUX_GPIO_H | 
|  |  | 
|  | /* see Documentation/gpio.txt */ | 
|  |  | 
|  | /* 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) | 
|  |  | 
|  | #ifdef CONFIG_GENERIC_GPIO | 
|  | #include <asm/gpio.h> | 
|  |  | 
|  | #else | 
|  |  | 
|  | #include <linux/kernel.h> | 
|  | #include <linux/types.h> | 
|  | #include <linux/errno.h> | 
|  |  | 
|  | struct device; | 
|  | struct gpio; | 
|  | struct gpio_chip; | 
|  |  | 
|  | /* | 
|  | * Some platforms don't support the GPIO programming interface. | 
|  | * | 
|  | * In case some driver uses it anyway (it should normally have | 
|  | * depended on GENERIC_GPIO), these routines help the compiler | 
|  | * optimize out much GPIO-related code ... or trigger a runtime | 
|  | * warning when something is wrongly called. | 
|  | */ | 
|  |  | 
|  | 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 int gpio_sysfs_set_active_low(unsigned gpio, int value) | 
|  | { | 
|  | /* GPIO can never have been requested */ | 
|  | 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 irq_to_gpio(unsigned irq) | 
|  | { | 
|  | /* irq can never have been returned from gpio_to_irq() */ | 
|  | WARN_ON(1); | 
|  | return -EINVAL; | 
|  | } | 
|  |  | 
|  | #endif | 
|  |  | 
|  | #endif /* __LINUX_GPIO_H */ |