Merge tag 'platform-drivers-x86-v6.8-3' of git://git.kernel.org/pub/scm/linux/kernel...
[linux-block.git] / drivers / pinctrl / pinmux.h
CommitLineData
af873fce 1/* SPDX-License-Identifier: GPL-2.0-only */
2744e8af
LW
2/*
3 * Internal interface between the core pin control system and the
4 * pinmux portions
5 *
6 * Copyright (C) 2011 ST-Ericsson SA
7 * Written on behalf of Linaro for ST-Ericsson
8 * Based on bits of regulator core, gpio core and clk core
9 *
10 * Author: Linus Walleij <linus.walleij@linaro.org>
2744e8af 11 */
e5530adc
AS
12
13#include <linux/types.h>
14
15struct dentry;
16struct seq_file;
17
18struct pinctrl_dev;
19struct pinctrl_gpio_range;
20struct pinctrl_map;
21struct pinctrl_setting;
22
2744e8af
LW
23#ifdef CONFIG_PINMUX
24
b9130b77 25int pinmux_check_ops(struct pinctrl_dev *pctldev);
7ecdb16f 26
3f713b7c 27int pinmux_validate_map(const struct pinctrl_map *map, int i);
1e2082b5 28
7cc4e6b0 29bool pinmux_can_be_used_for_gpio(struct pinctrl_dev *pctldev, unsigned int pin);
472a61e7 30
befe5bdf
LW
31int pinmux_request_gpio(struct pinctrl_dev *pctldev,
32 struct pinctrl_gpio_range *range,
7cc4e6b0
AS
33 unsigned int pin, unsigned int gpio);
34void pinmux_free_gpio(struct pinctrl_dev *pctldev, unsigned int pin,
befe5bdf
LW
35 struct pinctrl_gpio_range *range);
36int pinmux_gpio_direction(struct pinctrl_dev *pctldev,
37 struct pinctrl_gpio_range *range,
7cc4e6b0 38 unsigned int pin, bool input);
7ecdb16f 39
3f713b7c 40int pinmux_map_to_setting(const struct pinctrl_map *map,
7ecdb16f 41 struct pinctrl_setting *setting);
3f713b7c
MY
42void pinmux_free_setting(const struct pinctrl_setting *setting);
43int pinmux_enable_setting(const struct pinctrl_setting *setting);
44void pinmux_disable_setting(const struct pinctrl_setting *setting);
7ecdb16f 45
2744e8af
LW
46#else
47
b9130b77 48static inline int pinmux_check_ops(struct pinctrl_dev *pctldev)
2744e8af
LW
49{
50 return 0;
51}
52
3f713b7c 53static inline int pinmux_validate_map(const struct pinctrl_map *map, int i)
1e2082b5
SW
54{
55 return 0;
56}
57
472a61e7 58static inline bool pinmux_can_be_used_for_gpio(struct pinctrl_dev *pctldev,
7cc4e6b0 59 unsigned int pin)
472a61e7
SW
60{
61 return true;
62}
63
befe5bdf
LW
64static inline int pinmux_request_gpio(struct pinctrl_dev *pctldev,
65 struct pinctrl_gpio_range *range,
7cc4e6b0 66 unsigned int pin, unsigned int gpio)
befe5bdf
LW
67{
68 return 0;
69}
70
71static inline void pinmux_free_gpio(struct pinctrl_dev *pctldev,
7cc4e6b0 72 unsigned int pin,
befe5bdf
LW
73 struct pinctrl_gpio_range *range)
74{
75}
76
77static inline int pinmux_gpio_direction(struct pinctrl_dev *pctldev,
78 struct pinctrl_gpio_range *range,
7cc4e6b0 79 unsigned int pin, bool input)
befe5bdf
LW
80{
81 return 0;
82}
83
3f713b7c 84static inline int pinmux_map_to_setting(const struct pinctrl_map *map,
7ecdb16f 85 struct pinctrl_setting *setting)
2744e8af
LW
86{
87 return 0;
88}
89
3f713b7c 90static inline void pinmux_free_setting(const struct pinctrl_setting *setting)
befe5bdf
LW
91{
92}
93
3f713b7c 94static inline int pinmux_enable_setting(const struct pinctrl_setting *setting)
befe5bdf 95{
7ecdb16f 96 return 0;
befe5bdf
LW
97}
98
3f713b7c 99static inline void pinmux_disable_setting(const struct pinctrl_setting *setting)
befe5bdf
LW
100{
101}
102
c736d73c
SW
103#endif
104
105#if defined(CONFIG_PINMUX) && defined(CONFIG_DEBUG_FS)
106
3f713b7c 107void pinmux_show_map(struct seq_file *s, const struct pinctrl_map *map);
c736d73c 108void pinmux_show_setting(struct seq_file *s,
3f713b7c 109 const struct pinctrl_setting *setting);
c736d73c
SW
110void pinmux_init_device_debugfs(struct dentry *devroot,
111 struct pinctrl_dev *pctldev);
112
113#else
114
1e2082b5 115static inline void pinmux_show_map(struct seq_file *s,
3f713b7c 116 const struct pinctrl_map *map)
1e2082b5
SW
117{
118}
119
120static inline void pinmux_show_setting(struct seq_file *s,
3f713b7c 121 const struct pinctrl_setting *setting)
03665e0f
SW
122{
123}
124
1e2082b5
SW
125static inline void pinmux_init_device_debugfs(struct dentry *devroot,
126 struct pinctrl_dev *pctldev)
2744e8af
LW
127{
128}
129
130#endif
a76edc89
TL
131
132#ifdef CONFIG_GENERIC_PINMUX_FUNCTIONS
133
134/**
135 * struct function_desc - generic function descriptor
136 * @name: name of the function
137 * @group_names: array of pin group names
138 * @num_group_names: number of pin group names
139 * @data: pin controller driver specific data
140 */
141struct function_desc {
142 const char *name;
bd0aae66 143 const char * const *group_names;
a76edc89
TL
144 int num_group_names;
145 void *data;
146};
147
148int pinmux_generic_get_function_count(struct pinctrl_dev *pctldev);
149
150const char *
151pinmux_generic_get_function_name(struct pinctrl_dev *pctldev,
152 unsigned int selector);
153
154int pinmux_generic_get_function_groups(struct pinctrl_dev *pctldev,
155 unsigned int selector,
156 const char * const **groups,
7cc4e6b0 157 unsigned int * const num_groups);
a76edc89
TL
158
159struct function_desc *pinmux_generic_get_function(struct pinctrl_dev *pctldev,
160 unsigned int selector);
161
162int pinmux_generic_add_function(struct pinctrl_dev *pctldev,
163 const char *name,
bd0aae66 164 const char * const *groups,
7cc4e6b0 165 unsigned int const num_groups,
a76edc89
TL
166 void *data);
167
168int pinmux_generic_remove_function(struct pinctrl_dev *pctldev,
169 unsigned int selector);
170
a76edc89
TL
171void pinmux_generic_free_functions(struct pinctrl_dev *pctldev);
172
173#else
174
175static inline void pinmux_generic_free_functions(struct pinctrl_dev *pctldev)
176{
177}
178
179#endif /* CONFIG_GENERIC_PINMUX_FUNCTIONS */