gpio.h 6.0 KB
Newer Older
1
/* SPDX-License-Identifier: GPL-2.0 */
2 3 4 5 6 7 8 9 10 11
/*
 * <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>
 */
12 13 14
#ifndef __LINUX_GPIO_H
#define __LINUX_GPIO_H

15 16
#include <linux/errno.h>

17
/* see Documentation/driver-api/gpio/legacy.rst */
18

19 20 21 22 23 24 25 26 27 28 29
/* 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)

30 31 32
/* Gpio pin is active-low */
#define GPIOF_ACTIVE_LOW        (1 << 2)

33
/* Gpio pin is open drain */
34
#define GPIOF_OPEN_DRAIN	(1 << 3)
35

36
/* Gpio pin is open source */
37
#define GPIOF_OPEN_SOURCE	(1 << 4)
38

39 40
#define GPIOF_EXPORT		(1 << 5)
#define GPIOF_EXPORT_CHANGEABLE	(1 << 6)
41 42 43
#define GPIOF_EXPORT_DIR_FIXED	(GPIOF_EXPORT)
#define GPIOF_EXPORT_DIR_CHANGEABLE (GPIOF_EXPORT | GPIOF_EXPORT_CHANGEABLE)

44 45 46 47 48 49 50 51 52 53 54 55
/**
 * 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;
};

56
#ifdef CONFIG_GPIOLIB
57 58

#ifdef CONFIG_ARCH_HAVE_CUSTOM_GPIO_H
59
#include <asm/gpio.h>
60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
#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;
}

89
#endif /* ! CONFIG_ARCH_HAVE_CUSTOM_GPIO_H */
90

91 92 93 94 95 96 97 98 99
/* 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);

100
#else /* ! CONFIG_GPIOLIB */
101

102
#include <linux/kernel.h>
D
David Brownell 已提交
103
#include <linux/types.h>
104
#include <linux/bug.h>
105
#include <linux/pinctrl/pinctrl.h>
D
David Brownell 已提交
106

107
struct device;
108
struct gpio_chip;
109

110
static inline bool gpio_is_valid(int number)
111
{
112
	return false;
113 114
}

115
static inline int gpio_request(unsigned gpio, const char *label)
116 117 118 119
{
	return -ENOSYS;
}

120
static inline int gpio_request_one(unsigned gpio,
121 122 123 124 125
					unsigned long flags, const char *label)
{
	return -ENOSYS;
}

126
static inline int gpio_request_array(const struct gpio *array, size_t num)
127 128 129 130
{
	return -ENOSYS;
}

131 132
static inline void gpio_free(unsigned gpio)
{
133 134
	might_sleep();

135
	/* GPIO can never have been requested */
136 137 138
	WARN_ON(1);
}

139
static inline void gpio_free_array(const struct gpio *array, size_t num)
140 141 142 143 144 145 146
{
	might_sleep();

	/* GPIO can never have been requested */
	WARN_ON(1);
}

147
static inline int gpio_direction_input(unsigned gpio)
148 149 150 151
{
	return -ENOSYS;
}

152
static inline int gpio_direction_output(unsigned gpio, int value)
153 154 155 156
{
	return -ENOSYS;
}

157 158 159 160 161
static inline int gpio_set_debounce(unsigned gpio, unsigned debounce)
{
	return -ENOSYS;
}

162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194
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);
}

D
David Brownell 已提交
195 196 197 198 199 200 201
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;
}

202 203 204 205 206 207 208 209
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;
}

D
David Brownell 已提交
210 211 212 213 214 215
static inline void gpio_unexport(unsigned gpio)
{
	/* GPIO can never have been exported */
	WARN_ON(1);
}

216 217 218 219 220 221 222
static inline int gpio_to_irq(unsigned gpio)
{
	/* GPIO can never have been requested or set as input */
	WARN_ON(1);
	return -EINVAL;
}

223 224
static inline int gpiochip_lock_as_irq(struct gpio_chip *chip,
				       unsigned int offset)
225 226 227 228 229
{
	WARN_ON(1);
	return -EINVAL;
}

230 231
static inline void gpiochip_unlock_as_irq(struct gpio_chip *chip,
					  unsigned int offset)
232 233 234 235
{
	WARN_ON(1);
}

236 237 238 239 240 241 242
static inline int irq_to_gpio(unsigned irq)
{
	/* irq can never have been returned from gpio_to_irq() */
	WARN_ON(1);
	return -EINVAL;
}

243
static inline int
244
gpiochip_add_pin_range(struct gpio_chip *chip, const char *pinctl_name,
245
		       unsigned int gpio_offset, unsigned int pin_offset,
246
		       unsigned int npins)
247
{
248 249
	WARN_ON(1);
	return -EINVAL;
250 251
}

252 253 254 255 256 257 258 259 260
static inline int
gpiochip_add_pingroup_range(struct gpio_chip *chip,
			struct pinctrl_dev *pctldev,
			unsigned int gpio_offset, const char *pin_group)
{
	WARN_ON(1);
	return -EINVAL;
}

261 262 263
static inline void
gpiochip_remove_pin_ranges(struct gpio_chip *chip)
{
264
	WARN_ON(1);
265 266
}

267 268 269 270 271 272
static inline int devm_gpio_request(struct device *dev, unsigned gpio,
				    const char *label)
{
	WARN_ON(1);
	return -EINVAL;
}
273

274 275 276 277 278 279
static inline int devm_gpio_request_one(struct device *dev, unsigned gpio,
					unsigned long flags, const char *label)
{
	WARN_ON(1);
	return -EINVAL;
}
280

281 282 283 284 285 286
static inline void devm_gpio_free(struct device *dev, unsigned int gpio)
{
	WARN_ON(1);
}

#endif /* ! CONFIG_GPIOLIB */
287

288
#endif /* __LINUX_GPIO_H */