blob: 243112c7fa7d091f182c249db3b42a8feafbd545 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Alexandre Courbot79a9bec2013-10-17 10:21:36 -07002#ifndef __LINUX_GPIO_CONSUMER_H
3#define __LINUX_GPIO_CONSUMER_H
4
Arnd Bergmanncdf86cd22014-05-08 15:42:25 +02005#include <linux/bug.h>
Alexandre Courbot79a9bec2013-10-17 10:21:36 -07006#include <linux/err.h>
7#include <linux/kernel.h>
8
Alexandre Courbot79a9bec2013-10-17 10:21:36 -07009struct device;
Alexandre Courbot79a9bec2013-10-17 10:21:36 -070010
11/**
12 * Opaque descriptor for a GPIO. These are obtained using gpiod_get() and are
13 * preferable to the old integer-based handles.
14 *
15 * Contrary to integers, a pointer to a gpio_desc is guaranteed to be valid
16 * until the GPIO is released.
17 */
18struct gpio_desc;
19
Rojhalat Ibrahim66858522015-02-11 17:27:58 +010020/**
21 * Struct containing an array of descriptors that can be obtained using
22 * gpiod_get_array().
23 */
24struct gpio_descs {
25 unsigned int ndescs;
26 struct gpio_desc *desc[];
27};
28
Alexandre Courbot39b2bbe2014-07-25 23:38:36 +090029#define GPIOD_FLAGS_BIT_DIR_SET BIT(0)
30#define GPIOD_FLAGS_BIT_DIR_OUT BIT(1)
31#define GPIOD_FLAGS_BIT_DIR_VAL BIT(2)
Linus Walleijf926dfc2017-09-10 19:26:22 +020032#define GPIOD_FLAGS_BIT_OPEN_DRAIN BIT(3)
Alexandre Courbot39b2bbe2014-07-25 23:38:36 +090033
34/**
35 * Optional flags that can be passed to one of gpiod_* to configure direction
36 * and output value. These values cannot be OR'd.
37 */
38enum gpiod_flags {
39 GPIOD_ASIS = 0,
40 GPIOD_IN = GPIOD_FLAGS_BIT_DIR_SET,
41 GPIOD_OUT_LOW = GPIOD_FLAGS_BIT_DIR_SET | GPIOD_FLAGS_BIT_DIR_OUT,
42 GPIOD_OUT_HIGH = GPIOD_FLAGS_BIT_DIR_SET | GPIOD_FLAGS_BIT_DIR_OUT |
43 GPIOD_FLAGS_BIT_DIR_VAL,
Linus Walleijf926dfc2017-09-10 19:26:22 +020044 GPIOD_OUT_LOW_OPEN_DRAIN = GPIOD_FLAGS_BIT_DIR_SET |
45 GPIOD_FLAGS_BIT_DIR_OUT | GPIOD_FLAGS_BIT_OPEN_DRAIN,
46 GPIOD_OUT_HIGH_OPEN_DRAIN = GPIOD_FLAGS_BIT_DIR_SET |
47 GPIOD_FLAGS_BIT_DIR_OUT | GPIOD_FLAGS_BIT_DIR_VAL |
48 GPIOD_FLAGS_BIT_OPEN_DRAIN,
Alexandre Courbot39b2bbe2014-07-25 23:38:36 +090049};
50
Linus Walleij58b84f62014-08-19 12:00:53 -050051#ifdef CONFIG_GPIOLIB
52
Rojhalat Ibrahim66858522015-02-11 17:27:58 +010053/* Return the number of GPIOs associated with a device / function */
54int gpiod_count(struct device *dev, const char *con_id);
55
Alexandre Courbotbae48da2013-10-17 10:21:38 -070056/* Acquire and dispose GPIOs */
Uwe Kleine-Königb17d1bf2015-02-11 11:52:37 +010057struct gpio_desc *__must_check gpiod_get(struct device *dev,
Alexandre Courbot39b2bbe2014-07-25 23:38:36 +090058 const char *con_id,
59 enum gpiod_flags flags);
Uwe Kleine-Königb17d1bf2015-02-11 11:52:37 +010060struct gpio_desc *__must_check gpiod_get_index(struct device *dev,
Alexandre Courbotbae48da2013-10-17 10:21:38 -070061 const char *con_id,
Alexandre Courbot39b2bbe2014-07-25 23:38:36 +090062 unsigned int idx,
63 enum gpiod_flags flags);
Uwe Kleine-Königb17d1bf2015-02-11 11:52:37 +010064struct gpio_desc *__must_check gpiod_get_optional(struct device *dev,
Alexandre Courbot39b2bbe2014-07-25 23:38:36 +090065 const char *con_id,
66 enum gpiod_flags flags);
Uwe Kleine-Königb17d1bf2015-02-11 11:52:37 +010067struct gpio_desc *__must_check gpiod_get_index_optional(struct device *dev,
Thierry Reding29a1f2332014-04-25 17:10:06 +020068 const char *con_id,
Alexandre Courbot39b2bbe2014-07-25 23:38:36 +090069 unsigned int index,
70 enum gpiod_flags flags);
Rojhalat Ibrahim66858522015-02-11 17:27:58 +010071struct gpio_descs *__must_check gpiod_get_array(struct device *dev,
72 const char *con_id,
73 enum gpiod_flags flags);
74struct gpio_descs *__must_check gpiod_get_array_optional(struct device *dev,
75 const char *con_id,
76 enum gpiod_flags flags);
Alexandre Courbotbae48da2013-10-17 10:21:38 -070077void gpiod_put(struct gpio_desc *desc);
Rojhalat Ibrahim66858522015-02-11 17:27:58 +010078void gpiod_put_array(struct gpio_descs *descs);
Alexandre Courbotbae48da2013-10-17 10:21:38 -070079
Uwe Kleine-Königb17d1bf2015-02-11 11:52:37 +010080struct gpio_desc *__must_check devm_gpiod_get(struct device *dev,
Alexandre Courbot39b2bbe2014-07-25 23:38:36 +090081 const char *con_id,
82 enum gpiod_flags flags);
Uwe Kleine-Königb17d1bf2015-02-11 11:52:37 +010083struct gpio_desc *__must_check devm_gpiod_get_index(struct device *dev,
Alexandre Courbotbae48da2013-10-17 10:21:38 -070084 const char *con_id,
Alexandre Courbot39b2bbe2014-07-25 23:38:36 +090085 unsigned int idx,
86 enum gpiod_flags flags);
Uwe Kleine-Königb17d1bf2015-02-11 11:52:37 +010087struct gpio_desc *__must_check devm_gpiod_get_optional(struct device *dev,
Alexandre Courbot39b2bbe2014-07-25 23:38:36 +090088 const char *con_id,
89 enum gpiod_flags flags);
Thierry Reding29a1f2332014-04-25 17:10:06 +020090struct gpio_desc *__must_check
Uwe Kleine-Königb17d1bf2015-02-11 11:52:37 +010091devm_gpiod_get_index_optional(struct device *dev, const char *con_id,
Alexandre Courbot39b2bbe2014-07-25 23:38:36 +090092 unsigned int index, enum gpiod_flags flags);
Rojhalat Ibrahim331758e2015-02-11 17:28:02 +010093struct gpio_descs *__must_check devm_gpiod_get_array(struct device *dev,
94 const char *con_id,
95 enum gpiod_flags flags);
96struct gpio_descs *__must_check
97devm_gpiod_get_array_optional(struct device *dev, const char *con_id,
98 enum gpiod_flags flags);
Alexandre Courbotbae48da2013-10-17 10:21:38 -070099void devm_gpiod_put(struct device *dev, struct gpio_desc *desc);
Rojhalat Ibrahim331758e2015-02-11 17:28:02 +0100100void devm_gpiod_put_array(struct device *dev, struct gpio_descs *descs);
Alexandre Courbotbae48da2013-10-17 10:21:38 -0700101
Alexandre Courbot8e53b0f2014-11-25 17:16:31 +0900102int gpiod_get_direction(struct gpio_desc *desc);
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700103int gpiod_direction_input(struct gpio_desc *desc);
104int gpiod_direction_output(struct gpio_desc *desc, int value);
Philipp Zabelef70bbe2014-01-07 12:34:11 +0100105int gpiod_direction_output_raw(struct gpio_desc *desc, int value);
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700106
107/* Value get/set from non-sleeping context */
108int gpiod_get_value(const struct gpio_desc *desc);
Lukas Wunnereec1d562017-10-12 12:40:10 +0200109int gpiod_get_array_value(unsigned int array_size,
110 struct gpio_desc **desc_array, int *value_array);
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700111void gpiod_set_value(struct gpio_desc *desc, int value);
Rojhalat Ibrahim3fff99b2015-05-13 11:04:56 +0200112void gpiod_set_array_value(unsigned int array_size,
113 struct gpio_desc **desc_array, int *value_array);
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700114int gpiod_get_raw_value(const struct gpio_desc *desc);
Lukas Wunnereec1d562017-10-12 12:40:10 +0200115int gpiod_get_raw_array_value(unsigned int array_size,
116 struct gpio_desc **desc_array,
117 int *value_array);
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700118void gpiod_set_raw_value(struct gpio_desc *desc, int value);
Laura Abbott30277432018-05-21 10:57:07 -0700119int gpiod_set_raw_array_value(unsigned int array_size,
Rojhalat Ibrahim3fff99b2015-05-13 11:04:56 +0200120 struct gpio_desc **desc_array,
121 int *value_array);
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700122
123/* Value get/set from sleeping context */
124int gpiod_get_value_cansleep(const struct gpio_desc *desc);
Lukas Wunnereec1d562017-10-12 12:40:10 +0200125int gpiod_get_array_value_cansleep(unsigned int array_size,
126 struct gpio_desc **desc_array,
127 int *value_array);
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700128void gpiod_set_value_cansleep(struct gpio_desc *desc, int value);
Rojhalat Ibrahim3fff99b2015-05-13 11:04:56 +0200129void gpiod_set_array_value_cansleep(unsigned int array_size,
130 struct gpio_desc **desc_array,
131 int *value_array);
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700132int gpiod_get_raw_value_cansleep(const struct gpio_desc *desc);
Lukas Wunnereec1d562017-10-12 12:40:10 +0200133int gpiod_get_raw_array_value_cansleep(unsigned int array_size,
134 struct gpio_desc **desc_array,
135 int *value_array);
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700136void gpiod_set_raw_value_cansleep(struct gpio_desc *desc, int value);
Laura Abbott30277432018-05-21 10:57:07 -0700137int gpiod_set_raw_array_value_cansleep(unsigned int array_size,
Rojhalat Ibrahim3fff99b2015-05-13 11:04:56 +0200138 struct gpio_desc **desc_array,
139 int *value_array);
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700140
141int gpiod_set_debounce(struct gpio_desc *desc, unsigned debounce);
Andrew Jefferye10f72b2017-11-30 14:25:24 +1030142int gpiod_set_transitory(struct gpio_desc *desc, bool transitory);
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700143
144int gpiod_is_active_low(const struct gpio_desc *desc);
145int gpiod_cansleep(const struct gpio_desc *desc);
146
147int gpiod_to_irq(const struct gpio_desc *desc);
148
149/* Convert between the old gpio_ and new gpiod_ interfaces */
150struct gpio_desc *gpio_to_desc(unsigned gpio);
151int desc_to_gpio(const struct gpio_desc *desc);
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700152
Mika Westerberg40b73182014-10-21 13:33:59 +0200153/* Child properties interface */
Linus Walleij92542ed2017-12-29 22:52:02 +0100154struct device_node;
Mika Westerberg40b73182014-10-21 13:33:59 +0200155struct fwnode_handle;
156
Linus Walleij92542ed2017-12-29 22:52:02 +0100157struct gpio_desc *devm_gpiod_get_from_of_node(struct device *dev,
158 struct device_node *node,
159 const char *propname, int index,
160 enum gpiod_flags dflags,
161 const char *label);
Mika Westerberg40b73182014-10-21 13:33:59 +0200162struct gpio_desc *fwnode_get_named_gpiod(struct fwnode_handle *fwnode,
Boris Brezillon537b94d2017-02-02 14:53:11 +0100163 const char *propname, int index,
Alexander Steinb2987d72017-01-12 17:39:24 +0100164 enum gpiod_flags dflags,
165 const char *label);
Boris Brezillon537b94d2017-02-02 14:53:11 +0100166struct gpio_desc *devm_fwnode_get_index_gpiod_from_child(struct device *dev,
167 const char *con_id, int index,
168 struct fwnode_handle *child,
169 enum gpiod_flags flags,
170 const char *label);
Linus Walleij3498d862017-02-21 14:19:45 +0100171
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700172#else /* CONFIG_GPIOLIB */
173
Rojhalat Ibrahim66858522015-02-11 17:27:58 +0100174static inline int gpiod_count(struct device *dev, const char *con_id)
175{
176 return 0;
177}
178
Uwe Kleine-Königb17d1bf2015-02-11 11:52:37 +0100179static inline struct gpio_desc *__must_check gpiod_get(struct device *dev,
180 const char *con_id,
181 enum gpiod_flags flags)
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700182{
183 return ERR_PTR(-ENOSYS);
184}
Linus Walleij0dbc8b72014-09-01 15:15:40 +0200185static inline struct gpio_desc *__must_check
Uwe Kleine-Königb17d1bf2015-02-11 11:52:37 +0100186gpiod_get_index(struct device *dev,
187 const char *con_id,
188 unsigned int idx,
189 enum gpiod_flags flags)
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700190{
191 return ERR_PTR(-ENOSYS);
192}
Thierry Reding29a1f2332014-04-25 17:10:06 +0200193
194static inline struct gpio_desc *__must_check
Uwe Kleine-Königb17d1bf2015-02-11 11:52:37 +0100195gpiod_get_optional(struct device *dev, const char *con_id,
196 enum gpiod_flags flags)
Thierry Reding29a1f2332014-04-25 17:10:06 +0200197{
Dmitry Torokhov22c40362017-02-12 17:13:55 -0800198 return NULL;
Thierry Reding29a1f2332014-04-25 17:10:06 +0200199}
200
201static inline struct gpio_desc *__must_check
Uwe Kleine-Königb17d1bf2015-02-11 11:52:37 +0100202gpiod_get_index_optional(struct device *dev, const char *con_id,
203 unsigned int index, enum gpiod_flags flags)
Thierry Reding29a1f2332014-04-25 17:10:06 +0200204{
Dmitry Torokhov22c40362017-02-12 17:13:55 -0800205 return NULL;
Thierry Reding29a1f2332014-04-25 17:10:06 +0200206}
207
Rojhalat Ibrahim66858522015-02-11 17:27:58 +0100208static inline struct gpio_descs *__must_check
209gpiod_get_array(struct device *dev, const char *con_id,
210 enum gpiod_flags flags)
211{
212 return ERR_PTR(-ENOSYS);
213}
214
215static inline struct gpio_descs *__must_check
216gpiod_get_array_optional(struct device *dev, const char *con_id,
217 enum gpiod_flags flags)
218{
Dmitry Torokhov22c40362017-02-12 17:13:55 -0800219 return NULL;
Rojhalat Ibrahim66858522015-02-11 17:27:58 +0100220}
221
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700222static inline void gpiod_put(struct gpio_desc *desc)
223{
224 might_sleep();
225
226 /* GPIO can never have been requested */
227 WARN_ON(1);
228}
229
Rojhalat Ibrahim66858522015-02-11 17:27:58 +0100230static inline void gpiod_put_array(struct gpio_descs *descs)
231{
232 might_sleep();
233
234 /* GPIO can never have been requested */
235 WARN_ON(1);
236}
237
Linus Walleij0dbc8b72014-09-01 15:15:40 +0200238static inline struct gpio_desc *__must_check
Uwe Kleine-Königb17d1bf2015-02-11 11:52:37 +0100239devm_gpiod_get(struct device *dev,
Linus Walleij0dbc8b72014-09-01 15:15:40 +0200240 const char *con_id,
241 enum gpiod_flags flags)
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700242{
243 return ERR_PTR(-ENOSYS);
244}
245static inline
Linus Walleij0dbc8b72014-09-01 15:15:40 +0200246struct gpio_desc *__must_check
Uwe Kleine-Königb17d1bf2015-02-11 11:52:37 +0100247devm_gpiod_get_index(struct device *dev,
Linus Walleij0dbc8b72014-09-01 15:15:40 +0200248 const char *con_id,
249 unsigned int idx,
250 enum gpiod_flags flags)
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700251{
252 return ERR_PTR(-ENOSYS);
253}
Thierry Reding29a1f2332014-04-25 17:10:06 +0200254
255static inline struct gpio_desc *__must_check
Uwe Kleine-Königb17d1bf2015-02-11 11:52:37 +0100256devm_gpiod_get_optional(struct device *dev, const char *con_id,
Linus Walleij0dbc8b72014-09-01 15:15:40 +0200257 enum gpiod_flags flags)
Thierry Reding29a1f2332014-04-25 17:10:06 +0200258{
Dmitry Torokhov22c40362017-02-12 17:13:55 -0800259 return NULL;
Thierry Reding29a1f2332014-04-25 17:10:06 +0200260}
261
262static inline struct gpio_desc *__must_check
Uwe Kleine-Königb17d1bf2015-02-11 11:52:37 +0100263devm_gpiod_get_index_optional(struct device *dev, const char *con_id,
Linus Walleij0dbc8b72014-09-01 15:15:40 +0200264 unsigned int index, enum gpiod_flags flags)
Thierry Reding29a1f2332014-04-25 17:10:06 +0200265{
Dmitry Torokhov22c40362017-02-12 17:13:55 -0800266 return NULL;
Thierry Reding29a1f2332014-04-25 17:10:06 +0200267}
268
Rojhalat Ibrahim331758e2015-02-11 17:28:02 +0100269static inline struct gpio_descs *__must_check
270devm_gpiod_get_array(struct device *dev, const char *con_id,
271 enum gpiod_flags flags)
272{
273 return ERR_PTR(-ENOSYS);
274}
275
276static inline struct gpio_descs *__must_check
277devm_gpiod_get_array_optional(struct device *dev, const char *con_id,
278 enum gpiod_flags flags)
279{
Dmitry Torokhov22c40362017-02-12 17:13:55 -0800280 return NULL;
Rojhalat Ibrahim331758e2015-02-11 17:28:02 +0100281}
282
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700283static inline void devm_gpiod_put(struct device *dev, struct gpio_desc *desc)
284{
285 might_sleep();
286
287 /* GPIO can never have been requested */
288 WARN_ON(1);
289}
290
Rojhalat Ibrahim331758e2015-02-11 17:28:02 +0100291static inline void devm_gpiod_put_array(struct device *dev,
292 struct gpio_descs *descs)
293{
294 might_sleep();
295
296 /* GPIO can never have been requested */
297 WARN_ON(1);
298}
299
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700300
301static inline int gpiod_get_direction(const struct gpio_desc *desc)
302{
303 /* GPIO can never have been requested */
304 WARN_ON(1);
305 return -ENOSYS;
306}
307static inline int gpiod_direction_input(struct gpio_desc *desc)
308{
309 /* GPIO can never have been requested */
310 WARN_ON(1);
311 return -ENOSYS;
312}
313static inline int gpiod_direction_output(struct gpio_desc *desc, int value)
314{
315 /* GPIO can never have been requested */
316 WARN_ON(1);
317 return -ENOSYS;
318}
Philipp Zabelef70bbe2014-01-07 12:34:11 +0100319static inline int gpiod_direction_output_raw(struct gpio_desc *desc, int value)
320{
321 /* GPIO can never have been requested */
322 WARN_ON(1);
323 return -ENOSYS;
324}
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700325
326
327static inline int gpiod_get_value(const struct gpio_desc *desc)
328{
329 /* GPIO can never have been requested */
330 WARN_ON(1);
331 return 0;
332}
Lukas Wunnereec1d562017-10-12 12:40:10 +0200333static inline int gpiod_get_array_value(unsigned int array_size,
334 struct gpio_desc **desc_array,
335 int *value_array)
336{
337 /* GPIO can never have been requested */
338 WARN_ON(1);
339 return 0;
340}
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700341static inline void gpiod_set_value(struct gpio_desc *desc, int value)
342{
343 /* GPIO can never have been requested */
344 WARN_ON(1);
345}
Rojhalat Ibrahim3fff99b2015-05-13 11:04:56 +0200346static inline void gpiod_set_array_value(unsigned int array_size,
347 struct gpio_desc **desc_array,
348 int *value_array)
Rojhalat Ibrahim5f424242014-11-04 17:12:06 +0100349{
350 /* GPIO can never have been requested */
351 WARN_ON(1);
352}
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700353static inline int gpiod_get_raw_value(const struct gpio_desc *desc)
354{
355 /* GPIO can never have been requested */
356 WARN_ON(1);
357 return 0;
358}
Lukas Wunnereec1d562017-10-12 12:40:10 +0200359static inline int gpiod_get_raw_array_value(unsigned int array_size,
360 struct gpio_desc **desc_array,
361 int *value_array)
362{
363 /* GPIO can never have been requested */
364 WARN_ON(1);
365 return 0;
366}
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700367static inline void gpiod_set_raw_value(struct gpio_desc *desc, int value)
368{
369 /* GPIO can never have been requested */
370 WARN_ON(1);
371}
Laura Abbott30277432018-05-21 10:57:07 -0700372static inline int gpiod_set_raw_array_value(unsigned int array_size,
Rojhalat Ibrahim3fff99b2015-05-13 11:04:56 +0200373 struct gpio_desc **desc_array,
374 int *value_array)
Rojhalat Ibrahim5f424242014-11-04 17:12:06 +0100375{
376 /* GPIO can never have been requested */
377 WARN_ON(1);
Laura Abbott30277432018-05-21 10:57:07 -0700378 return 0;
Rojhalat Ibrahim5f424242014-11-04 17:12:06 +0100379}
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700380
381static inline int gpiod_get_value_cansleep(const struct gpio_desc *desc)
382{
383 /* GPIO can never have been requested */
384 WARN_ON(1);
385 return 0;
386}
Lukas Wunnereec1d562017-10-12 12:40:10 +0200387static inline int gpiod_get_array_value_cansleep(unsigned int array_size,
388 struct gpio_desc **desc_array,
389 int *value_array)
390{
391 /* GPIO can never have been requested */
392 WARN_ON(1);
393 return 0;
394}
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700395static inline void gpiod_set_value_cansleep(struct gpio_desc *desc, int value)
396{
397 /* GPIO can never have been requested */
398 WARN_ON(1);
399}
Rojhalat Ibrahim3fff99b2015-05-13 11:04:56 +0200400static inline void gpiod_set_array_value_cansleep(unsigned int array_size,
Rojhalat Ibrahim5f424242014-11-04 17:12:06 +0100401 struct gpio_desc **desc_array,
402 int *value_array)
403{
404 /* GPIO can never have been requested */
405 WARN_ON(1);
406}
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700407static inline int gpiod_get_raw_value_cansleep(const struct gpio_desc *desc)
408{
409 /* GPIO can never have been requested */
410 WARN_ON(1);
411 return 0;
412}
Lukas Wunnereec1d562017-10-12 12:40:10 +0200413static inline int gpiod_get_raw_array_value_cansleep(unsigned int array_size,
414 struct gpio_desc **desc_array,
415 int *value_array)
416{
417 /* GPIO can never have been requested */
418 WARN_ON(1);
419 return 0;
420}
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700421static inline void gpiod_set_raw_value_cansleep(struct gpio_desc *desc,
422 int value)
423{
424 /* GPIO can never have been requested */
425 WARN_ON(1);
426}
Laura Abbott30277432018-05-21 10:57:07 -0700427static inline int gpiod_set_raw_array_value_cansleep(unsigned int array_size,
Rojhalat Ibrahim5f424242014-11-04 17:12:06 +0100428 struct gpio_desc **desc_array,
429 int *value_array)
430{
431 /* GPIO can never have been requested */
432 WARN_ON(1);
Laura Abbott30277432018-05-21 10:57:07 -0700433 return 0;
Rojhalat Ibrahim5f424242014-11-04 17:12:06 +0100434}
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700435
436static inline int gpiod_set_debounce(struct gpio_desc *desc, unsigned debounce)
437{
438 /* GPIO can never have been requested */
439 WARN_ON(1);
440 return -ENOSYS;
441}
442
Andrew Jefferye10f72b2017-11-30 14:25:24 +1030443static inline int gpiod_set_transitory(struct gpio_desc *desc, bool transitory)
444{
445 /* GPIO can never have been requested */
446 WARN_ON(1);
447 return -ENOSYS;
448}
449
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700450static inline int gpiod_is_active_low(const struct gpio_desc *desc)
451{
452 /* GPIO can never have been requested */
453 WARN_ON(1);
454 return 0;
455}
456static inline int gpiod_cansleep(const struct gpio_desc *desc)
457{
458 /* GPIO can never have been requested */
459 WARN_ON(1);
460 return 0;
461}
462
463static inline int gpiod_to_irq(const struct gpio_desc *desc)
464{
465 /* GPIO can never have been requested */
466 WARN_ON(1);
467 return -EINVAL;
468}
469
470static inline struct gpio_desc *gpio_to_desc(unsigned gpio)
471{
472 return ERR_PTR(-EINVAL);
473}
Markus Pargmannc0017ed2015-08-14 16:10:59 +0200474
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700475static inline int desc_to_gpio(const struct gpio_desc *desc)
476{
477 /* GPIO can never have been requested */
478 WARN_ON(1);
479 return -EINVAL;
480}
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700481
Geert Uytterhoeven496e7ce2015-05-07 01:08:08 -0700482/* Child properties interface */
Linus Walleij92542ed2017-12-29 22:52:02 +0100483struct device_node;
Geert Uytterhoeven496e7ce2015-05-07 01:08:08 -0700484struct fwnode_handle;
485
Andy Shevchenkoa264d102017-01-09 16:02:28 +0200486static inline
Linus Walleij92542ed2017-12-29 22:52:02 +0100487struct gpio_desc *devm_gpiod_get_from_of_node(struct device *dev,
488 struct device_node *node,
489 const char *propname, int index,
490 enum gpiod_flags dflags,
491 const char *label)
492{
493 return ERR_PTR(-ENOSYS);
494}
495
496static inline
Andy Shevchenkoa264d102017-01-09 16:02:28 +0200497struct gpio_desc *fwnode_get_named_gpiod(struct fwnode_handle *fwnode,
Boris Brezillon537b94d2017-02-02 14:53:11 +0100498 const char *propname, int index,
Alexander Steinb2987d72017-01-12 17:39:24 +0100499 enum gpiod_flags dflags,
500 const char *label)
Geert Uytterhoeven496e7ce2015-05-07 01:08:08 -0700501{
502 return ERR_PTR(-ENOSYS);
503}
504
Andy Shevchenkoa264d102017-01-09 16:02:28 +0200505static inline
Boris Brezillon537b94d2017-02-02 14:53:11 +0100506struct gpio_desc *devm_fwnode_get_index_gpiod_from_child(struct device *dev,
507 const char *con_id, int index,
508 struct fwnode_handle *child,
509 enum gpiod_flags flags,
510 const char *label)
511{
512 return ERR_PTR(-ENOSYS);
513}
514
515#endif /* CONFIG_GPIOLIB */
516
517static inline
Boris Brezillon4b094792017-02-02 14:53:10 +0100518struct gpio_desc *devm_fwnode_get_gpiod_from_child(struct device *dev,
519 const char *con_id,
520 struct fwnode_handle *child,
521 enum gpiod_flags flags,
522 const char *label)
Geert Uytterhoeven496e7ce2015-05-07 01:08:08 -0700523{
Boris Brezillon537b94d2017-02-02 14:53:11 +0100524 return devm_fwnode_get_index_gpiod_from_child(dev, con_id, 0, child,
525 flags, label);
Geert Uytterhoeven496e7ce2015-05-07 01:08:08 -0700526}
527
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700528#if IS_ENABLED(CONFIG_GPIOLIB) && IS_ENABLED(CONFIG_GPIO_SYSFS)
529
530int gpiod_export(struct gpio_desc *desc, bool direction_may_change);
531int gpiod_export_link(struct device *dev, const char *name,
532 struct gpio_desc *desc);
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700533void gpiod_unexport(struct gpio_desc *desc);
534
535#else /* CONFIG_GPIOLIB && CONFIG_GPIO_SYSFS */
536
537static inline int gpiod_export(struct gpio_desc *desc,
538 bool direction_may_change)
539{
540 return -ENOSYS;
541}
542
543static inline int gpiod_export_link(struct device *dev, const char *name,
544 struct gpio_desc *desc)
545{
546 return -ENOSYS;
547}
548
Alexandre Courbot79a9bec2013-10-17 10:21:36 -0700549static inline void gpiod_unexport(struct gpio_desc *desc)
550{
551}
552
553#endif /* CONFIG_GPIOLIB && CONFIG_GPIO_SYSFS */
554
555#endif