Linus Walleij | 2744e8a | 2011-05-02 20:50:54 +0200 | [diff] [blame] | 1 | # |
| 2 | # PINCTRL infrastructure and drivers |
| 3 | # |
| 4 | |
Linus Walleij | 45f034e | 2011-11-05 21:28:46 +0100 | [diff] [blame] | 5 | config PINCTRL |
| 6 | bool |
Linus Walleij | 2744e8a | 2011-05-02 20:50:54 +0200 | [diff] [blame] | 7 | |
| 8 | if PINCTRL |
| 9 | |
Linus Walleij | 45f034e | 2011-11-05 21:28:46 +0100 | [diff] [blame] | 10 | menu "Pin controllers" |
| 11 | depends on PINCTRL |
| 12 | |
Linus Walleij | 2744e8a | 2011-05-02 20:50:54 +0200 | [diff] [blame] | 13 | config PINMUX |
Uwe Kleine-König | 244e95a | 2014-06-03 10:02:36 +0200 | [diff] [blame] | 14 | bool "Support pin multiplexing controllers" if COMPILE_TEST |
Linus Walleij | ae6b4d8 | 2011-10-19 18:14:33 +0200 | [diff] [blame] | 15 | |
| 16 | config PINCONF |
Uwe Kleine-König | 244e95a | 2014-06-03 10:02:36 +0200 | [diff] [blame] | 17 | bool "Support pin configuration controllers" if COMPILE_TEST |
Linus Walleij | 2744e8a | 2011-05-02 20:50:54 +0200 | [diff] [blame] | 18 | |
Linus Walleij | 394349f | 2011-11-24 18:27:15 +0100 | [diff] [blame] | 19 | config GENERIC_PINCONF |
| 20 | bool |
| 21 | select PINCONF |
| 22 | |
Linus Walleij | 2744e8a | 2011-05-02 20:50:54 +0200 | [diff] [blame] | 23 | config 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 Zhang | e9a03ad | 2013-09-03 16:28:59 +0800 | [diff] [blame] | 29 | config PINCTRL_ADI2 |
| 30 | bool "ADI pin controller driver" |
Sonic Zhang | 9d7278d | 2013-09-23 11:57:00 +0800 | [diff] [blame] | 31 | depends on BLACKFIN |
Sonic Zhang | e9a03ad | 2013-09-03 16:28:59 +0800 | [diff] [blame] | 32 | 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 Dewangan | c8ce878 | 2013-10-02 21:20:29 +0530 | [diff] [blame] | 39 | config 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 Zhang | e9a03ad | 2013-09-03 16:28:59 +0800 | [diff] [blame] | 50 | config PINCTRL_BF54x |
| 51 | def_bool y if BF54x |
| 52 | select PINCTRL_ADI2 |
| 53 | |
| 54 | config PINCTRL_BF60x |
| 55 | def_bool y if BF60x |
| 56 | select PINCTRL_ADI2 |
| 57 | |
Jean-Christophe PLAGNIOL-VILLARD | 6732ae5 | 2012-07-12 23:35:02 +0800 | [diff] [blame] | 58 | config PINCTRL_AT91 |
| 59 | bool "AT91 pinctrl driver" |
| 60 | depends on OF |
| 61 | depends on ARCH_AT91 |
| 62 | select PINMUX |
| 63 | select PINCONF |
Alexander Stein | 80cc373 | 2014-04-15 22:09:41 +0200 | [diff] [blame] | 64 | select GPIOLIB |
| 65 | select OF_GPIO |
| 66 | select GPIOLIB_IRQCHIP |
Jean-Christophe PLAGNIOL-VILLARD | 6732ae5 | 2012-07-12 23:35:02 +0800 | [diff] [blame] | 67 | help |
| 68 | Say Y here to enable the at91 pinctrl driver |
| 69 | |
Mathias Nyman | a5d811b | 2013-06-18 14:33:02 +0300 | [diff] [blame] | 70 | config PINCTRL_BAYTRAIL |
| 71 | bool "Intel Baytrail GPIO pin control" |
| 72 | depends on GPIOLIB && ACPI && X86 |
Mika Westerberg | e1ee5c5 | 2014-07-25 09:54:47 +0300 | [diff] [blame] | 73 | select GPIOLIB_IRQCHIP |
Mathias Nyman | a5d811b | 2013-06-18 14:33:02 +0300 | [diff] [blame] | 74 | 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 Arlott | e1b2dc7 | 2012-09-27 22:10:11 -0600 | [diff] [blame] | 82 | config PINCTRL_BCM2835 |
| 83 | bool |
| 84 | select PINMUX |
| 85 | select PINCONF |
| 86 | |
Sherman Yin | 7418b5c | 2014-04-02 15:40:37 -0700 | [diff] [blame] | 87 | config PINCTRL_BCM281XX |
| 88 | bool "Broadcom BCM281xx pinctrl driver" |
Uwe Kleine-König | e4742d5 | 2014-09-24 10:15:24 +0200 | [diff] [blame] | 89 | depends on OF && (ARCH_BCM_MOBILE || COMPILE_TEST) |
Sherman Yin | 54b1aa5 | 2013-12-20 18:13:35 -0800 | [diff] [blame] | 90 | select PINMUX |
| 91 | select PINCONF |
| 92 | select GENERIC_PINCONF |
| 93 | select REGMAP_MMIO |
| 94 | help |
Sherman Yin | 7418b5c | 2014-04-02 15:40:37 -0700 | [diff] [blame] | 95 | Say Y here to support Broadcom BCM281xx pinctrl driver, which is used |
| 96 | for the BCM281xx SoC family, including BCM11130, BCM11140, BCM11351, |
Sherman Yin | 54b1aa5 | 2013-12-20 18:13:35 -0800 | [diff] [blame] | 97 | BCM28145, and BCM28155 SoCs. This driver requires the pinctrl |
| 98 | framework. GPIO is provided by a separate GPIO driver. |
| 99 | |
John Crispin | 3f8c50c | 2012-08-28 12:44:59 +0200 | [diff] [blame] | 100 | config PINCTRL_LANTIQ |
| 101 | bool |
| 102 | depends on LANTIQ |
| 103 | select PINMUX |
| 104 | select PINCONF |
| 105 | |
John Crispin | e316cb2 | 2012-05-20 00:33:56 +0200 | [diff] [blame] | 106 | config PINCTRL_FALCON |
| 107 | bool |
| 108 | depends on SOC_FALCON |
| 109 | depends on PINCTRL_LANTIQ |
| 110 | |
Heiko Stübner | d3e5116 | 2013-06-10 22:16:22 +0200 | [diff] [blame] | 111 | config PINCTRL_ROCKCHIP |
| 112 | bool |
| 113 | select PINMUX |
| 114 | select GENERIC_PINCONF |
| 115 | select GENERIC_IRQ_CHIP |
Heiko Stübner | 751a99a | 2014-05-05 13:58:20 +0200 | [diff] [blame] | 116 | select MFD_SYSCON |
Heiko Stübner | d3e5116 | 2013-06-10 22:16:22 +0200 | [diff] [blame] | 117 | |
Tony Lindgren | 8b8b091 | 2012-07-10 02:05:46 -0700 | [diff] [blame] | 118 | config 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 Zhuang | 9dddb4d | 2013-02-17 19:42:55 +0800 | [diff] [blame] | 123 | select GENERIC_PINCONF |
Tony Lindgren | 8b8b091 | 2012-07-10 02:05:46 -0700 | [diff] [blame] | 124 | help |
| 125 | This selects the device tree based generic pinctrl driver. |
| 126 | |
Linus Walleij | 3bece55 | 2011-12-18 23:44:26 +0100 | [diff] [blame] | 127 | config PINCTRL_SIRF |
Barry Song | d3e26f2 | 2012-09-27 17:56:30 +0800 | [diff] [blame] | 128 | bool "CSR SiRFprimaII/SiRFmarco pin controller driver" |
| 129 | depends on ARCH_SIRF |
Rongjun Ying | 393daa8 | 2011-10-09 03:11:13 -0700 | [diff] [blame] | 130 | select PINMUX |
Linus Walleij | 7420d2d | 2014-04-15 14:43:47 +0800 | [diff] [blame] | 131 | select GPIOLIB_IRQCHIP |
Rongjun Ying | 393daa8 | 2011-10-09 03:11:13 -0700 | [diff] [blame] | 132 | |
Srinivas KANDAGATLA | 701016c | 2013-06-20 15:05:38 +0100 | [diff] [blame] | 133 | config PINCTRL_ST |
| 134 | bool |
| 135 | depends on OF |
| 136 | select PINMUX |
| 137 | select PINCONF |
Linus Walleij | 130cbe3 | 2014-04-08 14:45:47 +0200 | [diff] [blame] | 138 | select GPIOLIB_IRQCHIP |
Srinivas KANDAGATLA | 701016c | 2013-06-20 15:05:38 +0100 | [diff] [blame] | 139 | |
Stephen Warren | 971dac7 | 2012-02-01 14:04:47 -0700 | [diff] [blame] | 140 | config PINCTRL_TEGRA |
| 141 | bool |
Axel Lin | 507ccdb | 2012-11-12 10:00:22 +0800 | [diff] [blame] | 142 | select PINMUX |
| 143 | select PINCONF |
Stephen Warren | 971dac7 | 2012-02-01 14:04:47 -0700 | [diff] [blame] | 144 | |
| 145 | config PINCTRL_TEGRA20 |
| 146 | bool |
Stephen Warren | 971dac7 | 2012-02-01 14:04:47 -0700 | [diff] [blame] | 147 | select PINCTRL_TEGRA |
| 148 | |
| 149 | config PINCTRL_TEGRA30 |
| 150 | bool |
Stephen Warren | 971dac7 | 2012-02-01 14:04:47 -0700 | [diff] [blame] | 151 | select PINCTRL_TEGRA |
| 152 | |
Pritesh Raithatha | b6ae7a2 | 2013-01-08 13:02:37 +0530 | [diff] [blame] | 153 | config PINCTRL_TEGRA114 |
| 154 | bool |
| 155 | select PINCTRL_TEGRA |
| 156 | |
Ashwini Ghuge | 1a16bee | 2013-12-10 12:40:56 +0530 | [diff] [blame] | 157 | config PINCTRL_TEGRA124 |
| 158 | bool |
| 159 | select PINCTRL_TEGRA |
| 160 | |
Thierry Reding | dc0a393 | 2014-06-19 13:37:08 +0200 | [diff] [blame] | 161 | config PINCTRL_TEGRA_XUSB |
| 162 | def_bool y if ARCH_TEGRA |
| 163 | select GENERIC_PHY |
| 164 | select PINCONF |
| 165 | select PINMUX |
| 166 | |
James Hogan | d5025f9 | 2013-06-20 10:26:27 +0100 | [diff] [blame] | 167 | config PINCTRL_TZ1090 |
| 168 | bool "Toumaz Xenif TZ1090 pin control driver" |
| 169 | depends on SOC_TZ1090 |
| 170 | select PINMUX |
| 171 | select GENERIC_PINCONF |
| 172 | |
James Hogan | b58f027 | 2013-06-20 10:26:29 +0100 | [diff] [blame] | 173 | config 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 Walleij | 3bece55 | 2011-12-18 23:44:26 +0100 | [diff] [blame] | 179 | config PINCTRL_U300 |
| 180 | bool "U300 pin controller driver" |
Linus Walleij | 98da352 | 2011-05-02 20:54:38 +0200 | [diff] [blame] | 181 | depends on ARCH_U300 |
| 182 | select PINMUX |
Linus Walleij | dc0b1aa | 2011-11-16 21:58:10 +0100 | [diff] [blame] | 183 | select GENERIC_PINCONF |
Linus Walleij | 45f034e | 2011-11-05 21:28:46 +0100 | [diff] [blame] | 184 | |
Linus Walleij | ca402d3 | 2011-11-16 09:22:59 +0100 | [diff] [blame] | 185 | config PINCTRL_COH901 |
| 186 | bool "ST-Ericsson U300 COH 901 335/571 GPIO" |
Linus Walleij | 3c94d1b | 2012-06-18 20:07:50 +0200 | [diff] [blame] | 187 | depends on GPIOLIB && ARCH_U300 && PINCTRL_U300 |
Linus Walleij | 523dcce | 2014-03-25 13:37:17 +0100 | [diff] [blame] | 188 | select GPIOLIB_IRQCHIP |
Linus Walleij | ca402d3 | 2011-11-16 09:22:59 +0100 | [diff] [blame] | 189 | 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 Dewangan | 0a8d3e2 | 2013-08-06 18:42:35 +0530 | [diff] [blame] | 195 | config PINCTRL_PALMAS |
Mark Brown | 736658c | 2013-08-19 16:07:26 +0100 | [diff] [blame] | 196 | bool "Pinctrl driver for the PALMAS Series MFD devices" |
Laxman Dewangan | 0a8d3e2 | 2013-08-06 18:42:35 +0530 | [diff] [blame] | 197 | depends on OF && MFD_PALMAS |
Axel Lin | 63ca8db | 2013-08-22 14:30:08 +0800 | [diff] [blame] | 198 | select PINMUX |
Laxman Dewangan | 0a8d3e2 | 2013-08-06 18:42:35 +0530 | [diff] [blame] | 199 | 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 Tenart | 3de68d3 | 2014-05-19 19:36:29 +0200 | [diff] [blame] | 206 | source "drivers/pinctrl/berlin/Kconfig" |
Linus Walleij | edad3b2 | 2014-09-03 13:37:38 +0200 | [diff] [blame] | 207 | source "drivers/pinctrl/freescale/Kconfig" |
Thomas Petazzoni | 06763c7 | 2012-10-24 23:38:58 +0200 | [diff] [blame] | 208 | source "drivers/pinctrl/mvebu/Kconfig" |
Linus Walleij | 3a19805 | 2014-07-11 14:57:06 +0200 | [diff] [blame] | 209 | source "drivers/pinctrl/nomadik/Kconfig" |
Linus Walleij | 69b78b8 | 2014-07-09 13:55:12 +0200 | [diff] [blame] | 210 | source "drivers/pinctrl/qcom/Kconfig" |
Sachin Kamat | ebe629a | 2014-07-10 17:33:27 +0530 | [diff] [blame] | 211 | source "drivers/pinctrl/samsung/Kconfig" |
Laurent Pinchart | 6e54d8d | 2012-12-15 23:51:19 +0100 | [diff] [blame] | 212 | source "drivers/pinctrl/sh-pfc/Kconfig" |
Viresh Kumar | deda828 | 2012-03-28 22:27:07 +0530 | [diff] [blame] | 213 | source "drivers/pinctrl/spear/Kconfig" |
Maxime Ripard | 5f91077 | 2014-04-18 18:53:02 +0200 | [diff] [blame] | 214 | source "drivers/pinctrl/sunxi/Kconfig" |
Tony Prisk | 170c615 | 2013-02-20 09:32:19 +1300 | [diff] [blame] | 215 | source "drivers/pinctrl/vt8500/Kconfig" |
Viresh Kumar | deda828 | 2012-03-28 22:27:07 +0530 | [diff] [blame] | 216 | |
John Crispin | 3f8c50c | 2012-08-28 12:44:59 +0200 | [diff] [blame] | 217 | config PINCTRL_XWAY |
| 218 | bool |
| 219 | depends on SOC_TYPE_XWAY |
| 220 | depends on PINCTRL_LANTIQ |
| 221 | |
Christian Ruppert | 5aad0db | 2013-10-15 15:39:38 +0200 | [diff] [blame] | 222 | config PINCTRL_TB10X |
| 223 | bool |
| 224 | depends on ARC_PLAT_TB10X |
| 225 | |
Linus Walleij | 45f034e | 2011-11-05 21:28:46 +0100 | [diff] [blame] | 226 | endmenu |
Linus Walleij | 98da352 | 2011-05-02 20:54:38 +0200 | [diff] [blame] | 227 | |
Linus Walleij | 2744e8a | 2011-05-02 20:50:54 +0200 | [diff] [blame] | 228 | endif |