blob: c6f299ba25cb6c9d610507e138c7eb57dc535268 [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
98 select PINMUX
99 select PINCONF
100 select GENERIC_PINCONF
101 select OF_GPIO
102 select REGMAP_MMIO
103
Heiko Stübnerd3e51162013-06-10 22:16:22 +0200104config PINCTRL_ROCKCHIP
105 bool
106 select PINMUX
107 select GENERIC_PINCONF
108 select GENERIC_IRQ_CHIP
Heiko Stübner751a99a2014-05-05 13:58:20 +0200109 select MFD_SYSCON
Heiko Stübnerd3e51162013-06-10 22:16:22 +0200110
Tony Lindgren8b8b091b2012-07-10 02:05:46 -0700111config PINCTRL_SINGLE
112 tristate "One-register-per-pin type device tree based pinctrl driver"
113 depends on OF
114 select PINMUX
115 select PINCONF
Haojian Zhuang9dddb4d2013-02-17 19:42:55 +0800116 select GENERIC_PINCONF
Tony Lindgren8b8b091b2012-07-10 02:05:46 -0700117 help
118 This selects the device tree based generic pinctrl driver.
119
Linus Walleij3bece552011-12-18 23:44:26 +0100120config PINCTRL_SIRF
Barry Songa17272a2015-01-11 21:56:41 +0800121 bool "CSR SiRFprimaII pin controller driver"
Barry Songd3e26f22012-09-27 17:56:30 +0800122 depends on ARCH_SIRF
Rongjun Ying393daa82011-10-09 03:11:13 -0700123 select PINMUX
Linus Walleij7420d2d2014-04-15 14:43:47 +0800124 select GPIOLIB_IRQCHIP
Rongjun Ying393daa82011-10-09 03:11:13 -0700125
Srinivas KANDAGATLA701016c2013-06-20 15:05:38 +0100126config PINCTRL_ST
127 bool
128 depends on OF
129 select PINMUX
130 select PINCONF
Linus Walleij130cbe32014-04-08 14:45:47 +0200131 select GPIOLIB_IRQCHIP
Srinivas KANDAGATLA701016c2013-06-20 15:05:38 +0100132
Stephen Warren971dac72012-02-01 14:04:47 -0700133config PINCTRL_TEGRA
134 bool
Axel Lin507ccdb2012-11-12 10:00:22 +0800135 select PINMUX
136 select PINCONF
Stephen Warren971dac72012-02-01 14:04:47 -0700137
138config PINCTRL_TEGRA20
139 bool
Stephen Warren971dac72012-02-01 14:04:47 -0700140 select PINCTRL_TEGRA
141
142config PINCTRL_TEGRA30
143 bool
Stephen Warren971dac72012-02-01 14:04:47 -0700144 select PINCTRL_TEGRA
145
Pritesh Raithathab6ae7a22013-01-08 13:02:37 +0530146config PINCTRL_TEGRA114
147 bool
148 select PINCTRL_TEGRA
149
Ashwini Ghuge1a16bee2013-12-10 12:40:56 +0530150config PINCTRL_TEGRA124
151 bool
152 select PINCTRL_TEGRA
153
Stephen Warren9184f752015-02-24 14:00:51 -0700154config PINCTRL_TEGRA210
155 bool
156 select PINCTRL_TEGRA
157
Thierry Redingdc0a3932014-06-19 13:37:08 +0200158config PINCTRL_TEGRA_XUSB
159 def_bool y if ARCH_TEGRA
160 select GENERIC_PHY
161 select PINCONF
162 select PINMUX
163
James Hogand5025f92013-06-20 10:26:27 +0100164config PINCTRL_TZ1090
165 bool "Toumaz Xenif TZ1090 pin control driver"
166 depends on SOC_TZ1090
167 select PINMUX
168 select GENERIC_PINCONF
169
James Hoganb58f0272013-06-20 10:26:29 +0100170config PINCTRL_TZ1090_PDC
171 bool "Toumaz Xenif TZ1090 PDC pin control driver"
172 depends on SOC_TZ1090
173 select PINMUX
174 select PINCONF
175
Linus Walleij3bece552011-12-18 23:44:26 +0100176config PINCTRL_U300
177 bool "U300 pin controller driver"
Linus Walleij98da3522011-05-02 20:54:38 +0200178 depends on ARCH_U300
179 select PINMUX
Linus Walleijdc0b1aa2011-11-16 21:58:10 +0100180 select GENERIC_PINCONF
Linus Walleij45f034e2011-11-05 21:28:46 +0100181
Linus Walleijca402d32011-11-16 09:22:59 +0100182config PINCTRL_COH901
183 bool "ST-Ericsson U300 COH 901 335/571 GPIO"
Linus Walleij3c94d1b2012-06-18 20:07:50 +0200184 depends on GPIOLIB && ARCH_U300 && PINCTRL_U300
Linus Walleij523dcce2014-03-25 13:37:17 +0100185 select GPIOLIB_IRQCHIP
Linus Walleijca402d32011-11-16 09:22:59 +0100186 help
187 Say yes here to support GPIO interface on ST-Ericsson U300.
188 The names of the two IP block variants supported are
189 COH 901 335 and COH 901 571/3. They contain 3, 5 or 7
190 ports of 8 GPIO pins each.
191
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530192config PINCTRL_PALMAS
Mark Brown736658c2013-08-19 16:07:26 +0100193 bool "Pinctrl driver for the PALMAS Series MFD devices"
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530194 depends on OF && MFD_PALMAS
Axel Lin63ca8db2013-08-22 14:30:08 +0800195 select PINMUX
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530196 select GENERIC_PINCONF
197 help
198 Palmas device supports the configuration of pins for different
199 functionality. This driver supports the pinmux, push-pull and
200 open drain configuration for the Palmas series devices like
201 TPS65913, TPS80036 etc.
202
Soren Brinkmannadd958c2015-01-09 07:43:48 -0800203config PINCTRL_ZYNQ
204 bool "Pinctrl driver for Xilinx Zynq"
205 depends on ARCH_ZYNQ
206 select PINMUX
207 select GENERIC_PINCONF
208 help
209 This selectes the pinctrl driver for Xilinx Zynq.
210
Ray Juib17f2f92015-03-04 16:35:49 -0800211source "drivers/pinctrl/bcm/Kconfig"
Antoine Tenart3de68d32014-05-19 19:36:29 +0200212source "drivers/pinctrl/berlin/Kconfig"
Linus Walleijedad3b22014-09-03 13:37:38 +0200213source "drivers/pinctrl/freescale/Kconfig"
Mika Westerberg5fae8b82014-10-24 15:16:52 +0300214source "drivers/pinctrl/intel/Kconfig"
Thomas Petazzoni06763c72012-10-24 23:38:58 +0200215source "drivers/pinctrl/mvebu/Kconfig"
Linus Walleij3a198052014-07-11 14:57:06 +0200216source "drivers/pinctrl/nomadik/Kconfig"
Linus Walleij69b78b82014-07-09 13:55:12 +0200217source "drivers/pinctrl/qcom/Kconfig"
Sachin Kamatebe629a2014-07-10 17:33:27 +0530218source "drivers/pinctrl/samsung/Kconfig"
Laurent Pinchart6e54d8d2012-12-15 23:51:19 +0100219source "drivers/pinctrl/sh-pfc/Kconfig"
Viresh Kumardeda8282012-03-28 22:27:07 +0530220source "drivers/pinctrl/spear/Kconfig"
Maxime Ripard5f910772014-04-18 18:53:02 +0200221source "drivers/pinctrl/sunxi/Kconfig"
Tony Prisk170c6152013-02-20 09:32:19 +1300222source "drivers/pinctrl/vt8500/Kconfig"
Hongzhou Yanga6df4102015-01-21 13:28:15 +0800223source "drivers/pinctrl/mediatek/Kconfig"
Viresh Kumardeda8282012-03-28 22:27:07 +0530224
John Crispin3f8c50c2012-08-28 12:44:59 +0200225config PINCTRL_XWAY
226 bool
227 depends on SOC_TYPE_XWAY
228 depends on PINCTRL_LANTIQ
229
Christian Ruppert5aad0db2013-10-15 15:39:38 +0200230config PINCTRL_TB10X
231 bool
232 depends on ARC_PLAT_TB10X
233
Linus Walleij45f034e2011-11-05 21:28:46 +0100234endmenu
Linus Walleij98da3522011-05-02 20:54:38 +0200235
Linus Walleij2744e8a2011-05-02 20:50:54 +0200236endif