xref: /OK3568_Linux_fs/kernel/include/asm-generic/gpio.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */
2*4882a593Smuzhiyun #ifndef _ASM_GENERIC_GPIO_H
3*4882a593Smuzhiyun #define _ASM_GENERIC_GPIO_H
4*4882a593Smuzhiyun 
5*4882a593Smuzhiyun #include <linux/types.h>
6*4882a593Smuzhiyun #include <linux/errno.h>
7*4882a593Smuzhiyun 
8*4882a593Smuzhiyun #ifdef CONFIG_GPIOLIB
9*4882a593Smuzhiyun 
10*4882a593Smuzhiyun #include <linux/compiler.h>
11*4882a593Smuzhiyun #include <linux/gpio/driver.h>
12*4882a593Smuzhiyun #include <linux/gpio/consumer.h>
13*4882a593Smuzhiyun 
14*4882a593Smuzhiyun /* Platforms may implement their GPIO interface with library code,
15*4882a593Smuzhiyun  * at a small performance cost for non-inlined operations and some
16*4882a593Smuzhiyun  * extra memory (for code and for per-GPIO table entries).
17*4882a593Smuzhiyun  *
18*4882a593Smuzhiyun  * While the GPIO programming interface defines valid GPIO numbers
19*4882a593Smuzhiyun  * to be in the range 0..MAX_INT, this library restricts them to the
20*4882a593Smuzhiyun  * smaller range 0..ARCH_NR_GPIOS-1.
21*4882a593Smuzhiyun  *
22*4882a593Smuzhiyun  * ARCH_NR_GPIOS is somewhat arbitrary; it usually reflects the sum of
23*4882a593Smuzhiyun  * builtin/SoC GPIOs plus a number of GPIOs on expanders; the latter is
24*4882a593Smuzhiyun  * actually an estimate of a board-specific value.
25*4882a593Smuzhiyun  */
26*4882a593Smuzhiyun 
27*4882a593Smuzhiyun #ifndef ARCH_NR_GPIOS
28*4882a593Smuzhiyun #if defined(CONFIG_ARCH_NR_GPIO) && CONFIG_ARCH_NR_GPIO > 0
29*4882a593Smuzhiyun #define ARCH_NR_GPIOS CONFIG_ARCH_NR_GPIO
30*4882a593Smuzhiyun #else
31*4882a593Smuzhiyun #define ARCH_NR_GPIOS		512
32*4882a593Smuzhiyun #endif
33*4882a593Smuzhiyun #endif
34*4882a593Smuzhiyun 
35*4882a593Smuzhiyun /*
36*4882a593Smuzhiyun  * "valid" GPIO numbers are nonnegative and may be passed to
37*4882a593Smuzhiyun  * setup routines like gpio_request().  only some valid numbers
38*4882a593Smuzhiyun  * can successfully be requested and used.
39*4882a593Smuzhiyun  *
40*4882a593Smuzhiyun  * Invalid GPIO numbers are useful for indicating no-such-GPIO in
41*4882a593Smuzhiyun  * platform data and other tables.
42*4882a593Smuzhiyun  */
43*4882a593Smuzhiyun 
gpio_is_valid(int number)44*4882a593Smuzhiyun static inline bool gpio_is_valid(int number)
45*4882a593Smuzhiyun {
46*4882a593Smuzhiyun 	return number >= 0 && number < ARCH_NR_GPIOS;
47*4882a593Smuzhiyun }
48*4882a593Smuzhiyun 
49*4882a593Smuzhiyun struct device;
50*4882a593Smuzhiyun struct gpio;
51*4882a593Smuzhiyun struct seq_file;
52*4882a593Smuzhiyun struct module;
53*4882a593Smuzhiyun struct device_node;
54*4882a593Smuzhiyun struct gpio_desc;
55*4882a593Smuzhiyun 
56*4882a593Smuzhiyun /* caller holds gpio_lock *OR* gpio is marked as requested */
gpio_to_chip(unsigned gpio)57*4882a593Smuzhiyun static inline struct gpio_chip *gpio_to_chip(unsigned gpio)
58*4882a593Smuzhiyun {
59*4882a593Smuzhiyun 	return gpiod_to_chip(gpio_to_desc(gpio));
60*4882a593Smuzhiyun }
61*4882a593Smuzhiyun 
62*4882a593Smuzhiyun /* Always use the library code for GPIO management calls,
63*4882a593Smuzhiyun  * or when sleeping may be involved.
64*4882a593Smuzhiyun  */
65*4882a593Smuzhiyun extern int gpio_request(unsigned gpio, const char *label);
66*4882a593Smuzhiyun extern void gpio_free(unsigned gpio);
67*4882a593Smuzhiyun 
gpio_direction_input(unsigned gpio)68*4882a593Smuzhiyun static inline int gpio_direction_input(unsigned gpio)
69*4882a593Smuzhiyun {
70*4882a593Smuzhiyun 	return gpiod_direction_input(gpio_to_desc(gpio));
71*4882a593Smuzhiyun }
gpio_direction_output(unsigned gpio,int value)72*4882a593Smuzhiyun static inline int gpio_direction_output(unsigned gpio, int value)
73*4882a593Smuzhiyun {
74*4882a593Smuzhiyun 	return gpiod_direction_output_raw(gpio_to_desc(gpio), value);
75*4882a593Smuzhiyun }
76*4882a593Smuzhiyun 
gpio_set_debounce(unsigned gpio,unsigned debounce)77*4882a593Smuzhiyun static inline int gpio_set_debounce(unsigned gpio, unsigned debounce)
78*4882a593Smuzhiyun {
79*4882a593Smuzhiyun 	return gpiod_set_debounce(gpio_to_desc(gpio), debounce);
80*4882a593Smuzhiyun }
81*4882a593Smuzhiyun 
gpio_get_value_cansleep(unsigned gpio)82*4882a593Smuzhiyun static inline int gpio_get_value_cansleep(unsigned gpio)
83*4882a593Smuzhiyun {
84*4882a593Smuzhiyun 	return gpiod_get_raw_value_cansleep(gpio_to_desc(gpio));
85*4882a593Smuzhiyun }
gpio_set_value_cansleep(unsigned gpio,int value)86*4882a593Smuzhiyun static inline void gpio_set_value_cansleep(unsigned gpio, int value)
87*4882a593Smuzhiyun {
88*4882a593Smuzhiyun 	return gpiod_set_raw_value_cansleep(gpio_to_desc(gpio), value);
89*4882a593Smuzhiyun }
90*4882a593Smuzhiyun 
91*4882a593Smuzhiyun 
92*4882a593Smuzhiyun /* A platform's <asm/gpio.h> code may want to inline the I/O calls when
93*4882a593Smuzhiyun  * the GPIO is constant and refers to some always-present controller,
94*4882a593Smuzhiyun  * giving direct access to chip registers and tight bitbanging loops.
95*4882a593Smuzhiyun  */
__gpio_get_value(unsigned gpio)96*4882a593Smuzhiyun static inline int __gpio_get_value(unsigned gpio)
97*4882a593Smuzhiyun {
98*4882a593Smuzhiyun 	return gpiod_get_raw_value(gpio_to_desc(gpio));
99*4882a593Smuzhiyun }
__gpio_set_value(unsigned gpio,int value)100*4882a593Smuzhiyun static inline void __gpio_set_value(unsigned gpio, int value)
101*4882a593Smuzhiyun {
102*4882a593Smuzhiyun 	return gpiod_set_raw_value(gpio_to_desc(gpio), value);
103*4882a593Smuzhiyun }
104*4882a593Smuzhiyun 
__gpio_cansleep(unsigned gpio)105*4882a593Smuzhiyun static inline int __gpio_cansleep(unsigned gpio)
106*4882a593Smuzhiyun {
107*4882a593Smuzhiyun 	return gpiod_cansleep(gpio_to_desc(gpio));
108*4882a593Smuzhiyun }
109*4882a593Smuzhiyun 
__gpio_to_irq(unsigned gpio)110*4882a593Smuzhiyun static inline int __gpio_to_irq(unsigned gpio)
111*4882a593Smuzhiyun {
112*4882a593Smuzhiyun 	return gpiod_to_irq(gpio_to_desc(gpio));
113*4882a593Smuzhiyun }
114*4882a593Smuzhiyun 
115*4882a593Smuzhiyun extern int gpio_request_one(unsigned gpio, unsigned long flags, const char *label);
116*4882a593Smuzhiyun extern int gpio_request_array(const struct gpio *array, size_t num);
117*4882a593Smuzhiyun extern void gpio_free_array(const struct gpio *array, size_t num);
118*4882a593Smuzhiyun 
119*4882a593Smuzhiyun /*
120*4882a593Smuzhiyun  * A sysfs interface can be exported by individual drivers if they want,
121*4882a593Smuzhiyun  * but more typically is configured entirely from userspace.
122*4882a593Smuzhiyun  */
gpio_export(unsigned gpio,bool direction_may_change)123*4882a593Smuzhiyun static inline int gpio_export(unsigned gpio, bool direction_may_change)
124*4882a593Smuzhiyun {
125*4882a593Smuzhiyun 	return gpiod_export(gpio_to_desc(gpio), direction_may_change);
126*4882a593Smuzhiyun }
127*4882a593Smuzhiyun 
gpio_export_link(struct device * dev,const char * name,unsigned gpio)128*4882a593Smuzhiyun static inline int gpio_export_link(struct device *dev, const char *name,
129*4882a593Smuzhiyun 				   unsigned gpio)
130*4882a593Smuzhiyun {
131*4882a593Smuzhiyun 	return gpiod_export_link(dev, name, gpio_to_desc(gpio));
132*4882a593Smuzhiyun }
133*4882a593Smuzhiyun 
gpio_unexport(unsigned gpio)134*4882a593Smuzhiyun static inline void gpio_unexport(unsigned gpio)
135*4882a593Smuzhiyun {
136*4882a593Smuzhiyun 	gpiod_unexport(gpio_to_desc(gpio));
137*4882a593Smuzhiyun }
138*4882a593Smuzhiyun 
139*4882a593Smuzhiyun #else	/* !CONFIG_GPIOLIB */
140*4882a593Smuzhiyun 
141*4882a593Smuzhiyun #include <linux/kernel.h>
142*4882a593Smuzhiyun 
gpio_is_valid(int number)143*4882a593Smuzhiyun static inline bool gpio_is_valid(int number)
144*4882a593Smuzhiyun {
145*4882a593Smuzhiyun 	/* only non-negative numbers are valid */
146*4882a593Smuzhiyun 	return number >= 0;
147*4882a593Smuzhiyun }
148*4882a593Smuzhiyun 
149*4882a593Smuzhiyun /* platforms that don't directly support access to GPIOs through I2C, SPI,
150*4882a593Smuzhiyun  * or other blocking infrastructure can use these wrappers.
151*4882a593Smuzhiyun  */
152*4882a593Smuzhiyun 
gpio_cansleep(unsigned gpio)153*4882a593Smuzhiyun static inline int gpio_cansleep(unsigned gpio)
154*4882a593Smuzhiyun {
155*4882a593Smuzhiyun 	return 0;
156*4882a593Smuzhiyun }
157*4882a593Smuzhiyun 
gpio_get_value_cansleep(unsigned gpio)158*4882a593Smuzhiyun static inline int gpio_get_value_cansleep(unsigned gpio)
159*4882a593Smuzhiyun {
160*4882a593Smuzhiyun 	might_sleep();
161*4882a593Smuzhiyun 	return __gpio_get_value(gpio);
162*4882a593Smuzhiyun }
163*4882a593Smuzhiyun 
gpio_set_value_cansleep(unsigned gpio,int value)164*4882a593Smuzhiyun static inline void gpio_set_value_cansleep(unsigned gpio, int value)
165*4882a593Smuzhiyun {
166*4882a593Smuzhiyun 	might_sleep();
167*4882a593Smuzhiyun 	__gpio_set_value(gpio, value);
168*4882a593Smuzhiyun }
169*4882a593Smuzhiyun 
170*4882a593Smuzhiyun #endif /* !CONFIG_GPIOLIB */
171*4882a593Smuzhiyun 
172*4882a593Smuzhiyun #endif /* _ASM_GENERIC_GPIO_H */
173