blob: c6a66de6ed72d0d4e96d061737d4ba3b9a4f3cd3 [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
Mathias Nymana5d811b2013-06-18 14:33:02 +030070config PINCTRL_BAYTRAIL
71 bool "Intel Baytrail GPIO pin control"
72 depends on GPIOLIB && ACPI && X86
Mika Westerberge1ee5c52014-07-25 09:54:47 +030073 select GPIOLIB_IRQCHIP
Mathias Nymana5d811b2013-06-18 14:33:02 +030074 help
75 driver for memory mapped GPIO functionality on Intel Baytrail
76 platforms. Supports 3 banks with 102, 28 and 44 gpios.
77 Most pins are usually muxed to some other functionality by firmware,
78 so only a small amount is available for gpio use.
79
80 Requires ACPI device enumeration code to set up a platform device.
81
Simon Arlotte1b2dc72012-09-27 22:10:11 -060082config PINCTRL_BCM2835
83 bool
84 select PINMUX
85 select PINCONF
86
Sherman Yin7418b5c2014-04-02 15:40:37 -070087config PINCTRL_BCM281XX
88 bool "Broadcom BCM281xx pinctrl driver"
Uwe Kleine-Könige4742d52014-09-24 10:15:24 +020089 depends on OF && (ARCH_BCM_MOBILE || COMPILE_TEST)
Sherman Yin54b1aa52013-12-20 18:13:35 -080090 select PINMUX
91 select PINCONF
92 select GENERIC_PINCONF
93 select REGMAP_MMIO
94 help
Sherman Yin7418b5c2014-04-02 15:40:37 -070095 Say Y here to support Broadcom BCM281xx pinctrl driver, which is used
96 for the BCM281xx SoC family, including BCM11130, BCM11140, BCM11351,
Sherman Yin54b1aa52013-12-20 18:13:35 -080097 BCM28145, and BCM28155 SoCs. This driver requires the pinctrl
98 framework. GPIO is provided by a separate GPIO driver.
99
John Crispin3f8c50c2012-08-28 12:44:59 +0200100config PINCTRL_LANTIQ
101 bool
102 depends on LANTIQ
103 select PINMUX
104 select PINCONF
105
John Crispine316cb22012-05-20 00:33:56 +0200106config PINCTRL_FALCON
107 bool
108 depends on SOC_FALCON
109 depends on PINCTRL_LANTIQ
110
Heiko Stübnerd3e51162013-06-10 22:16:22 +0200111config PINCTRL_ROCKCHIP
112 bool
113 select PINMUX
114 select GENERIC_PINCONF
115 select GENERIC_IRQ_CHIP
Heiko Stübner751a99a2014-05-05 13:58:20 +0200116 select MFD_SYSCON
Heiko Stübnerd3e51162013-06-10 22:16:22 +0200117
Tony Lindgren8b8b0912012-07-10 02:05:46 -0700118config PINCTRL_SINGLE
119 tristate "One-register-per-pin type device tree based pinctrl driver"
120 depends on OF
121 select PINMUX
122 select PINCONF
Haojian Zhuang9dddb4d2013-02-17 19:42:55 +0800123 select GENERIC_PINCONF
Tony Lindgren8b8b0912012-07-10 02:05:46 -0700124 help
125 This selects the device tree based generic pinctrl driver.
126
Linus Walleij3bece552011-12-18 23:44:26 +0100127config PINCTRL_SIRF
Barry Songd3e26f22012-09-27 17:56:30 +0800128 bool "CSR SiRFprimaII/SiRFmarco pin controller driver"
129 depends on ARCH_SIRF
Rongjun Ying393daa82011-10-09 03:11:13 -0700130 select PINMUX
Linus Walleij7420d2d2014-04-15 14:43:47 +0800131 select GPIOLIB_IRQCHIP
Rongjun Ying393daa82011-10-09 03:11:13 -0700132
Srinivas KANDAGATLA701016c2013-06-20 15:05:38 +0100133config PINCTRL_ST
134 bool
135 depends on OF
136 select PINMUX
137 select PINCONF
Linus Walleij130cbe32014-04-08 14:45:47 +0200138 select GPIOLIB_IRQCHIP
Srinivas KANDAGATLA701016c2013-06-20 15:05:38 +0100139
Stephen Warren971dac72012-02-01 14:04:47 -0700140config PINCTRL_TEGRA
141 bool
Axel Lin507ccdb2012-11-12 10:00:22 +0800142 select PINMUX
143 select PINCONF
Stephen Warren971dac72012-02-01 14:04:47 -0700144
145config PINCTRL_TEGRA20
146 bool
Stephen Warren971dac72012-02-01 14:04:47 -0700147 select PINCTRL_TEGRA
148
149config PINCTRL_TEGRA30
150 bool
Stephen Warren971dac72012-02-01 14:04:47 -0700151 select PINCTRL_TEGRA
152
Pritesh Raithathab6ae7a22013-01-08 13:02:37 +0530153config PINCTRL_TEGRA114
154 bool
155 select PINCTRL_TEGRA
156
Ashwini Ghuge1a16bee2013-12-10 12:40:56 +0530157config PINCTRL_TEGRA124
158 bool
159 select PINCTRL_TEGRA
160
Thierry Redingdc0a3932014-06-19 13:37:08 +0200161config PINCTRL_TEGRA_XUSB
162 def_bool y if ARCH_TEGRA
163 select GENERIC_PHY
164 select PINCONF
165 select PINMUX
166
James Hogand5025f92013-06-20 10:26:27 +0100167config PINCTRL_TZ1090
168 bool "Toumaz Xenif TZ1090 pin control driver"
169 depends on SOC_TZ1090
170 select PINMUX
171 select GENERIC_PINCONF
172
James Hoganb58f0272013-06-20 10:26:29 +0100173config PINCTRL_TZ1090_PDC
174 bool "Toumaz Xenif TZ1090 PDC pin control driver"
175 depends on SOC_TZ1090
176 select PINMUX
177 select PINCONF
178
Linus Walleij3bece552011-12-18 23:44:26 +0100179config PINCTRL_U300
180 bool "U300 pin controller driver"
Linus Walleij98da3522011-05-02 20:54:38 +0200181 depends on ARCH_U300
182 select PINMUX
Linus Walleijdc0b1aa2011-11-16 21:58:10 +0100183 select GENERIC_PINCONF
Linus Walleij45f034e2011-11-05 21:28:46 +0100184
Linus Walleijca402d32011-11-16 09:22:59 +0100185config PINCTRL_COH901
186 bool "ST-Ericsson U300 COH 901 335/571 GPIO"
Linus Walleij3c94d1b2012-06-18 20:07:50 +0200187 depends on GPIOLIB && ARCH_U300 && PINCTRL_U300
Linus Walleij523dcce2014-03-25 13:37:17 +0100188 select GPIOLIB_IRQCHIP
Linus Walleijca402d32011-11-16 09:22:59 +0100189 help
190 Say yes here to support GPIO interface on ST-Ericsson U300.
191 The names of the two IP block variants supported are
192 COH 901 335 and COH 901 571/3. They contain 3, 5 or 7
193 ports of 8 GPIO pins each.
194
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530195config PINCTRL_PALMAS
Mark Brown736658c2013-08-19 16:07:26 +0100196 bool "Pinctrl driver for the PALMAS Series MFD devices"
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530197 depends on OF && MFD_PALMAS
Axel Lin63ca8db2013-08-22 14:30:08 +0800198 select PINMUX
Laxman Dewangan0a8d3e22013-08-06 18:42:35 +0530199 select GENERIC_PINCONF
200 help
201 Palmas device supports the configuration of pins for different
202 functionality. This driver supports the pinmux, push-pull and
203 open drain configuration for the Palmas series devices like
204 TPS65913, TPS80036 etc.
205
Antoine Tenart3de68d32014-05-19 19:36:29 +0200206source "drivers/pinctrl/berlin/Kconfig"
Linus Walleijedad3b22014-09-03 13:37:38 +0200207source "drivers/pinctrl/freescale/Kconfig"
Thomas Petazzoni06763c72012-10-24 23:38:58 +0200208source "drivers/pinctrl/mvebu/Kconfig"
Linus Walleij3a198052014-07-11 14:57:06 +0200209source "drivers/pinctrl/nomadik/Kconfig"
Linus Walleij69b78b82014-07-09 13:55:12 +0200210source "drivers/pinctrl/qcom/Kconfig"
Sachin Kamatebe629a2014-07-10 17:33:27 +0530211source "drivers/pinctrl/samsung/Kconfig"
Laurent Pinchart6e54d8d2012-12-15 23:51:19 +0100212source "drivers/pinctrl/sh-pfc/Kconfig"
Viresh Kumardeda8282012-03-28 22:27:07 +0530213source "drivers/pinctrl/spear/Kconfig"
Maxime Ripard5f910772014-04-18 18:53:02 +0200214source "drivers/pinctrl/sunxi/Kconfig"
Tony Prisk170c6152013-02-20 09:32:19 +1300215source "drivers/pinctrl/vt8500/Kconfig"
Viresh Kumardeda8282012-03-28 22:27:07 +0530216
John Crispin3f8c50c2012-08-28 12:44:59 +0200217config PINCTRL_XWAY
218 bool
219 depends on SOC_TYPE_XWAY
220 depends on PINCTRL_LANTIQ
221
Christian Ruppert5aad0db2013-10-15 15:39:38 +0200222config PINCTRL_TB10X
223 bool
224 depends on ARC_PLAT_TB10X
225
Linus Walleij45f034e2011-11-05 21:28:46 +0100226endmenu
Linus Walleij98da3522011-05-02 20:54:38 +0200227
Linus Walleij2744e8a2011-05-02 20:50:54 +0200228endif