blob: fb8200b8e8ec60911ddad766b740e879202d0b94 [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
38 bool "Pinctrl and GPIO driver for ams AS3722 PMIC"
39 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
Heiko Stübnerd3e51162013-06-10 22:16:22 +0200132config PINCTRL_ROCKCHIP
133 bool
134 select PINMUX
135 select GENERIC_PINCONF
136 select GENERIC_IRQ_CHIP
Heiko Stübner751a99a2014-05-05 13:58:20 +0200137 select MFD_SYSCON
Heiko Stübnerd3e51162013-06-10 22:16:22 +0200138
Tony Lindgren8b8b0912012-07-10 02:05:46 -0700139config PINCTRL_SINGLE
140 tristate "One-register-per-pin type device tree based pinctrl driver"
141 depends on OF
142 select PINMUX
143 select PINCONF
Haojian Zhuang9dddb4d2013-02-17 19:42:55 +0800144 select GENERIC_PINCONF
Tony Lindgren8b8b0912012-07-10 02:05:46 -0700145 help
146 This selects the device tree based generic pinctrl driver.
147
Linus Walleij3bece552011-12-18 23:44:26 +0100148config PINCTRL_SIRF
Barry Songa17272a2015-01-11 21:56:41 +0800149 bool "CSR SiRFprimaII pin controller driver"
Barry Songd3e26f22012-09-27 17:56:30 +0800150 depends on ARCH_SIRF
Rongjun Ying393daa82011-10-09 03:11:13 -0700151 select PINMUX
Wei Chenf9367792015-05-18 07:28:32 +0000152 select PINCONF
153 select GENERIC_PINCONF
Linus Walleij7420d2d2014-04-15 14:43:47 +0800154 select GPIOLIB_IRQCHIP
Rongjun Ying393daa82011-10-09 03:11:13 -0700155
Andrew Brestickercefc03e2015-05-06 12:59:03 -0700156config PINCTRL_PISTACHIO
157 def_bool y if MACH_PISTACHIO
158 depends on GPIOLIB
159 select PINMUX
160 select GENERIC_PINCONF
161 select GPIOLIB_IRQCHIP
162 select OF_GPIO
163
Srinivas KANDAGATLA701016c2013-06-20 15:05:38 +0100164config PINCTRL_ST
165 bool
166 depends on OF
167 select PINMUX
168 select PINCONF
Linus Walleij130cbe32014-04-08 14:45:47 +0200169 select GPIOLIB_IRQCHIP
Srinivas KANDAGATLA701016c2013-06-20 15:05:38 +0100170
James Hogand5025f92013-06-20 10:26:27 +0100171config PINCTRL_TZ1090
172 bool "Toumaz Xenif TZ1090 pin control driver"
173 depends on SOC_TZ1090
174 select PINMUX
175 select GENERIC_PINCONF
176
James Hoganb58f0272013-06-20 10:26:29 +0100177config PINCTRL_TZ1090_PDC
178 bool "Toumaz Xenif TZ1090 PDC pin control driver"
179 depends on SOC_TZ1090
180 select PINMUX
181 select PINCONF
182
Linus Walleij3bece552011-12-18 23:44:26 +0100183config PINCTRL_U300
184 bool "U300 pin controller driver"
Linus Walleij98da3522011-05-02 20:54:38 +0200185 depends on ARCH_U300
186 select PINMUX
Linus Walleijdc0b1aa2011-11-16 21:58:10 +0100187 select GENERIC_PINCONF
Linus Walleij45f034e2011-11-05 21:28:46 +0100188
Linus Walleijca402d32011-11-16 09:22:59 +0100189config PINCTRL_COH901
190 bool "ST-Ericsson U300 COH 901 335/571 GPIO"
Linus Walleij3c94d1b2012-06-18 20:07:50 +0200191 depends on GPIOLIB && ARCH_U300 && PINCTRL_U300
Linus Walleij523dcce2014-03-25 13:37:17 +0100192 select GPIOLIB_IRQCHIP
Linus Walleijca402d32011-11-16 09:22:59 +0100193 help
194 Say yes here to support GPIO interface on ST-Ericsson U300.
195 The names of the two IP block variants supported are
196 COH 901 335 and COH 901 571/3. They contain 3, 5 or 7
197 ports of 8 GPIO pins each.
198
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530199config PINCTRL_PALMAS
Mark Brown736658c2013-08-19 16:07:26 +0100200 bool "Pinctrl driver for the PALMAS Series MFD devices"
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530201 depends on OF && MFD_PALMAS
Axel Lin63ca8db2013-08-22 14:30:08 +0800202 select PINMUX
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530203 select GENERIC_PINCONF
204 help
205 Palmas device supports the configuration of pins for different
206 functionality. This driver supports the pinmux, push-pull and
207 open drain configuration for the Palmas series devices like
208 TPS65913, TPS80036 etc.
209
Joshua Henderson2ba384e2016-02-01 15:48:30 -0700210config PINCTRL_PIC32
211 bool "Microchip PIC32 pin controller driver"
212 depends on OF
213 depends on MACH_PIC32
214 select PINMUX
215 select GENERIC_PINCONF
216 select GPIOLIB_IRQCHIP
217 select OF_GPIO
218 help
219 This is the pin controller and gpio driver for Microchip PIC32
220 microcontrollers. This option is selected automatically when specific
221 machine and arch are selected to build.
222
223config PINCTRL_PIC32MZDA
224 def_bool y if PIC32MZDA
225 select PINCTRL_PIC32
226
Soren Brinkmannadd958c2015-01-09 07:43:48 -0800227config PINCTRL_ZYNQ
228 bool "Pinctrl driver for Xilinx Zynq"
229 depends on ARCH_ZYNQ
230 select PINMUX
231 select GENERIC_PINCONF
232 help
Masahiro Yamada485dba22015-11-30 16:57:35 +0900233 This selects the pinctrl driver for Xilinx Zynq.
Soren Brinkmannadd958c2015-01-09 07:43:48 -0800234
Ray Juib17f2f92015-03-04 16:35:49 -0800235source "drivers/pinctrl/bcm/Kconfig"
Antoine Tenart3de68d32014-05-19 19:36:29 +0200236source "drivers/pinctrl/berlin/Kconfig"
Linus Walleijedad3b22014-09-03 13:37:38 +0200237source "drivers/pinctrl/freescale/Kconfig"
Mika Westerberg5fae8b82014-10-24 15:16:52 +0300238source "drivers/pinctrl/intel/Kconfig"
Thomas Petazzoni06763c72012-10-24 23:38:58 +0200239source "drivers/pinctrl/mvebu/Kconfig"
Linus Walleij3a198052014-07-11 14:57:06 +0200240source "drivers/pinctrl/nomadik/Kconfig"
Robert Jarzmik4b15ec92015-11-21 19:04:53 +0100241source "drivers/pinctrl/pxa/Kconfig"
Linus Walleij69b78b82014-07-09 13:55:12 +0200242source "drivers/pinctrl/qcom/Kconfig"
Sachin Kamatebe629a2014-07-10 17:33:27 +0530243source "drivers/pinctrl/samsung/Kconfig"
Laurent Pinchart6e54d8d2012-12-15 23:51:19 +0100244source "drivers/pinctrl/sh-pfc/Kconfig"
Viresh Kumardeda8282012-03-28 22:27:07 +0530245source "drivers/pinctrl/spear/Kconfig"
Maxime Coquelinaceb16d2016-01-14 13:16:30 +0100246source "drivers/pinctrl/stm32/Kconfig"
Maxime Ripard5f910772014-04-18 18:53:02 +0200247source "drivers/pinctrl/sunxi/Kconfig"
Masahiro Yamada25cbac72016-01-24 00:30:08 +0900248source "drivers/pinctrl/tegra/Kconfig"
Masahiro Yamada6e908892015-07-14 11:40:01 +0900249source "drivers/pinctrl/uniphier/Kconfig"
Tony Prisk170c6152013-02-20 09:32:19 +1300250source "drivers/pinctrl/vt8500/Kconfig"
Hongzhou Yanga6df4102015-01-21 13:28:15 +0800251source "drivers/pinctrl/mediatek/Kconfig"
Viresh Kumardeda8282012-03-28 22:27:07 +0530252
John Crispin3f8c50c2012-08-28 12:44:59 +0200253config PINCTRL_XWAY
254 bool
255 depends on SOC_TYPE_XWAY
256 depends on PINCTRL_LANTIQ
257
Christian Ruppert5aad0db2013-10-15 15:39:38 +0200258config PINCTRL_TB10X
259 bool
Linus Walleijb99e6fb2015-04-15 10:00:35 +0200260 depends on OF && ARC_PLAT_TB10X
261 select GPIOLIB
Christian Ruppert5aad0db2013-10-15 15:39:38 +0200262
Linus Walleij45f034e2011-11-05 21:28:46 +0100263endmenu