Merge tag 'pm-5.10-rc1-2' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael...
[linux-2.6-microblaze.git] / include / linux / gpio / machine.h
1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef __LINUX_GPIO_MACHINE_H
3 #define __LINUX_GPIO_MACHINE_H
4
5 #include <linux/types.h>
6 #include <linux/list.h>
7
8 enum gpio_lookup_flags {
9         GPIO_ACTIVE_HIGH                = (0 << 0),
10         GPIO_ACTIVE_LOW                 = (1 << 0),
11         GPIO_OPEN_DRAIN                 = (1 << 1),
12         GPIO_OPEN_SOURCE                = (1 << 2),
13         GPIO_PERSISTENT                 = (0 << 3),
14         GPIO_TRANSITORY                 = (1 << 3),
15         GPIO_PULL_UP                    = (1 << 4),
16         GPIO_PULL_DOWN                  = (1 << 5),
17
18         GPIO_LOOKUP_FLAGS_DEFAULT       = GPIO_ACTIVE_HIGH | GPIO_PERSISTENT,
19 };
20
21 /**
22  * struct gpiod_lookup - lookup table
23  * @key: either the name of the chip the GPIO belongs to, or the GPIO line name
24  *       Note that GPIO line names are not guaranteed to be globally unique,
25  *       so this will use the first match found!
26  * @chip_hwnum: hardware number (i.e. relative to the chip) of the GPIO, or
27  *              U16_MAX to indicate that @key is a GPIO line name
28  * @con_id: name of the GPIO from the device's point of view
29  * @idx: index of the GPIO in case several GPIOs share the same name
30  * @flags: bitmask of gpio_lookup_flags GPIO_* values
31  *
32  * gpiod_lookup is a lookup table for associating GPIOs to specific devices and
33  * functions using platform data.
34  */
35 struct gpiod_lookup {
36         const char *key;
37         u16 chip_hwnum;
38         const char *con_id;
39         unsigned int idx;
40         unsigned long flags;
41 };
42
43 struct gpiod_lookup_table {
44         struct list_head list;
45         const char *dev_id;
46         struct gpiod_lookup table[];
47 };
48
49 /**
50  * struct gpiod_hog - GPIO line hog table
51  * @chip_label: name of the chip the GPIO belongs to
52  * @chip_hwnum: hardware number (i.e. relative to the chip) of the GPIO
53  * @line_name: consumer name for the hogged line
54  * @lflags: bitmask of gpio_lookup_flags GPIO_* values
55  * @dflags: GPIO flags used to specify the direction and value
56  */
57 struct gpiod_hog {
58         struct list_head list;
59         const char *chip_label;
60         u16 chip_hwnum;
61         const char *line_name;
62         unsigned long lflags;
63         int dflags;
64 };
65
66 /*
67  * Simple definition of a single GPIO under a con_id
68  */
69 #define GPIO_LOOKUP(_key, _chip_hwnum, _con_id, _flags) \
70         GPIO_LOOKUP_IDX(_key, _chip_hwnum, _con_id, 0, _flags)
71
72 /*
73  * Use this macro if you need to have several GPIOs under the same con_id.
74  * Each GPIO needs to use a different index and can be accessed using
75  * gpiod_get_index()
76  */
77 #define GPIO_LOOKUP_IDX(_key, _chip_hwnum, _con_id, _idx, _flags)         \
78 {                                                                         \
79         .key = _key,                                                      \
80         .chip_hwnum = _chip_hwnum,                                        \
81         .con_id = _con_id,                                                \
82         .idx = _idx,                                                      \
83         .flags = _flags,                                                  \
84 }
85
86 /*
87  * Simple definition of a single GPIO hog in an array.
88  */
89 #define GPIO_HOG(_chip_label, _chip_hwnum, _line_name, _lflags, _dflags)  \
90 {                                                                         \
91         .chip_label = _chip_label,                                        \
92         .chip_hwnum = _chip_hwnum,                                        \
93         .line_name = _line_name,                                          \
94         .lflags = _lflags,                                                \
95         .dflags = _dflags,                                                \
96 }
97
98 #ifdef CONFIG_GPIOLIB
99 void gpiod_add_lookup_table(struct gpiod_lookup_table *table);
100 void gpiod_add_lookup_tables(struct gpiod_lookup_table **tables, size_t n);
101 void gpiod_remove_lookup_table(struct gpiod_lookup_table *table);
102 void gpiod_add_hogs(struct gpiod_hog *hogs);
103 #else /* ! CONFIG_GPIOLIB */
104 static inline
105 void gpiod_add_lookup_table(struct gpiod_lookup_table *table) {}
106 static inline
107 void gpiod_add_lookup_tables(struct gpiod_lookup_table **tables, size_t n) {}
108 static inline
109 void gpiod_remove_lookup_table(struct gpiod_lookup_table *table) {}
110 static inline void gpiod_add_hogs(struct gpiod_hog *hogs) {}
111 #endif /* CONFIG_GPIOLIB */
112
113 #endif /* __LINUX_GPIO_MACHINE_H */