blob: 1ebe5be05d5f81fa6cc6452a8b6398748a0118a7 [file] [log] [blame]
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00001/* 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
8enum gpio_lookup_flags {
David Brazdil0f672f62019-12-10 10:32:29 +00009 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,
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000019};
20
21/**
22 * struct gpiod_lookup - lookup table
23 * @chip_label: name of the chip the GPIO belongs to
24 * @chip_hwnum: hardware number (i.e. relative to the chip) of the GPIO
25 * @con_id: name of the GPIO from the device's point of view
26 * @idx: index of the GPIO in case several GPIOs share the same name
David Brazdil0f672f62019-12-10 10:32:29 +000027 * @flags: bitmask of gpio_lookup_flags GPIO_* values
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000028 *
29 * gpiod_lookup is a lookup table for associating GPIOs to specific devices and
30 * functions using platform data.
31 */
32struct gpiod_lookup {
33 const char *chip_label;
34 u16 chip_hwnum;
35 const char *con_id;
36 unsigned int idx;
David Brazdil0f672f62019-12-10 10:32:29 +000037 unsigned long flags;
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000038};
39
40struct gpiod_lookup_table {
41 struct list_head list;
42 const char *dev_id;
43 struct gpiod_lookup table[];
44};
45
46/**
47 * struct gpiod_hog - GPIO line hog table
48 * @chip_label: name of the chip the GPIO belongs to
49 * @chip_hwnum: hardware number (i.e. relative to the chip) of the GPIO
50 * @line_name: consumer name for the hogged line
David Brazdil0f672f62019-12-10 10:32:29 +000051 * @lflags: bitmask of gpio_lookup_flags GPIO_* values
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000052 * @dflags: GPIO flags used to specify the direction and value
53 */
54struct gpiod_hog {
55 struct list_head list;
56 const char *chip_label;
57 u16 chip_hwnum;
58 const char *line_name;
David Brazdil0f672f62019-12-10 10:32:29 +000059 unsigned long lflags;
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000060 int dflags;
61};
62
63/*
64 * Simple definition of a single GPIO under a con_id
65 */
66#define GPIO_LOOKUP(_chip_label, _chip_hwnum, _con_id, _flags) \
67 GPIO_LOOKUP_IDX(_chip_label, _chip_hwnum, _con_id, 0, _flags)
68
69/*
70 * Use this macro if you need to have several GPIOs under the same con_id.
71 * Each GPIO needs to use a different index and can be accessed using
72 * gpiod_get_index()
73 */
74#define GPIO_LOOKUP_IDX(_chip_label, _chip_hwnum, _con_id, _idx, _flags) \
75{ \
76 .chip_label = _chip_label, \
77 .chip_hwnum = _chip_hwnum, \
78 .con_id = _con_id, \
79 .idx = _idx, \
80 .flags = _flags, \
81}
82
83/*
84 * Simple definition of a single GPIO hog in an array.
85 */
86#define GPIO_HOG(_chip_label, _chip_hwnum, _line_name, _lflags, _dflags) \
87{ \
88 .chip_label = _chip_label, \
89 .chip_hwnum = _chip_hwnum, \
90 .line_name = _line_name, \
91 .lflags = _lflags, \
92 .dflags = _dflags, \
93}
94
95#ifdef CONFIG_GPIOLIB
96void gpiod_add_lookup_table(struct gpiod_lookup_table *table);
97void gpiod_add_lookup_tables(struct gpiod_lookup_table **tables, size_t n);
98void gpiod_remove_lookup_table(struct gpiod_lookup_table *table);
99void gpiod_add_hogs(struct gpiod_hog *hogs);
David Brazdil0f672f62019-12-10 10:32:29 +0000100#else /* ! CONFIG_GPIOLIB */
Andrew Scullb4b6d4a2019-01-02 15:54:55 +0000101static inline
102void gpiod_add_lookup_table(struct gpiod_lookup_table *table) {}
103static inline
104void gpiod_add_lookup_tables(struct gpiod_lookup_table **tables, size_t n) {}
105static inline
106void gpiod_remove_lookup_table(struct gpiod_lookup_table *table) {}
107static inline void gpiod_add_hogs(struct gpiod_hog *hogs) {}
David Brazdil0f672f62019-12-10 10:32:29 +0000108#endif /* CONFIG_GPIOLIB */
Andrew Scullb4b6d4a2019-01-02 15:54:55 +0000109
110#endif /* __LINUX_GPIO_MACHINE_H */