blob: aeb5729fbda61976de6501ec75ca26c2628c623c [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
John Crispine316cb22012-05-20 00:33:56 +020091config PINCTRL_FALCON
92 bool
93 depends on SOC_FALCON
94 depends on PINCTRL_LANTIQ
95
Beniamino Galvani6ac73092015-01-17 19:15:14 +010096config PINCTRL_MESON
97 bool
Linus Walleijb99e6fb2015-04-15 10:00:35 +020098 depends on OF
Beniamino Galvani6ac73092015-01-17 19:15:14 +010099 select PINMUX
100 select PINCONF
101 select GENERIC_PINCONF
Linus Walleijb99e6fb2015-04-15 10:00:35 +0200102 select GPIOLIB
Beniamino Galvani6ac73092015-01-17 19:15:14 +0100103 select OF_GPIO
104 select REGMAP_MMIO
105
Heiko Stübnerd3e51162013-06-10 22:16:22 +0200106config PINCTRL_ROCKCHIP
107 bool
108 select PINMUX
109 select GENERIC_PINCONF
110 select GENERIC_IRQ_CHIP
Heiko Stübner751a99a2014-05-05 13:58:20 +0200111 select MFD_SYSCON
Heiko Stübnerd3e51162013-06-10 22:16:22 +0200112
Tony Lindgren8b8b091b2012-07-10 02:05:46 -0700113config PINCTRL_SINGLE
114 tristate "One-register-per-pin type device tree based pinctrl driver"
115 depends on OF
116 select PINMUX
117 select PINCONF
Haojian Zhuang9dddb4d2013-02-17 19:42:55 +0800118 select GENERIC_PINCONF
Tony Lindgren8b8b091b2012-07-10 02:05:46 -0700119 help
120 This selects the device tree based generic pinctrl driver.
121
Linus Walleij3bece552011-12-18 23:44:26 +0100122config PINCTRL_SIRF
Barry Songa17272a2015-01-11 21:56:41 +0800123 bool "CSR SiRFprimaII pin controller driver"
Barry Songd3e26f22012-09-27 17:56:30 +0800124 depends on ARCH_SIRF
Rongjun Ying393daa82011-10-09 03:11:13 -0700125 select PINMUX
Linus Walleij7420d2d2014-04-15 14:43:47 +0800126 select GPIOLIB_IRQCHIP
Rongjun Ying393daa82011-10-09 03:11:13 -0700127
Srinivas KANDAGATLA701016c2013-06-20 15:05:38 +0100128config PINCTRL_ST
129 bool
130 depends on OF
131 select PINMUX
132 select PINCONF
Linus Walleij130cbe32014-04-08 14:45:47 +0200133 select GPIOLIB_IRQCHIP
Srinivas KANDAGATLA701016c2013-06-20 15:05:38 +0100134
Stephen Warren971dac72012-02-01 14:04:47 -0700135config PINCTRL_TEGRA
136 bool
Axel Lin507ccdb2012-11-12 10:00:22 +0800137 select PINMUX
138 select PINCONF
Stephen Warren971dac72012-02-01 14:04:47 -0700139
140config PINCTRL_TEGRA20
141 bool
Stephen Warren971dac72012-02-01 14:04:47 -0700142 select PINCTRL_TEGRA
143
144config PINCTRL_TEGRA30
145 bool
Stephen Warren971dac72012-02-01 14:04:47 -0700146 select PINCTRL_TEGRA
147
Pritesh Raithathab6ae7a22013-01-08 13:02:37 +0530148config PINCTRL_TEGRA114
149 bool
150 select PINCTRL_TEGRA
151
Ashwini Ghuge1a16bee2013-12-10 12:40:56 +0530152config PINCTRL_TEGRA124
153 bool
154 select PINCTRL_TEGRA
155
Stephen Warren9184f752015-02-24 14:00:51 -0700156config PINCTRL_TEGRA210
157 bool
158 select PINCTRL_TEGRA
159
Thierry Redingdc0a3932014-06-19 13:37:08 +0200160config PINCTRL_TEGRA_XUSB
161 def_bool y if ARCH_TEGRA
162 select GENERIC_PHY
163 select PINCONF
164 select PINMUX
165
James Hogand5025f92013-06-20 10:26:27 +0100166config PINCTRL_TZ1090
167 bool "Toumaz Xenif TZ1090 pin control driver"
168 depends on SOC_TZ1090
169 select PINMUX
170 select GENERIC_PINCONF
171
James Hoganb58f0272013-06-20 10:26:29 +0100172config PINCTRL_TZ1090_PDC
173 bool "Toumaz Xenif TZ1090 PDC pin control driver"
174 depends on SOC_TZ1090
175 select PINMUX
176 select PINCONF
177
Linus Walleij3bece552011-12-18 23:44:26 +0100178config PINCTRL_U300
179 bool "U300 pin controller driver"
Linus Walleij98da3522011-05-02 20:54:38 +0200180 depends on ARCH_U300
181 select PINMUX
Linus Walleijdc0b1aa2011-11-16 21:58:10 +0100182 select GENERIC_PINCONF
Linus Walleij45f034e2011-11-05 21:28:46 +0100183
Linus Walleijca402d32011-11-16 09:22:59 +0100184config PINCTRL_COH901
185 bool "ST-Ericsson U300 COH 901 335/571 GPIO"
Linus Walleij3c94d1b2012-06-18 20:07:50 +0200186 depends on GPIOLIB && ARCH_U300 && PINCTRL_U300
Linus Walleij523dcce2014-03-25 13:37:17 +0100187 select GPIOLIB_IRQCHIP
Linus Walleijca402d32011-11-16 09:22:59 +0100188 help
189 Say yes here to support GPIO interface on ST-Ericsson U300.
190 The names of the two IP block variants supported are
191 COH 901 335 and COH 901 571/3. They contain 3, 5 or 7
192 ports of 8 GPIO pins each.
193
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530194config PINCTRL_PALMAS
Mark Brown736658c2013-08-19 16:07:26 +0100195 bool "Pinctrl driver for the PALMAS Series MFD devices"
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530196 depends on OF && MFD_PALMAS
Axel Lin63ca8db2013-08-22 14:30:08 +0800197 select PINMUX
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530198 select GENERIC_PINCONF
199 help
200 Palmas device supports the configuration of pins for different
201 functionality. This driver supports the pinmux, push-pull and
202 open drain configuration for the Palmas series devices like
203 TPS65913, TPS80036 etc.
204
Soren Brinkmannadd958c2015-01-09 07:43:48 -0800205config PINCTRL_ZYNQ
206 bool "Pinctrl driver for Xilinx Zynq"
207 depends on ARCH_ZYNQ
208 select PINMUX
209 select GENERIC_PINCONF
210 help
211 This selectes the pinctrl driver for Xilinx Zynq.
212
Ray Juib17f2f92015-03-04 16:35:49 -0800213source "drivers/pinctrl/bcm/Kconfig"
Antoine Tenart3de68d32014-05-19 19:36:29 +0200214source "drivers/pinctrl/berlin/Kconfig"
Linus Walleijedad3b22014-09-03 13:37:38 +0200215source "drivers/pinctrl/freescale/Kconfig"
Mika Westerberg5fae8b82014-10-24 15:16:52 +0300216source "drivers/pinctrl/intel/Kconfig"
Thomas Petazzoni06763c72012-10-24 23:38:58 +0200217source "drivers/pinctrl/mvebu/Kconfig"
Linus Walleij3a198052014-07-11 14:57:06 +0200218source "drivers/pinctrl/nomadik/Kconfig"
Linus Walleij69b78b82014-07-09 13:55:12 +0200219source "drivers/pinctrl/qcom/Kconfig"
Sachin Kamatebe629a2014-07-10 17:33:27 +0530220source "drivers/pinctrl/samsung/Kconfig"
Laurent Pinchart6e54d8d2012-12-15 23:51:19 +0100221source "drivers/pinctrl/sh-pfc/Kconfig"
Viresh Kumardeda8282012-03-28 22:27:07 +0530222source "drivers/pinctrl/spear/Kconfig"
Maxime Ripard5f910772014-04-18 18:53:02 +0200223source "drivers/pinctrl/sunxi/Kconfig"
Tony Prisk170c6152013-02-20 09:32:19 +1300224source "drivers/pinctrl/vt8500/Kconfig"
Hongzhou Yanga6df4102015-01-21 13:28:15 +0800225source "drivers/pinctrl/mediatek/Kconfig"
Viresh Kumardeda8282012-03-28 22:27:07 +0530226
John Crispin3f8c50c2012-08-28 12:44:59 +0200227config PINCTRL_XWAY
228 bool
229 depends on SOC_TYPE_XWAY
230 depends on PINCTRL_LANTIQ
231
Christian Ruppert5aad0db2013-10-15 15:39:38 +0200232config PINCTRL_TB10X
233 bool
Linus Walleijb99e6fb2015-04-15 10:00:35 +0200234 depends on OF && ARC_PLAT_TB10X
235 select GPIOLIB
Christian Ruppert5aad0db2013-10-15 15:39:38 +0200236
Linus Walleij45f034e2011-11-05 21:28:46 +0100237endmenu
Linus Walleij98da3522011-05-02 20:54:38 +0200238
Linus Walleij2744e8a2011-05-02 20:50:54 +0200239endif