hc
2023-02-15 9c2dfff96adcfcdf2a1143893a7dd749b9f3677a
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
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
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
#
# PINCTRL infrastructure and drivers
#
 
menu "Pin controllers"
 
config PINCTRL
   bool "Support pin controllers"
   depends on DM
   help
     This enables the basic support for pinctrl framework.  You may want
     to enable some more options depending on what you want to do.
 
config PINCTRL_FULL
   bool "Support full pin controllers"
   depends on PINCTRL && OF_CONTROL
   default y
   help
     This provides Linux-compatible device tree interface for the pinctrl
     subsystem.  This feature depends on device tree configuration because
     it parses a device tree to look for the pinctrl device which the
     peripheral device is associated with.
 
     If this option is disabled (it is the only possible choice for non-DT
     boards), the pinctrl core provides no systematic mechanism for
     identifying peripheral devices, applying needed pinctrl settings.
     It is totally up to the implementation of each low-level driver.
     You can save memory footprint in return for some limitations.
 
config PINCTRL_GENERIC
   bool "Support generic pin controllers"
   depends on PINCTRL_FULL
   default y
   help
     Say Y here if you want to use the pinctrl subsystem through the
     generic DT interface.  If enabled, some functions become available
     to parse common properties such as "pins", "groups", "functions" and
     some pin configuration parameters.  It would be easier if you only
     need the generic DT interface for pin muxing and pin configuration.
     If you need to handle vendor-specific DT properties, you can disable
     this option and implement your own set_state callback in the pinctrl
     operations.
 
config PINMUX
   bool "Support pin multiplexing controllers"
   depends on PINCTRL_GENERIC
   default y
   help
     This option enables pin multiplexing through the generic pinctrl
     framework. Most SoCs have their own own multiplexing arrangement
     where a single pin can be used for several functions. An SoC pinctrl
     driver allows the required function to be selected for each pin.
     The driver is typically controlled by the device tree.
 
config PINCONF
   bool "Support pin configuration controllers"
   depends on PINCTRL_GENERIC
   help
     This option enables pin configuration through the generic pinctrl
     framework.
 
config SPL_PINCTRL
   bool "Support pin controllers in SPL"
   depends on SPL && SPL_DM
   help
     This option is an SPL-variant of the PINCTRL option.
     See the help of PINCTRL for details.
 
config SPL_PINCTRL_FULL
   bool "Support full pin controllers in SPL"
   depends on SPL_PINCTRL && SPL_OF_CONTROL
   default n if TARGET_STM32F746_DISCO
   default y
   help
     This option is an SPL-variant of the PINCTRL_FULL option.
     See the help of PINCTRL_FULL for details.
 
config SPL_PINCTRL_GENERIC
   bool "Support generic pin controllers in SPL"
   depends on SPL_PINCTRL_FULL
   default y
   help
     This option is an SPL-variant of the PINCTRL_GENERIC option.
     See the help of PINCTRL_GENERIC for details.
 
config SPL_PINMUX
   bool "Support pin multiplexing controllers in SPL"
   depends on SPL_PINCTRL_GENERIC
   default y
   help
     This option is an SPL-variant of the PINMUX option.
     See the help of PINMUX for details.
     The pinctrl subsystem can add a substantial overhead to the SPL
     image since it typically requires quite a few tables either in the
     driver or in the device tree. If this is acceptable and you need
     to adjust pin multiplexing in SPL in order to boot into U-Boot,
     enable this option. You will need to enable device tree in SPL
     for this to work.
 
config SPL_PINCONF
   bool "Support pin configuration controllers in SPL"
   depends on SPL_PINCTRL_GENERIC
   help
     This option is an SPL-variant of the PINCONF option.
     See the help of PINCONF for details.
 
if PINCTRL || SPL_PINCTRL
 
config PINCTRL_AR933X
   bool "QCA/Athores ar933x pin control driver"
   depends on DM && SOC_AR933X
   help
     Support pin multiplexing control on QCA/Athores ar933x SoCs.
     The driver is controlled by a device tree node which contains
     both the GPIO definitions and pin control functions for each
     available multiplex function.
 
config PINCTRL_AT91
   bool "AT91 pinctrl driver"
   depends on DM
   help
     This option is to enable the AT91 pinctrl driver for AT91 PIO
     controller.
 
     AT91 PIO controller is a combined gpio-controller, pin-mux and
     pin-config module. Each I/O pin may be dedicated as a general-purpose
     I/O or be assigned to a function of an embedded peripheral. Each I/O
     pin has a glitch filter providing rejection of glitches lower than
     one-half of peripheral clock cycle and a debouncing filter providing
     rejection of unwanted pulses from key or push button operations. You
     can also control the multi-driver capability, pull-up and pull-down
     feature on each I/O pin.
 
