gpio.h 5.6 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
struct pinctrl_dev;
110

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

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

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

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

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

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

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

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

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

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

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

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

203 204 205 206 207 208 209 210
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 已提交
211 212 213 214 215 216
static inline void gpio_unexport(unsigned gpio)
{
	/* GPIO can never have been exported */
	WARN_ON(1);
}

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

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

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

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

244 245 246 247 248 249
static inline int devm_gpio_request(struct device *dev, unsigned gpio,
				    const char *label)
{
	WARN_ON(1);
	return -EINVAL;
}
250

251 252 253 254 255 256
static inline int devm_gpio_request_one(struct device *dev, unsigned gpio,
					unsigned long flags, const char *label)
{
	WARN_ON(1);
	return -EINVAL;
}
257

258 259 260 261 262 263
static inline void devm_gpio_free(struct device *dev, unsigned int gpio)
{
	WARN_ON(1);
}

#endif /* ! CONFIG_GPIOLIB */
264

265
#endif /* __LINUX_GPIO_H */