Thomas Gleixner | ec8f24b | 2019-05-19 13:07:45 +0100 | [diff] [blame] | 1 | # SPDX-License-Identifier: GPL-2.0-only |
David Brownell | a9c5fff | 2008-02-04 22:28:17 -0800 | [diff] [blame] | 2 | # |
Linus Walleij | e849dc0 | 2011-05-20 00:40:19 -0600 | [diff] [blame] | 3 | # GPIO infrastructure and drivers |
David Brownell | a9c5fff | 2008-02-04 22:28:17 -0800 | [diff] [blame] | 4 | # |
| 5 | |
Mark Brown | 7563bbf | 2012-04-15 10:52:54 +0100 | [diff] [blame] | 6 | config ARCH_HAVE_CUSTOM_GPIO_H |
| 7 | bool |
| 8 | help |
| 9 | Selecting this config option from the architecture Kconfig allows |
| 10 | the architecture to provide a custom asm/gpio.h implementation |
| 11 | overriding the default implementations. New uses of this are |
| 12 | strongly discouraged. |
| 13 | |
Michael Buesch | 7444a72 | 2008-07-25 01:46:11 -0700 | [diff] [blame] | 14 | menuconfig GPIOLIB |
| 15 | bool "GPIO Support" |
Michael Buesch | 7444a72 | 2008-07-25 01:46:11 -0700 | [diff] [blame] | 16 | help |
| 17 | This enables GPIO support through the generic GPIO library. |
| 18 | You only need to enable this, if you also want to enable |
Linus Walleij | e849dc0 | 2011-05-20 00:40:19 -0600 | [diff] [blame] | 19 | one or more of the GPIO drivers below. |
Michael Buesch | 7444a72 | 2008-07-25 01:46:11 -0700 | [diff] [blame] | 20 | |
| 21 | If unsure, say N. |
| 22 | |
| 23 | if GPIOLIB |
David Brownell | a9c5fff | 2008-02-04 22:28:17 -0800 | [diff] [blame] | 24 | |
Laura Abbott | 3027743 | 2018-05-21 10:57:07 -0700 | [diff] [blame] | 25 | config GPIOLIB_FASTPATH_LIMIT |
| 26 | int "Maximum number of GPIOs for fast path" |
| 27 | range 32 512 |
| 28 | default 512 |
| 29 | help |
Enrico Weigelt, metux IT consult | c42e34c | 2019-03-05 01:35:31 +0100 | [diff] [blame] | 30 | This adjusts the point at which certain APIs will switch from |
| 31 | using a stack allocated buffer to a dynamically allocated buffer. |
Laura Abbott | 3027743 | 2018-05-21 10:57:07 -0700 | [diff] [blame] | 32 | |
Enrico Weigelt, metux IT consult | c42e34c | 2019-03-05 01:35:31 +0100 | [diff] [blame] | 33 | You shouldn't need to change this unless you really need to |
| 34 | optimize either stack space or performance. Change this carefully |
| 35 | since setting an incorrect value could cause stack corruption. |
Laura Abbott | 3027743 | 2018-05-21 10:57:07 -0700 | [diff] [blame] | 36 | |
Grant Likely | f141ed65 | 2012-04-07 14:31:33 -0600 | [diff] [blame] | 37 | config OF_GPIO |
| 38 | def_bool y |
Linus Walleij | 92c74bc | 2016-07-05 08:46:43 +0200 | [diff] [blame] | 39 | depends on OF |
Linus Walleij | 2527ecc | 2016-08-16 09:58:25 +0200 | [diff] [blame] | 40 | depends on HAS_IOMEM |
Grant Likely | f141ed65 | 2012-04-07 14:31:33 -0600 | [diff] [blame] | 41 | |
Mathias Nyman | e29482e | 2012-11-30 12:37:36 +0100 | [diff] [blame] | 42 | config GPIO_ACPI |
| 43 | def_bool y |
| 44 | depends on ACPI |
| 45 | |
Linus Walleij | 1425052 | 2014-03-25 10:40:18 +0100 | [diff] [blame] | 46 | config GPIOLIB_IRQCHIP |
Linus Walleij | fc34627 | 2014-05-29 16:52:46 +0200 | [diff] [blame] | 47 | select IRQ_DOMAIN |
Linus Walleij | 1425052 | 2014-03-25 10:40:18 +0100 | [diff] [blame] | 48 | bool |
| 49 | |
David Brownell | a9c5fff | 2008-02-04 22:28:17 -0800 | [diff] [blame] | 50 | config DEBUG_GPIO |
| 51 | bool "Debug GPIO calls" |
| 52 | depends on DEBUG_KERNEL |
| 53 | help |
| 54 | Say Y here to add some extra checks and diagnostics to GPIO calls. |
Matt LaPlante | 692105b | 2009-01-26 11:12:25 +0100 | [diff] [blame] | 55 | These checks help ensure that GPIOs have been properly initialized |
| 56 | before they are used, and that sleeping calls are not made from |
| 57 | non-sleeping contexts. They can make bitbanged serial protocols |
David Brownell | a9c5fff | 2008-02-04 22:28:17 -0800 | [diff] [blame] | 58 | slower. The diagnostics help catch the type of setup errors |
| 59 | that are most common when setting up new platforms or boards. |
| 60 | |
David Brownell | d8f388d8 | 2008-07-25 01:46:07 -0700 | [diff] [blame] | 61 | config GPIO_SYSFS |
| 62 | bool "/sys/class/gpio/... (sysfs interface)" |
Kees Cook | 4c0ea23 | 2013-01-16 18:53:32 -0800 | [diff] [blame] | 63 | depends on SYSFS |
David Brownell | d8f388d8 | 2008-07-25 01:46:07 -0700 | [diff] [blame] | 64 | help |
Linus Walleij | db9477f | 2019-05-23 08:54:19 +0200 | [diff] [blame] | 65 | Say Y here to add the legacy sysfs interface for GPIOs. |
David Brownell | d8f388d8 | 2008-07-25 01:46:07 -0700 | [diff] [blame] | 66 | |
Linus Walleij | db9477f | 2019-05-23 08:54:19 +0200 | [diff] [blame] | 67 | This ABI is deprecated. If you want to use GPIO from userspace, |
| 68 | use the character device /dev/gpiochipN with the appropriate |
| 69 | ioctl() operations instead. The character device is always |
| 70 | available. |
David Brownell | d8f388d8 | 2008-07-25 01:46:07 -0700 | [diff] [blame] | 71 | |
Grant Likely | c103de2 | 2011-06-04 18:38:28 -0600 | [diff] [blame] | 72 | config GPIO_GENERIC |
Linus Walleij | 3085a4a | 2016-10-03 09:46:58 +0200 | [diff] [blame] | 73 | depends on HAS_IOMEM # Only for IOMEM drivers |
Grant Likely | c103de2 | 2011-06-04 18:38:28 -0600 | [diff] [blame] | 74 | tristate |
| 75 | |
Michael Walle | ebe3631 | 2020-05-28 16:58:44 +0200 | [diff] [blame] | 76 | config GPIO_REGMAP |
| 77 | depends on REGMAP |
| 78 | tristate |
| 79 | |
Linus Walleij | e849dc0 | 2011-05-20 00:40:19 -0600 | [diff] [blame] | 80 | # put drivers in the right section, in alphabetical order |
David Brownell | a9c5fff | 2008-02-04 22:28:17 -0800 | [diff] [blame] | 81 | |
Linus Walleij | 177b038 | 2015-04-08 15:11:16 +0200 | [diff] [blame] | 82 | # This symbol is selected by both I2C and SPI expanders |
Wolfram Sang | e952805 | 2010-03-05 13:44:33 -0800 | [diff] [blame] | 83 | config GPIO_MAX730X |
| 84 | tristate |
| 85 | |
Linus Walleij | 177b038 | 2015-04-08 15:11:16 +0200 | [diff] [blame] | 86 | menu "Memory mapped GPIO drivers" |
Linus Walleij | 3085a4a | 2016-10-03 09:46:58 +0200 | [diff] [blame] | 87 | depends on HAS_IOMEM |
John Linn | 0bcb606 | 2008-11-12 13:25:38 -0800 | [diff] [blame] | 88 | |
Alexander Shiyan | af0a33e | 2014-10-03 11:31:57 +0400 | [diff] [blame] | 89 | config GPIO_74XX_MMIO |
| 90 | tristate "GPIO driver for 74xx-ICs with MMIO access" |
| 91 | depends on OF_GPIO |
| 92 | select GPIO_GENERIC |
| 93 | help |
| 94 | Say yes here to support GPIO functionality for 74xx-compatible ICs |
| 95 | with MMIO access. Compatible models include: |
| 96 | 1 bit: 741G125 (Input), 741G74 (Output) |
| 97 | 2 bits: 742G125 (Input), 7474 (Output) |
| 98 | 4 bits: 74125 (Input), 74175 (Output) |
| 99 | 6 bits: 74365 (Input), 74174 (Output) |
| 100 | 8 bits: 74244 (Input), 74273 (Output) |
| 101 | 16 bits: 741624 (Input), 7416374 (Output) |
| 102 | |
Linus Walleij | 223fa27 | 2015-04-08 10:08:56 +0200 | [diff] [blame] | 103 | config GPIO_ALTERA |
| 104 | tristate "Altera GPIO" |
| 105 | depends on OF_GPIO |
Linus Walleij | 223fa27 | 2015-04-08 10:08:56 +0200 | [diff] [blame] | 106 | select GPIOLIB_IRQCHIP |
| 107 | help |
| 108 | Say Y or M here to build support for the Altera PIO device. |
| 109 | |
| 110 | If driver is built as a module it will be called gpio-altera. |
| 111 | |
YD Tseng | 6057d40f | 2015-10-19 11:07:37 +0800 | [diff] [blame] | 112 | config GPIO_AMDPT |
| 113 | tristate "AMD Promontory GPIO support" |
| 114 | depends on ACPI |
Axel Lin | 574b782 | 2016-02-29 22:00:01 +0800 | [diff] [blame] | 115 | select GPIO_GENERIC |
YD Tseng | 6057d40f | 2015-10-19 11:07:37 +0800 | [diff] [blame] | 116 | help |
| 117 | driver for GPIO functionality on Promontory IOHub |
| 118 | Require ACPI ASL code to enumerate as a platform device. |
| 119 | |
Joel Stanley | 361b791 | 2016-08-30 17:24:27 +0930 | [diff] [blame] | 120 | config GPIO_ASPEED |
| 121 | tristate "Aspeed GPIO support" |
| 122 | depends on (ARCH_ASPEED || COMPILE_TEST) && OF_GPIO |
| 123 | select GPIOLIB_IRQCHIP |
| 124 | help |
| 125 | Say Y here to support Aspeed AST2400 and AST2500 GPIO controllers. |
| 126 | |
Linus Walleij | f8b410e | 2019-09-27 13:48:33 +0200 | [diff] [blame] | 127 | config GPIO_ASPEED_SGPIO |
| 128 | bool "Aspeed SGPIO support" |
| 129 | depends on (ARCH_ASPEED || COMPILE_TEST) && OF_GPIO |
| 130 | select GPIO_GENERIC |
| 131 | select GPIOLIB_IRQCHIP |
| 132 | help |
| 133 | Say Y here to support Aspeed AST2500 SGPIO functionality. |
| 134 | |
Alban Bedel | ab32770 | 2016-01-28 20:44:29 +0100 | [diff] [blame] | 135 | config GPIO_ATH79 |
| 136 | tristate "Atheros AR71XX/AR724X/AR913X GPIO support" |
| 137 | default y if ATH79 |
Alban Bedel | 409d878 | 2016-01-28 20:44:30 +0100 | [diff] [blame] | 138 | depends on ATH79 || COMPILE_TEST |
Alban Bedel | ab32770 | 2016-01-28 20:44:29 +0100 | [diff] [blame] | 139 | select GPIO_GENERIC |
Alban Bedel | 2b8f89e | 2016-01-28 20:44:32 +0100 | [diff] [blame] | 140 | select GPIOLIB_IRQCHIP |
Alban Bedel | ab32770 | 2016-01-28 20:44:29 +0100 | [diff] [blame] | 141 | help |
| 142 | Select this option to enable GPIO driver for |
| 143 | Atheros AR71XX/AR724X/AR913X SoC devices. |
| 144 | |
Dave Stevenson | a98d90e | 2018-02-20 14:19:33 +0200 | [diff] [blame] | 145 | config GPIO_RASPBERRYPI_EXP |
| 146 | tristate "Raspberry Pi 3 GPIO Expander" |
| 147 | default RASPBERRYPI_FIRMWARE |
| 148 | depends on OF_GPIO |
Baruch Siach | 94337b7 | 2018-03-02 11:47:01 +0200 | [diff] [blame] | 149 | # Make sure not 'y' when RASPBERRYPI_FIRMWARE is 'm'. This can only |
| 150 | # happen when COMPILE_TEST=y, hence the added !RASPBERRYPI_FIRMWARE. |
Arnd Bergmann | 7ed9150 | 2018-02-28 14:48:08 +0100 | [diff] [blame] | 151 | depends on (ARCH_BCM2835 && RASPBERRYPI_FIRMWARE) || (COMPILE_TEST && !RASPBERRYPI_FIRMWARE) |
Dave Stevenson | a98d90e | 2018-02-20 14:19:33 +0200 | [diff] [blame] | 152 | help |
| 153 | Turn on GPIO support for the expander on Raspberry Pi 3 boards, using |
| 154 | the firmware mailbox to communicate with VideoCore on BCM283x chips. |
| 155 | |
Linus Walleij | ea948cf | 2015-04-08 14:36:17 +0200 | [diff] [blame] | 156 | config GPIO_BCM_KONA |
| 157 | bool "Broadcom Kona GPIO" |
| 158 | depends on OF_GPIO && (ARCH_BCM_MOBILE || COMPILE_TEST) |
| 159 | help |
| 160 | Turn on GPIO support for Broadcom "Kona" chips. |
| 161 | |
Chris Packham | 6a41b6c | 2019-10-25 09:27:03 +1300 | [diff] [blame] | 162 | config GPIO_BCM_XGS_IPROC |
| 163 | tristate "BRCM XGS iProc GPIO support" |
| 164 | depends on OF_GPIO && (ARCH_BCM_IPROC || COMPILE_TEST) |
| 165 | select GPIO_GENERIC |
| 166 | select GPIOLIB_IRQCHIP |
| 167 | default ARCH_BCM_IPROC |
| 168 | help |
| 169 | Say yes here to enable GPIO support for Broadcom XGS iProc SoCs. |
| 170 | |
Gregory Fong | 3b0213d | 2015-05-28 19:14:05 -0700 | [diff] [blame] | 171 | config GPIO_BRCMSTB |
| 172 | tristate "BRCMSTB GPIO support" |
Florian Fainelli | a02588a | 2016-01-06 10:55:23 -0800 | [diff] [blame] | 173 | default y if (ARCH_BRCMSTB || BMIPS_GENERIC) |
| 174 | depends on OF_GPIO && (ARCH_BRCMSTB || BMIPS_GENERIC || COMPILE_TEST) |
Gregory Fong | 3b0213d | 2015-05-28 19:14:05 -0700 | [diff] [blame] | 175 | select GPIO_GENERIC |
Doug Berger | 0ba31dc | 2017-10-24 12:54:50 -0700 | [diff] [blame] | 176 | select IRQ_DOMAIN |
Gregory Fong | 3b0213d | 2015-05-28 19:14:05 -0700 | [diff] [blame] | 177 | help |
| 178 | Say yes here to enable GPIO support for Broadcom STB (BCM7XXX) SoCs. |
| 179 | |
Jan Kotas | 72ab2f7 | 2018-12-18 16:10:42 +0000 | [diff] [blame] | 180 | config GPIO_CADENCE |
| 181 | tristate "Cadence GPIO support" |
| 182 | depends on OF_GPIO |
| 183 | select GPIO_GENERIC |
| 184 | select GPIOLIB_IRQCHIP |
| 185 | help |
| 186 | Say yes here to enable support for Cadence GPIO controller. |
| 187 | |
Alexander Shiyan | a3b8d4a | 2012-10-09 20:05:56 +0400 | [diff] [blame] | 188 | config GPIO_CLPS711X |
Alexander Shiyan | 55fe14a | 2013-04-26 19:47:28 +0400 | [diff] [blame] | 189 | tristate "CLPS711X GPIO support" |
Alexander Shiyan | ffd4bf1 | 2013-12-24 18:08:54 +0400 | [diff] [blame] | 190 | depends on ARCH_CLPS711X || COMPILE_TEST |
Alexander Shiyan | 55fe14a | 2013-04-26 19:47:28 +0400 | [diff] [blame] | 191 | select GPIO_GENERIC |
| 192 | help |
| 193 | Say yes here to support GPIO on CLPS711X SoCs. |
Alexander Shiyan | a3b8d4a | 2012-10-09 20:05:56 +0400 | [diff] [blame] | 194 | |
Grygorii Strashko | ee89cf6 | 2013-11-21 17:34:36 +0200 | [diff] [blame] | 195 | config GPIO_DAVINCI |
| 196 | bool "TI Davinci/Keystone GPIO support" |
| 197 | default y if ARCH_DAVINCI |
Keerthy | 6eeea32 | 2019-06-05 11:25:19 +0530 | [diff] [blame] | 198 | depends on (ARM || ARM64) && (ARCH_DAVINCI || ARCH_KEYSTONE || ARCH_K3) |
Grygorii Strashko | ee89cf6 | 2013-11-21 17:34:36 +0200 | [diff] [blame] | 199 | help |
| 200 | Say yes here to enable GPIO support for TI Davinci/Keystone SoCs. |
| 201 | |
Jamie Iles | 7779b345 | 2014-02-25 17:01:01 -0600 | [diff] [blame] | 202 | config GPIO_DWAPB |
| 203 | tristate "Synopsys DesignWare APB GPIO driver" |
| 204 | select GPIO_GENERIC |
| 205 | select GENERIC_IRQ_CHIP |
Jamie Iles | 7779b345 | 2014-02-25 17:01:01 -0600 | [diff] [blame] | 206 | help |
| 207 | Say Y or M here to build support for the Synopsys DesignWare APB |
| 208 | GPIO block. |
| 209 | |
Baolin Wang | 25518e0 | 2018-03-05 10:56:51 +0800 | [diff] [blame] | 210 | config GPIO_EIC_SPRD |
| 211 | tristate "Spreadtrum EIC support" |
| 212 | depends on ARCH_SPRD || COMPILE_TEST |
| 213 | depends on OF_GPIO |
| 214 | select GPIOLIB_IRQCHIP |
| 215 | help |
| 216 | Say yes here to support Spreadtrum EIC device. |
| 217 | |
Magnus Damm | a07e103 | 2012-05-17 15:22:23 +0900 | [diff] [blame] | 218 | config GPIO_EM |
| 219 | tristate "Emma Mobile GPIO" |
Peter Robinson | 22eaf13 | 2016-11-20 17:48:36 +0000 | [diff] [blame] | 220 | depends on (ARCH_EMEV2 || COMPILE_TEST) && OF_GPIO |
Magnus Damm | a07e103 | 2012-05-17 15:22:23 +0900 | [diff] [blame] | 221 | help |
| 222 | Say yes here to support GPIO on Renesas Emma Mobile SoCs. |
| 223 | |
H Hartley Sweeten | c6b52c1 | 2011-06-01 10:09:19 -0700 | [diff] [blame] | 224 | config GPIO_EP93XX |
| 225 | def_bool y |
| 226 | depends on ARCH_EP93XX |
H Hartley Sweeten | 1e4c884 | 2011-06-08 14:35:33 -0700 | [diff] [blame] | 227 | select GPIO_GENERIC |
Linus Walleij | a419a3d | 2018-08-22 22:41:11 +0200 | [diff] [blame] | 228 | select GPIOLIB_IRQCHIP |
H Hartley Sweeten | c6b52c1 | 2011-06-01 10:09:19 -0700 | [diff] [blame] | 229 | |
Sudip Mukherjee | 6596e59 | 2017-01-19 22:23:20 +0000 | [diff] [blame] | 230 | config GPIO_EXAR |
| 231 | tristate "Support for GPIO pins on XR17V352/354/358" |
| 232 | depends on SERIAL_8250_EXAR |
| 233 | help |
| 234 | Selecting this option will enable handling of GPIO pins present |
| 235 | on Exar XR17V352/354/358 chips. |
| 236 | |
Linus Walleij | 223fa27 | 2015-04-08 10:08:56 +0200 | [diff] [blame] | 237 | config GPIO_GE_FPGA |
| 238 | bool "GE FPGA based GPIO" |
| 239 | depends on GE_FPGA |
| 240 | select GPIO_GENERIC |
| 241 | help |
| 242 | Support for common GPIO functionality provided on some GE Single Board |
| 243 | Computers. |
| 244 | |
| 245 | This driver provides basic support (configure as input or output, read |
| 246 | and write pin state) for GPIO implemented in a number of GE single |
| 247 | board computers. |
| 248 | |
Linus Walleij | 9d3a15a | 2017-03-13 00:28:16 +0100 | [diff] [blame] | 249 | config GPIO_FTGPIO010 |
| 250 | bool "Faraday FTGPIO010 GPIO" |
Linus Walleij | 49cec4d | 2017-01-22 13:18:44 +0100 | [diff] [blame] | 251 | depends on OF_GPIO |
| 252 | select GPIO_GENERIC |
| 253 | select GPIOLIB_IRQCHIP |
Linus Walleij | d8307c0 | 2017-03-13 00:28:17 +0100 | [diff] [blame] | 254 | default (ARCH_GEMINI || ARCH_MOXART) |
Linus Walleij | 49cec4d | 2017-01-22 13:18:44 +0100 | [diff] [blame] | 255 | help |
Linus Walleij | 9d3a15a | 2017-03-13 00:28:16 +0100 | [diff] [blame] | 256 | Support for common GPIOs from the Faraday FTGPIO010 IP core, found in |
| 257 | Cortina systems Gemini platforms, Moxa ART and others. |
Linus Walleij | 49cec4d | 2017-01-22 13:18:44 +0100 | [diff] [blame] | 258 | |
Linus Walleij | 223fa27 | 2015-04-08 10:08:56 +0200 | [diff] [blame] | 259 | config GPIO_GENERIC_PLATFORM |
| 260 | tristate "Generic memory-mapped GPIO controller support (MMIO platform device)" |
| 261 | select GPIO_GENERIC |
| 262 | help |
| 263 | Say yes here to support basic platform_device memory-mapped GPIO controllers. |
| 264 | |
| 265 | config GPIO_GRGPIO |
| 266 | tristate "Aeroflex Gaisler GRGPIO support" |
Linus Walleij | 048c28c | 2016-08-16 12:07:31 +0200 | [diff] [blame] | 267 | depends on OF_GPIO |
Linus Walleij | 223fa27 | 2015-04-08 10:08:56 +0200 | [diff] [blame] | 268 | select GPIO_GENERIC |
| 269 | select IRQ_DOMAIN |
| 270 | help |
| 271 | Select this to support Aeroflex Gaisler GRGPIO cores from the GRLIB |
| 272 | VHDL IP core library. |
| 273 | |
Jonathan Neuschäfer | 8f55fed | 2018-02-09 13:07:29 +0100 | [diff] [blame] | 274 | config GPIO_HLWD |
| 275 | tristate "Nintendo Wii (Hollywood) GPIO" |
| 276 | depends on OF_GPIO |
| 277 | select GPIO_GENERIC |
Jonathan Neuschäfer | 588de43c | 2019-01-14 20:14:49 +0100 | [diff] [blame] | 278 | select GPIOLIB_IRQCHIP |
Jonathan Neuschäfer | 8f55fed | 2018-02-09 13:07:29 +0100 | [diff] [blame] | 279 | help |
| 280 | Select this to support the GPIO controller of the Nintendo Wii. |
| 281 | |
| 282 | If unsure, say N. |
| 283 | |
Linus Walleij | 223fa27 | 2015-04-08 10:08:56 +0200 | [diff] [blame] | 284 | config GPIO_ICH |
| 285 | tristate "Intel ICH GPIO" |
| 286 | depends on PCI && X86 |
| 287 | select MFD_CORE |
| 288 | select LPC_ICH |
| 289 | help |
| 290 | Say yes here to support the GPIO functionality of a number of Intel |
| 291 | ICH-based chipsets. Currently supported devices: ICH6, ICH7, ICH8 |
| 292 | ICH9, ICH10, Series 5/3400 (eg Ibex Peak), Series 6/C200 (eg |
| 293 | Cougar Point), NM10 (Tiger Point), and 3100 (Whitmore Lake). |
| 294 | |
| 295 | If unsure, say N. |
| 296 | |
| 297 | config GPIO_IOP |
| 298 | tristate "Intel IOP GPIO" |
Arnd Bergmann | 59d3ae9 | 2019-08-09 18:33:15 +0200 | [diff] [blame] | 299 | depends on ARCH_IOP32X || COMPILE_TEST |
Alexander Shiyan | 6d12541 | 2016-09-09 09:20:03 +0300 | [diff] [blame] | 300 | select GPIO_GENERIC |
Linus Walleij | 223fa27 | 2015-04-08 10:08:56 +0200 | [diff] [blame] | 301 | help |
| 302 | Say yes here to support the GPIO functionality of a number of Intel |
| 303 | IOP32X or IOP33X. |
| 304 | |
| 305 | If unsure, say N. |
| 306 | |
Linus Walleij | 813e7d3 | 2019-01-25 21:59:11 +0100 | [diff] [blame] | 307 | config GPIO_IXP4XX |
| 308 | bool "Intel IXP4xx GPIO" |
| 309 | depends on ARM # For <asm/mach-types.h> |
| 310 | depends on ARCH_IXP4XX |
| 311 | select GPIO_GENERIC |
Linus Walleij | aa7d618 | 2019-08-08 14:32:38 +0200 | [diff] [blame] | 312 | select GPIOLIB_IRQCHIP |
Linus Walleij | 813e7d3 | 2019-01-25 21:59:11 +0100 | [diff] [blame] | 313 | select IRQ_DOMAIN_HIERARCHY |
| 314 | help |
| 315 | Say yes here to support the GPIO functionality of a number of Intel |
| 316 | IXP4xx series of chips. |
| 317 | |
| 318 | If unsure, say N. |
Paul Kocialkowski | c16485a | 2019-12-03 15:12:43 +0100 | [diff] [blame] | 319 | config GPIO_LOGICVC |
| 320 | tristate "Xylon LogiCVC GPIO support" |
| 321 | depends on MFD_SYSCON && OF |
| 322 | help |
| 323 | Say yes here to support GPIO functionality of the Xylon LogiCVC |
| 324 | programmable logic block. |
Linus Walleij | 813e7d3 | 2019-01-25 21:59:11 +0100 | [diff] [blame] | 325 | |
Linus Walleij | 223fa27 | 2015-04-08 10:08:56 +0200 | [diff] [blame] | 326 | config GPIO_LOONGSON |
| 327 | bool "Loongson-2/3 GPIO support" |
Jiaxun Yang | 268a2d6 | 2019-10-20 22:43:13 +0800 | [diff] [blame] | 328 | depends on CPU_LOONGSON2EF || CPU_LOONGSON64 |
Linus Walleij | 223fa27 | 2015-04-08 10:08:56 +0200 | [diff] [blame] | 329 | help |
| 330 | driver for GPIO functionality on Loongson-2F/3A/3B processors. |
| 331 | |
Joachim Eastwood | 13a43fd | 2015-05-02 23:11:34 +0200 | [diff] [blame] | 332 | config GPIO_LPC18XX |
Paul Gortmaker | 54b7299 | 2016-06-05 14:23:43 -0400 | [diff] [blame] | 333 | tristate "NXP LPC18XX/43XX GPIO support" |
Joachim Eastwood | 13a43fd | 2015-05-02 23:11:34 +0200 | [diff] [blame] | 334 | default y if ARCH_LPC18XX |
| 335 | depends on OF_GPIO && (ARCH_LPC18XX || COMPILE_TEST) |
Vladimir Zapolskiy | 5ddabfe | 2018-11-29 00:48:41 +0200 | [diff] [blame] | 336 | select IRQ_DOMAIN_HIERARCHY |
Joachim Eastwood | 13a43fd | 2015-05-02 23:11:34 +0200 | [diff] [blame] | 337 | help |
| 338 | Select this option to enable GPIO driver for |
| 339 | NXP LPC18XX/43XX devices. |
| 340 | |
Arnd Bergmann | f2ee731 | 2019-08-09 16:40:31 +0200 | [diff] [blame] | 341 | config GPIO_LPC32XX |
| 342 | tristate "NXP LPC32XX GPIO support" |
| 343 | depends on OF_GPIO && (ARCH_LPC32XX || COMPILE_TEST) |
| 344 | help |
| 345 | Select this option to enable GPIO driver for |
| 346 | NXP LPC32XX devices. |
| 347 | |
Jassi Brar | 0da094d | 2015-01-19 18:35:53 +0800 | [diff] [blame] | 348 | config GPIO_MB86S7X |
Ard Biesheuvel | e1289db | 2017-10-27 21:21:47 +0100 | [diff] [blame] | 349 | tristate "GPIO support for Fujitsu MB86S7x Platforms" |
Jassi Brar | 0da094d | 2015-01-19 18:35:53 +0800 | [diff] [blame] | 350 | help |
| 351 | Say yes here to support the GPIO controller in Fujitsu MB86S70 SoCs. |
Fabian Vogt | 9af4d80 | 2014-02-24 20:54:58 +0100 | [diff] [blame] | 352 | |
Andreas Werner | f436bc2 | 2016-02-29 19:44:43 +0100 | [diff] [blame] | 353 | config GPIO_MENZ127 |
| 354 | tristate "MEN 16Z127 GPIO support" |
| 355 | depends on MCB |
| 356 | select GPIO_GENERIC |
| 357 | help |
Enrico Weigelt, metux IT consult | c42e34c | 2019-03-05 01:35:31 +0100 | [diff] [blame] | 358 | Say yes here to support the MEN 16Z127 GPIO Controller |
Andreas Werner | f436bc2 | 2016-02-29 19:44:43 +0100 | [diff] [blame] | 359 | |
John Crispin | 5238f7b | 2012-05-11 18:48:39 +0200 | [diff] [blame] | 360 | config GPIO_MM_LANTIQ |
| 361 | bool "Lantiq Memory mapped GPIOs" |
| 362 | depends on LANTIQ && SOC_XWAY |
| 363 | help |
| 364 | This enables support for memory mapped GPIOs on the External Bus Unit |
| 365 | (EBU) found on Lantiq SoCs. The gpios are output only as they are |
| 366 | created by attaching a 16bit latch to the bus. |
| 367 | |
Grant Likely | 6eae1ac | 2011-07-06 11:54:19 -0600 | [diff] [blame] | 368 | config GPIO_MPC5200 |
| 369 | def_bool y |
| 370 | depends on PPC_MPC52xx |
| 371 | |
Wolfram Sang | c68308d | 2011-09-21 12:49:20 +0200 | [diff] [blame] | 372 | config GPIO_MPC8XXX |
Liu Gang | 5df7fd4 | 2016-01-12 20:10:09 +0800 | [diff] [blame] | 373 | bool "MPC512x/MPC8xxx/QorIQ GPIO support" |
Wolfram Sang | c68308d | 2011-09-21 12:49:20 +0200 | [diff] [blame] | 374 | depends on PPC_MPC512x || PPC_MPC831x || PPC_MPC834x || PPC_MPC837x || \ |
Liu Gang | 5df7fd4 | 2016-01-12 20:10:09 +0800 | [diff] [blame] | 375 | FSL_SOC_BOOKE || PPC_86xx || ARCH_LAYERSCAPE || ARM || \ |
| 376 | COMPILE_TEST |
| 377 | select GPIO_GENERIC |
Arnd Bergmann | a8fa91a | 2016-04-19 14:10:08 +0200 | [diff] [blame] | 378 | select IRQ_DOMAIN |
Wolfram Sang | c68308d | 2011-09-21 12:49:20 +0200 | [diff] [blame] | 379 | help |
| 380 | Say Y here if you're going to use hardware that connects to the |
Liu Gang | 5df7fd4 | 2016-01-12 20:10:09 +0800 | [diff] [blame] | 381 | MPC512x/831x/834x/837x/8572/8610/QorIQ GPIOs. |
Wolfram Sang | c68308d | 2011-09-21 12:49:20 +0200 | [diff] [blame] | 382 | |
Sergio Paracuellos | 4ba9c3a | 2018-07-05 15:43:10 +0200 | [diff] [blame] | 383 | config GPIO_MT7621 |
| 384 | bool "Mediatek MT7621 GPIO Support" |
| 385 | depends on SOC_MT7620 || SOC_MT7621 || COMPILE_TEST |
Arnd Bergmann | 7a9a5df | 2018-07-10 17:18:47 +0200 | [diff] [blame] | 386 | depends on OF_GPIO |
Sergio Paracuellos | 4ba9c3a | 2018-07-05 15:43:10 +0200 | [diff] [blame] | 387 | select GPIO_GENERIC |
| 388 | select GPIOLIB_IRQCHIP |
| 389 | help |
| 390 | Say yes here to support the Mediatek MT7621 SoC GPIO device |
| 391 | |
Thomas Petazzoni | fefe7b0 | 2012-09-19 22:52:58 +0200 | [diff] [blame] | 392 | config GPIO_MVEBU |
| 393 | def_bool y |
Gregory CLEMENT | 3b4c94b | 2017-05-19 18:09:23 +0200 | [diff] [blame] | 394 | depends on PLAT_ORION || ARCH_MVEBU |
Linus Walleij | 048c28c | 2016-08-16 12:07:31 +0200 | [diff] [blame] | 395 | depends on OF_GPIO |
Thomas Petazzoni | fefe7b0 | 2012-09-19 22:52:58 +0200 | [diff] [blame] | 396 | select GENERIC_IRQ_CHIP |
Gregory CLEMENT | f37e335 | 2017-05-24 16:32:06 +0200 | [diff] [blame] | 397 | select REGMAP_MMIO |
Thomas Petazzoni | fefe7b0 | 2012-09-19 22:52:58 +0200 | [diff] [blame] | 398 | |
Shawn Guo | d37a65b | 2011-06-06 00:07:54 +0800 | [diff] [blame] | 399 | config GPIO_MXC |
| 400 | def_bool y |
Anson Huang | d4e9361 | 2020-03-07 21:31:57 +0800 | [diff] [blame] | 401 | depends on ARCH_MXC || COMPILE_TEST |
Grant Likely | c103de2 | 2011-06-04 18:38:28 -0600 | [diff] [blame] | 402 | select GPIO_GENERIC |
Shawn Guo | e4ea933 | 2011-06-07 16:25:37 +0800 | [diff] [blame] | 403 | select GENERIC_IRQ_CHIP |
Grant Likely | c103de2 | 2011-06-04 18:38:28 -0600 | [diff] [blame] | 404 | |
| 405 | config GPIO_MXS |
| 406 | def_bool y |
Anson Huang | 6876ca3 | 2020-03-09 09:57:38 +0800 | [diff] [blame] | 407 | depends on ARCH_MXS || COMPILE_TEST |
Shawn Guo | 06f88a8 | 2011-06-06 22:31:29 +0800 | [diff] [blame] | 408 | select GPIO_GENERIC |
Shawn Guo | 498c17c | 2011-06-07 22:00:54 +0800 | [diff] [blame] | 409 | select GENERIC_IRQ_CHIP |
Shawn Guo | d37a65b | 2011-06-06 00:07:54 +0800 | [diff] [blame] | 410 | |
David Daney | aca58a6 | 2013-07-29 14:29:10 -0700 | [diff] [blame] | 411 | config GPIO_OCTEON |
| 412 | tristate "Cavium OCTEON GPIO" |
Geert Uytterhoeven | e4c6a52 | 2020-06-23 16:40:01 +0200 | [diff] [blame^] | 413 | depends on CAVIUM_OCTEON_SOC |
David Daney | aca58a6 | 2013-07-29 14:29:10 -0700 | [diff] [blame] | 414 | default y |
| 415 | help |
| 416 | Say yes here to support the on-chip GPIO lines on the OCTEON |
| 417 | family of SOCs. |
| 418 | |
Javier Martinez Canillas | cd0a374 | 2014-04-06 16:58:15 +0200 | [diff] [blame] | 419 | config GPIO_OMAP |
Tony Lindgren | cac089f | 2015-04-23 16:56:22 -0700 | [diff] [blame] | 420 | tristate "TI OMAP GPIO support" if ARCH_OMAP2PLUS || COMPILE_TEST |
Javier Martinez Canillas | cd0a374 | 2014-04-06 16:58:15 +0200 | [diff] [blame] | 421 | default y if ARCH_OMAP |
Arnd Bergmann | 9d5d96e | 2014-04-28 11:07:03 +0200 | [diff] [blame] | 422 | depends on ARM |
| 423 | select GENERIC_IRQ_CHIP |
Javier Martinez Canillas | fb655f5 | 2014-04-06 16:58:16 +0200 | [diff] [blame] | 424 | select GPIOLIB_IRQCHIP |
Javier Martinez Canillas | cd0a374 | 2014-04-06 16:58:15 +0200 | [diff] [blame] | 425 | help |
| 426 | Say yes here to enable GPIO support for TI OMAP SoCs. |
| 427 | |
Baruch Siach | 1e9c285 | 2009-06-18 16:48:58 -0700 | [diff] [blame] | 428 | config GPIO_PL061 |
Rob Herring | 6168444 | 2020-04-08 19:41:10 -0600 | [diff] [blame] | 429 | tristate "PrimeCell PL061 GPIO support" |
Rob Herring | 8a24284 | 2013-11-05 21:27:02 -0600 | [diff] [blame] | 430 | depends on ARM_AMBA |
Axel Lin | a5d6d27 | 2014-02-04 20:39:01 +0800 | [diff] [blame] | 431 | select IRQ_DOMAIN |
Linus Walleij | 8d5b24b | 2014-03-25 10:42:35 +0100 | [diff] [blame] | 432 | select GPIOLIB_IRQCHIP |
Baruch Siach | 1e9c285 | 2009-06-18 16:48:58 -0700 | [diff] [blame] | 433 | help |
| 434 | Say yes here to support the PrimeCell PL061 GPIO device |
| 435 | |
Baolin Wang | 348f3cd | 2018-03-05 10:56:52 +0800 | [diff] [blame] | 436 | config GPIO_PMIC_EIC_SPRD |
| 437 | tristate "Spreadtrum PMIC EIC support" |
| 438 | depends on MFD_SC27XX_PMIC || COMPILE_TEST |
| 439 | depends on OF_GPIO |
| 440 | select GPIOLIB_IRQCHIP |
| 441 | help |
| 442 | Say yes here to support Spreadtrum PMIC EIC device. |
| 443 | |
Haojian Zhuang | 157d264 | 2011-10-17 20:37:52 +0800 | [diff] [blame] | 444 | config GPIO_PXA |
| 445 | bool "PXA GPIO support" |
Tiezhu Yang | 22e4ebd | 2020-05-22 12:12:20 +0800 | [diff] [blame] | 446 | depends on ARCH_PXA || ARCH_MMP || COMPILE_TEST |
Haojian Zhuang | 157d264 | 2011-10-17 20:37:52 +0800 | [diff] [blame] | 447 | help |
| 448 | Say yes here to support the PXA GPIO device |
| 449 | |
Magnus Damm | 119f5e4 | 2013-03-13 20:32:13 +0900 | [diff] [blame] | 450 | config GPIO_RCAR |
| 451 | tristate "Renesas R-Car GPIO" |
Simon Horman | 2af66e1 | 2016-02-23 10:36:51 +0900 | [diff] [blame] | 452 | depends on ARCH_RENESAS || COMPILE_TEST |
Geert Uytterhoeven | c7f3c5d | 2015-01-12 11:07:59 +0100 | [diff] [blame] | 453 | select GPIOLIB_IRQCHIP |
Magnus Damm | 119f5e4 | 2013-03-13 20:32:13 +0900 | [diff] [blame] | 454 | help |
| 455 | Say yes here to support GPIO on Renesas R-Car SoCs. |
| 456 | |
Manivannan Sadhasivam | d57eb82 | 2019-10-21 12:14:12 +0530 | [diff] [blame] | 457 | config GPIO_RDA |
| 458 | bool "RDA Micro GPIO controller support" |
| 459 | depends on ARCH_RDA || COMPILE_TEST |
| 460 | depends on OF_GPIO |
| 461 | select GPIO_GENERIC |
| 462 | select GPIOLIB_IRQCHIP |
| 463 | help |
| 464 | Say Y here to support RDA Micro GPIO controller. |
| 465 | |
Russell King | 380639c | 2016-08-31 08:49:44 +0100 | [diff] [blame] | 466 | config GPIO_REG |
| 467 | bool |
| 468 | help |
| 469 | A 32-bit single register GPIO fixed in/out implementation. This |
| 470 | can be used to represent any register as a set of GPIO signals. |
| 471 | |
Andrei.Stefanescu@microchip.com | fb0b35d | 2018-12-12 11:57:15 +0000 | [diff] [blame] | 472 | config GPIO_SAMA5D2_PIOBU |
| 473 | tristate "SAMA5D2 PIOBU GPIO support" |
| 474 | depends on MFD_SYSCON |
Linus Walleij | a7c23f8 | 2018-12-22 11:04:55 +0100 | [diff] [blame] | 475 | depends on OF_GPIO |
Andrei.Stefanescu@microchip.com | fb0b35d | 2018-12-12 11:57:15 +0000 | [diff] [blame] | 476 | select GPIO_SYSCON |
| 477 | help |
| 478 | Say yes here to use the PIOBU pins as GPIOs. |
| 479 | |
| 480 | PIOBU pins on the SAMA5D2 can be used as GPIOs. |
| 481 | The difference from regular GPIOs is that they |
| 482 | maintain their value during backup/self-refresh. |
| 483 | |
Yash Shah | 96868dc | 2019-12-10 16:41:13 +0530 | [diff] [blame] | 484 | config GPIO_SIFIVE |
| 485 | bool "SiFive GPIO support" |
| 486 | depends on OF_GPIO && IRQ_DOMAIN_HIERARCHY |
| 487 | select GPIO_GENERIC |
| 488 | select GPIOLIB_IRQCHIP |
| 489 | select REGMAP_MMIO |
| 490 | help |
| 491 | Say yes here to support the GPIO device on SiFive SoCs. |
| 492 | |
Uwe Kleine-König | be8c8fa | 2018-09-27 09:48:08 +0200 | [diff] [blame] | 493 | config GPIO_SIOX |
| 494 | tristate "SIOX GPIO support" |
| 495 | depends on SIOX |
| 496 | select GPIOLIB_IRQCHIP |
| 497 | help |
| 498 | Say yes here to support SIOX I/O devices. These are units connected |
| 499 | via a SIOX bus and have a number of fixed-direction I/O lines. |
| 500 | |
Eugeniy Paltsev | 2505c7b | 2018-09-28 16:15:30 +0300 | [diff] [blame] | 501 | config GPIO_SNPS_CREG |
| 502 | bool "Synopsys GPIO via CREG (Control REGisters) driver" |
| 503 | depends on ARC || COMPILE_TEST |
Randy Dunlap | a7c0b4b | 2018-10-12 20:46:29 -0700 | [diff] [blame] | 504 | depends on OF_GPIO |
Eugeniy Paltsev | 2505c7b | 2018-09-28 16:15:30 +0300 | [diff] [blame] | 505 | help |
| 506 | This driver supports GPIOs via CREG on various Synopsys SoCs. |
| 507 | This is a single-register MMIO GPIO driver for complex cases |
| 508 | where only several fields in register belong to GPIO lines and |
| 509 | each GPIO line owns a field with different length and on/off value. |
| 510 | |
Shiraz Hashim | b53bc28 | 2012-11-16 10:45:25 +0530 | [diff] [blame] | 511 | config GPIO_SPEAR_SPICS |
| 512 | bool "ST SPEAr13xx SPI Chip Select as GPIO support" |
| 513 | depends on PLAT_SPEAR |
| 514 | select GENERIC_IRQ_CHIP |
| 515 | help |
| 516 | Say yes here to support ST SPEAr SPI Chip Select as GPIO device |
| 517 | |
Baolin Wang | 9a3821c | 2018-02-24 10:07:18 +0800 | [diff] [blame] | 518 | config GPIO_SPRD |
| 519 | tristate "Spreadtrum GPIO support" |
| 520 | depends on ARCH_SPRD || COMPILE_TEST |
| 521 | depends on OF_GPIO |
| 522 | select GPIOLIB_IRQCHIP |
| 523 | help |
| 524 | Say yes here to support Spreadtrum GPIO device. |
| 525 | |
Alessandro Rubini | 7b0d44f3 | 2012-04-12 10:48:55 +0200 | [diff] [blame] | 526 | config GPIO_STA2X11 |
| 527 | bool "STA2x11/ConneXt GPIO support" |
| 528 | depends on MFD_STA2X11 |
| 529 | select GENERIC_IRQ_CHIP |
| 530 | help |
| 531 | Say yes here to support the STA2x11/ConneXt GPIO device. |
| 532 | The GPIO module has 128 GPIO pins with alternate functions. |
| 533 | |
Linus Walleij | be9cab5 | 2015-04-08 14:51:23 +0200 | [diff] [blame] | 534 | config GPIO_STP_XWAY |
| 535 | bool "XWAY STP GPIOs" |
Martin Blumenstingl | 5099837 | 2019-07-03 00:32:48 +0200 | [diff] [blame] | 536 | depends on SOC_XWAY || COMPILE_TEST |
| 537 | depends on OF_GPIO |
Linus Walleij | be9cab5 | 2015-04-08 14:51:23 +0200 | [diff] [blame] | 538 | help |
| 539 | This enables support for the Serial To Parallel (STP) unit found on |
| 540 | XWAY SoC. The STP allows the SoC to drive a shift registers cascade, |
| 541 | that can be up to 24 bit. This peripheral is aimed at driving leds. |
| 542 | Some of the gpios/leds can be auto updated by the soc with dsl and |
| 543 | phy status. |
| 544 | |
Alexander Shiyan | 6a8a0c1 | 2014-03-11 21:55:14 +0400 | [diff] [blame] | 545 | config GPIO_SYSCON |
| 546 | tristate "GPIO based on SYSCON" |
| 547 | depends on MFD_SYSCON && OF |
| 548 | help |
| 549 | Say yes here to support GPIO functionality though SYSCON driver. |
| 550 | |
Linus Walleij | 223fa27 | 2015-04-08 10:08:56 +0200 | [diff] [blame] | 551 | config GPIO_TB10X |
| 552 | bool |
Linus Walleij | 0d1e31a | 2018-08-06 16:59:42 +0200 | [diff] [blame] | 553 | select GPIO_GENERIC |
Linus Walleij | 223fa27 | 2015-04-08 10:08:56 +0200 | [diff] [blame] | 554 | select GENERIC_IRQ_CHIP |
| 555 | select OF_GPIO |
| 556 | |
Alexander Stein | 4dd4dd1 | 2016-02-24 20:54:32 +0100 | [diff] [blame] | 557 | config GPIO_TEGRA |
Arnd Bergmann | 0bfb85c | 2016-07-06 14:54:03 +0200 | [diff] [blame] | 558 | bool "NVIDIA Tegra GPIO support" |
| 559 | default ARCH_TEGRA |
Alexander Stein | 4dd4dd1 | 2016-02-24 20:54:32 +0100 | [diff] [blame] | 560 | depends on ARCH_TEGRA || COMPILE_TEST |
Linus Walleij | 048c28c | 2016-08-16 12:07:31 +0200 | [diff] [blame] | 561 | depends on OF_GPIO |
Arnd Bergmann | 0bfb85c | 2016-07-06 14:54:03 +0200 | [diff] [blame] | 562 | help |
| 563 | Say yes here to support GPIO pins on NVIDIA Tegra SoCs. |
Alexander Stein | 4dd4dd1 | 2016-02-24 20:54:32 +0100 | [diff] [blame] | 564 | |
Thierry Reding | 5b2b135 | 2017-11-07 19:15:56 +0100 | [diff] [blame] | 565 | config GPIO_TEGRA186 |
| 566 | tristate "NVIDIA Tegra186 GPIO support" |
Thierry Reding | 286e7be | 2019-12-13 14:00:34 +0100 | [diff] [blame] | 567 | default ARCH_TEGRA_186_SOC || ARCH_TEGRA_194_SOC |
| 568 | depends on ARCH_TEGRA_186_SOC || ARCH_TEGRA_194_SOC || COMPILE_TEST |
Thierry Reding | 5b2b135 | 2017-11-07 19:15:56 +0100 | [diff] [blame] | 569 | depends on OF_GPIO |
| 570 | select GPIOLIB_IRQCHIP |
Thierry Reding | 2a36550 | 2019-10-02 16:45:02 +0200 | [diff] [blame] | 571 | select IRQ_DOMAIN_HIERARCHY |
Thierry Reding | 5b2b135 | 2017-11-07 19:15:56 +0100 | [diff] [blame] | 572 | help |
| 573 | Say yes here to support GPIO pins on NVIDIA Tegra186 SoCs. |
| 574 | |
Julien Grossholtz | 5041e79 | 2016-01-13 11:57:43 -0500 | [diff] [blame] | 575 | config GPIO_TS4800 |
| 576 | tristate "TS-4800 DIO blocks and compatibles" |
| 577 | depends on OF_GPIO |
Julien Grossholtz | 6dcfd72 | 2016-02-26 18:06:59 -0500 | [diff] [blame] | 578 | depends on SOC_IMX51 || COMPILE_TEST |
Julien Grossholtz | 5041e79 | 2016-01-13 11:57:43 -0500 | [diff] [blame] | 579 | select GPIO_GENERIC |
| 580 | help |
| 581 | This driver support TS-4800 FPGA GPIO controllers. |
| 582 | |
David Daney | 5a2a300 | 2017-08-17 17:53:35 -0700 | [diff] [blame] | 583 | config GPIO_THUNDERX |
| 584 | tristate "Cavium ThunderX/OCTEON-TX GPIO" |
| 585 | depends on ARCH_THUNDER || (64BIT && COMPILE_TEST) |
Masahiro Yamada | 311de3c | 2017-09-06 10:40:52 +0900 | [diff] [blame] | 586 | depends on PCI_MSI |
Linus Walleij | a7fc89f | 2019-08-08 14:32:40 +0200 | [diff] [blame] | 587 | select GPIOLIB_IRQCHIP |
Masahiro Yamada | 311de3c | 2017-09-06 10:40:52 +0900 | [diff] [blame] | 588 | select IRQ_DOMAIN_HIERARCHY |
David Daney | 5a2a300 | 2017-08-17 17:53:35 -0700 | [diff] [blame] | 589 | select IRQ_FASTEOI_HIERARCHY_HANDLERS |
| 590 | help |
| 591 | Say yes here to support the on-chip GPIO lines on the ThunderX |
| 592 | and OCTEON-TX families of SoCs. |
| 593 | |
Masahiro Yamada | dbe776c | 2017-10-12 20:36:16 +0900 | [diff] [blame] | 594 | config GPIO_UNIPHIER |
| 595 | tristate "UniPhier GPIO support" |
| 596 | depends on ARCH_UNIPHIER || COMPILE_TEST |
| 597 | depends on OF_GPIO |
| 598 | select IRQ_DOMAIN_HIERARCHY |
| 599 | help |
| 600 | Say yes here to support UniPhier GPIOs. |
| 601 | |
Stefan Agner | 7f2691a | 2014-10-16 21:47:58 +0200 | [diff] [blame] | 602 | config GPIO_VF610 |
| 603 | def_bool y |
| 604 | depends on ARCH_MXC && SOC_VF610 |
| 605 | select GPIOLIB_IRQCHIP |
| 606 | help |
| 607 | Say yes here to support Vybrid vf610 GPIOs. |
| 608 | |
Linus Walleij | 223fa27 | 2015-04-08 10:08:56 +0200 | [diff] [blame] | 609 | config GPIO_VR41XX |
| 610 | tristate "NEC VR4100 series General-purpose I/O Uint support" |
| 611 | depends on CPU_VR41XX |
| 612 | help |
| 613 | Say yes here to support the NEC VR4100 series General-purpose I/O Uint |
| 614 | |
| 615 | config GPIO_VX855 |
| 616 | tristate "VIA VX855/VX875 GPIO" |
Peter Robinson | 72aba2e | 2016-11-20 17:37:25 +0000 | [diff] [blame] | 617 | depends on (X86 || COMPILE_TEST) && PCI |
Linus Walleij | 223fa27 | 2015-04-08 10:08:56 +0200 | [diff] [blame] | 618 | select MFD_CORE |
| 619 | select MFD_VX855 |
| 620 | help |
| 621 | Support access to the VX855/VX875 GPIO lines through the gpio library. |
| 622 | |
| 623 | This driver provides common support for accessing the device, |
| 624 | additional drivers must be enabled in order to use the |
| 625 | functionality of the device. |
| 626 | |
Srinivas Kandagatla | 59c32468 | 2020-01-07 13:08:44 +0000 | [diff] [blame] | 627 | config GPIO_WCD934X |
| 628 | tristate "Qualcomm Technologies Inc WCD9340/WCD9341 gpio controller driver" |
| 629 | depends on MFD_WCD934X && OF_GPIO |
| 630 | help |
| 631 | This driver is to supprot GPIO block found on the Qualcomm Technologies |
| 632 | Inc WCD9340/WCD9341 Audio Codec. |
| 633 | |
Feng Kan | 29cbf45 | 2014-07-31 12:03:25 -0700 | [diff] [blame] | 634 | config GPIO_XGENE |
| 635 | bool "APM X-Gene GPIO controller support" |
| 636 | depends on ARM64 && OF_GPIO |
| 637 | help |
| 638 | This driver is to support the GPIO block within the APM X-Gene SoC |
| 639 | platform's generic flash controller. The GPIO pins are muxed with |
| 640 | the generic flash controller's address and data pins. Say yes |
| 641 | here to enable the GFC GPIO functionality. |
| 642 | |
Y Vo | b2b35e1 | 2015-01-16 14:34:19 +0700 | [diff] [blame] | 643 | config GPIO_XGENE_SB |
| 644 | tristate "APM X-Gene GPIO standby controller support" |
Andy Shevchenko | b24bc58 | 2020-05-12 21:27:20 +0300 | [diff] [blame] | 645 | depends on (ARCH_XGENE || COMPILE_TEST) |
Y Vo | b2b35e1 | 2015-01-16 14:34:19 +0700 | [diff] [blame] | 646 | select GPIO_GENERIC |
Matthias Brugger | e5f7e31 | 2016-03-04 11:59:58 +0100 | [diff] [blame] | 647 | select GPIOLIB_IRQCHIP |
Masahiro Yamada | c23d200 | 2017-07-12 08:11:50 +0900 | [diff] [blame] | 648 | select IRQ_DOMAIN_HIERARCHY |
Y Vo | b2b35e1 | 2015-01-16 14:34:19 +0700 | [diff] [blame] | 649 | help |
| 650 | This driver supports the GPIO block within the APM X-Gene |
| 651 | Standby Domain. Say yes here to enable the GPIO functionality. |
| 652 | |
John Linn | 0bcb606 | 2008-11-12 13:25:38 -0800 | [diff] [blame] | 653 | config GPIO_XILINX |
Ricardo Ribalda Delgado | c54c58b | 2014-12-17 16:51:10 +0100 | [diff] [blame] | 654 | tristate "Xilinx GPIO support" |
John Linn | 0bcb606 | 2008-11-12 13:25:38 -0800 | [diff] [blame] | 655 | help |
| 656 | Say yes here to support the Xilinx FPGA GPIO device |
| 657 | |
Kamlakant Patel | ff71880 | 2015-04-28 20:10:45 +0530 | [diff] [blame] | 658 | config GPIO_XLP |
| 659 | tristate "Netlogic XLP GPIO support" |
Jayachandran C | 240d3d5 | 2017-05-22 08:58:31 +0000 | [diff] [blame] | 660 | depends on OF_GPIO && (CPU_XLP || ARCH_THUNDER2 || COMPILE_TEST) |
Kamlakant Patel | ff71880 | 2015-04-28 20:10:45 +0530 | [diff] [blame] | 661 | select GPIOLIB_IRQCHIP |
| 662 | help |
| 663 | This driver provides support for GPIO interface on Netlogic XLP MIPS64 |
| 664 | SoCs. Currently supported XLP variants are XLP8XX, XLP3XX, XLP2XX, |
Jayachandran C | 240d3d5 | 2017-05-22 08:58:31 +0000 | [diff] [blame] | 665 | XLP9XX and XLP5XX. The same GPIO controller block is also present in |
| 666 | Cavium's ThunderX2 CN99XX SoCs. |
Kamlakant Patel | ff71880 | 2015-04-28 20:10:45 +0530 | [diff] [blame] | 667 | |
| 668 | If unsure, say N. |
| 669 | |
Baruch Siach | 3b31d0e | 2013-12-12 11:18:41 +0200 | [diff] [blame] | 670 | config GPIO_XTENSA |
| 671 | bool "Xtensa GPIO32 support" |
| 672 | depends on XTENSA |
Baruch Siach | a1a2bde | 2013-12-18 09:10:29 +0200 | [diff] [blame] | 673 | depends on HAVE_XTENSA_GPIO32 |
Baruch Siach | 3b31d0e | 2013-12-12 11:18:41 +0200 | [diff] [blame] | 674 | depends on !SMP |
| 675 | help |
| 676 | Say yes here to support the Xtensa internal GPIO32 IMPWIRE (input) |
| 677 | and EXPSTATE (output) ports |
| 678 | |
Linus Walleij | 223fa27 | 2015-04-08 10:08:56 +0200 | [diff] [blame] | 679 | config GPIO_ZEVIO |
| 680 | bool "LSI ZEVIO SoC memory mapped GPIOs" |
| 681 | depends on ARM && OF_GPIO |
Yoichi Yuasa | 27fdd32 | 2009-06-29 11:11:05 +0900 | [diff] [blame] | 682 | help |
Linus Walleij | 223fa27 | 2015-04-08 10:08:56 +0200 | [diff] [blame] | 683 | Say yes here to support the GPIO controller in LSI ZEVIO SoCs. |
Yoichi Yuasa | 27fdd32 | 2009-06-29 11:11:05 +0900 | [diff] [blame] | 684 | |
Linus Walleij | 223fa27 | 2015-04-08 10:08:56 +0200 | [diff] [blame] | 685 | config GPIO_ZYNQ |
| 686 | tristate "Xilinx Zynq GPIO support" |
Anurag Kumar Vulisha | bdf7a4a | 2015-06-04 17:40:32 +0530 | [diff] [blame] | 687 | depends on ARCH_ZYNQ || ARCH_ZYNQMP |
Mika Westerberg | 7f87210 | 2014-07-25 09:54:46 +0300 | [diff] [blame] | 688 | select GPIOLIB_IRQCHIP |
Mathias Nyman | 1d09aaa | 2012-12-12 17:42:38 +0200 | [diff] [blame] | 689 | help |
Linus Walleij | 223fa27 | 2015-04-08 10:08:56 +0200 | [diff] [blame] | 690 | Say yes here to support Xilinx Zynq GPIO controller. |
Mathias Nyman | 1d09aaa | 2012-12-12 17:42:38 +0200 | [diff] [blame] | 691 | |
Linus Walleij | 0963670 | 2015-11-01 10:50:19 +0100 | [diff] [blame] | 692 | config GPIO_ZX |
| 693 | bool "ZTE ZX GPIO support" |
Peter Robinson | 752fda8 | 2016-11-20 17:44:48 +0000 | [diff] [blame] | 694 | depends on ARCH_ZX || COMPILE_TEST |
Linus Walleij | 0963670 | 2015-11-01 10:50:19 +0100 | [diff] [blame] | 695 | select GPIOLIB_IRQCHIP |
| 696 | help |
| 697 | Say yes here to support the GPIO device on ZTE ZX SoCs. |
| 698 | |
Kelvin Cheung | bd37c99 | 2016-04-06 20:34:53 +0800 | [diff] [blame] | 699 | config GPIO_LOONGSON1 |
| 700 | tristate "Loongson1 GPIO support" |
| 701 | depends on MACH_LOONGSON32 |
| 702 | select GPIO_GENERIC |
| 703 | help |
| 704 | Say Y or M here to support GPIO on Loongson1 SoCs. |
| 705 | |
Enrico Weigelt, metux IT consult | e09d168 | 2019-02-22 10:54:15 +0100 | [diff] [blame] | 706 | config GPIO_AMD_FCH |
| 707 | tristate "GPIO support for AMD Fusion Controller Hub (G-series SOCs)" |
| 708 | help |
| 709 | This option enables driver for GPIO on AMDs Fusion Controller Hub, |
| 710 | as found on G-series SOCs (eg. GX-412TC) |
| 711 | |
| 712 | Note: This driver doesn't registers itself automatically, as it |
| 713 | needs to be provided with platform specific configuration. |
| 714 | (See eg. CONFIG_PCENGINES_APU2.) |
Linus Walleij | 177b038 | 2015-04-08 15:11:16 +0200 | [diff] [blame] | 715 | endmenu |
| 716 | |
Linus Walleij | bc6a73b | 2015-10-30 10:32:19 +0100 | [diff] [blame] | 717 | menu "Port-mapped I/O GPIO drivers" |
Linus Walleij | 7768feb | 2015-11-01 10:39:07 +0100 | [diff] [blame] | 718 | depends on X86 # Unconditional I/O space access |
Linus Walleij | bc6a73b | 2015-10-30 10:32:19 +0100 | [diff] [blame] | 719 | |
William Breathitt Gray | 1b06d64 | 2016-01-20 13:50:11 -0500 | [diff] [blame] | 720 | config GPIO_104_DIO_48E |
| 721 | tristate "ACCES 104-DIO-48E GPIO support" |
William Breathitt Gray | 35decc8 | 2017-12-29 15:13:46 -0500 | [diff] [blame] | 722 | depends on PC104 |
| 723 | select ISA_BUS_API |
William Breathitt Gray | 1b06d64 | 2016-01-20 13:50:11 -0500 | [diff] [blame] | 724 | select GPIOLIB_IRQCHIP |
| 725 | help |
William Breathitt Gray | 4c23db0 | 2016-05-01 18:44:39 -0400 | [diff] [blame] | 726 | Enables GPIO support for the ACCES 104-DIO-48E series (104-DIO-48E, |
| 727 | 104-DIO-24E). The base port addresses for the devices may be |
| 728 | configured via the base module parameter. The interrupt line numbers |
| 729 | for the devices may be configured via the irq module parameter. |
William Breathitt Gray | 1b06d64 | 2016-01-20 13:50:11 -0500 | [diff] [blame] | 730 | |
Linus Walleij | bc6a73b | 2015-10-30 10:32:19 +0100 | [diff] [blame] | 731 | config GPIO_104_IDIO_16 |
| 732 | tristate "ACCES 104-IDIO-16 GPIO support" |
William Breathitt Gray | 35decc8 | 2017-12-29 15:13:46 -0500 | [diff] [blame] | 733 | depends on PC104 |
| 734 | select ISA_BUS_API |
William Breathitt Gray | a118414 | 2015-11-03 07:54:23 -0500 | [diff] [blame] | 735 | select GPIOLIB_IRQCHIP |
Linus Walleij | bc6a73b | 2015-10-30 10:32:19 +0100 | [diff] [blame] | 736 | help |
William Breathitt Gray | 86ea8a9 | 2016-05-01 18:45:11 -0400 | [diff] [blame] | 737 | Enables GPIO support for the ACCES 104-IDIO-16 family (104-IDIO-16, |
| 738 | 104-IDIO-16E, 104-IDO-16, 104-IDIO-8, 104-IDIO-8E, 104-IDO-8). The |
| 739 | base port addresses for the devices may be configured via the base |
| 740 | module parameter. The interrupt line numbers for the devices may be |
| 741 | configured via the irq module parameter. |
Linus Walleij | bc6a73b | 2015-10-30 10:32:19 +0100 | [diff] [blame] | 742 | |
William Breathitt Gray | 6ddcf9b | 2015-11-23 12:54:50 -0500 | [diff] [blame] | 743 | config GPIO_104_IDI_48 |
| 744 | tristate "ACCES 104-IDI-48 GPIO support" |
William Breathitt Gray | 35decc8 | 2017-12-29 15:13:46 -0500 | [diff] [blame] | 745 | depends on PC104 |
| 746 | select ISA_BUS_API |
William Breathitt Gray | 6ddcf9b | 2015-11-23 12:54:50 -0500 | [diff] [blame] | 747 | select GPIOLIB_IRQCHIP |
| 748 | help |
William Breathitt Gray | 72bf744 | 2016-05-01 18:44:55 -0400 | [diff] [blame] | 749 | Enables GPIO support for the ACCES 104-IDI-48 family (104-IDI-48A, |
| 750 | 104-IDI-48AC, 104-IDI-48B, 104-IDI-48BC). The base port addresses for |
| 751 | the devices may be configured via the base module parameter. The |
| 752 | interrupt line numbers for the devices may be configured via the irq |
| 753 | module parameter. |
William Breathitt Gray | 6ddcf9b | 2015-11-23 12:54:50 -0500 | [diff] [blame] | 754 | |
Linus Walleij | bc6a73b | 2015-10-30 10:32:19 +0100 | [diff] [blame] | 755 | config GPIO_F7188X |
Peter Hung | 1920906f | 2016-01-22 15:23:33 +0800 | [diff] [blame] | 756 | tristate "F71869, F71869A, F71882FG, F71889F and F81866 GPIO support" |
Linus Walleij | bc6a73b | 2015-10-30 10:32:19 +0100 | [diff] [blame] | 757 | help |
| 758 | This option enables support for GPIOs found on Fintek Super-I/O |
Peter Hung | 1920906f | 2016-01-22 15:23:33 +0800 | [diff] [blame] | 759 | chips F71869, F71869A, F71882FG, F71889F and F81866. |
Linus Walleij | bc6a73b | 2015-10-30 10:32:19 +0100 | [diff] [blame] | 760 | |
| 761 | To compile this driver as a module, choose M here: the module will |
| 762 | be called f7188x-gpio. |
| 763 | |
William Breathitt Gray | 6ea5dcd | 2016-08-02 09:57:47 -0400 | [diff] [blame] | 764 | config GPIO_GPIO_MM |
| 765 | tristate "Diamond Systems GPIO-MM GPIO support" |
William Breathitt Gray | 35decc8 | 2017-12-29 15:13:46 -0500 | [diff] [blame] | 766 | depends on PC104 |
| 767 | select ISA_BUS_API |
William Breathitt Gray | 6ea5dcd | 2016-08-02 09:57:47 -0400 | [diff] [blame] | 768 | help |
| 769 | Enables GPIO support for the Diamond Systems GPIO-MM and GPIO-MM-12. |
| 770 | |
| 771 | The Diamond Systems GPIO-MM device features 48 lines of digital I/O |
| 772 | via the emulation of dual 82C55A PPI chips. This driver provides GPIO |
| 773 | support for these 48 channels of digital I/O. |
| 774 | |
| 775 | The base port addresses for the devices may be configured via the base |
| 776 | array module parameter. |
| 777 | |
Linus Walleij | bc6a73b | 2015-10-30 10:32:19 +0100 | [diff] [blame] | 778 | config GPIO_IT87 |
| 779 | tristate "IT87xx GPIO support" |
Linus Walleij | bc6a73b | 2015-10-30 10:32:19 +0100 | [diff] [blame] | 780 | help |
| 781 | Say yes here to support GPIO functionality of IT87xx Super I/O chips. |
| 782 | |
| 783 | This driver is tested with ITE IT8728 and IT8732 Super I/O chips, and |
Leonid Bloch | a5ec96d | 2018-08-09 01:26:36 +0300 | [diff] [blame] | 784 | supports the IT8761E, IT8613, IT8620E, and IT8628E Super I/O chips as |
| 785 | well. |
Linus Walleij | bc6a73b | 2015-10-30 10:32:19 +0100 | [diff] [blame] | 786 | |
| 787 | To compile this driver as a module, choose M here: the module will |
| 788 | be called gpio_it87 |
| 789 | |
| 790 | config GPIO_SCH |
| 791 | tristate "Intel SCH/TunnelCreek/Centerton/Quark X1000 GPIO" |
Peter Robinson | 72aba2e | 2016-11-20 17:37:25 +0000 | [diff] [blame] | 792 | depends on (X86 || COMPILE_TEST) && PCI |
Linus Walleij | bc6a73b | 2015-10-30 10:32:19 +0100 | [diff] [blame] | 793 | select MFD_CORE |
| 794 | select LPC_SCH |
| 795 | help |
| 796 | Say yes here to support GPIO interface on Intel Poulsbo SCH, |
| 797 | Intel Tunnel Creek processor, Intel Centerton processor or |
| 798 | Intel Quark X1000 SoC. |
| 799 | |
| 800 | The Intel SCH contains a total of 14 GPIO pins. Ten GPIOs are |
| 801 | powered by the core power rail and are turned off during sleep |
| 802 | modes (S3 and higher). The remaining four GPIOs are powered by |
| 803 | the Intel SCH suspend power supply. These GPIOs remain |
| 804 | active during S3. The suspend powered GPIOs can be used to wake the |
| 805 | system from the Suspend-to-RAM state. |
| 806 | |
| 807 | The Intel Tunnel Creek processor has 5 GPIOs powered by the |
| 808 | core power rail and 9 from suspend power supply. |
| 809 | |
| 810 | The Intel Centerton processor has a total of 30 GPIO pins. |
| 811 | Twenty-one are powered by the core power rail and 9 from the |
| 812 | suspend power supply. |
| 813 | |
| 814 | The Intel Quark X1000 SoC has 2 GPIOs powered by the core |
| 815 | power well and 6 from the suspend power well. |
| 816 | |
| 817 | config GPIO_SCH311X |
| 818 | tristate "SMSC SCH311x SuperI/O GPIO" |
| 819 | help |
| 820 | Driver to enable the GPIOs found on SMSC SMSC SCH3112, SCH3114 and |
| 821 | SCH3116 "Super I/O" chipsets. |
| 822 | |
| 823 | To compile this driver as a module, choose M here: the module will |
| 824 | be called gpio-sch311x. |
| 825 | |
| 826 | config GPIO_TS5500 |
| 827 | tristate "TS-5500 DIO blocks and compatibles" |
| 828 | depends on TS5500 || COMPILE_TEST |
| 829 | help |
| 830 | This driver supports Digital I/O exposed by pin blocks found on some |
| 831 | Technologic Systems platforms. It includes, but is not limited to, 3 |
| 832 | blocks of the TS-5500: DIO1, DIO2 and the LCD port, and the TS-5600 |
| 833 | LCD port. |
| 834 | |
Maciej S. Szmigiero | a0d6500 | 2018-01-06 00:46:08 +0100 | [diff] [blame] | 835 | config GPIO_WINBOND |
| 836 | tristate "Winbond Super I/O GPIO support" |
Maciej S. Szmigiero | b995ff3 | 2018-02-23 15:55:17 +0100 | [diff] [blame] | 837 | select ISA_BUS_API |
Maciej S. Szmigiero | a0d6500 | 2018-01-06 00:46:08 +0100 | [diff] [blame] | 838 | help |
| 839 | This option enables support for GPIOs found on Winbond Super I/O |
| 840 | chips. |
| 841 | Currently, only W83627UHG (also known as Nuvoton NCT6627UD) is |
| 842 | supported. |
| 843 | |
| 844 | You will need to provide a module parameter "gpios", or a |
| 845 | boot-time parameter "gpio_winbond.gpios" with a bitmask of GPIO |
| 846 | ports to enable (bit 0 is GPIO1, bit 1 is GPIO2, etc.). |
| 847 | |
| 848 | To compile this driver as a module, choose M here: the module will |
| 849 | be called gpio-winbond. |
| 850 | |
William Breathitt Gray | 9c26df9 | 2016-01-20 13:45:33 -0500 | [diff] [blame] | 851 | config GPIO_WS16C48 |
| 852 | tristate "WinSystems WS16C48 GPIO support" |
William Breathitt Gray | 35decc8 | 2017-12-29 15:13:46 -0500 | [diff] [blame] | 853 | select ISA_BUS_API |
William Breathitt Gray | 9c26df9 | 2016-01-20 13:45:33 -0500 | [diff] [blame] | 854 | select GPIOLIB_IRQCHIP |
| 855 | help |
William Breathitt Gray | cc73660 | 2016-05-01 18:45:24 -0400 | [diff] [blame] | 856 | Enables GPIO support for the WinSystems WS16C48. The base port |
| 857 | addresses for the devices may be configured via the base module |
| 858 | parameter. The interrupt line numbers for the devices may be |
| 859 | configured via the irq module parameter. |
William Breathitt Gray | 9c26df9 | 2016-01-20 13:45:33 -0500 | [diff] [blame] | 860 | |
Linus Walleij | bc6a73b | 2015-10-30 10:32:19 +0100 | [diff] [blame] | 861 | endmenu |
| 862 | |
Linus Walleij | 177b038 | 2015-04-08 15:11:16 +0200 | [diff] [blame] | 863 | menu "I2C GPIO expanders" |
| 864 | depends on I2C |
David Brownell | a9c5fff | 2008-02-04 22:28:17 -0800 | [diff] [blame] | 865 | |
Linus Walleij | bf5a16b | 2015-04-08 14:14:40 +0200 | [diff] [blame] | 866 | config GPIO_ADP5588 |
| 867 | tristate "ADP5588 I2C GPIO expander" |
Mark Brown | 31ba56f | 2012-06-23 13:29:25 +0100 | [diff] [blame] | 868 | help |
Linus Walleij | bf5a16b | 2015-04-08 14:14:40 +0200 | [diff] [blame] | 869 | This option enables support for 18 GPIOs found |
| 870 | on Analog Devices ADP5588 GPIO Expanders. |
Wolfram Sang | e952805 | 2010-03-05 13:44:33 -0800 | [diff] [blame] | 871 | |
Linus Walleij | bf5a16b | 2015-04-08 14:14:40 +0200 | [diff] [blame] | 872 | config GPIO_ADP5588_IRQ |
| 873 | bool "Interrupt controller support for ADP5588" |
| 874 | depends on GPIO_ADP5588=y |
Randy Dunlap | e9646f0 | 2019-05-23 15:00:41 -0700 | [diff] [blame] | 875 | select GPIOLIB_IRQCHIP |
Eric Miao | bbcd6d5 | 2008-07-25 01:46:14 -0700 | [diff] [blame] | 876 | help |
Linus Walleij | bf5a16b | 2015-04-08 14:14:40 +0200 | [diff] [blame] | 877 | Say yes here to enable the adp5588 to be used as an interrupt |
| 878 | controller. It requires the driver to be built in the kernel. |
David Brownell | a9c5fff | 2008-02-04 22:28:17 -0800 | [diff] [blame] | 879 | |
Linus Walleij | bf5a16b | 2015-04-08 14:14:40 +0200 | [diff] [blame] | 880 | config GPIO_ADNP |
| 881 | tristate "Avionic Design N-bit GPIO expander" |
Linus Walleij | 269a46f | 2015-11-01 10:43:16 +0100 | [diff] [blame] | 882 | depends on OF_GPIO |
Zhu, Lejun | 104fb1d | 2014-06-03 13:26:04 +0800 | [diff] [blame] | 883 | select GPIOLIB_IRQCHIP |
| 884 | help |
Linus Walleij | bf5a16b | 2015-04-08 14:14:40 +0200 | [diff] [blame] | 885 | This option enables support for N GPIOs found on Avionic Design |
| 886 | I2C GPIO expanders. The register space will be extended by powers |
| 887 | of two, so the controller will need to accommodate for that. For |
| 888 | example: if a controller provides 48 pins, 6 registers will be |
| 889 | enough to represent all pins, but the driver will assume a |
| 890 | register layout for 64 pins (8 registers). |
Milo Kim | 0cc59b9 | 2013-12-06 11:18:42 +0900 | [diff] [blame] | 891 | |
Linus Walleij | 2a0b0a5 | 2019-02-01 21:41:31 +0100 | [diff] [blame] | 892 | config GPIO_GW_PLD |
| 893 | tristate "Gateworks PLD GPIO Expander" |
| 894 | depends on OF_GPIO |
| 895 | help |
| 896 | Say yes here to provide access to the Gateworks I2C PLD GPIO |
| 897 | Expander. This is used at least on the Cambria GW2358-4. |
| 898 | |
David Brownell | a9c5fff | 2008-02-04 22:28:17 -0800 | [diff] [blame] | 899 | config GPIO_MAX7300 |
Eric Miao | bbcd6d5 | 2008-07-25 01:46:14 -0700 | [diff] [blame] | 900 | tristate "Maxim MAX7300 GPIO expander" |
Eric Miao | bbcd6d5 | 2008-07-25 01:46:14 -0700 | [diff] [blame] | 901 | select GPIO_MAX730X |
| 902 | help |
Axel Lin | 2b861f4 | 2013-05-19 14:25:48 +0800 | [diff] [blame] | 903 | GPIO driver for Maxim MAX7300 I2C-based GPIO expander. |
David Brownell | a9c5fff | 2008-02-04 22:28:17 -0800 | [diff] [blame] | 904 | |
Eric Miao | bbcd6d5 | 2008-07-25 01:46:14 -0700 | [diff] [blame] | 905 | config GPIO_MAX732X |
| 906 | tristate "MAX7319, MAX7320-7327 I2C Port Expanders" |
Eric Miao | bbcd6d5 | 2008-07-25 01:46:14 -0700 | [diff] [blame] | 907 | help |
| 908 | Say yes here to support the MAX7319, MAX7320-7327 series of I2C |
| 909 | Port Expanders. Each IO port on these chips has a fixed role of |
| 910 | Input (designated by 'I'), Push-Pull Output ('O'), or Open-Drain |
| 911 | Input and Output (designed by 'P'). The combinations are listed |
| 912 | below: |
| 913 | |
Enrico Weigelt, metux IT consult | c42e34c | 2019-03-05 01:35:31 +0100 | [diff] [blame] | 914 | 8 bits: max7319 (8I), max7320 (8O), max7321 (8P), |
| 915 | max7322 (4I4O), max7323 (4P4O) |
Eric Miao | bbcd6d5 | 2008-07-25 01:46:14 -0700 | [diff] [blame] | 916 | |
Enrico Weigelt, metux IT consult | c42e34c | 2019-03-05 01:35:31 +0100 | [diff] [blame] | 917 | 16 bits: max7324 (8I8O), max7325 (8P8O), |
| 918 | max7326 (4I12O), max7327 (4P12O) |
Eric Miao | bbcd6d5 | 2008-07-25 01:46:14 -0700 | [diff] [blame] | 919 | |
| 920 | Board setup code must specify the model to use, and the start |
| 921 | number for these GPIOs. |
| 922 | |
Marc Zyngier | a80a0bb | 2010-05-26 14:42:16 -0700 | [diff] [blame] | 923 | config GPIO_MAX732X_IRQ |
| 924 | bool "Interrupt controller support for MAX732x" |
Martin Schwidefsky | 0244ad0 | 2013-08-30 09:39:53 +0200 | [diff] [blame] | 925 | depends on GPIO_MAX732X=y |
Linus Walleij | 984f664 | 2015-01-30 11:32:01 +0100 | [diff] [blame] | 926 | select GPIOLIB_IRQCHIP |
Marc Zyngier | a80a0bb | 2010-05-26 14:42:16 -0700 | [diff] [blame] | 927 | help |
| 928 | Say yes here to enable the max732x to be used as an interrupt |
| 929 | controller. It requires the driver to be built in the kernel. |
| 930 | |
wu guoxing | 608589b | 2012-01-30 14:31:20 +0800 | [diff] [blame] | 931 | config GPIO_MC9S08DZ60 |
| 932 | bool "MX35 3DS BOARD MC9S08DZ60 GPIO functions" |
Axel Lin | 4c30aa3 | 2012-08-29 09:35:24 +0800 | [diff] [blame] | 933 | depends on I2C=y && MACH_MX35_3DS |
wu guoxing | 608589b | 2012-01-30 14:31:20 +0800 | [diff] [blame] | 934 | help |
| 935 | Select this to enable the MC9S08DZ60 GPIO driver |
| 936 | |
Guennadi Liakhovetski | f3dc363 | 2008-02-06 01:39:03 -0800 | [diff] [blame] | 937 | config GPIO_PCA953X |
Aaron Sierra | eb32b5a | 2014-02-13 13:59:23 +0100 | [diff] [blame] | 938 | tristate "PCA95[357]x, PCA9698, TCA64xx, and MAX7310 I/O ports" |
Marek Vasut | 4bc16f9 | 2018-12-16 18:38:58 +0100 | [diff] [blame] | 939 | select REGMAP_I2C |
eric miao | 9e60fdc | 2008-02-04 22:28:26 -0800 | [diff] [blame] | 940 | help |
David Brownell | 7059d4b | 2008-07-04 09:59:37 -0700 | [diff] [blame] | 941 | Say yes here to provide access to several register-oriented |
| 942 | SMBus I/O expanders, made mostly by NXP or TI. Compatible |
| 943 | models include: |
| 944 | |
Enrico Weigelt, metux IT consult | c42e34c | 2019-03-05 01:35:31 +0100 | [diff] [blame] | 945 | 4 bits: pca9536, pca9537 |
David Brownell | 7059d4b | 2008-07-04 09:59:37 -0700 | [diff] [blame] | 946 | |
Enrico Weigelt, metux IT consult | c42e34c | 2019-03-05 01:35:31 +0100 | [diff] [blame] | 947 | 8 bits: max7310, max7315, pca6107, pca9534, pca9538, pca9554, |
| 948 | pca9556, pca9557, pca9574, tca6408, tca9554, xra1202 |
David Brownell | 7059d4b | 2008-07-04 09:59:37 -0700 | [diff] [blame] | 949 | |
Enrico Weigelt, metux IT consult | c42e34c | 2019-03-05 01:35:31 +0100 | [diff] [blame] | 950 | 16 bits: max7312, max7313, pca9535, pca9539, pca9555, pca9575, |
| 951 | tca6416 |
eric miao | 9e60fdc | 2008-02-04 22:28:26 -0800 | [diff] [blame] | 952 | |
Enrico Weigelt, metux IT consult | c42e34c | 2019-03-05 01:35:31 +0100 | [diff] [blame] | 953 | 24 bits: tca6424 |
Aaron Sierra | 1e19169 | 2014-02-07 16:35:48 -0600 | [diff] [blame] | 954 | |
Enrico Weigelt, metux IT consult | c42e34c | 2019-03-05 01:35:31 +0100 | [diff] [blame] | 955 | 40 bits: pca9505, pca9698 |
Aaron Sierra | 1e19169 | 2014-02-07 16:35:48 -0600 | [diff] [blame] | 956 | |
Marc Zyngier | 89ea8bb | 2010-03-05 13:44:36 -0800 | [diff] [blame] | 957 | config GPIO_PCA953X_IRQ |
| 958 | bool "Interrupt controller support for PCA953x" |
Andy Shevchenko | e33a58a | 2020-05-21 00:19:15 +0300 | [diff] [blame] | 959 | depends on GPIO_PCA953X |
Linus Walleij | 7bcbce5 | 2014-05-09 13:27:57 +0200 | [diff] [blame] | 960 | select GPIOLIB_IRQCHIP |
Marc Zyngier | 89ea8bb | 2010-03-05 13:44:36 -0800 | [diff] [blame] | 961 | help |
| 962 | Say yes here to enable the pca953x to be used as an interrupt |
| 963 | controller. It requires the driver to be built in the kernel. |
| 964 | |
David Brownell | 15fae37 | 2008-02-04 22:28:24 -0800 | [diff] [blame] | 965 | config GPIO_PCF857X |
David Brownell | 1673ad5 | 2008-07-21 14:21:34 -0700 | [diff] [blame] | 966 | tristate "PCF857x, PCA{85,96}7x, and MAX732[89] I2C GPIO expanders" |
Geert Uytterhoeven | a39294b | 2015-02-05 16:49:08 +0100 | [diff] [blame] | 967 | select GPIOLIB_IRQCHIP |
Arnd Bergmann | 901acf5 | 2012-09-28 23:36:15 +0200 | [diff] [blame] | 968 | select IRQ_DOMAIN |
David Brownell | 15fae37 | 2008-02-04 22:28:24 -0800 | [diff] [blame] | 969 | help |
| 970 | Say yes here to provide access to most "quasi-bidirectional" I2C |
| 971 | GPIO expanders used for additional digital outputs or inputs. |
| 972 | Most of these parts are from NXP, though TI is a second source for |
| 973 | some of them. Compatible models include: |
| 974 | |
| 975 | 8 bits: pcf8574, pcf8574a, pca8574, pca8574a, |
David Brownell | 1673ad5 | 2008-07-21 14:21:34 -0700 | [diff] [blame] | 976 | pca9670, pca9672, pca9674, pca9674a, |
Enrico Weigelt, metux IT consult | c42e34c | 2019-03-05 01:35:31 +0100 | [diff] [blame] | 977 | max7328, max7329 |
David Brownell | 15fae37 | 2008-02-04 22:28:24 -0800 | [diff] [blame] | 978 | |
| 979 | 16 bits: pcf8575, pcf8575c, pca8575, |
| 980 | pca9671, pca9673, pca9675 |
| 981 | |
| 982 | Your board setup code will need to declare the expanders in |
| 983 | use, and assign numbers to the GPIOs they expose. Those GPIOs |
| 984 | can then be used from drivers and other kernel code, just like |
| 985 | other GPIOs, but only accessible from task contexts. |
| 986 | |
| 987 | This driver provides an in-kernel interface to those GPIOs using |
| 988 | platform-neutral GPIO calls. |
| 989 | |
Andrew F. Davis | b866526 | 2016-01-25 10:14:12 -0600 | [diff] [blame] | 990 | config GPIO_TPIC2810 |
| 991 | tristate "TPIC2810 8-Bit I2C GPO expander" |
| 992 | help |
| 993 | Say yes here to enable the GPO driver for the TI TPIC2810 chip. |
| 994 | |
| 995 | To compile this driver as a module, choose M here: the module will |
| 996 | be called gpio-tpic2810. |
| 997 | |
Lucile Quirion | 9c66863 | 2016-08-12 11:16:49 -0400 | [diff] [blame] | 998 | config GPIO_TS4900 |
| 999 | tristate "Technologic Systems FPGA I2C GPIO" |
Jean Delvare | 4c5f15b | 2016-10-14 14:24:09 +0200 | [diff] [blame] | 1000 | depends on SOC_IMX6 || COMPILE_TEST |
Lucile Quirion | 9c66863 | 2016-08-12 11:16:49 -0400 | [diff] [blame] | 1001 | select REGMAP_I2C |
| 1002 | help |
| 1003 | Say yes here to enabled the GPIO driver for Technologic's FPGA core. |
| 1004 | Series supported include TS-4100, TS-4900, TS-7970 and TS-7990. |
| 1005 | |
Linus Walleij | 177b038 | 2015-04-08 15:11:16 +0200 | [diff] [blame] | 1006 | endmenu |
| 1007 | |
| 1008 | menu "MFD GPIO expanders" |
Linus Walleij | be9cab5 | 2015-04-08 14:51:23 +0200 | [diff] [blame] | 1009 | |
| 1010 | config GPIO_ADP5520 |
| 1011 | tristate "GPIO Support for ADP5520 PMIC" |
| 1012 | depends on PMIC_ADP5520 |
| 1013 | help |
| 1014 | This option enables support for on-chip GPIO found |
| 1015 | on Analog Devices ADP5520 PMICs. |
| 1016 | |
Thor Thayer | 26a48c4 | 2016-06-02 12:52:24 -0500 | [diff] [blame] | 1017 | config GPIO_ALTERA_A10SR |
| 1018 | tristate "Altera Arria10 System Resource GPIO" |
| 1019 | depends on MFD_ALTERA_A10SR |
| 1020 | help |
| 1021 | Driver for Arria10 Development Kit GPIO expansion which |
| 1022 | includes reads of pushbuttons and DIP switches as well |
| 1023 | as writes to LEDs. |
| 1024 | |
Linus Walleij | be9cab5 | 2015-04-08 14:51:23 +0200 | [diff] [blame] | 1025 | config GPIO_ARIZONA |
| 1026 | tristate "Wolfson Microelectronics Arizona class devices" |
| 1027 | depends on MFD_ARIZONA |
| 1028 | help |
| 1029 | Support for GPIOs on Wolfson Arizona class devices. |
| 1030 | |
Matti Vaittinen | 18bc64b | 2019-06-03 10:26:45 +0300 | [diff] [blame] | 1031 | config GPIO_BD70528 |
| 1032 | tristate "ROHM BD70528 GPIO support" |
| 1033 | depends on MFD_ROHM_BD70528 |
| 1034 | help |
| 1035 | Support for GPIOs on ROHM BD70528 PMIC. There are four GPIOs |
| 1036 | available on the ROHM PMIC in total. The GPIOs can also |
| 1037 | generate interrupts. |
| 1038 | |
| 1039 | This driver can also be built as a module. If so, the module |
| 1040 | will be called gpio-bd70528. |
| 1041 | |
Matti Vaittinen | c31f625 | 2020-01-20 15:47:37 +0200 | [diff] [blame] | 1042 | config GPIO_BD71828 |
| 1043 | tristate "ROHM BD71828 GPIO support" |
| 1044 | depends on MFD_ROHM_BD71828 |
| 1045 | help |
| 1046 | Support for GPIOs on ROHM BD71828 PMIC. There are three GPIOs |
| 1047 | available on the ROHM PMIC in total. The GPIOs are limited to |
| 1048 | outputs only and pins must be configured to GPIO outputs by |
| 1049 | OTP. Enable this only if you want to use these pins as outputs. |
| 1050 | |
| 1051 | This driver can also be built as a module. If so, the module |
| 1052 | will be called gpio-bd71828. |
| 1053 | |
Marek Vasut | 9384793 | 2017-04-25 20:32:09 +0200 | [diff] [blame] | 1054 | config GPIO_BD9571MWV |
| 1055 | tristate "ROHM BD9571 GPIO support" |
| 1056 | depends on MFD_BD9571MWV |
| 1057 | help |
| 1058 | Support for GPIOs on ROHM BD9571 PMIC. There are two GPIOs |
| 1059 | available on the ROHM PMIC in total, both of which can also |
| 1060 | generate interrupts. |
| 1061 | |
| 1062 | This driver can also be built as a module. If so, the module |
| 1063 | will be called gpio-bd9571mwv. |
| 1064 | |
Linus Walleij | be9cab5 | 2015-04-08 14:51:23 +0200 | [diff] [blame] | 1065 | config GPIO_CRYSTAL_COVE |
| 1066 | tristate "GPIO support for Crystal Cove PMIC" |
Peter Robinson | 72aba2e | 2016-11-20 17:37:25 +0000 | [diff] [blame] | 1067 | depends on (X86 || COMPILE_TEST) && INTEL_SOC_PMIC |
Linus Walleij | be9cab5 | 2015-04-08 14:51:23 +0200 | [diff] [blame] | 1068 | select GPIOLIB_IRQCHIP |
| 1069 | help |
| 1070 | Support for GPIO pins on Crystal Cove PMIC. |
| 1071 | |
| 1072 | Say Yes if you have a Intel SoC based tablet with Crystal Cove PMIC |
| 1073 | inside. |
| 1074 | |
| 1075 | This driver can also be built as a module. If so, the module will be |
| 1076 | called gpio-crystalcove. |
| 1077 | |
| 1078 | config GPIO_CS5535 |
| 1079 | tristate "AMD CS5535/CS5536 GPIO support" |
Peter Robinson | 72aba2e | 2016-11-20 17:37:25 +0000 | [diff] [blame] | 1080 | depends on X86 || MIPS || COMPILE_TEST |
Linus Walleij | be9cab5 | 2015-04-08 14:51:23 +0200 | [diff] [blame] | 1081 | depends on MFD_CS5535 |
| 1082 | help |
| 1083 | The AMD CS5535 and CS5536 southbridges support 28 GPIO pins that |
| 1084 | can be used for quite a number of things. The CS5535/6 is found on |
| 1085 | AMD Geode and Lemote Yeeloong devices. |
| 1086 | |
| 1087 | If unsure, say N. |
| 1088 | |
| 1089 | config GPIO_DA9052 |
| 1090 | tristate "Dialog DA9052 GPIO" |
| 1091 | depends on PMIC_DA9052 |
| 1092 | help |
| 1093 | Say yes here to enable the GPIO driver for the DA9052 chip. |
| 1094 | |
| 1095 | config GPIO_DA9055 |
| 1096 | tristate "Dialog Semiconductor DA9055 GPIO" |
| 1097 | depends on MFD_DA9055 |
| 1098 | help |
| 1099 | Say yes here to enable the GPIO driver for the DA9055 chip. |
| 1100 | |
| 1101 | The Dialog DA9055 PMIC chip has 3 GPIO pins that can be |
| 1102 | be controller by this driver. |
| 1103 | |
| 1104 | If driver is built as a module it will be called gpio-da9055. |
| 1105 | |
| 1106 | config GPIO_DLN2 |
| 1107 | tristate "Diolan DLN2 GPIO support" |
| 1108 | depends on MFD_DLN2 |
| 1109 | select GPIOLIB_IRQCHIP |
| 1110 | |
| 1111 | help |
| 1112 | Select this option to enable GPIO driver for the Diolan DLN2 |
| 1113 | board. |
| 1114 | |
| 1115 | This driver can also be built as a module. If so, the module |
| 1116 | will be called gpio-dln2. |
| 1117 | |
Linus Walleij | 3c6e8d0 | 2016-09-16 13:48:12 +0200 | [diff] [blame] | 1118 | config HTC_EGPIO |
| 1119 | bool "HTC EGPIO support" |
Geert Uytterhoeven | e4c6a52 | 2020-06-23 16:40:01 +0200 | [diff] [blame^] | 1120 | depends on ARM |
Linus Walleij | 3c6e8d0 | 2016-09-16 13:48:12 +0200 | [diff] [blame] | 1121 | help |
Enrico Weigelt, metux IT consult | c42e34c | 2019-03-05 01:35:31 +0100 | [diff] [blame] | 1122 | This driver supports the CPLD egpio chip present on |
| 1123 | several HTC phones. It provides basic support for input |
| 1124 | pins, output pins, and irqs. |
Linus Walleij | 3c6e8d0 | 2016-09-16 13:48:12 +0200 | [diff] [blame] | 1125 | |
Linus Walleij | be9cab5 | 2015-04-08 14:51:23 +0200 | [diff] [blame] | 1126 | config GPIO_JANZ_TTL |
| 1127 | tristate "Janz VMOD-TTL Digital IO Module" |
| 1128 | depends on MFD_JANZ_CMODIO |
| 1129 | help |
| 1130 | This enables support for the Janz VMOD-TTL Digital IO module. |
| 1131 | This driver provides support for driving the pins in output |
| 1132 | mode only. Input mode is not supported. |
| 1133 | |
| 1134 | config GPIO_KEMPLD |
| 1135 | tristate "Kontron ETX / COMexpress GPIO" |
| 1136 | depends on MFD_KEMPLD |
| 1137 | help |
| 1138 | This enables support for the PLD GPIO interface on some Kontron ETX |
| 1139 | and COMexpress (ETXexpress) modules. |
| 1140 | |
| 1141 | This driver can also be built as a module. If so, the module will be |
| 1142 | called gpio-kempld. |
| 1143 | |
| 1144 | config GPIO_LP3943 |
| 1145 | tristate "TI/National Semiconductor LP3943 GPIO expander" |
| 1146 | depends on MFD_LP3943 |
| 1147 | help |
| 1148 | GPIO driver for LP3943 MFD. |
| 1149 | LP3943 can be used as a GPIO expander which provides up to 16 GPIOs. |
| 1150 | Open drain outputs are required for this usage. |
| 1151 | |
Keerthy | 83f1410 | 2016-08-31 14:28:11 +0530 | [diff] [blame] | 1152 | config GPIO_LP873X |
| 1153 | tristate "TI LP873X GPO" |
| 1154 | depends on MFD_TI_LP873X |
| 1155 | help |
| 1156 | This driver supports the GPO on TI Lp873x PMICs. 2 GPOs are present |
| 1157 | on LP873X PMICs. |
| 1158 | |
| 1159 | This driver can also be built as a module. If so, the module will be |
Enrico Weigelt, metux IT consult | c42e34c | 2019-03-05 01:35:31 +0100 | [diff] [blame] | 1160 | called gpio-lp873x. |
Keerthy | 83f1410 | 2016-08-31 14:28:11 +0530 | [diff] [blame] | 1161 | |
Keerthy | 5c7f2c7 | 2017-06-15 12:03:11 +0530 | [diff] [blame] | 1162 | config GPIO_LP87565 |
| 1163 | tristate "TI LP87565 GPIO" |
| 1164 | depends on MFD_TI_LP87565 |
| 1165 | help |
| 1166 | This driver supports the GPIO on TI Lp873565 PMICs. 3 GPIOs are present |
| 1167 | on LP87565 PMICs. |
| 1168 | |
| 1169 | This driver can also be built as a module. If so, the module will be |
| 1170 | called gpio-lp87565. |
| 1171 | |
Richard Fitzgerald | aca429f | 2018-05-21 11:00:02 +0100 | [diff] [blame] | 1172 | config GPIO_MADERA |
| 1173 | tristate "Cirrus Logic Madera class codecs" |
| 1174 | depends on PINCTRL_MADERA |
| 1175 | help |
| 1176 | Support for GPIOs on Cirrus Logic Madera class codecs. |
| 1177 | |
Laxman Dewangan | 02c5ba1 | 2016-05-13 10:49:14 +0530 | [diff] [blame] | 1178 | config GPIO_MAX77620 |
| 1179 | tristate "GPIO support for PMIC MAX77620 and MAX20024" |
| 1180 | depends on MFD_MAX77620 |
Dmitry Osipenko | c5706c7 | 2020-01-06 04:51:54 +0300 | [diff] [blame] | 1181 | select GPIOLIB_IRQCHIP |
Laxman Dewangan | 02c5ba1 | 2016-05-13 10:49:14 +0530 | [diff] [blame] | 1182 | help |
| 1183 | GPIO driver for MAX77620 and MAX20024 PMIC from Maxim Semiconductor. |
| 1184 | MAX77620 PMIC has 8 pins that can be configured as GPIOs. The |
| 1185 | driver also provides interrupt support for each of the gpios. |
| 1186 | Say yes here to enable the max77620 to be used as gpio controller. |
| 1187 | |
Bartosz Golaszewski | 72b5135 | 2019-04-23 11:04:48 +0200 | [diff] [blame] | 1188 | config GPIO_MAX77650 |
| 1189 | tristate "Maxim MAX77650/77651 GPIO support" |
| 1190 | depends on MFD_MAX77650 |
| 1191 | help |
| 1192 | GPIO driver for MAX77650/77651 PMIC from Maxim Semiconductor. |
| 1193 | These chips have a single pin that can be configured as GPIO. |
| 1194 | |
Linus Walleij | be9cab5 | 2015-04-08 14:51:23 +0200 | [diff] [blame] | 1195 | config GPIO_MSIC |
| 1196 | bool "Intel MSIC mixed signal gpio support" |
Peter Robinson | 72aba2e | 2016-11-20 17:37:25 +0000 | [diff] [blame] | 1197 | depends on (X86 || COMPILE_TEST) && MFD_INTEL_MSIC |
Linus Walleij | be9cab5 | 2015-04-08 14:51:23 +0200 | [diff] [blame] | 1198 | help |
| 1199 | Enable support for GPIO on intel MSIC controllers found in |
| 1200 | intel MID devices |
| 1201 | |
| 1202 | config GPIO_PALMAS |
| 1203 | bool "TI PALMAS series PMICs GPIO" |
| 1204 | depends on MFD_PALMAS |
| 1205 | help |
| 1206 | Select this option to enable GPIO driver for the TI PALMAS |
| 1207 | series chip family. |
| 1208 | |
Laxman Dewangan | e9fe32b | 2012-05-14 12:46:12 +0530 | [diff] [blame] | 1209 | config GPIO_RC5T583 |
| 1210 | bool "RICOH RC5T583 GPIO" |
| 1211 | depends on MFD_RC5T583 |
| 1212 | help |
| 1213 | Select this option to enable GPIO driver for the Ricoh RC5T583 |
| 1214 | chip family. |
| 1215 | This driver provides the support for driving/reading the gpio pins |
| 1216 | of RC5T583 device through standard gpio library. |
| 1217 | |
Rabin Vincent | 03f822f | 2010-07-02 16:52:09 +0530 | [diff] [blame] | 1218 | config GPIO_STMPE |
| 1219 | bool "STMPE GPIOs" |
| 1220 | depends on MFD_STMPE |
Linus Walleij | 1dfb4a0 | 2015-01-13 08:00:29 +0100 | [diff] [blame] | 1221 | depends on OF_GPIO |
Linus Walleij | fe44e70 | 2014-04-15 23:38:56 +0200 | [diff] [blame] | 1222 | select GPIOLIB_IRQCHIP |
Rabin Vincent | 03f822f | 2010-07-02 16:52:09 +0530 | [diff] [blame] | 1223 | help |
| 1224 | This enables support for the GPIOs found on the STMPE I/O |
| 1225 | Expanders. |
| 1226 | |
Sundar Iyer | f4e8afd | 2010-12-13 09:33:13 +0530 | [diff] [blame] | 1227 | config GPIO_TC3589X |
| 1228 | bool "TC3589X GPIOs" |
| 1229 | depends on MFD_TC3589X |
Linus Walleij | 1422731 | 2015-03-19 15:52:45 +0100 | [diff] [blame] | 1230 | depends on OF_GPIO |
Linus Walleij | cf42f1c | 2014-04-09 13:38:33 +0200 | [diff] [blame] | 1231 | select GPIOLIB_IRQCHIP |
Rabin Vincent | d88b25b | 2010-05-10 23:43:47 +0200 | [diff] [blame] | 1232 | help |
Sundar Iyer | f4e8afd | 2010-12-13 09:33:13 +0530 | [diff] [blame] | 1233 | This enables support for the GPIOs found on the TC3589X |
Rabin Vincent | d88b25b | 2010-05-10 23:43:47 +0200 | [diff] [blame] | 1234 | I/O Expander. |
| 1235 | |
Linus Walleij | be9cab5 | 2015-04-08 14:51:23 +0200 | [diff] [blame] | 1236 | config GPIO_TIMBERDALE |
| 1237 | bool "Support for timberdale GPIO IP" |
| 1238 | depends on MFD_TIMBERDALE |
Masahiro Yamada | a7f7f62 | 2020-06-14 01:50:22 +0900 | [diff] [blame] | 1239 | help |
Linus Walleij | be9cab5 | 2015-04-08 14:51:23 +0200 | [diff] [blame] | 1240 | Add support for the GPIO IP in the timberdale FPGA. |
| 1241 | |
Andrew F. Davis | 99f0fd5 | 2016-02-06 10:12:10 -0600 | [diff] [blame] | 1242 | config GPIO_TPS65086 |
| 1243 | tristate "TI TPS65086 GPO" |
| 1244 | depends on MFD_TPS65086 |
| 1245 | help |
| 1246 | This driver supports the GPO on TI TPS65086x PMICs. |
| 1247 | |
Nicolas Saenz Julienne | c366c76 | 2016-01-30 17:06:44 +0000 | [diff] [blame] | 1248 | config GPIO_TPS65218 |
| 1249 | tristate "TPS65218 GPIO" |
| 1250 | depends on MFD_TPS65218 |
| 1251 | help |
| 1252 | Select this option to enable GPIO driver for the TPS65218 |
| 1253 | chip family. |
| 1254 | |
Linus Walleij | be9cab5 | 2015-04-08 14:51:23 +0200 | [diff] [blame] | 1255 | config GPIO_TPS6586X |
| 1256 | bool "TPS6586X GPIO" |
| 1257 | depends on MFD_TPS6586X |
| 1258 | help |
| 1259 | Select this option to enable GPIO driver for the TPS6586X |
| 1260 | chip family. |
| 1261 | |
| 1262 | config GPIO_TPS65910 |
| 1263 | bool "TPS65910 GPIO" |
| 1264 | depends on MFD_TPS65910 |
| 1265 | help |
| 1266 | Select this option to enable GPIO driver for the TPS65910 |
| 1267 | chip family. |
| 1268 | |
Margarita Olaya | 668a6cc | 2011-06-09 14:50:19 -0500 | [diff] [blame] | 1269 | config GPIO_TPS65912 |
| 1270 | tristate "TI TPS65912 GPIO" |
Andrew F. Davis | ca801a2 | 2016-01-25 09:43:47 -0600 | [diff] [blame] | 1271 | depends on MFD_TPS65912 |
Margarita Olaya | 668a6cc | 2011-06-09 14:50:19 -0500 | [diff] [blame] | 1272 | help |
| 1273 | This driver supports TPS65912 gpio chip |
| 1274 | |
Rajmohan Mani | 275b13a | 2017-07-28 17:30:25 -0700 | [diff] [blame] | 1275 | config GPIO_TPS68470 |
| 1276 | bool "TPS68470 GPIO" |
| 1277 | depends on MFD_TPS68470 |
| 1278 | help |
| 1279 | Select this option to enable GPIO driver for the TPS68470 |
| 1280 | chip family. |
| 1281 | There are 7 GPIOs and few sensor related GPIOs supported |
| 1282 | by the TPS68470. While the 7 GPIOs can be configured as |
| 1283 | input or output as appropriate, the sensor related GPIOs |
| 1284 | are "output only" GPIOs. |
| 1285 | |
| 1286 | This driver config is bool, as the GPIO functionality |
| 1287 | of the TPS68470 must be available before dependent |
| 1288 | drivers are loaded. |
| 1289 | |
Andrew Lunn | b868db9 | 2019-01-25 02:09:07 +0100 | [diff] [blame] | 1290 | config GPIO_TQMX86 |
| 1291 | tristate "TQ-Systems QTMX86 GPIO" |
| 1292 | depends on MFD_TQMX86 || COMPILE_TEST |
| 1293 | select GPIOLIB_IRQCHIP |
| 1294 | help |
| 1295 | This driver supports GPIO on the TQMX86 IO controller. |
| 1296 | |
David Brownell | e9d35947 | 2008-10-20 23:51:46 +0200 | [diff] [blame] | 1297 | config GPIO_TWL4030 |
| 1298 | tristate "TWL4030, TWL5030, and TPS659x0 GPIOs" |
| 1299 | depends on TWL4030_CORE |
| 1300 | help |
| 1301 | Say yes here to access the GPIO signals of various multi-function |
| 1302 | power management chips from Texas Instruments. |
| 1303 | |
Peter Ujfalusi | 70ffd69 | 2012-08-16 15:13:15 +0300 | [diff] [blame] | 1304 | config GPIO_TWL6040 |
| 1305 | tristate "TWL6040 GPO" |
| 1306 | depends on TWL6040_CORE |
| 1307 | help |
| 1308 | Say yes here to access the GPO signals of twl6040 |
| 1309 | audio chip from Texas Instruments. |
| 1310 | |
Linus Walleij | be9cab5 | 2015-04-08 14:51:23 +0200 | [diff] [blame] | 1311 | config GPIO_UCB1400 |
| 1312 | tristate "Philips UCB1400 GPIO" |
| 1313 | depends on UCB1400_CORE |
| 1314 | help |
| 1315 | This enables support for the Philips UCB1400 GPIO pins. |
| 1316 | The UCB1400 is an AC97 audio codec. |
| 1317 | |
Bin Gao | 0ba19cf | 2016-07-25 14:59:38 -0700 | [diff] [blame] | 1318 | config GPIO_WHISKEY_COVE |
| 1319 | tristate "GPIO support for Whiskey Cove PMIC" |
Andy Shevchenko | b5238b4 | 2017-04-04 15:38:56 +0300 | [diff] [blame] | 1320 | depends on (X86 || COMPILE_TEST) && INTEL_SOC_PMIC_BXTWC |
Bin Gao | 0ba19cf | 2016-07-25 14:59:38 -0700 | [diff] [blame] | 1321 | select GPIOLIB_IRQCHIP |
| 1322 | help |
| 1323 | Support for GPIO pins on Whiskey Cove PMIC. |
| 1324 | |
| 1325 | Say Yes if you have a Intel SoC based tablet with Whiskey Cove PMIC |
| 1326 | inside. |
| 1327 | |
| 1328 | This driver can also be built as a module. If so, the module will be |
| 1329 | called gpio-wcove. |
| 1330 | |
Mark Brown | e4b736f | 2009-07-27 14:46:00 +0100 | [diff] [blame] | 1331 | config GPIO_WM831X |
| 1332 | tristate "WM831x GPIOs" |
| 1333 | depends on MFD_WM831X |
| 1334 | help |
| 1335 | Say yes here to access the GPIO signals of WM831x power management |
| 1336 | chips from Wolfson Microelectronics. |
| 1337 | |
Mark Brown | 38f6ce4 | 2010-01-07 16:10:08 +0000 | [diff] [blame] | 1338 | config GPIO_WM8350 |
| 1339 | tristate "WM8350 GPIOs" |
| 1340 | depends on MFD_WM8350 |
| 1341 | help |
| 1342 | Say yes here to access the GPIO signals of WM8350 power management |
| 1343 | chips from Wolfson Microelectronics. |
| 1344 | |
Mark Brown | 2955c30 | 2010-01-29 18:20:30 +0000 | [diff] [blame] | 1345 | config GPIO_WM8994 |
| 1346 | tristate "WM8994 GPIOs" |
| 1347 | depends on MFD_WM8994 |
| 1348 | help |
| 1349 | Say yes here to access the GPIO signals of WM8994 audio hub |
| 1350 | CODECs from Wolfson Microelectronics. |
| 1351 | |
Linus Walleij | 177b038 | 2015-04-08 15:11:16 +0200 | [diff] [blame] | 1352 | endmenu |
| 1353 | |
| 1354 | menu "PCI GPIO expanders" |
| 1355 | depends on PCI |
Michael Buesch | ff1d5c2 | 2008-07-25 01:46:10 -0700 | [diff] [blame] | 1356 | |
Linus Walleij | 92c33ef | 2015-04-08 14:30:37 +0200 | [diff] [blame] | 1357 | config GPIO_AMD8111 |
| 1358 | tristate "AMD 8111 GPIO driver" |
Peter Robinson | 72aba2e | 2016-11-20 17:37:25 +0000 | [diff] [blame] | 1359 | depends on X86 || COMPILE_TEST |
Michael Buesch | ff1d5c2 | 2008-07-25 01:46:10 -0700 | [diff] [blame] | 1360 | help |
Linus Walleij | 92c33ef | 2015-04-08 14:30:37 +0200 | [diff] [blame] | 1361 | The AMD 8111 south bridge contains 32 GPIO pins which can be used. |
Andres Salomon | 5f0a96b0 | 2009-12-14 18:00:32 -0800 | [diff] [blame] | 1362 | |
Linus Walleij | 92c33ef | 2015-04-08 14:30:37 +0200 | [diff] [blame] | 1363 | Note, that usually system firmware/ACPI handles GPIO pins on their |
| 1364 | own and users might easily break their systems with uncarefull usage |
| 1365 | of this driver! |
Michael Buesch | ff1d5c2 | 2008-07-25 01:46:10 -0700 | [diff] [blame] | 1366 | |
Linus Walleij | 92c33ef | 2015-04-08 14:30:37 +0200 | [diff] [blame] | 1367 | If unsure, say N |
Andres Salomon | 5f0a96b0 | 2009-12-14 18:00:32 -0800 | [diff] [blame] | 1368 | |
Michael Buesch | ff1d5c2 | 2008-07-25 01:46:10 -0700 | [diff] [blame] | 1369 | config GPIO_BT8XX |
| 1370 | tristate "BT8XX GPIO abuser" |
Andrew F. Davis | 0374452 | 2015-12-06 14:52:45 -0600 | [diff] [blame] | 1371 | depends on VIDEO_BT848=n |
Michael Buesch | ff1d5c2 | 2008-07-25 01:46:10 -0700 | [diff] [blame] | 1372 | help |
Geert Uytterhoeven | 22520ed | 2014-03-11 11:23:44 +0100 | [diff] [blame] | 1373 | The BT8xx frame grabber chip has 24 GPIO pins that can be abused |
Michael Buesch | ff1d5c2 | 2008-07-25 01:46:10 -0700 | [diff] [blame] | 1374 | as a cheap PCI GPIO card. |
| 1375 | |
| 1376 | This chip can be found on Miro, Hauppauge and STB TV-cards. |
| 1377 | |
| 1378 | The card needs to be physically altered for using it as a |
| 1379 | GPIO card. For more information on how to build a GPIO card |
| 1380 | from a BT8xx TV card, see the documentation file at |
Jonathan Neuschäfer | 5f07224 | 2019-10-04 18:40:55 +0200 | [diff] [blame] | 1381 | Documentation/driver-api/gpio/bt8xxgpio.rst |
Michael Buesch | ff1d5c2 | 2008-07-25 01:46:10 -0700 | [diff] [blame] | 1382 | |
| 1383 | If unsure, say N. |
| 1384 | |
David Cohen | 84743ea | 2013-10-04 13:01:41 -0700 | [diff] [blame] | 1385 | config GPIO_INTEL_MID |
Andy Shevchenko | c78e3cf | 2016-07-07 23:45:08 +0300 | [diff] [blame] | 1386 | bool "Intel MID GPIO support" |
| 1387 | depends on X86_INTEL_MID |
Linus Walleij | fc34627 | 2014-05-29 16:52:46 +0200 | [diff] [blame] | 1388 | select GPIOLIB_IRQCHIP |
Alek Du | 8bf0261 | 2009-09-22 16:46:36 -0700 | [diff] [blame] | 1389 | help |
Andy Shevchenko | c78e3cf | 2016-07-07 23:45:08 +0300 | [diff] [blame] | 1390 | Say Y here to support Intel MID GPIO. |
Alek Du | 8bf0261 | 2009-09-22 16:46:36 -0700 | [diff] [blame] | 1391 | |
Andy Shevchenko | ccf6fd6 | 2016-07-08 14:08:23 +0300 | [diff] [blame] | 1392 | config GPIO_MERRIFIELD |
| 1393 | tristate "Intel Merrifield GPIO support" |
| 1394 | depends on X86_INTEL_MID |
| 1395 | select GPIOLIB_IRQCHIP |
| 1396 | help |
| 1397 | Say Y here to support Intel Merrifield GPIO. |
Juergen Beisert | 0c36ec3 | 2008-07-21 14:21:34 -0700 | [diff] [blame] | 1398 | |
Shravan Kumar Ramani | c78c42d | 2019-03-26 10:42:48 -0400 | [diff] [blame] | 1399 | config GPIO_MLXBF |
| 1400 | tristate "Mellanox BlueField SoC GPIO" |
Shravan Kumar Ramani | cbe706b | 2019-03-27 10:15:15 -0400 | [diff] [blame] | 1401 | depends on (MELLANOX_PLATFORM && ARM64 && ACPI) || (64BIT && COMPILE_TEST) |
Shravan Kumar Ramani | c78c42d | 2019-03-26 10:42:48 -0400 | [diff] [blame] | 1402 | select GPIO_GENERIC |
| 1403 | help |
| 1404 | Say Y here if you want GPIO support on Mellanox BlueField SoC. |
| 1405 | |
Asmaa Mnebhi | bc0ae0e | 2020-03-02 16:04:46 -0500 | [diff] [blame] | 1406 | config GPIO_MLXBF2 |
| 1407 | tristate "Mellanox BlueField 2 SoC GPIO" |
| 1408 | depends on (MELLANOX_PLATFORM && ARM64 && ACPI) || (64BIT && COMPILE_TEST) |
| 1409 | select GPIO_GENERIC |
| 1410 | help |
| 1411 | Say Y here if you want GPIO support on Mellanox BlueField 2 SoC. |
| 1412 | |
Linus Walleij | 92c33ef | 2015-04-08 14:30:37 +0200 | [diff] [blame] | 1413 | config GPIO_ML_IOH |
| 1414 | tristate "OKI SEMICONDUCTOR ML7213 IOH GPIO support" |
Peter Robinson | 72aba2e | 2016-11-20 17:37:25 +0000 | [diff] [blame] | 1415 | depends on X86 || COMPILE_TEST |
Linus Walleij | 92c33ef | 2015-04-08 14:30:37 +0200 | [diff] [blame] | 1416 | select GENERIC_IRQ_CHIP |
| 1417 | help |
| 1418 | ML7213 is companion chip for Intel Atom E6xx series. |
| 1419 | This driver can be used for OKI SEMICONDUCTOR ML7213 IOH(Input/Output |
| 1420 | Hub) which is for IVI(In-Vehicle Infotainment) use. |
| 1421 | This driver can access the IOH's GPIO device. |
| 1422 | |
Tomoya MORINAGA | 04c17aa8 | 2010-10-27 15:33:21 -0700 | [diff] [blame] | 1423 | config GPIO_PCH |
Tomoya MORINAGA | 868fea0 | 2011-10-28 09:23:32 +0900 | [diff] [blame] | 1424 | tristate "Intel EG20T PCH/LAPIS Semiconductor IOH(ML7223/ML7831) GPIO" |
Andrew F. Davis | 0374452 | 2015-12-06 14:52:45 -0600 | [diff] [blame] | 1425 | depends on X86_32 || MIPS || COMPILE_TEST |
Tomoya MORINAGA | 38eb18a | 2011-07-21 09:19:59 +0900 | [diff] [blame] | 1426 | select GENERIC_IRQ_CHIP |
Tomoya MORINAGA | 04c17aa8 | 2010-10-27 15:33:21 -0700 | [diff] [blame] | 1427 | help |
| 1428 | This driver is for PCH(Platform controller Hub) GPIO of Intel Topcliff |
| 1429 | which is an IOH(Input/Output Hub) for x86 embedded processor. |
| 1430 | This driver can access PCH GPIO device. |
| 1431 | |
Tomoya MORINAGA | 868fea0 | 2011-10-28 09:23:32 +0900 | [diff] [blame] | 1432 | This driver also can be used for LAPIS Semiconductor IOH(Input/ |
| 1433 | Output Hub), ML7223 and ML7831. |
Tomoya MORINAGA | bc786cc | 2011-05-09 19:58:49 +0900 | [diff] [blame] | 1434 | ML7223 IOH is for MP(Media Phone) use. |
Tomoya MORINAGA | 868fea0 | 2011-10-28 09:23:32 +0900 | [diff] [blame] | 1435 | ML7831 IOH is for general purpose use. |
| 1436 | ML7223/ML7831 is companion chip for Intel Atom E6xx series. |
| 1437 | ML7223/ML7831 is completely compatible for Intel EG20T PCH. |
Tomoya MORINAGA | bc786cc | 2011-05-09 19:58:49 +0900 | [diff] [blame] | 1438 | |
William Breathitt Gray | 02e74fc | 2017-02-01 15:37:55 -0500 | [diff] [blame] | 1439 | config GPIO_PCI_IDIO_16 |
| 1440 | tristate "ACCES PCI-IDIO-16 GPIO support" |
| 1441 | select GPIOLIB_IRQCHIP |
| 1442 | help |
| 1443 | Enables GPIO support for the ACCES PCI-IDIO-16. An interrupt is |
| 1444 | generated when any of the inputs change state (low to high or high to |
| 1445 | low). Input filter control is not supported by this driver, and the |
| 1446 | input filters are deactivated by this driver. |
| 1447 | |
William Breathitt Gray | 5855620 | 2018-01-09 17:21:45 -0500 | [diff] [blame] | 1448 | config GPIO_PCIE_IDIO_24 |
| 1449 | tristate "ACCES PCIe-IDIO-24 GPIO support" |
| 1450 | select GPIOLIB_IRQCHIP |
| 1451 | help |
| 1452 | Enables GPIO support for the ACCES PCIe-IDIO-24 family (PCIe-IDIO-24, |
| 1453 | PCIe-IDI-24, PCIe-IDO-24, PCIe-IDIO-12). An interrupt is generated |
| 1454 | when any of the inputs change state (low to high or high to low). |
| 1455 | Input filter control is not supported by this driver, and the input |
| 1456 | filters are deactivated by this driver. |
| 1457 | |
Florian Fainelli | 9956d02 | 2010-03-21 01:06:09 +0100 | [diff] [blame] | 1458 | config GPIO_RDC321X |
| 1459 | tristate "RDC R-321x GPIO support" |
Randy Dunlap | e4be3cb | 2010-05-11 13:24:20 -0700 | [diff] [blame] | 1460 | select MFD_CORE |
Florian Fainelli | 9956d02 | 2010-03-21 01:06:09 +0100 | [diff] [blame] | 1461 | select MFD_RDC321X |
| 1462 | help |
| 1463 | Support for the RDC R321x SoC GPIOs over southbridge |
| 1464 | PCI configuration space. |
| 1465 | |
Richard Röjfors | 35570ac | 2009-12-15 16:46:18 -0800 | [diff] [blame] | 1466 | config GPIO_SODAVILLE |
David Brownell | a9c5fff | 2008-02-04 22:28:17 -0800 | [diff] [blame] | 1467 | bool "Intel Sodaville GPIO support" |
Andrew F. Davis | 0374452 | 2015-12-06 14:52:45 -0600 | [diff] [blame] | 1468 | depends on X86 && OF |
Juergen Beisert | 0c36ec3 | 2008-07-21 14:21:34 -0700 | [diff] [blame] | 1469 | select GPIO_GENERIC |
| 1470 | select GENERIC_IRQ_CHIP |
Wolfram Sang | e952805 | 2010-03-05 13:44:33 -0800 | [diff] [blame] | 1471 | help |
Juergen Beisert | 0c36ec3 | 2008-07-21 14:21:34 -0700 | [diff] [blame] | 1472 | Say Y here to support Intel Sodaville GPIO. |
Wolfram Sang | e952805 | 2010-03-05 13:44:33 -0800 | [diff] [blame] | 1473 | |
Linus Walleij | 177b038 | 2015-04-08 15:11:16 +0200 | [diff] [blame] | 1474 | endmenu |
David Brownell | e58b9e2 | 2008-02-04 22:28:25 -0800 | [diff] [blame] | 1475 | |
Linus Walleij | 177b038 | 2015-04-08 15:11:16 +0200 | [diff] [blame] | 1476 | menu "SPI GPIO expanders" |
| 1477 | depends on SPI_MASTER |
David Brownell | e58b9e2 | 2008-02-04 22:28:25 -0800 | [diff] [blame] | 1478 | |
Linus Walleij | a7ec2e7 | 2015-04-08 14:34:51 +0200 | [diff] [blame] | 1479 | config GPIO_74X164 |
| 1480 | tristate "74x164 serial-in/parallel-out 8-bits shift register" |
Linus Walleij | 048c28c | 2016-08-16 12:07:31 +0200 | [diff] [blame] | 1481 | depends on OF_GPIO |
Linus Walleij | a7ec2e7 | 2015-04-08 14:34:51 +0200 | [diff] [blame] | 1482 | help |
| 1483 | Driver for 74x164 compatible serial-in/parallel-out 8-outputs |
| 1484 | shift registers. This driver can be used to provide access |
| 1485 | to more gpio outputs. |
David Brownell | e58b9e2 | 2008-02-04 22:28:25 -0800 | [diff] [blame] | 1486 | |
Lukas Wunner | b2f68ed | 2017-10-12 12:40:10 +0200 | [diff] [blame] | 1487 | config GPIO_MAX3191X |
| 1488 | tristate "Maxim MAX3191x industrial serializer" |
| 1489 | select CRC8 |
| 1490 | help |
| 1491 | GPIO driver for Maxim MAX31910, MAX31911, MAX31912, MAX31913, |
| 1492 | MAX31953 and MAX31963 industrial serializer, a daisy-chainable |
| 1493 | chip to make 8 digital 24V inputs available via SPI. Supports |
| 1494 | CRC checksums to guard against electromagnetic interference, |
| 1495 | as well as undervoltage and overtemperature detection. |
| 1496 | |
David Brownell | e58b9e2 | 2008-02-04 22:28:25 -0800 | [diff] [blame] | 1497 | config GPIO_MAX7301 |
| 1498 | tristate "Maxim MAX7301 GPIO expander" |
Richard Röjfors | 1e5db00 | 2009-09-22 16:46:34 -0700 | [diff] [blame] | 1499 | select GPIO_MAX730X |
| 1500 | help |
| 1501 | GPIO driver for Maxim MAX7301 SPI-based GPIO expander. |
| 1502 | |
Linus Walleij | 0963670 | 2015-11-01 10:50:19 +0100 | [diff] [blame] | 1503 | config GPIO_MC33880 |
| 1504 | tristate "Freescale MC33880 high-side/low-side switch" |
| 1505 | help |
| 1506 | SPI driver for Freescale MC33880 high-side/low-side switch. |
| 1507 | This provides GPIO interface supporting inputs and outputs. |
| 1508 | |
Andrew F. Davis | df6df93 | 2016-01-25 10:37:31 -0600 | [diff] [blame] | 1509 | config GPIO_PISOSR |
| 1510 | tristate "Generic parallel-in/serial-out shift register" |
| 1511 | help |
| 1512 | GPIO driver for SPI compatible parallel-in/serial-out shift |
| 1513 | registers. These are input only devices. |
| 1514 | |
Nandor Han | 5704520 | 2017-05-15 08:58:25 +0300 | [diff] [blame] | 1515 | config GPIO_XRA1403 |
| 1516 | tristate "EXAR XRA1403 16-bit GPIO expander" |
Arnd Bergmann | 665dff9 | 2017-05-30 13:13:17 +0200 | [diff] [blame] | 1517 | select REGMAP_SPI |
Nandor Han | 5704520 | 2017-05-15 08:58:25 +0300 | [diff] [blame] | 1518 | help |
| 1519 | GPIO driver for EXAR XRA1403 16-bit SPI-based GPIO expander. |
| 1520 | |
Marek Behún | 856ed97 | 2019-08-12 18:11:17 +0200 | [diff] [blame] | 1521 | config GPIO_MOXTET |
| 1522 | tristate "Turris Mox Moxtet bus GPIO expander" |
| 1523 | depends on MOXTET |
| 1524 | help |
| 1525 | Say yes here if you are building for the Turris Mox router. |
| 1526 | This is the driver needed for configuring the GPIOs via the Moxtet |
| 1527 | bus. For example the Mox module with SFP cage needs this driver |
| 1528 | so that phylink can use corresponding GPIOs. |
| 1529 | |
Linus Walleij | 0963670 | 2015-11-01 10:50:19 +0100 | [diff] [blame] | 1530 | endmenu |
| 1531 | |
Linus Walleij | 177b038 | 2015-04-08 15:11:16 +0200 | [diff] [blame] | 1532 | menu "USB GPIO expanders" |
| 1533 | depends on USB |
Lars Poeschel | 9d5b72d | 2012-11-05 15:48:24 +0100 | [diff] [blame] | 1534 | |
| 1535 | config GPIO_VIPERBOARD |
| 1536 | tristate "Viperboard GPIO a & b support" |
Andrew F. Davis | 0374452 | 2015-12-06 14:52:45 -0600 | [diff] [blame] | 1537 | depends on MFD_VIPERBOARD |
Lars Poeschel | 9d5b72d | 2012-11-05 15:48:24 +0100 | [diff] [blame] | 1538 | help |
| 1539 | Say yes here to access the GPIO signals of Nano River |
| 1540 | Technologies Viperboard. There are two GPIO chips on the |
| 1541 | board: gpioa and gpiob. |
Enrico Weigelt, metux IT consult | c42e34c | 2019-03-05 01:35:31 +0100 | [diff] [blame] | 1542 | See viperboard API specification and Nano |
| 1543 | River Tech's viperboard.h for detailed meaning |
| 1544 | of the module parameters. |
Lars Poeschel | 9d5b72d | 2012-11-05 15:48:24 +0100 | [diff] [blame] | 1545 | |
Linus Walleij | 177b038 | 2015-04-08 15:11:16 +0200 | [diff] [blame] | 1546 | endmenu |
Daniel Baluta | 6732127 | 2014-11-06 15:48:05 +0200 | [diff] [blame] | 1547 | |
Geert Uytterhoeven | 828546e | 2020-05-11 16:52:55 +0200 | [diff] [blame] | 1548 | config GPIO_AGGREGATOR |
| 1549 | tristate "GPIO Aggregator" |
| 1550 | help |
| 1551 | Say yes here to enable the GPIO Aggregator, which provides a way to |
| 1552 | aggregate existing GPIO lines into a new virtual GPIO chip. |
| 1553 | This can serve the following purposes: |
| 1554 | - Assign permissions for a collection of GPIO lines to a user, |
| 1555 | - Export a collection of GPIO lines to a virtual machine, |
| 1556 | - Provide a generic driver for a GPIO-operated device in an |
| 1557 | industrial control context, to be operated from userspace using |
| 1558 | the GPIO chardev interface. |
| 1559 | |
Bartosz Golaszewski | 6e4484e | 2019-03-13 11:37:17 +0100 | [diff] [blame] | 1560 | config GPIO_MOCKUP |
| 1561 | tristate "GPIO Testing Driver" |
Bartosz Golaszewski | 6e4484e | 2019-03-13 11:37:17 +0100 | [diff] [blame] | 1562 | select IRQ_SIM |
| 1563 | help |
| 1564 | This enables GPIO Testing driver, which provides a way to test GPIO |
| 1565 | subsystem through sysfs(or char device) and debugfs. GPIO_SYSFS |
| 1566 | must be selected for this test. |
| 1567 | User could use it through the script in |
| 1568 | tools/testing/selftests/gpio/gpio-mockup.sh. Reference the usage in |
| 1569 | it. |
| 1570 | |
Michael Buesch | 7444a72 | 2008-07-25 01:46:11 -0700 | [diff] [blame] | 1571 | endif |