blob: 542a12a17991d04f1f0a51e3a6100b39a6b9dcd2 [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
8if PINCTRL
9
Linus Walleij45f034e2011-11-05 21:28:46 +010010menu "Pin controllers"
11 depends on PINCTRL
12
Linus Walleij2744e8a2011-05-02 20:50:54 +020013config PINMUX
Uwe Kleine-König244e95a2014-06-03 10:02:36 +020014 bool "Support pin multiplexing controllers" if COMPILE_TEST
Linus Walleijae6b4d82011-10-19 18:14:33 +020015
16config PINCONF
Uwe Kleine-König244e95a2014-06-03 10:02:36 +020017 bool "Support pin configuration controllers" if COMPILE_TEST
Linus Walleij2744e8a2011-05-02 20:50:54 +020018
Linus Walleij394349f2011-11-24 18:27:15 +010019config GENERIC_PINCONF
20 bool
21 select PINCONF
22
Linus Walleij2744e8a2011-05-02 20:50:54 +020023config DEBUG_PINCTRL
24 bool "Debug PINCTRL calls"
25 depends on DEBUG_KERNEL
26 help
27 Say Y here to add some extra checks and diagnostics to PINCTRL calls.
28
Sonic Zhange9a03ad2013-09-03 16:28:59 +080029config PINCTRL_ADI2
30 bool "ADI pin controller driver"
Sonic Zhang9d7278d2013-09-23 11:57:00 +080031 depends on BLACKFIN
Sonic Zhange9a03ad2013-09-03 16:28:59 +080032 select PINMUX
33 select IRQ_DOMAIN
34 help
35 This is the pin controller and gpio driver for ADI BF54x, BF60x and
36 future processors. This option is selected automatically when specific
37 machine and arch are selected to build.
38
Laxman Dewanganc8ce8782013-10-02 21:20:29 +053039config PINCTRL_AS3722
40 bool "Pinctrl and GPIO driver for ams AS3722 PMIC"
41 depends on MFD_AS3722 && GPIOLIB
42 select PINMUX
43 select GENERIC_PINCONF
44 help
45 AS3722 device supports the configuration of GPIO pins for different
46 functionality. This driver supports the pinmux, push-pull and
47 open drain configuration for the GPIO pins of AS3722 devices. It also
48 supports the GPIO functionality through gpiolib.
49
Sonic Zhange9a03ad2013-09-03 16:28:59 +080050config PINCTRL_BF54x
51 def_bool y if BF54x
52 select PINCTRL_ADI2
53
54config PINCTRL_BF60x
55 def_bool y if BF60x
56 select PINCTRL_ADI2
57
Jean-Christophe PLAGNIOL-VILLARD6732ae52012-07-12 23:35:02 +080058config PINCTRL_AT91
59 bool "AT91 pinctrl driver"
60 depends on OF
61 depends on ARCH_AT91
62 select PINMUX
63 select PINCONF
Alexander Stein80cc3732014-04-15 22:09:41 +020064 select GPIOLIB
65 select OF_GPIO
66 select GPIOLIB_IRQCHIP
Jean-Christophe PLAGNIOL-VILLARD6732ae52012-07-12 23:35:02 +080067 help
68 Say Y here to enable the at91 pinctrl driver
69
Ken Xuedbad75d2015-03-10 15:02:19 +080070config PINCTRL_AMD
71 bool "AMD GPIO pin control"
72 depends on GPIOLIB
73 select GPIOLIB_IRQCHIP
74 select PINCONF
75 select GENERIC_PINCONF
76 help
77 driver for memory mapped GPIO functionality on AMD platforms
78 (x86 or arm).Most pins are usually muxed to some other
79 functionality by firmware,so only a small amount is available
80 for gpio use.
81
82 Requires ACPI/FDT device enumeration code to set up a platform
83 device.
84
John Crispin3f8c50c2012-08-28 12:44:59 +020085config PINCTRL_LANTIQ
86 bool
87 depends on LANTIQ
88 select PINMUX
89 select PINCONF
90
Joachim Eastwood2f77ac92015-04-28 00:14:08 +020091config PINCTRL_LPC18XX
92 bool "NXP LPC18XX/43XX SCU pinctrl driver"
93 depends on OF && (ARCH_LPC18XX || COMPILE_TEST)
94 default ARCH_LPC18XX
95 select PINMUX
96 select GENERIC_PINCONF
97 help
98 Pinctrl driver for NXP LPC18xx/43xx System Control Unit (SCU).
99
John Crispine316cb22012-05-20 00:33:56 +0200100config PINCTRL_FALCON
101 bool
102 depends on SOC_FALCON
103 depends on PINCTRL_LANTIQ
104
Beniamino Galvani6ac73092015-01-17 19:15:14 +0100105config PINCTRL_MESON
106 bool
Linus Walleijb99e6fb2015-04-15 10:00:35 +0200107 depends on OF
Beniamino Galvani6ac73092015-01-17 19:15:14 +0100108 select PINMUX
109 select PINCONF
110 select GENERIC_PINCONF
Linus Walleijb99e6fb2015-04-15 10:00:35 +0200111 select GPIOLIB
Beniamino Galvani6ac73092015-01-17 19:15:14 +0100112 select OF_GPIO
113 select REGMAP_MMIO
114
Heiko Stübnerd3e51162013-06-10 22:16:22 +0200115config PINCTRL_ROCKCHIP
116 bool
117 select PINMUX
118 select GENERIC_PINCONF
119 select GENERIC_IRQ_CHIP
Heiko Stübner751a99a2014-05-05 13:58:20 +0200120 select MFD_SYSCON
Heiko Stübnerd3e51162013-06-10 22:16:22 +0200121
Tony Lindgren8b8b091b2012-07-10 02:05:46 -0700122config PINCTRL_SINGLE
123 tristate "One-register-per-pin type device tree based pinctrl driver"
124 depends on OF
125 select PINMUX
126 select PINCONF
Haojian Zhuang9dddb4d2013-02-17 19:42:55 +0800127 select GENERIC_PINCONF
Tony Lindgren8b8b091b2012-07-10 02:05:46 -0700128 help
129 This selects the device tree based generic pinctrl driver.
130
Linus Walleij3bece552011-12-18 23:44:26 +0100131config PINCTRL_SIRF
Barry Songa17272a2015-01-11 21:56:41 +0800132 bool "CSR SiRFprimaII pin controller driver"
Barry Songd3e26f22012-09-27 17:56:30 +0800133 depends on ARCH_SIRF
Rongjun Ying393daa82011-10-09 03:11:13 -0700134 select PINMUX
Linus Walleij7420d2d2014-04-15 14:43:47 +0800135 select GPIOLIB_IRQCHIP
Rongjun Ying393daa82011-10-09 03:11:13 -0700136
Andrew Brestickercefc03e2015-05-06 12:59:03 -0700137config PINCTRL_PISTACHIO
138 def_bool y if MACH_PISTACHIO
139 depends on GPIOLIB
140 select PINMUX
141 select GENERIC_PINCONF
142 select GPIOLIB_IRQCHIP
143 select OF_GPIO
144
Srinivas KANDAGATLA701016c2013-06-20 15:05:38 +0100145config PINCTRL_ST
146 bool
147 depends on OF
148 select PINMUX
149 select PINCONF
Linus Walleij130cbe32014-04-08 14:45:47 +0200150 select GPIOLIB_IRQCHIP
Srinivas KANDAGATLA701016c2013-06-20 15:05:38 +0100151
Stephen Warren971dac72012-02-01 14:04:47 -0700152config PINCTRL_TEGRA
153 bool
Axel Lin507ccdb2012-11-12 10:00:22 +0800154 select PINMUX
155 select PINCONF
Stephen Warren971dac72012-02-01 14:04:47 -0700156
157config PINCTRL_TEGRA20
158 bool
Stephen Warren971dac72012-02-01 14:04:47 -0700159 select PINCTRL_TEGRA
160
161config PINCTRL_TEGRA30
162 bool
Stephen Warren971dac72012-02-01 14:04:47 -0700163 select PINCTRL_TEGRA
164
Pritesh Raithathab6ae7a22013-01-08 13:02:37 +0530165config PINCTRL_TEGRA114
166 bool
167 select PINCTRL_TEGRA
168
Ashwini Ghuge1a16bee2013-12-10 12:40:56 +0530169config PINCTRL_TEGRA124
170 bool
171 select PINCTRL_TEGRA
172
Stephen Warren9184f752015-02-24 14:00:51 -0700173config PINCTRL_TEGRA210
174 bool
175 select PINCTRL_TEGRA
176
Thierry Redingdc0a3932014-06-19 13:37:08 +0200177config PINCTRL_TEGRA_XUSB
178 def_bool y if ARCH_TEGRA
179 select GENERIC_PHY
180 select PINCONF
181 select PINMUX
182
James Hogand5025f92013-06-20 10:26:27 +0100183config PINCTRL_TZ1090
184 bool "Toumaz Xenif TZ1090 pin control driver"
185 depends on SOC_TZ1090
186 select PINMUX
187 select GENERIC_PINCONF
188
James Hoganb58f0272013-06-20 10:26:29 +0100189config PINCTRL_TZ1090_PDC
190 bool "Toumaz Xenif TZ1090 PDC pin control driver"
191 depends on SOC_TZ1090
192 select PINMUX
193 select PINCONF
194
Linus Walleij3bece552011-12-18 23:44:26 +0100195config PINCTRL_U300
196 bool "U300 pin controller driver"
Linus Walleij98da3522011-05-02 20:54:38 +0200197 depends on ARCH_U300
198 select PINMUX
Linus Walleijdc0b1aa2011-11-16 21:58:10 +0100199 select GENERIC_PINCONF
Linus Walleij45f034e2011-11-05 21:28:46 +0100200
Linus Walleijca402d32011-11-16 09:22:59 +0100201config PINCTRL_COH901
202 bool "ST-Ericsson U300 COH 901 335/571 GPIO"
Linus Walleij3c94d1b2012-06-18 20:07:50 +0200203 depends on GPIOLIB && ARCH_U300 && PINCTRL_U300
Linus Walleij523dcce2014-03-25 13:37:17 +0100204 select GPIOLIB_IRQCHIP
Linus Walleijca402d32011-11-16 09:22:59 +0100205 help
206 Say yes here to support GPIO interface on ST-Ericsson U300.
207 The names of the two IP block variants supported are
208 COH 901 335 and COH 901 571/3. They contain 3, 5 or 7
209 ports of 8 GPIO pins each.
210
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530211config PINCTRL_PALMAS
Mark Brown736658c2013-08-19 16:07:26 +0100212 bool "Pinctrl driver for the PALMAS Series MFD devices"
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530213 depends on OF && MFD_PALMAS
Axel Lin63ca8db2013-08-22 14:30:08 +0800214 select PINMUX
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530215 select GENERIC_PINCONF
216 help
217 Palmas device supports the configuration of pins for different
218 functionality. This driver supports the pinmux, push-pull and
219 open drain configuration for the Palmas series devices like
220 TPS65913, TPS80036 etc.
221
Soren Brinkmannadd958c2015-01-09 07:43:48 -0800222config PINCTRL_ZYNQ
223 bool "Pinctrl driver for Xilinx Zynq"
224 depends on ARCH_ZYNQ
225 select PINMUX
226 select GENERIC_PINCONF
227 help
228 This selectes the pinctrl driver for Xilinx Zynq.
229
Ray Juib17f2f92015-03-04 16:35:49 -0800230source "drivers/pinctrl/bcm/Kconfig"
Antoine Tenart3de68d32014-05-19 19:36:29 +0200231source "drivers/pinctrl/berlin/Kconfig"
Linus Walleijedad3b22014-09-03 13:37:38 +0200232source "drivers/pinctrl/freescale/Kconfig"
Mika Westerberg5fae8b82014-10-24 15:16:52 +0300233source "drivers/pinctrl/intel/Kconfig"
Thomas Petazzoni06763c72012-10-24 23:38:58 +0200234source "drivers/pinctrl/mvebu/Kconfig"
Linus Walleij3a198052014-07-11 14:57:06 +0200235source "drivers/pinctrl/nomadik/Kconfig"
Linus Walleij69b78b82014-07-09 13:55:12 +0200236source "drivers/pinctrl/qcom/Kconfig"
Sachin Kamatebe629a2014-07-10 17:33:27 +0530237source "drivers/pinctrl/samsung/Kconfig"
Laurent Pinchart6e54d8d2012-12-15 23:51:19 +0100238source "drivers/pinctrl/sh-pfc/Kconfig"
Viresh Kumardeda8282012-03-28 22:27:07 +0530239source "drivers/pinctrl/spear/Kconfig"
Maxime Ripard5f910772014-04-18 18:53:02 +0200240source "drivers/pinctrl/sunxi/Kconfig"
Tony Prisk170c6152013-02-20 09:32:19 +1300241source "drivers/pinctrl/vt8500/Kconfig"
Hongzhou Yanga6df4102015-01-21 13:28:15 +0800242source "drivers/pinctrl/mediatek/Kconfig"
Viresh Kumardeda8282012-03-28 22:27:07 +0530243
John Crispin3f8c50c2012-08-28 12:44:59 +0200244config PINCTRL_XWAY
245 bool
246 depends on SOC_TYPE_XWAY
247 depends on PINCTRL_LANTIQ
248
Christian Ruppert5aad0db2013-10-15 15:39:38 +0200249config PINCTRL_TB10X
250 bool
Linus Walleijb99e6fb2015-04-15 10:00:35 +0200251 depends on OF && ARC_PLAT_TB10X
252 select GPIOLIB
Christian Ruppert5aad0db2013-10-15 15:39:38 +0200253
Linus Walleij45f034e2011-11-05 21:28:46 +0100254endmenu
Linus Walleij98da3522011-05-02 20:54:38 +0200255
Linus Walleij2744e8a2011-05-02 20:50:54 +0200256endif