config PINCTRL_AT91PIO4
   bool "AT91 PIO4 pinctrl driver"
   depends on DM
   help
     This option is to enable the AT91 pinctrl driver for AT91 PIO4
     controller which is available on SAMA5D2 SoC.
 
config PINCTRL_MAX96745
   bool "Maxim MAX96745 pinctrl driver"
   depends on DM && I2C_MUX_MAX96745
   help
     This option is to enable the pinctrl driver for Maxim
     MAX96745.
 
config PINCTRL_MAX96752F
   bool "Maxim MAX96752F pinctrl driver"
   depends on DM && I2C_MUX_MAX96752F
   select PINCONF
   help
     This option is to enable the pinctrl driver for Maxim
     MAX96752F.
 
config PINCTRL_MAX96755F
   bool "Maxim MAX96755F pinctrl driver"
   depends on DM && I2C_MUX_MAX96755F
   help
     This option is to enable the pinctrl driver for Maxim
     MAX96755F.
 
config PINCTRL_PIC32
   bool "Microchip PIC32 pin-control and pin-mux driver"
   depends on DM && MACH_PIC32
   default y
   help
     Supports individual pin selection and configuration for each
     remappable peripheral available on Microchip PIC32
     SoCs. This driver is controlled by a device tree node which
     contains both GPIO defintion and pin control functions.
 
config PINCTRL_QCA953X
   bool "QCA/Athores qca953x pin control driver"
   depends on DM && SOC_QCA953X
   help
     Support pin multiplexing control on QCA/Athores qca953x SoCs.
 
     The driver is controlled by a device tree node which contains both
     the GPIO definitions and pin control functions for each available
     multiplex function.
 
config PINCTRL_ROCKCHIP
   bool "Rockchip pin control driver"
   depends on PINCTRL_FULL && ARCH_ROCKCHIP
   default y
   help
     Support pin multiplexing control on Rockchip SoCs.
 
     The driver is controlled by a device tree node which contains both
     the GPIO definitions and pin control functions for each available
     multiplex function.
 
config SPL_PINCTRL_ROCKCHIP
   bool "Support Rockchip pin controllers in SPL"
   depends on SPL_PINCTRL_FULL && ARCH_ROCKCHIP
   default y
   help
     This option is an SPL-variant of the PINCTRL_ROCKCHIP option.
     See the help of PINCTRL_ROCKCHIP for details.
 
config PINCTRL_SANDBOX
   bool "Sandbox pinctrl driver"
   depends on SANDBOX
   help
     This enables pinctrl driver for sandbox.
 
     Currently, this driver actually does nothing but print debug
     messages when pinctrl operations are invoked.
 
config PINCTRL_SINGLE
   bool "Single register pin-control and pin-multiplex driver"
   depends on DM
   help
     This enables pinctrl driver for systems using a single register for
     pin configuration and multiplexing. TI's AM335X SoCs are examples of
     such systems.
 
     Depending on the platform make sure to also enable OF_TRANSLATE and
     eventually SPL_OF_TRANSLATE to get correct address translations.
 
config PINCTRL_STI
   bool "STMicroelectronics STi pin-control and pin-mux driver"
   depends on DM && ARCH_STI
   default y
   help
     Support pin multiplexing control on STMicrolectronics STi SoCs.
 
     The driver is controlled by a device tree node which contains both
     the GPIO definitions and pin control functions for each available
     multiplex function.
 
config PINCTRL_STM32
   bool "ST STM32 pin control driver"
   depends on DM
   help
     Supports pin multiplexing control on stm32 SoCs.
 
     The driver is controlled by a device tree node which contains both
     the GPIO definitions and pin control functions for each available
     multiplex function.
 
config ASPEED_AST2500_PINCTRL
  bool "Aspeed AST2500 pin control driver"
  depends on DM && PINCTRL_GENERIC && ASPEED_AST2500
  default y
  help
    Support pin multiplexing control on Aspeed ast2500 SoC. The driver uses
   Generic Pinctrl framework and is compatible with the Linux driver,
   i.e. it uses the same device tree configuration.
 
endif
 
source "drivers/pinctrl/meson/Kconfig"
source "drivers/pinctrl/nxp/Kconfig"
source "drivers/pinctrl/uniphier/Kconfig"
source "drivers/pinctrl/exynos/Kconfig"
source "drivers/pinctrl/mvebu/Kconfig"
 
endmenu