blob: 0e75d94972bae3865b3d8b64bca28e987b24d1da [file] [log] [blame]
Linus Walleij2744e8a2011-05-02 20:50:54 +02001#
2# PINCTRL infrastructure and drivers
3#
4
Linus Walleij45f034e2011-11-05 21:28:46 +01005config PINCTRL
6 bool
Linus Walleij2744e8a2011-05-02 20:50:54 +02007
Linus Walleij45f034e2011-11-05 21:28:46 +01008menu "Pin controllers"
9 depends on PINCTRL
10
Linus Walleij2744e8a2011-05-02 20:50:54 +020011config PINMUX
Uwe Kleine-König244e95a2014-06-03 10:02:36 +020012 bool "Support pin multiplexing controllers" if COMPILE_TEST
Linus Walleijae6b4d82011-10-19 18:14:33 +020013
14config PINCONF
Uwe Kleine-König244e95a2014-06-03 10:02:36 +020015 bool "Support pin configuration controllers" if COMPILE_TEST
Linus Walleij2744e8a2011-05-02 20:50:54 +020016
Linus Walleij394349f2011-11-24 18:27:15 +010017config GENERIC_PINCONF
18 bool
19 select PINCONF
20
Linus Walleij2744e8a2011-05-02 20:50:54 +020021config DEBUG_PINCTRL
22 bool "Debug PINCTRL calls"
23 depends on DEBUG_KERNEL
24 help
25 Say Y here to add some extra checks and diagnostics to PINCTRL calls.
26
Sonic Zhange9a03ad2013-09-03 16:28:59 +080027config PINCTRL_ADI2
28 bool "ADI pin controller driver"
Sonic Zhang9d7278d2013-09-23 11:57:00 +080029 depends on BLACKFIN
Sonic Zhange9a03ad2013-09-03 16:28:59 +080030 select PINMUX
31 select IRQ_DOMAIN
32 help
33 This is the pin controller and gpio driver for ADI BF54x, BF60x and
34 future processors. This option is selected automatically when specific
35 machine and arch are selected to build.
36
Laxman Dewanganc8ce8782013-10-02 21:20:29 +053037config PINCTRL_AS3722
Paul Gortmaker9385f352016-06-13 17:10:22 -040038 tristate "Pinctrl and GPIO driver for ams AS3722 PMIC"
Laxman Dewanganc8ce8782013-10-02 21:20:29 +053039 depends on MFD_AS3722 && GPIOLIB
40 select PINMUX
41 select GENERIC_PINCONF
42 help
43 AS3722 device supports the configuration of GPIO pins for different
44 functionality. This driver supports the pinmux, push-pull and
45 open drain configuration for the GPIO pins of AS3722 devices. It also
46 supports the GPIO functionality through gpiolib.
47
Sonic Zhange9a03ad2013-09-03 16:28:59 +080048config PINCTRL_BF54x
49 def_bool y if BF54x
50 select PINCTRL_ADI2
51
52config PINCTRL_BF60x
53 def_bool y if BF60x
54 select PINCTRL_ADI2
55
Jean-Christophe PLAGNIOL-VILLARD6732ae52012-07-12 23:35:02 +080056config PINCTRL_AT91
57 bool "AT91 pinctrl driver"
58 depends on OF
59 depends on ARCH_AT91
60 select PINMUX
61 select PINCONF
Alexander Stein80cc3732014-04-15 22:09:41 +020062 select GPIOLIB
63 select OF_GPIO
64 select GPIOLIB_IRQCHIP
Jean-Christophe PLAGNIOL-VILLARD6732ae52012-07-12 23:35:02 +080065 help
66 Say Y here to enable the at91 pinctrl driver
67
Ludovic Desroches77618082015-09-16 17:36:57 +020068config PINCTRL_AT91PIO4
69 bool "AT91 PIO4 pinctrl driver"
70 depends on OF
71 depends on ARCH_AT91
72 select PINMUX
73 select GENERIC_PINCONF
74 select GPIOLIB
75 select GPIOLIB_IRQCHIP
76 select OF_GPIO
77 help
78 Say Y here to enable the at91 pinctrl/gpio driver for Atmel PIO4
79 controller available on sama5d2 SoC.
80
Ken Xuedbad75d2015-03-10 15:02:19 +080081config PINCTRL_AMD
Jean Delvare337ea0f2016-02-11 12:06:37 +010082 tristate "AMD GPIO pin control"
Ken Xuedbad75d2015-03-10 15:02:19 +080083 depends on GPIOLIB
84 select GPIOLIB_IRQCHIP
85 select PINCONF
86 select GENERIC_PINCONF
87 help
88 driver for memory mapped GPIO functionality on AMD platforms
89 (x86 or arm).Most pins are usually muxed to some other
90 functionality by firmware,so only a small amount is available
91 for gpio use.
92
93 Requires ACPI/FDT device enumeration code to set up a platform
94 device.
95
Baruch Siach38b0e502015-05-05 13:55:10 +030096config PINCTRL_DIGICOLOR
97 bool
98 depends on OF && (ARCH_DIGICOLOR || COMPILE_TEST)
99 select PINMUX
100 select GENERIC_PINCONF
101
John Crispin3f8c50c2012-08-28 12:44:59 +0200102config PINCTRL_LANTIQ
103 bool
104 depends on LANTIQ
105 select PINMUX
106 select PINCONF
107
Joachim Eastwood2f77ac92015-04-28 00:14:08 +0200108config PINCTRL_LPC18XX
109 bool "NXP LPC18XX/43XX SCU pinctrl driver"
110 depends on OF && (ARCH_LPC18XX || COMPILE_TEST)
111 default ARCH_LPC18XX
112 select PINMUX
113 select GENERIC_PINCONF
114 help
115 Pinctrl driver for NXP LPC18xx/43xx System Control Unit (SCU).
116
John Crispine316cb22012-05-20 00:33:56 +0200117config PINCTRL_FALCON
118 bool
119 depends on SOC_FALCON
120 depends on PINCTRL_LANTIQ
121
Beniamino Galvani6ac73092015-01-17 19:15:14 +0100122config PINCTRL_MESON
123 bool
Linus Walleijb99e6fb2015-04-15 10:00:35 +0200124 depends on OF
Beniamino Galvani6ac73092015-01-17 19:15:14 +0100125 select PINMUX
126 select PINCONF
127 select GENERIC_PINCONF
Linus Walleijb99e6fb2015-04-15 10:00:35 +0200128 select GPIOLIB
Beniamino Galvani6ac73092015-01-17 19:15:14 +0100129 select OF_GPIO
130 select REGMAP_MMIO
131
Neil Armstrong611dac12016-05-11 09:34:21 +0200132config PINCTRL_OXNAS
133 bool
134 depends on OF
135 select PINMUX
136 select PINCONF
137 select GENERIC_PINCONF
138 select GPIOLIB
139 select OF_GPIO
140 select GPIOLIB_IRQCHIP
141 select MFD_SYSCON
142
Heiko Stübnerd3e51162013-06-10 22:16:22 +0200143config PINCTRL_ROCKCHIP
144 bool
145 select PINMUX
146 select GENERIC_PINCONF
147 select GENERIC_IRQ_CHIP
Heiko Stübner751a99a2014-05-05 13:58:20 +0200148 select MFD_SYSCON
Heiko Stübnerd3e51162013-06-10 22:16:22 +0200149
Tony Lindgren8b8b091b2012-07-10 02:05:46 -0700150config PINCTRL_SINGLE
151 tristate "One-register-per-pin type device tree based pinctrl driver"
152 depends on OF
153 select PINMUX
154 select PINCONF
Haojian Zhuang9dddb4d2013-02-17 19:42:55 +0800155 select GENERIC_PINCONF
Tony Lindgren8b8b091b2012-07-10 02:05:46 -0700156 help
157 This selects the device tree based generic pinctrl driver.
158
Linus Walleij3bece552011-12-18 23:44:26 +0100159config PINCTRL_SIRF
Barry Songa17272a2015-01-11 21:56:41 +0800160 bool "CSR SiRFprimaII pin controller driver"
Barry Songd3e26f22012-09-27 17:56:30 +0800161 depends on ARCH_SIRF
Rongjun Ying393daa82011-10-09 03:11:13 -0700162 select PINMUX
Wei Chenf9367792015-05-18 07:28:32 +0000163 select PINCONF
164 select GENERIC_PINCONF
Linus Walleij7420d2d2014-04-15 14:43:47 +0800165 select GPIOLIB_IRQCHIP
Rongjun Ying393daa82011-10-09 03:11:13 -0700166
Andrew Brestickercefc03e2015-05-06 12:59:03 -0700167config PINCTRL_PISTACHIO
168 def_bool y if MACH_PISTACHIO
169 depends on GPIOLIB
170 select PINMUX
171 select GENERIC_PINCONF
172 select GPIOLIB_IRQCHIP
173 select OF_GPIO
174
Srinivas KANDAGATLA701016c2013-06-20 15:05:38 +0100175config PINCTRL_ST
176 bool
177 depends on OF
178 select PINMUX
179 select PINCONF
Linus Walleij130cbe32014-04-08 14:45:47 +0200180 select GPIOLIB_IRQCHIP
Srinivas KANDAGATLA701016c2013-06-20 15:05:38 +0100181
James Hogand5025f92013-06-20 10:26:27 +0100182config PINCTRL_TZ1090
183 bool "Toumaz Xenif TZ1090 pin control driver"
184 depends on SOC_TZ1090
185 select PINMUX
186 select GENERIC_PINCONF
187
James Hoganb58f0272013-06-20 10:26:29 +0100188config PINCTRL_TZ1090_PDC
189 bool "Toumaz Xenif TZ1090 PDC pin control driver"
190 depends on SOC_TZ1090
191 select PINMUX
192 select PINCONF
193
Linus Walleij3bece552011-12-18 23:44:26 +0100194config PINCTRL_U300
195 bool "U300 pin controller driver"
Linus Walleij98da3522011-05-02 20:54:38 +0200196 depends on ARCH_U300
197 select PINMUX
Linus Walleijdc0b1aa2011-11-16 21:58:10 +0100198 select GENERIC_PINCONF
Linus Walleij45f034e2011-11-05 21:28:46 +0100199
Linus Walleijca402d32011-11-16 09:22:59 +0100200config PINCTRL_COH901
201 bool "ST-Ericsson U300 COH 901 335/571 GPIO"
Linus Walleij3c94d1b2012-06-18 20:07:50 +0200202 depends on GPIOLIB && ARCH_U300 && PINCTRL_U300
Linus Walleij523dcce2014-03-25 13:37:17 +0100203 select GPIOLIB_IRQCHIP
Linus Walleijca402d32011-11-16 09:22:59 +0100204 help
205 Say yes here to support GPIO interface on ST-Ericsson U300.
206 The names of the two IP block variants supported are
207 COH 901 335 and COH 901 571/3. They contain 3, 5 or 7
208 ports of 8 GPIO pins each.
209
Laxman Dewangan2df723d42016-05-13 10:49:15 +0530210config PINCTRL_MAX77620
211 tristate "MAX77620/MAX20024 Pincontrol support"
212 depends on MFD_MAX77620
Arnd Bergmann79f28b9f2016-06-13 17:18:35 +0200213 select PINMUX
Laxman Dewangan2df723d42016-05-13 10:49:15 +0530214 select GENERIC_PINCONF
215 help
216 Say Yes here to enable Pin control support for Maxim PMIC MAX77620.
217 This PMIC has 8 GPIO pins that work as GPIO as well as special
218 function in alternate mode. This driver also configure push-pull,
219 open drain, FPS slots etc.
220
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530221config PINCTRL_PALMAS
Paul Gortmaker767b8ce2016-06-13 17:10:21 -0400222 tristate "Pinctrl driver for the PALMAS Series MFD devices"
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530223 depends on OF && MFD_PALMAS
Axel Lin63ca8db2013-08-22 14:30:08 +0800224 select PINMUX
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530225 select GENERIC_PINCONF
226 help
227 Palmas device supports the configuration of pins for different
228 functionality. This driver supports the pinmux, push-pull and
229 open drain configuration for the Palmas series devices like
230 TPS65913, TPS80036 etc.
231
Joshua Henderson2ba384e2016-02-01 15:48:30 -0700232config PINCTRL_PIC32
233 bool "Microchip PIC32 pin controller driver"
234 depends on OF
235 depends on MACH_PIC32
236 select PINMUX
237 select GENERIC_PINCONF
238 select GPIOLIB_IRQCHIP
239 select OF_GPIO
240 help
241 This is the pin controller and gpio driver for Microchip PIC32
242 microcontrollers. This option is selected automatically when specific
243 machine and arch are selected to build.
244
245config PINCTRL_PIC32MZDA
246 def_bool y if PIC32MZDA
247 select PINCTRL_PIC32
248
Soren Brinkmannadd958c2015-01-09 07:43:48 -0800249config PINCTRL_ZYNQ
250 bool "Pinctrl driver for Xilinx Zynq"
251 depends on ARCH_ZYNQ
252 select PINMUX
253 select GENERIC_PINCONF
254 help
Masahiro Yamada485dba22015-11-30 16:57:35 +0900255 This selects the pinctrl driver for Xilinx Zynq.
Soren Brinkmannadd958c2015-01-09 07:43:48 -0800256
Andrew Jeffery4d3d0e422016-08-30 17:24:24 +0930257source "drivers/pinctrl/aspeed/Kconfig"
Ray Juib17f2f92015-03-04 16:35:49 -0800258source "drivers/pinctrl/bcm/Kconfig"
Antoine Tenart3de68d32014-05-19 19:36:29 +0200259source "drivers/pinctrl/berlin/Kconfig"
Linus Walleijedad3b22014-09-03 13:37:38 +0200260source "drivers/pinctrl/freescale/Kconfig"
Mika Westerberg5fae8b82014-10-24 15:16:52 +0300261source "drivers/pinctrl/intel/Kconfig"
Thomas Petazzoni06763c72012-10-24 23:38:58 +0200262source "drivers/pinctrl/mvebu/Kconfig"
Linus Walleij3a198052014-07-11 14:57:06 +0200263source "drivers/pinctrl/nomadik/Kconfig"
Robert Jarzmik4b15ec92015-11-21 19:04:53 +0100264source "drivers/pinctrl/pxa/Kconfig"
Linus Walleij69b78b82014-07-09 13:55:12 +0200265source "drivers/pinctrl/qcom/Kconfig"
Sachin Kamatebe629a2014-07-10 17:33:27 +0530266source "drivers/pinctrl/samsung/Kconfig"
Laurent Pinchart6e54d8d2012-12-15 23:51:19 +0100267source "drivers/pinctrl/sh-pfc/Kconfig"
Viresh Kumardeda8282012-03-28 22:27:07 +0530268source "drivers/pinctrl/spear/Kconfig"
Maxime Coquelinaceb16d2016-01-14 13:16:30 +0100269source "drivers/pinctrl/stm32/Kconfig"
Maxime Ripard5f910772014-04-18 18:53:02 +0200270source "drivers/pinctrl/sunxi/Kconfig"
Masahiro Yamada25cbac72016-01-24 00:30:08 +0900271source "drivers/pinctrl/tegra/Kconfig"
Masahiro Yamada6e908892015-07-14 11:40:01 +0900272source "drivers/pinctrl/uniphier/Kconfig"
Tony Prisk170c6152013-02-20 09:32:19 +1300273source "drivers/pinctrl/vt8500/Kconfig"
Hongzhou Yanga6df4102015-01-21 13:28:15 +0800274source "drivers/pinctrl/mediatek/Kconfig"
Viresh Kumardeda8282012-03-28 22:27:07 +0530275
John Crispin3f8c50c2012-08-28 12:44:59 +0200276config PINCTRL_XWAY
277 bool
278 depends on SOC_TYPE_XWAY
279 depends on PINCTRL_LANTIQ
280
Christian Ruppert5aad0db2013-10-15 15:39:38 +0200281config PINCTRL_TB10X
282 bool
Linus Walleijb99e6fb2015-04-15 10:00:35 +0200283 depends on OF && ARC_PLAT_TB10X
284 select GPIOLIB
Christian Ruppert5aad0db2013-10-15 15:39:38 +0200285
Linus Walleij45f034e2011-11-05 21:28:46 +0100286endmenu