Commit | Line | Data |
---|---|---|
ec8f24b7 | 1 | # SPDX-License-Identifier: GPL-2.0-only |
a9c5fff5 | 2 | # |
e849dc04 | 3 | # GPIO infrastructure and drivers |
a9c5fff5 DB |
4 | # |
5 | ||
7444a72e MB |
6 | menuconfig GPIOLIB |
7 | bool "GPIO Support" | |
7444a72e MB |
8 | help |
9 | This enables GPIO support through the generic GPIO library. | |
dd1695a2 | 10 | You only need to enable this if you also want to enable |
e849dc04 | 11 | one or more of the GPIO drivers below. |
7444a72e MB |
12 | |
13 | If unsure, say N. | |
a9c5fff5 | 14 | |
7444a72e | 15 | if GPIOLIB |
a9c5fff5 | 16 | |
3027743f LA |
17 | config GPIOLIB_FASTPATH_LIMIT |
18 | int "Maximum number of GPIOs for fast path" | |
19 | range 32 512 | |
20 | default 512 | |
21 | help | |
c42e34c9 EWI |
22 | This adjusts the point at which certain APIs will switch from |
23 | using a stack allocated buffer to a dynamically allocated buffer. | |
3027743f | 24 | |
c42e34c9 EWI |
25 | You shouldn't need to change this unless you really need to |
26 | optimize either stack space or performance. Change this carefully | |
27 | since setting an incorrect value could cause stack corruption. | |
3027743f | 28 | |
f141ed65 GL |
29 | config OF_GPIO |
30 | def_bool y | |
92c74bce | 31 | depends on OF |
2527ecc9 | 32 | depends on HAS_IOMEM |
f141ed65 | 33 | |
e29482e8 MN |
34 | config GPIO_ACPI |
35 | def_bool y | |
36 | depends on ACPI | |
37 | ||
14250520 | 38 | config GPIOLIB_IRQCHIP |
fc346270 | 39 | select IRQ_DOMAIN |
14250520 LW |
40 | bool |
41 | ||
a99cc668 AB |
42 | config OF_GPIO_MM_GPIOCHIP |
43 | bool | |
44 | help | |
45 | This adds support for the legacy 'struct of_mm_gpio_chip' interface | |
46 | from PowerPC. Existing drivers using this interface need to select | |
47 | this symbol, but new drivers should use the generic gpio-regmap | |
48 | infrastructure instead. | |
49 | ||
a9c5fff5 DB |
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. | |
692105b8 ML |
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 | |
a9c5fff5 DB |
58 | slower. The diagnostics help catch the type of setup errors |
59 | that are most common when setting up new platforms or boards. | |
60 | ||
d8f388d8 | 61 | config GPIO_SYSFS |
3b4feb21 | 62 | bool "/sys/class/gpio/... (sysfs interface)" if EXPERT |
4c0ea233 | 63 | depends on SYSFS |
3b4feb21 | 64 | select GPIO_CDEV # We need to encourage the new ABI |
d8f388d8 | 65 | help |
db9477f8 | 66 | Say Y here to add the legacy sysfs interface for GPIOs. |
d8f388d8 | 67 | |
db9477f8 LW |
68 | This ABI is deprecated. If you want to use GPIO from userspace, |
69 | use the character device /dev/gpiochipN with the appropriate | |
d143493c KG |
70 | ioctl() operations instead. |
71 | ||
72 | config GPIO_CDEV | |
3dcf0643 | 73 | bool "Character device (/dev/gpiochipN) support" if EXPERT |
d143493c KG |
74 | default y |
75 | help | |
76 | Say Y here to add the character device /dev/gpiochipN interface | |
77 | for GPIOs. The character device allows userspace to control GPIOs | |
78 | using ioctl() operations. | |
79 | ||
80 | Only say N if you are sure that the GPIO character device is not | |
81 | required. | |
82 | ||
83 | If unsure, say Y. | |
d8f388d8 | 84 | |
957ebb61 KG |
85 | config GPIO_CDEV_V1 |
86 | bool "Support GPIO ABI Version 1" | |
87 | default y | |
88 | depends on GPIO_CDEV | |
89 | help | |
90 | Say Y here to support version 1 of the GPIO CDEV ABI. | |
91 | ||
92 | This ABI version is deprecated. | |
93 | Please use the latest ABI for new developments. | |
94 | ||
95 | If unsure, say Y. | |
96 | ||
c103de24 | 97 | config GPIO_GENERIC |
3085a4a4 | 98 | depends on HAS_IOMEM # Only for IOMEM drivers |
c103de24 GL |
99 | tristate |
100 | ||
ebe36319 | 101 | config GPIO_REGMAP |
d49765b5 | 102 | select REGMAP |
ebe36319 MW |
103 | tristate |
104 | ||
9d50f95b CK |
105 | config GPIO_SWNODE_UNDEFINED |
106 | bool | |
107 | help | |
108 | This adds a special place holder for software nodes to contain an | |
109 | undefined GPIO reference, this is primarily used by SPI to allow a | |
110 | list of GPIO chip selects to mark a certain chip select as being | |
111 | controlled the SPI device's internal chip select mechanism and not | |
112 | a GPIO. | |
113 | ||
e849dc04 | 114 | # put drivers in the right section, in alphabetical order |
a9c5fff5 | 115 | |
177b0381 | 116 | # This symbol is selected by both I2C and SPI expanders |
e952805d WS |
117 | config GPIO_MAX730X |
118 | tristate | |
119 | ||
b9b1fc1a WBG |
120 | config GPIO_IDIO_16 |
121 | tristate | |
db022478 WBG |
122 | select REGMAP_IRQ |
123 | select GPIOLIB_IRQCHIP | |
124 | select GPIO_REGMAP | |
b9b1fc1a WBG |
125 | help |
126 | Enables support for the idio-16 library functions. The idio-16 library | |
127 | provides functions to facilitate communication with devices within the | |
128 | ACCES IDIO-16 family such as the 104-IDIO-16 and the PCI-IDIO-16. | |
129 | ||
130 | If built as a module its name will be gpio-idio-16. | |
131 | ||
177b0381 | 132 | menu "Memory mapped GPIO drivers" |
3085a4a4 | 133 | depends on HAS_IOMEM |
0bcb6069 | 134 | |
af0a33e2 AS |
135 | config GPIO_74XX_MMIO |
136 | tristate "GPIO driver for 74xx-ICs with MMIO access" | |
137 | depends on OF_GPIO | |
138 | select GPIO_GENERIC | |
139 | help | |
140 | Say yes here to support GPIO functionality for 74xx-compatible ICs | |
141 | with MMIO access. Compatible models include: | |
142 | 1 bit: 741G125 (Input), 741G74 (Output) | |
143 | 2 bits: 742G125 (Input), 7474 (Output) | |
144 | 4 bits: 74125 (Input), 74175 (Output) | |
145 | 6 bits: 74365 (Input), 74174 (Output) | |
146 | 8 bits: 74244 (Input), 74273 (Output) | |
147 | 16 bits: 741624 (Input), 7416374 (Output) | |
148 | ||
223fa272 LW |
149 | config GPIO_ALTERA |
150 | tristate "Altera GPIO" | |
223fa272 LW |
151 | select GPIOLIB_IRQCHIP |
152 | help | |
153 | Say Y or M here to build support for the Altera PIO device. | |
154 | ||
155 | If driver is built as a module it will be called gpio-altera. | |
156 | ||
6057d40f YT |
157 | config GPIO_AMDPT |
158 | tristate "AMD Promontory GPIO support" | |
159 | depends on ACPI | |
574b782e | 160 | select GPIO_GENERIC |
6057d40f | 161 | help |
dd1695a2 RD |
162 | Driver for GPIO functionality on Promontory IOHub. |
163 | Requires ACPI ASL code to enumerate as a platform device. | |
6057d40f | 164 | |
361b7911 JS |
165 | config GPIO_ASPEED |
166 | tristate "Aspeed GPIO support" | |
167 | depends on (ARCH_ASPEED || COMPILE_TEST) && OF_GPIO | |
168 | select GPIOLIB_IRQCHIP | |
169 | help | |
170 | Say Y here to support Aspeed AST2400 and AST2500 GPIO controllers. | |
171 | ||
f8b410e3 LW |
172 | config GPIO_ASPEED_SGPIO |
173 | bool "Aspeed SGPIO support" | |
174 | depends on (ARCH_ASPEED || COMPILE_TEST) && OF_GPIO | |
175 | select GPIO_GENERIC | |
176 | select GPIOLIB_IRQCHIP | |
177 | help | |
178 | Say Y here to support Aspeed AST2500 SGPIO functionality. | |
179 | ||
ab32770e AB |
180 | config GPIO_ATH79 |
181 | tristate "Atheros AR71XX/AR724X/AR913X GPIO support" | |
182 | default y if ATH79 | |
409d8783 | 183 | depends on ATH79 || COMPILE_TEST |
ab32770e | 184 | select GPIO_GENERIC |
2b8f89e1 | 185 | select GPIOLIB_IRQCHIP |
ab32770e AB |
186 | help |
187 | Select this option to enable GPIO driver for | |
188 | Atheros AR71XX/AR724X/AR913X SoC devices. | |
189 | ||
a98d90e7 DS |
190 | config GPIO_RASPBERRYPI_EXP |
191 | tristate "Raspberry Pi 3 GPIO Expander" | |
192 | default RASPBERRYPI_FIRMWARE | |
193 | depends on OF_GPIO | |
94337b72 BS |
194 | # Make sure not 'y' when RASPBERRYPI_FIRMWARE is 'm'. This can only |
195 | # happen when COMPILE_TEST=y, hence the added !RASPBERRYPI_FIRMWARE. | |
7ed91505 | 196 | depends on (ARCH_BCM2835 && RASPBERRYPI_FIRMWARE) || (COMPILE_TEST && !RASPBERRYPI_FIRMWARE) |
a98d90e7 DS |
197 | help |
198 | Turn on GPIO support for the expander on Raspberry Pi 3 boards, using | |
199 | the firmware mailbox to communicate with VideoCore on BCM283x chips. | |
200 | ||
ea948cff LW |
201 | config GPIO_BCM_KONA |
202 | bool "Broadcom Kona GPIO" | |
c9ab610e | 203 | depends on ARCH_BCM_MOBILE || COMPILE_TEST |
86fabf1b | 204 | select GPIOLIB_IRQCHIP |
ea948cff LW |
205 | help |
206 | Turn on GPIO support for Broadcom "Kona" chips. | |
207 | ||
6a41b6c5 CP |
208 | config GPIO_BCM_XGS_IPROC |
209 | tristate "BRCM XGS iProc GPIO support" | |
210 | depends on OF_GPIO && (ARCH_BCM_IPROC || COMPILE_TEST) | |
211 | select GPIO_GENERIC | |
212 | select GPIOLIB_IRQCHIP | |
213 | default ARCH_BCM_IPROC | |
214 | help | |
215 | Say yes here to enable GPIO support for Broadcom XGS iProc SoCs. | |
216 | ||
602ae04f NP |
217 | config GPIO_BLZP1600 |
218 | tristate "Blaize BLZP1600 GPIO support" | |
219 | default y if ARCH_BLAIZE | |
df9b3454 | 220 | depends on ARCH_BLAIZE || COMPILE_TEST |
602ae04f NP |
221 | depends on OF_GPIO |
222 | select GPIO_GENERIC | |
223 | select GPIOLIB_IRQCHIP | |
224 | help | |
225 | Say Y or M here to add support for the Blaize BLZP1600 GPIO device. | |
226 | The controller is based on the Verisilicon Microelectronics GPIO APB v0.2 | |
227 | IP block. | |
228 | ||
3b0213d5 GF |
229 | config GPIO_BRCMSTB |
230 | tristate "BRCMSTB GPIO support" | |
a02588a0 | 231 | default y if (ARCH_BRCMSTB || BMIPS_GENERIC) |
e7ba9d11 | 232 | depends on OF_GPIO && (ARCH_BRCMSTB || ARCH_BCM2835 || BMIPS_GENERIC || COMPILE_TEST) |
3b0213d5 | 233 | select GPIO_GENERIC |
0ba31dc2 | 234 | select IRQ_DOMAIN |
3b0213d5 GF |
235 | help |
236 | Say yes here to enable GPIO support for Broadcom STB (BCM7XXX) SoCs. | |
237 | ||
72ab2f76 JK |
238 | config GPIO_CADENCE |
239 | tristate "Cadence GPIO support" | |
240 | depends on OF_GPIO | |
241 | select GPIO_GENERIC | |
242 | select GPIOLIB_IRQCHIP | |
243 | help | |
244 | Say yes here to enable support for Cadence GPIO controller. | |
245 | ||
a3b8d4a5 | 246 | config GPIO_CLPS711X |
55fe14ab | 247 | tristate "CLPS711X GPIO support" |
ffd4bf1a | 248 | depends on ARCH_CLPS711X || COMPILE_TEST |
55fe14ab AS |
249 | select GPIO_GENERIC |
250 | help | |
251 | Say yes here to support GPIO on CLPS711X SoCs. | |
a3b8d4a5 | 252 | |
ee89cf63 | 253 | config GPIO_DAVINCI |
8dab99c9 | 254 | tristate "TI Davinci/Keystone GPIO support" |
ee89cf63 | 255 | default y if ARCH_DAVINCI |
56d6ff4b | 256 | depends on ((ARM || ARM64) && (ARCH_DAVINCI || ARCH_KEYSTONE || ARCH_K3)) || COMPILE_TEST |
43475664 | 257 | select GPIOLIB_IRQCHIP |
ee89cf63 GS |
258 | help |
259 | Say yes here to enable GPIO support for TI Davinci/Keystone SoCs. | |
260 | ||
7779b345 JI |
261 | config GPIO_DWAPB |
262 | tristate "Synopsys DesignWare APB GPIO driver" | |
263 | select GPIO_GENERIC | |
0ea68393 | 264 | select GPIOLIB_IRQCHIP |
7779b345 JI |
265 | help |
266 | Say Y or M here to build support for the Synopsys DesignWare APB | |
267 | GPIO block. | |
268 | ||
25518e02 BW |
269 | config GPIO_EIC_SPRD |
270 | tristate "Spreadtrum EIC support" | |
271 | depends on ARCH_SPRD || COMPILE_TEST | |
272 | depends on OF_GPIO | |
273 | select GPIOLIB_IRQCHIP | |
274 | help | |
275 | Say yes here to support Spreadtrum EIC device. | |
276 | ||
a07e103e MD |
277 | config GPIO_EM |
278 | tristate "Emma Mobile GPIO" | |
22eaf13c | 279 | depends on (ARCH_EMEV2 || COMPILE_TEST) && OF_GPIO |
a07e103e MD |
280 | help |
281 | Say yes here to support GPIO on Renesas Emma Mobile SoCs. | |
282 | ||
0868ad38 JC |
283 | config GPIO_EN7523 |
284 | tristate "Airoha GPIO support" | |
285 | depends on ARCH_AIROHA | |
286 | default ARCH_AIROHA | |
287 | select GPIO_GENERIC | |
288 | select GPIOLIB_IRQCHIP | |
289 | help | |
290 | Say Y or M here to support the GPIO controller block on the | |
291 | Airoha EN7523 SoC. It supports two banks of 32 GPIOs. | |
292 | ||
c6b52c13 HS |
293 | config GPIO_EP93XX |
294 | def_bool y | |
295 | depends on ARCH_EP93XX | |
1e4c8842 | 296 | select GPIO_GENERIC |
a419a3d9 | 297 | select GPIOLIB_IRQCHIP |
c6b52c13 | 298 | |
6596e59e SM |
299 | config GPIO_EXAR |
300 | tristate "Support for GPIO pins on XR17V352/354/358" | |
301 | depends on SERIAL_8250_EXAR | |
36fb7218 | 302 | select REGMAP_MMIO |
6596e59e SM |
303 | help |
304 | Selecting this option will enable handling of GPIO pins present | |
305 | on Exar XR17V352/354/358 chips. | |
306 | ||
223fa272 LW |
307 | config GPIO_GE_FPGA |
308 | bool "GE FPGA based GPIO" | |
55b47353 | 309 | depends on GE_FPGA || COMPILE_TEST |
223fa272 LW |
310 | select GPIO_GENERIC |
311 | help | |
312 | Support for common GPIO functionality provided on some GE Single Board | |
313 | Computers. | |
314 | ||
315 | This driver provides basic support (configure as input or output, read | |
316 | and write pin state) for GPIO implemented in a number of GE single | |
317 | board computers. | |
318 | ||
9d3a15aa LW |
319 | config GPIO_FTGPIO010 |
320 | bool "Faraday FTGPIO010 GPIO" | |
49cec4d8 LW |
321 | depends on OF_GPIO |
322 | select GPIO_GENERIC | |
323 | select GPIOLIB_IRQCHIP | |
d8307c09 | 324 | default (ARCH_GEMINI || ARCH_MOXART) |
49cec4d8 | 325 | help |
9d3a15aa LW |
326 | Support for common GPIOs from the Faraday FTGPIO010 IP core, found in |
327 | Cortina systems Gemini platforms, Moxa ART and others. | |
49cec4d8 | 328 | |
223fa272 LW |
329 | config GPIO_GENERIC_PLATFORM |
330 | tristate "Generic memory-mapped GPIO controller support (MMIO platform device)" | |
331 | select GPIO_GENERIC | |
332 | help | |
333 | Say yes here to support basic platform_device memory-mapped GPIO controllers. | |
334 | ||
ecc4b141 AV |
335 | config GPIO_GRANITERAPIDS |
336 | tristate "Intel Granite Rapids-D vGPIO support" | |
337 | depends on X86 || COMPILE_TEST | |
338 | select GPIOLIB_IRQCHIP | |
339 | help | |
340 | Select this to enable virtual GPIO support on platforms with the | |
341 | following SoCs: | |
342 | ||
343 | - Intel Granite Rapids-D | |
344 | ||
345 | The driver enables basic GPIO functionality and implements interrupt | |
346 | support. The virtual GPIO driver controls GPIO lines via a firmware | |
347 | interface. The physical GPIO pins reside on device that is external | |
348 | from the main SoC package, such as a BMC or a CPLD. | |
349 | ||
350 | To compile this driver as a module, choose M here: the module will | |
351 | be called gpio-graniterapids. | |
352 | ||
223fa272 LW |
353 | config GPIO_GRGPIO |
354 | tristate "Aeroflex Gaisler GRGPIO support" | |
5393f40a | 355 | depends on OF || COMPILE_TEST |
223fa272 | 356 | select GPIO_GENERIC |
3dff3563 | 357 | select GPIOLIB_IRQCHIP |
223fa272 LW |
358 | help |
359 | Select this to support Aeroflex Gaisler GRGPIO cores from the GRLIB | |
360 | VHDL IP core library. | |
361 | ||
356b01a9 LJ |
362 | config GPIO_HISI |
363 | tristate "HiSilicon GPIO controller driver" | |
80280df7 | 364 | depends on ARM64 || COMPILE_TEST |
356b01a9 LJ |
365 | select GPIO_GENERIC |
366 | select GPIOLIB_IRQCHIP | |
367 | help | |
368 | Say Y or M here to build support for the HiSilicon GPIO controller | |
369 | driver GPIO block. | |
dd1695a2 | 370 | This GPIO controller supports double-edge interrupt and multi-core |
356b01a9 LJ |
371 | concurrent access. |
372 | ||
8f55fed3 JN |
373 | config GPIO_HLWD |
374 | tristate "Nintendo Wii (Hollywood) GPIO" | |
375 | depends on OF_GPIO | |
376 | select GPIO_GENERIC | |
588de43c | 377 | select GPIOLIB_IRQCHIP |
8f55fed3 JN |
378 | help |
379 | Select this to support the GPIO controller of the Nintendo Wii. | |
380 | ||
381 | If unsure, say N. | |
382 | ||
223fa272 LW |
383 | config GPIO_ICH |
384 | tristate "Intel ICH GPIO" | |
29f4c4da | 385 | depends on (X86 && LPC_ICH) || (COMPILE_TEST && HAS_IOPORT) |
223fa272 LW |
386 | help |
387 | Say yes here to support the GPIO functionality of a number of Intel | |
388 | ICH-based chipsets. Currently supported devices: ICH6, ICH7, ICH8 | |
dd1695a2 | 389 | ICH9, ICH10, Series 5/3400 (e.g. Ibex Peak), Series 6/C200 (e.g. |
223fa272 LW |
390 | Cougar Point), NM10 (Tiger Point), and 3100 (Whitmore Lake). |
391 | ||
392 | If unsure, say N. | |
393 | ||
0bd459dd SW |
394 | config GPIO_IMX_SCU |
395 | def_bool y | |
396 | depends on IMX_SCU | |
397 | ||
813e7d36 LW |
398 | config GPIO_IXP4XX |
399 | bool "Intel IXP4xx GPIO" | |
813e7d36 | 400 | depends on ARCH_IXP4XX |
c83227a5 | 401 | depends on OF |
813e7d36 | 402 | select GPIO_GENERIC |
aa7d618a | 403 | select GPIOLIB_IRQCHIP |
813e7d36 LW |
404 | select IRQ_DOMAIN_HIERARCHY |
405 | help | |
406 | Say yes here to support the GPIO functionality of a number of Intel | |
407 | IXP4xx series of chips. | |
408 | ||
409 | If unsure, say N. | |
c83227a5 | 410 | |
c16485ad PK |
411 | config GPIO_LOGICVC |
412 | tristate "Xylon LogiCVC GPIO support" | |
413 | depends on MFD_SYSCON && OF | |
414 | help | |
415 | Say yes here to support GPIO functionality of the Xylon LogiCVC | |
416 | programmable logic block. | |
813e7d36 | 417 | |
223fa272 LW |
418 | config GPIO_LOONGSON |
419 | bool "Loongson-2/3 GPIO support" | |
268a2d60 | 420 | depends on CPU_LOONGSON2EF || CPU_LOONGSON64 |
223fa272 | 421 | help |
dd1695a2 | 422 | Driver for GPIO functionality on Loongson-2F/3A/3B processors. |
223fa272 | 423 | |
7944d3b7 YZ |
424 | config GPIO_LOONGSON_64BIT |
425 | tristate "Loongson 64 bit GPIO support" | |
426 | depends on LOONGARCH || COMPILE_TEST | |
b96eb88f | 427 | depends on OF_GPIO |
7944d3b7 YZ |
428 | select GPIO_GENERIC |
429 | help | |
430 | Say yes here to support the GPIO functionality of a number of | |
431 | Loongson series of chips. The Loongson GPIO controller supports | |
432 | up to 60 GPIOS in total, 4 of which are dedicated GPIO pins, and | |
433 | the remaining 56 are reused with other functions, with edge or | |
434 | level triggered interrupts. | |
435 | ||
13a43fd9 | 436 | config GPIO_LPC18XX |
54b72998 | 437 | tristate "NXP LPC18XX/43XX GPIO support" |
13a43fd9 JE |
438 | default y if ARCH_LPC18XX |
439 | depends on OF_GPIO && (ARCH_LPC18XX || COMPILE_TEST) | |
5ddabfe8 | 440 | select IRQ_DOMAIN_HIERARCHY |
01e4397d | 441 | select GPIOLIB_IRQCHIP |
13a43fd9 JE |
442 | help |
443 | Select this option to enable GPIO driver for | |
444 | NXP LPC18XX/43XX devices. | |
445 | ||
f2ee7314 AB |
446 | config GPIO_LPC32XX |
447 | tristate "NXP LPC32XX GPIO support" | |
448 | depends on OF_GPIO && (ARCH_LPC32XX || COMPILE_TEST) | |
449 | help | |
450 | Select this option to enable GPIO driver for | |
451 | NXP LPC32XX devices. | |
452 | ||
0da094d8 | 453 | config GPIO_MB86S7X |
e1289dba | 454 | tristate "GPIO support for Fujitsu MB86S7x Platforms" |
0da094d8 JB |
455 | help |
456 | Say yes here to support the GPIO controller in Fujitsu MB86S70 SoCs. | |
457 | ||
f436bc27 AW |
458 | config GPIO_MENZ127 |
459 | tristate "MEN 16Z127 GPIO support" | |
460 | depends on MCB | |
461 | select GPIO_GENERIC | |
462 | help | |
dd1695a2 | 463 | Say yes here to support the MEN 16Z127 GPIO Controller. |
f436bc27 | 464 | |
223fa272 LW |
465 | config GPIO_MM_LANTIQ |
466 | bool "Lantiq Memory mapped GPIOs" | |
467 | depends on LANTIQ && SOC_XWAY | |
a99cc668 | 468 | select OF_GPIO_MM_GPIOCHIP |
223fa272 LW |
469 | help |
470 | This enables support for memory mapped GPIOs on the External Bus Unit | |
dd1695a2 RD |
471 | (EBU) found on Lantiq SoCs. The GPIOs are output only as they are |
472 | created by attaching a 16-bit latch to the bus. | |
223fa272 | 473 | |
6eae1ace GL |
474 | config GPIO_MPC5200 |
475 | def_bool y | |
476 | depends on PPC_MPC52xx | |
a99cc668 | 477 | select OF_GPIO_MM_GPIOCHIP |
6eae1ace | 478 | |
c68308dd | 479 | config GPIO_MPC8XXX |
5df7fd46 | 480 | bool "MPC512x/MPC8xxx/QorIQ GPIO support" |
c68308dd | 481 | depends on PPC_MPC512x || PPC_MPC831x || PPC_MPC834x || PPC_MPC837x || \ |
5df7fd46 LG |
482 | FSL_SOC_BOOKE || PPC_86xx || ARCH_LAYERSCAPE || ARM || \ |
483 | COMPILE_TEST | |
484 | select GPIO_GENERIC | |
8da238b1 | 485 | select GPIOLIB_IRQCHIP |
c68308dd WS |
486 | help |
487 | Say Y here if you're going to use hardware that connects to the | |
5df7fd46 | 488 | MPC512x/831x/834x/837x/8572/8610/QorIQ GPIOs. |
c68308dd | 489 | |
4ba9c3af SP |
490 | config GPIO_MT7621 |
491 | bool "Mediatek MT7621 GPIO Support" | |
492 | depends on SOC_MT7620 || SOC_MT7621 || COMPILE_TEST | |
7a9a5df0 | 493 | depends on OF_GPIO |
4ba9c3af SP |
494 | select GPIO_GENERIC |
495 | select GPIOLIB_IRQCHIP | |
496 | help | |
dd1695a2 | 497 | Say yes here to support the Mediatek MT7621 SoC GPIO device. |
4ba9c3af | 498 | |
fefe7b09 | 499 | config GPIO_MVEBU |
70327137 | 500 | bool "Marvell Orion and EBU GPIO support" if COMPILE_TEST |
956ee0c5 | 501 | depends on PLAT_ORION || ARCH_MVEBU || COMPILE_TEST |
70327137 | 502 | default PLAT_ORION || ARCH_MVEBU |
fefe7b09 | 503 | select GENERIC_IRQ_CHIP |
f37e335f | 504 | select REGMAP_MMIO |
fefe7b09 | 505 | |
d37a65bb | 506 | config GPIO_MXC |
12d16b39 | 507 | tristate "i.MX GPIO support" |
d4e93614 | 508 | depends on ARCH_MXC || COMPILE_TEST |
c103de24 | 509 | select GPIO_GENERIC |
e4ea9333 | 510 | select GENERIC_IRQ_CHIP |
c103de24 GL |
511 | |
512 | config GPIO_MXS | |
97c6e28d | 513 | bool "Freescale MXS GPIO support" if COMPILE_TEST |
6876ca31 | 514 | depends on ARCH_MXS || COMPILE_TEST |
97c6e28d | 515 | default y if ARCH_MXS |
06f88a8a | 516 | select GPIO_GENERIC |
498c17cf | 517 | select GENERIC_IRQ_CHIP |
d37a65bb | 518 | |
966942ae TL |
519 | config GPIO_NOMADIK |
520 | bool "Nomadik GPIO driver" | |
3c30cc26 | 521 | depends on ARCH_U8500 || ARCH_NOMADIK || MACH_EYEQ5 || COMPILE_TEST |
966942ae TL |
522 | select GPIOLIB_IRQCHIP |
523 | help | |
3c30cc26 TL |
524 | Say yes here to support the Nomadik SoC GPIO block. This block is also |
525 | used by the Mobileye EyeQ5 SoC. | |
966942ae TL |
526 | |
527 | It handles up to 32 GPIOs per bank, that can all be interrupt sources. | |
528 | It is deeply interconnected with the associated pinctrl driver as GPIO | |
529 | registers handle muxing ("alternate functions") as well. | |
530 | ||
c4f8457d JL |
531 | config GPIO_NPCM_SGPIO |
532 | bool "Nuvoton SGPIO support" | |
533 | depends on ARCH_NPCM || COMPILE_TEST | |
534 | select GPIOLIB_IRQCHIP | |
535 | help | |
536 | Say Y here to support Nuvoton NPCM7XX/NPCM8XX SGPIO functionality. | |
537 | ||
aca58a66 DD |
538 | config GPIO_OCTEON |
539 | tristate "Cavium OCTEON GPIO" | |
e4c6a52c | 540 | depends on CAVIUM_OCTEON_SOC |
aca58a66 DD |
541 | default y |
542 | help | |
543 | Say yes here to support the on-chip GPIO lines on the OCTEON | |
544 | family of SOCs. | |
545 | ||
cd0a3748 | 546 | config GPIO_OMAP |
934bacb6 BG |
547 | tristate "TI OMAP GPIO support" |
548 | depends on ARCH_OMAP || COMPILE_TEST | |
cd0a3748 | 549 | default y if ARCH_OMAP |
9d5d96ef | 550 | select GENERIC_IRQ_CHIP |
fb655f57 | 551 | select GPIOLIB_IRQCHIP |
cd0a3748 JMC |
552 | help |
553 | Say yes here to enable GPIO support for TI OMAP SoCs. | |
554 | ||
1e9c2859 | 555 | config GPIO_PL061 |
61684440 | 556 | tristate "PrimeCell PL061 GPIO support" |
bcb4be09 | 557 | depends on ARM_AMBA || COMPILE_TEST |
a5d6d271 | 558 | select IRQ_DOMAIN |
8d5b24bd | 559 | select GPIOLIB_IRQCHIP |
1e9c2859 | 560 | help |
dd1695a2 | 561 | Say yes here to support the PrimeCell PL061 GPIO device. |
1e9c2859 | 562 | |
a987b78f LH |
563 | config GPIO_POLARFIRE_SOC |
564 | bool "Microchip FPGA GPIO support" | |
565 | select REGMAP_MMIO | |
566 | help | |
567 | Say yes here to support the GPIO controllers on Microchip FPGAs. | |
568 | ||
157d2644 HZ |
569 | config GPIO_PXA |
570 | bool "PXA GPIO support" | |
22e4ebd0 | 571 | depends on ARCH_PXA || ARCH_MMP || COMPILE_TEST |
e2d9a7ea | 572 | select GPIOLIB_IRQCHIP |
157d2644 | 573 | help |
dd1695a2 | 574 | Say yes here to support the PXA GPIO device. |
157d2644 | 575 | |
119f5e44 | 576 | config GPIO_RCAR |
032653ef | 577 | tristate "Renesas R-Car and RZ/G GPIO support" |
2af66e1d | 578 | depends on ARCH_RENESAS || COMPILE_TEST |
c7f3c5d3 | 579 | select GPIOLIB_IRQCHIP |
119f5e44 | 580 | help |
032653ef | 581 | Say yes here to support GPIO on Renesas R-Car or RZ/G SoCs. |
119f5e44 | 582 | |
d57eb825 MS |
583 | config GPIO_RDA |
584 | bool "RDA Micro GPIO controller support" | |
585 | depends on ARCH_RDA || COMPILE_TEST | |
586 | depends on OF_GPIO | |
587 | select GPIO_GENERIC | |
588 | select GPIOLIB_IRQCHIP | |
589 | help | |
590 | Say Y here to support RDA Micro GPIO controller. | |
591 | ||
0d82fb11 SV |
592 | config GPIO_REALTEK_OTTO |
593 | tristate "Realtek Otto GPIO support" | |
594 | depends on MACH_REALTEK_RTL | |
595 | default MACH_REALTEK_RTL | |
596 | select GPIO_GENERIC | |
597 | select GPIOLIB_IRQCHIP | |
598 | help | |
599 | The GPIO controller on the Otto MIPS platform supports up to two | |
600 | banks of 32 GPIOs, with edge triggered interrupts. The 32 GPIOs | |
601 | are grouped in four 8-bit wide ports. | |
602 | ||
603 | When built as a module, the module will be called realtek_otto_gpio. | |
604 | ||
380639c7 RK |
605 | config GPIO_REG |
606 | bool | |
607 | help | |
608 | A 32-bit single register GPIO fixed in/out implementation. This | |
609 | can be used to represent any register as a set of GPIO signals. | |
610 | ||
936ee267 JX |
611 | config GPIO_ROCKCHIP |
612 | tristate "Rockchip GPIO support" | |
613 | depends on ARCH_ROCKCHIP || COMPILE_TEST | |
d6912b12 | 614 | select GENERIC_IRQ_CHIP |
936ee267 JX |
615 | select GPIOLIB_IRQCHIP |
616 | default ARCH_ROCKCHIP | |
617 | help | |
618 | Say yes here to support GPIO on Rockchip SoCs. | |
619 | ||
eee636bf TC |
620 | config GPIO_RTD |
621 | tristate "Realtek DHC GPIO support" | |
3d1c5b62 | 622 | depends on ARCH_REALTEK || COMPILE_TEST |
eee636bf TC |
623 | default y |
624 | select GPIOLIB_IRQCHIP | |
625 | help | |
626 | This option enables support for GPIOs found on Realtek DHC(Digital | |
627 | Home Center) SoCs family, including RTD1295, RTD1315E, RTD1319, | |
628 | RTD1319D, RTD1395, RTD1619 and RTD1619B. | |
629 | ||
630 | Say yes here to support GPIO functionality and GPIO interrupt on | |
631 | Realtek DHC SoCs. | |
632 | ||
fb0b35d3 AS |
633 | config GPIO_SAMA5D2_PIOBU |
634 | tristate "SAMA5D2 PIOBU GPIO support" | |
635 | depends on MFD_SYSCON | |
a7c23f8d | 636 | depends on OF_GPIO |
b06d7b45 | 637 | depends on ARCH_AT91 || COMPILE_TEST |
fb0b35d3 AS |
638 | select GPIO_SYSCON |
639 | help | |
640 | Say yes here to use the PIOBU pins as GPIOs. | |
641 | ||
642 | PIOBU pins on the SAMA5D2 can be used as GPIOs. | |
643 | The difference from regular GPIOs is that they | |
644 | maintain their value during backup/self-refresh. | |
645 | ||
96868dce | 646 | config GPIO_SIFIVE |
6b4c76de | 647 | tristate "SiFive GPIO support" |
18eedf2b RD |
648 | depends on OF_GPIO |
649 | select IRQ_DOMAIN_HIERARCHY | |
96868dce YS |
650 | select GPIO_GENERIC |
651 | select GPIOLIB_IRQCHIP | |
652 | select REGMAP_MMIO | |
653 | help | |
654 | Say yes here to support the GPIO device on SiFive SoCs. | |
655 | ||
be8c8fac UKK |
656 | config GPIO_SIOX |
657 | tristate "SIOX GPIO support" | |
658 | depends on SIOX | |
659 | select GPIOLIB_IRQCHIP | |
660 | help | |
661 | Say yes here to support SIOX I/O devices. These are units connected | |
662 | via a SIOX bus and have a number of fixed-direction I/O lines. | |
663 | ||
2505c7b0 EP |
664 | config GPIO_SNPS_CREG |
665 | bool "Synopsys GPIO via CREG (Control REGisters) driver" | |
666 | depends on ARC || COMPILE_TEST | |
a7c0b4b8 | 667 | depends on OF_GPIO |
2505c7b0 EP |
668 | help |
669 | This driver supports GPIOs via CREG on various Synopsys SoCs. | |
670 | This is a single-register MMIO GPIO driver for complex cases | |
671 | where only several fields in register belong to GPIO lines and | |
672 | each GPIO line owns a field with different length and on/off value. | |
673 | ||
d0055324 YL |
674 | config GPIO_SPACEMIT_K1 |
675 | tristate "SPACEMIT K1 GPIO support" | |
676 | depends on ARCH_SPACEMIT || COMPILE_TEST | |
677 | depends on OF_GPIO | |
678 | select GPIO_GENERIC | |
679 | select GPIOLIB_IRQCHIP | |
680 | help | |
681 | Say yes here to support the SpacemiT's K1 GPIO device. | |
682 | ||
b53bc281 SH |
683 | config GPIO_SPEAR_SPICS |
684 | bool "ST SPEAr13xx SPI Chip Select as GPIO support" | |
685 | depends on PLAT_SPEAR | |
686 | select GENERIC_IRQ_CHIP | |
687 | help | |
dd1695a2 | 688 | Say yes here to support ST SPEAr SPI Chip Select as GPIO device. |
b53bc281 | 689 | |
9a3821c2 BW |
690 | config GPIO_SPRD |
691 | tristate "Spreadtrum GPIO support" | |
692 | depends on ARCH_SPRD || COMPILE_TEST | |
693 | depends on OF_GPIO | |
694 | select GPIOLIB_IRQCHIP | |
695 | help | |
696 | Say yes here to support Spreadtrum GPIO device. | |
697 | ||
be9cab5b LW |
698 | config GPIO_STP_XWAY |
699 | bool "XWAY STP GPIOs" | |
5099837d MB |
700 | depends on SOC_XWAY || COMPILE_TEST |
701 | depends on OF_GPIO | |
be9cab5b LW |
702 | help |
703 | This enables support for the Serial To Parallel (STP) unit found on | |
704 | XWAY SoC. The STP allows the SoC to drive a shift registers cascade, | |
dd1695a2 RD |
705 | that can be up to 24 bits. This peripheral is aimed at driving LEDs. |
706 | Some of the GPIOs/LEDs can be auto updated by the SoC with DSL and | |
be9cab5b LW |
707 | phy status. |
708 | ||
6a8a0c1d AS |
709 | config GPIO_SYSCON |
710 | tristate "GPIO based on SYSCON" | |
711 | depends on MFD_SYSCON && OF | |
712 | help | |
713 | Say yes here to support GPIO functionality though SYSCON driver. | |
714 | ||
d2c19e89 P |
715 | config GPIO_TANGIER |
716 | tristate | |
717 | select GPIOLIB_IRQCHIP | |
718 | help | |
719 | GPIO support for Intel Tangier and compatible platforms. | |
34840be5 | 720 | Currently supported: |
9409d8cf | 721 | - Elkhart Lake |
34840be5 | 722 | - Merrifield |
d2c19e89 P |
723 | |
724 | If built as a module its name will be gpio-tangier. | |
725 | ||
223fa272 LW |
726 | config GPIO_TB10X |
727 | bool | |
0d1e31ab | 728 | select GPIO_GENERIC |
223fa272 LW |
729 | select GENERIC_IRQ_CHIP |
730 | select OF_GPIO | |
731 | ||
4dd4dd1d | 732 | config GPIO_TEGRA |
4a6eac2b | 733 | tristate "NVIDIA Tegra GPIO support" |
0bfb85c6 | 734 | default ARCH_TEGRA |
4dd4dd1d | 735 | depends on ARCH_TEGRA || COMPILE_TEST |
048c28c9 | 736 | depends on OF_GPIO |
298d75c9 TR |
737 | select GPIOLIB_IRQCHIP |
738 | select IRQ_DOMAIN_HIERARCHY | |
0bfb85c6 AB |
739 | help |
740 | Say yes here to support GPIO pins on NVIDIA Tegra SoCs. | |
4dd4dd1d | 741 | |
5b2b135a TR |
742 | config GPIO_TEGRA186 |
743 | tristate "NVIDIA Tegra186 GPIO support" | |
bef29ca3 LPC |
744 | default ARCH_TEGRA_186_SOC || ARCH_TEGRA_194_SOC || ARCH_TEGRA_234_SOC |
745 | depends on ARCH_TEGRA_186_SOC || ARCH_TEGRA_194_SOC || ARCH_TEGRA_234_SOC || COMPILE_TEST | |
5b2b135a TR |
746 | depends on OF_GPIO |
747 | select GPIOLIB_IRQCHIP | |
2a365505 | 748 | select IRQ_DOMAIN_HIERARCHY |
5b2b135a | 749 | help |
bef29ca3 | 750 | Say yes here to support GPIO pins on NVIDIA Tegra186, 194 and 234 SoCs. |
5b2b135a | 751 | |
5041e791 JG |
752 | config GPIO_TS4800 |
753 | tristate "TS-4800 DIO blocks and compatibles" | |
754 | depends on OF_GPIO | |
6dcfd729 | 755 | depends on SOC_IMX51 || COMPILE_TEST |
5041e791 JG |
756 | select GPIO_GENERIC |
757 | help | |
758 | This driver support TS-4800 FPGA GPIO controllers. | |
759 | ||
5a2a3002 DD |
760 | config GPIO_THUNDERX |
761 | tristate "Cavium ThunderX/OCTEON-TX GPIO" | |
762 | depends on ARCH_THUNDER || (64BIT && COMPILE_TEST) | |
311de3ce | 763 | depends on PCI_MSI |
a7fc89f9 | 764 | select GPIOLIB_IRQCHIP |
311de3ce | 765 | select IRQ_DOMAIN_HIERARCHY |
5a2a3002 DD |
766 | select IRQ_FASTEOI_HIERARCHY_HANDLERS |
767 | help | |
768 | Say yes here to support the on-chip GPIO lines on the ThunderX | |
769 | and OCTEON-TX families of SoCs. | |
770 | ||
dbe776c2 MY |
771 | config GPIO_UNIPHIER |
772 | tristate "UniPhier GPIO support" | |
773 | depends on ARCH_UNIPHIER || COMPILE_TEST | |
774 | depends on OF_GPIO | |
775 | select IRQ_DOMAIN_HIERARCHY | |
776 | help | |
777 | Say yes here to support UniPhier GPIOs. | |
778 | ||
7f2691a1 | 779 | config GPIO_VF610 |
73dc041f | 780 | tristate "VF610 GPIO support" |
f5759578 | 781 | default y if SOC_VF610 |
3eac8bbe | 782 | depends on ARCH_MXC || COMPILE_TEST |
7f2691a1 | 783 | select GPIOLIB_IRQCHIP |
da5dd31e | 784 | select GPIO_GENERIC |
7f2691a1 | 785 | help |
30a35c07 | 786 | Say yes here to support i.MX or Vybrid vf610 GPIOs. |
7f2691a1 | 787 | |
2ad74f40 NI |
788 | config GPIO_VISCONTI |
789 | tristate "Toshiba Visconti GPIO support" | |
790 | depends on ARCH_VISCONTI || COMPILE_TEST | |
791 | depends on OF_GPIO | |
792 | select GPIOLIB_IRQCHIP | |
793 | select GPIO_GENERIC | |
794 | select IRQ_DOMAIN_HIERARCHY | |
795 | help | |
796 | Say yes here to support GPIO on Tohisba Visconti. | |
797 | ||
59c32468 | 798 | config GPIO_WCD934X |
dd1695a2 | 799 | tristate "Qualcomm Technologies Inc WCD9340/WCD9341 GPIO controller driver" |
59c32468 SK |
800 | depends on MFD_WCD934X && OF_GPIO |
801 | help | |
0bb8e80b | 802 | This driver is to support GPIO block found on the Qualcomm Technologies |
59c32468 SK |
803 | Inc WCD9340/WCD9341 Audio Codec. |
804 | ||
29cbf458 FK |
805 | config GPIO_XGENE |
806 | bool "APM X-Gene GPIO controller support" | |
807 | depends on ARM64 && OF_GPIO | |
808 | help | |
809 | This driver is to support the GPIO block within the APM X-Gene SoC | |
810 | platform's generic flash controller. The GPIO pins are muxed with | |
811 | the generic flash controller's address and data pins. Say yes | |
812 | here to enable the GFC GPIO functionality. | |
813 | ||
b2b35e10 V |
814 | config GPIO_XGENE_SB |
815 | tristate "APM X-Gene GPIO standby controller support" | |
b24bc583 | 816 | depends on (ARCH_XGENE || COMPILE_TEST) |
b2b35e10 | 817 | select GPIO_GENERIC |
e5f7e312 | 818 | select GPIOLIB_IRQCHIP |
c23d200f | 819 | select IRQ_DOMAIN_HIERARCHY |
b2b35e10 V |
820 | help |
821 | This driver supports the GPIO block within the APM X-Gene | |
822 | Standby Domain. Say yes here to enable the GPIO functionality. | |
823 | ||
0bcb6069 | 824 | config GPIO_XILINX |
c54c58ba | 825 | tristate "Xilinx GPIO support" |
a32c7cae | 826 | select GPIOLIB_IRQCHIP |
0bcb6069 | 827 | help |
dd1695a2 | 828 | Say yes here to support the Xilinx FPGA GPIO device. |
0bcb6069 | 829 | |
ff718800 | 830 | config GPIO_XLP |
ea708ac5 RH |
831 | tristate "Cavium ThunderX2 GPIO support" |
832 | depends on ARCH_THUNDER2 || COMPILE_TEST | |
ff718800 KP |
833 | select GPIOLIB_IRQCHIP |
834 | help | |
ea708ac5 RH |
835 | This driver provides support for GPIO interface on Cavium's ThunderX2 |
836 | CN99XX SoCs (Originally from Netlogic XLP). | |
ff718800 KP |
837 | |
838 | If unsure, say N. | |
839 | ||
3b31d0ec BS |
840 | config GPIO_XTENSA |
841 | bool "Xtensa GPIO32 support" | |
842 | depends on XTENSA | |
a1a2bdec | 843 | depends on HAVE_XTENSA_GPIO32 |
3b31d0ec BS |
844 | depends on !SMP |
845 | help | |
846 | Say yes here to support the Xtensa internal GPIO32 IMPWIRE (input) | |
dd1695a2 | 847 | and EXPSTATE (output) ports. |
3b31d0ec | 848 | |
223fa272 LW |
849 | config GPIO_ZEVIO |
850 | bool "LSI ZEVIO SoC memory mapped GPIOs" | |
9c8224d0 | 851 | depends on ARM |
27fdd325 | 852 | help |
223fa272 | 853 | Say yes here to support the GPIO controller in LSI ZEVIO SoCs. |
27fdd325 | 854 | |
223fa272 LW |
855 | config GPIO_ZYNQ |
856 | tristate "Xilinx Zynq GPIO support" | |
6273ef35 | 857 | depends on ARCH_ZYNQ || ARCH_ZYNQMP || COMPILE_TEST |
7f87210e | 858 | select GPIOLIB_IRQCHIP |
be9b06b2 | 859 | help |
223fa272 | 860 | Say yes here to support Xilinx Zynq GPIO controller. |
92021490 | 861 | |
7687a5b0 | 862 | config GPIO_ZYNQMP_MODEPIN |
dd1695a2 | 863 | tristate "ZynqMP ps-mode pin GPIO configuration driver" |
6273ef35 | 864 | depends on ZYNQMP_FIRMWARE || COMPILE_TEST |
7687a5b0 PM |
865 | default ZYNQMP_FIRMWARE |
866 | help | |
dd1695a2 | 867 | Say yes here to support the ZynqMP ps-mode pin GPIO configuration |
7687a5b0 PM |
868 | driver. |
869 | ||
dd1695a2 | 870 | This ps-mode pin GPIO driver is based on GPIO framework. PS_MODE |
7687a5b0 PM |
871 | is 4-bits boot mode pins. It sets and gets the status of |
872 | the ps-mode pin. Every pin can be configured as input/output. | |
873 | ||
bd37c999 KC |
874 | config GPIO_LOONGSON1 |
875 | tristate "Loongson1 GPIO support" | |
876 | depends on MACH_LOONGSON32 | |
877 | select GPIO_GENERIC | |
878 | help | |
879 | Say Y or M here to support GPIO on Loongson1 SoCs. | |
880 | ||
e09d168f EWI |
881 | config GPIO_AMD_FCH |
882 | tristate "GPIO support for AMD Fusion Controller Hub (G-series SOCs)" | |
883 | help | |
dd1695a2 RD |
884 | This option enables driver for GPIO on AMD's Fusion Controller Hub, |
885 | as found on G-series SOCs (e.g. GX-412TC). | |
e09d168f | 886 | |
dd1695a2 RD |
887 | Note: This driver doesn't register itself automatically, as it |
888 | needs to be provided with platform-specific configuration. | |
889 | (See e.g. CONFIG_PCENGINES_APU2.) | |
93224edf DP |
890 | |
891 | config GPIO_MSC313 | |
892 | bool "MStar MSC313 GPIO support" | |
4675b78c | 893 | depends on ARCH_MSTARV7 || COMPILE_TEST |
93224edf DP |
894 | default ARCH_MSTARV7 |
895 | select GPIOLIB_IRQCHIP | |
896 | select IRQ_DOMAIN_HIERARCHY | |
897 | help | |
898 | Say Y here to support the main GPIO block on MStar/SigmaStar | |
dd1695a2 | 899 | ARMv7-based SoCs. |
93224edf | 900 | |
4195926a TB |
901 | config GPIO_IDT3243X |
902 | tristate "IDT 79RC3243X GPIO support" | |
903 | depends on MIKROTIK_RB532 || COMPILE_TEST | |
904 | select GPIO_GENERIC | |
905 | select GPIOLIB_IRQCHIP | |
906 | help | |
907 | Select this option to enable GPIO driver for | |
dd1695a2 | 908 | IDT 79RC3243X-based devices like Mikrotik RB532. |
4195926a TB |
909 | |
910 | To compile this driver as a module, choose M here: the module will | |
911 | be called gpio-idt3243x. | |
912 | ||
177b0381 | 913 | endmenu |
be9b06b2 | 914 | |
bc6a73bb | 915 | menu "Port-mapped I/O GPIO drivers" |
2c99754e NS |
916 | depends on X86 && HAS_IOPORT # I/O space access |
917 | ||
918 | config GPIO_VX855 | |
919 | tristate "VIA VX855/VX875 GPIO" | |
920 | depends on PCI | |
921 | select MFD_CORE | |
922 | select MFD_VX855 | |
923 | help | |
924 | Support access to the VX855/VX875 GPIO lines through the GPIO library. | |
925 | ||
926 | This driver provides common support for accessing the device. | |
927 | Additional drivers must be enabled in order to use the | |
928 | functionality of the device. | |
bc6a73bb | 929 | |
fb38af4a WBG |
930 | config GPIO_I8255 |
931 | tristate | |
0b7c490d | 932 | select GPIO_REGMAP |
fb38af4a WBG |
933 | help |
934 | Enables support for the i8255 interface library functions. The i8255 | |
935 | interface library provides functions to facilitate communication with | |
936 | interfaces compatible with the venerable Intel 8255 Programmable | |
937 | Peripheral Interface (PPI). The Intel 8255 PPI chip was first released | |
938 | in the early 1970s but compatible interfaces are nowadays typically | |
939 | found embedded in larger VLSI processing chips and FPGA components. | |
940 | ||
941 | If built as a module its name will be gpio-i8255. | |
942 | ||
1b06d64f WBG |
943 | config GPIO_104_DIO_48E |
944 | tristate "ACCES 104-DIO-48E GPIO support" | |
35decc80 WBG |
945 | depends on PC104 |
946 | select ISA_BUS_API | |
2f7e845f WBG |
947 | select REGMAP_MMIO |
948 | select REGMAP_IRQ | |
1b06d64f | 949 | select GPIOLIB_IRQCHIP |
71b7b397 | 950 | select GPIO_I8255 |
92f7a358 | 951 | select I8254 |
1b06d64f | 952 | help |
4c23db0f WBG |
953 | Enables GPIO support for the ACCES 104-DIO-48E series (104-DIO-48E, |
954 | 104-DIO-24E). The base port addresses for the devices may be | |
955 | configured via the base module parameter. The interrupt line numbers | |
956 | for the devices may be configured via the irq module parameter. | |
1b06d64f | 957 | |
bc6a73bb LW |
958 | config GPIO_104_IDIO_16 |
959 | tristate "ACCES 104-IDIO-16 GPIO support" | |
35decc80 WBG |
960 | depends on PC104 |
961 | select ISA_BUS_API | |
2c210c9a | 962 | select REGMAP_MMIO |
c4ec384c | 963 | select GPIO_IDIO_16 |
bc6a73bb | 964 | help |
86ea8a95 WBG |
965 | Enables GPIO support for the ACCES 104-IDIO-16 family (104-IDIO-16, |
966 | 104-IDIO-16E, 104-IDO-16, 104-IDIO-8, 104-IDIO-8E, 104-IDO-8). The | |
967 | base port addresses for the devices may be configured via the base | |
968 | module parameter. The interrupt line numbers for the devices may be | |
969 | configured via the irq module parameter. | |
bc6a73bb | 970 | |
6ddcf9b4 WBG |
971 | config GPIO_104_IDI_48 |
972 | tristate "ACCES 104-IDI-48 GPIO support" | |
35decc80 WBG |
973 | depends on PC104 |
974 | select ISA_BUS_API | |
e28432a7 WBG |
975 | select REGMAP_MMIO |
976 | select REGMAP_IRQ | |
6ddcf9b4 | 977 | select GPIOLIB_IRQCHIP |
59e2131a | 978 | select GPIO_REGMAP |
6ddcf9b4 | 979 | help |
72bf7443 WBG |
980 | Enables GPIO support for the ACCES 104-IDI-48 family (104-IDI-48A, |
981 | 104-IDI-48AC, 104-IDI-48B, 104-IDI-48BC). The base port addresses for | |
982 | the devices may be configured via the base module parameter. The | |
983 | interrupt line numbers for the devices may be configured via the irq | |
984 | module parameter. | |
6ddcf9b4 | 985 | |
bc6a73bb | 986 | config GPIO_F7188X |
d0918a84 | 987 | tristate "Fintek and Nuvoton Super-I/O GPIO support" |
bc6a73bb LW |
988 | help |
989 | This option enables support for GPIOs found on Fintek Super-I/O | |
1920906f | 990 | chips F71869, F71869A, F71882FG, F71889F and F81866. |
3002b864 | 991 | As well as Nuvoton Super-I/O chip NCT6126D. |
bc6a73bb LW |
992 | |
993 | To compile this driver as a module, choose M here: the module will | |
994 | be called f7188x-gpio. | |
995 | ||
6ea5dcdf WBG |
996 | config GPIO_GPIO_MM |
997 | tristate "Diamond Systems GPIO-MM GPIO support" | |
35decc80 WBG |
998 | depends on PC104 |
999 | select ISA_BUS_API | |
1c05004f | 1000 | select REGMAP_MMIO |
949506dc | 1001 | select GPIO_I8255 |
6ea5dcdf WBG |
1002 | help |
1003 | Enables GPIO support for the Diamond Systems GPIO-MM and GPIO-MM-12. | |
1004 | ||
1005 | The Diamond Systems GPIO-MM device features 48 lines of digital I/O | |
1006 | via the emulation of dual 82C55A PPI chips. This driver provides GPIO | |
1007 | support for these 48 channels of digital I/O. | |
1008 | ||
1009 | The base port addresses for the devices may be configured via the base | |
1010 | array module parameter. | |
1011 | ||
bc6a73bb LW |
1012 | config GPIO_IT87 |
1013 | tristate "IT87xx GPIO support" | |
bc6a73bb LW |
1014 | help |
1015 | Say yes here to support GPIO functionality of IT87xx Super I/O chips. | |
1016 | ||
1017 | This driver is tested with ITE IT8728 and IT8732 Super I/O chips, and | |
a5ec96dd LB |
1018 | supports the IT8761E, IT8613, IT8620E, and IT8628E Super I/O chips as |
1019 | well. | |
bc6a73bb LW |
1020 | |
1021 | To compile this driver as a module, choose M here: the module will | |
dd1695a2 | 1022 | be called gpio_it87. |
bc6a73bb LW |
1023 | |
1024 | config GPIO_SCH | |
1025 | tristate "Intel SCH/TunnelCreek/Centerton/Quark X1000 GPIO" | |
fdc1f5df | 1026 | depends on (X86 || COMPILE_TEST) && ACPI |
71cf76d4 | 1027 | depends on LPC_SCH |
7a816384 | 1028 | select GPIOLIB_IRQCHIP |
bc6a73bb LW |
1029 | help |
1030 | Say yes here to support GPIO interface on Intel Poulsbo SCH, | |
1031 | Intel Tunnel Creek processor, Intel Centerton processor or | |
1032 | Intel Quark X1000 SoC. | |
1033 | ||
1034 | The Intel SCH contains a total of 14 GPIO pins. Ten GPIOs are | |
1035 | powered by the core power rail and are turned off during sleep | |
1036 | modes (S3 and higher). The remaining four GPIOs are powered by | |
1037 | the Intel SCH suspend power supply. These GPIOs remain | |
dd1695a2 | 1038 | active during S3. The suspend-powered GPIOs can be used to wake the |
bc6a73bb LW |
1039 | system from the Suspend-to-RAM state. |
1040 | ||
1041 | The Intel Tunnel Creek processor has 5 GPIOs powered by the | |
1042 | core power rail and 9 from suspend power supply. | |
1043 | ||
1044 | The Intel Centerton processor has a total of 30 GPIO pins. | |
1045 | Twenty-one are powered by the core power rail and 9 from the | |
1046 | suspend power supply. | |
1047 | ||
1048 | The Intel Quark X1000 SoC has 2 GPIOs powered by the core | |
1049 | power well and 6 from the suspend power well. | |
1050 | ||
1051 | config GPIO_SCH311X | |
1052 | tristate "SMSC SCH311x SuperI/O GPIO" | |
1053 | help | |
1054 | Driver to enable the GPIOs found on SMSC SMSC SCH3112, SCH3114 and | |
1055 | SCH3116 "Super I/O" chipsets. | |
1056 | ||
1057 | To compile this driver as a module, choose M here: the module will | |
1058 | be called gpio-sch311x. | |
1059 | ||
1060 | config GPIO_TS5500 | |
1061 | tristate "TS-5500 DIO blocks and compatibles" | |
1062 | depends on TS5500 || COMPILE_TEST | |
1063 | help | |
1064 | This driver supports Digital I/O exposed by pin blocks found on some | |
1065 | Technologic Systems platforms. It includes, but is not limited to, 3 | |
1066 | blocks of the TS-5500: DIO1, DIO2 and the LCD port, and the TS-5600 | |
1067 | LCD port. | |
1068 | ||
a0d65009 MS |
1069 | config GPIO_WINBOND |
1070 | tristate "Winbond Super I/O GPIO support" | |
b995ff3b | 1071 | select ISA_BUS_API |
a0d65009 MS |
1072 | help |
1073 | This option enables support for GPIOs found on Winbond Super I/O | |
1074 | chips. | |
1075 | Currently, only W83627UHG (also known as Nuvoton NCT6627UD) is | |
1076 | supported. | |
1077 | ||
1078 | You will need to provide a module parameter "gpios", or a | |
1079 | boot-time parameter "gpio_winbond.gpios" with a bitmask of GPIO | |
1080 | ports to enable (bit 0 is GPIO1, bit 1 is GPIO2, etc.). | |
1081 | ||
1082 | To compile this driver as a module, choose M here: the module will | |
1083 | be called gpio-winbond. | |
1084 | ||
9c26df9b WBG |
1085 | config GPIO_WS16C48 |
1086 | tristate "WinSystems WS16C48 GPIO support" | |
35decc80 | 1087 | select ISA_BUS_API |
0988ffa0 WBG |
1088 | select REGMAP_IRQ |
1089 | select REGMAP_MMIO | |
9c26df9b | 1090 | select GPIOLIB_IRQCHIP |
0988ffa0 | 1091 | select GPIO_REGMAP |
9c26df9b | 1092 | help |
cc736607 WBG |
1093 | Enables GPIO support for the WinSystems WS16C48. The base port |
1094 | addresses for the devices may be configured via the base module | |
1095 | parameter. The interrupt line numbers for the devices may be | |
1096 | configured via the irq module parameter. | |
9c26df9b | 1097 | |
bc6a73bb LW |
1098 | endmenu |
1099 | ||
177b0381 LW |
1100 | menu "I2C GPIO expanders" |
1101 | depends on I2C | |
92021490 | 1102 | |
bf5a16ba LW |
1103 | config GPIO_ADNP |
1104 | tristate "Avionic Design N-bit GPIO expander" | |
269a46f8 | 1105 | depends on OF_GPIO |
104fb1d5 ZL |
1106 | select GPIOLIB_IRQCHIP |
1107 | help | |
bf5a16ba LW |
1108 | This option enables support for N GPIOs found on Avionic Design |
1109 | I2C GPIO expanders. The register space will be extended by powers | |
1110 | of two, so the controller will need to accommodate for that. For | |
1111 | example: if a controller provides 48 pins, 6 registers will be | |
1112 | enough to represent all pins, but the driver will assume a | |
1113 | register layout for 64 pins (8 registers). | |
0cc59b9d | 1114 | |
03810031 EG |
1115 | config GPIO_FXL6408 |
1116 | tristate "FXL6408 I2C GPIO expander" | |
1117 | select GPIO_REGMAP | |
1118 | select REGMAP_I2C | |
1119 | help | |
1120 | GPIO driver for Fairchild Semiconductor FXL6408 GPIO expander. | |
1121 | ||
1122 | To compile this driver as a module, choose M here: the module will | |
1123 | be called gpio-fxl6408. | |
1124 | ||
659ad5f7 OS |
1125 | config GPIO_DS4520 |
1126 | tristate "DS4520 I2C GPIO expander" | |
1127 | select REGMAP_I2C | |
1128 | select GPIO_REGMAP | |
1129 | help | |
1130 | GPIO driver for ADI DS4520 I2C-based GPIO expander. | |
1131 | Say yes here to enable the GPIO driver for the ADI DS4520 chip. | |
1132 | ||
1133 | To compile this driver as a module, choose M here: the module will | |
1134 | be called gpio-ds4520. | |
1135 | ||
2a0b0a57 LW |
1136 | config GPIO_GW_PLD |
1137 | tristate "Gateworks PLD GPIO Expander" | |
1138 | depends on OF_GPIO | |
1139 | help | |
1140 | Say yes here to provide access to the Gateworks I2C PLD GPIO | |
1141 | Expander. This is used at least on the Cambria GW2358-4. | |
1142 | ||
e952805d WS |
1143 | config GPIO_MAX7300 |
1144 | tristate "Maxim MAX7300 GPIO expander" | |
e952805d WS |
1145 | select GPIO_MAX730X |
1146 | help | |
2b861f4b | 1147 | GPIO driver for Maxim MAX7300 I2C-based GPIO expander. |
e952805d | 1148 | |
bbcd6d54 EM |
1149 | config GPIO_MAX732X |
1150 | tristate "MAX7319, MAX7320-7327 I2C Port Expanders" | |
bbcd6d54 EM |
1151 | help |
1152 | Say yes here to support the MAX7319, MAX7320-7327 series of I2C | |
1153 | Port Expanders. Each IO port on these chips has a fixed role of | |
1154 | Input (designated by 'I'), Push-Pull Output ('O'), or Open-Drain | |
1155 | Input and Output (designed by 'P'). The combinations are listed | |
1156 | below: | |
1157 | ||
c42e34c9 EWI |
1158 | 8 bits: max7319 (8I), max7320 (8O), max7321 (8P), |
1159 | max7322 (4I4O), max7323 (4P4O) | |
bbcd6d54 | 1160 | |
c42e34c9 EWI |
1161 | 16 bits: max7324 (8I8O), max7325 (8P8O), |
1162 | max7326 (4I12O), max7327 (4P12O) | |
bbcd6d54 EM |
1163 | |
1164 | Board setup code must specify the model to use, and the start | |
1165 | number for these GPIOs. | |
1166 | ||
a80a0bbe MZ |
1167 | config GPIO_MAX732X_IRQ |
1168 | bool "Interrupt controller support for MAX732x" | |
0244ad00 | 1169 | depends on GPIO_MAX732X=y |
984f6643 | 1170 | select GPIOLIB_IRQCHIP |
a80a0bbe MZ |
1171 | help |
1172 | Say yes here to enable the max732x to be used as an interrupt | |
1173 | controller. It requires the driver to be built in the kernel. | |
1174 | ||
f3dc3630 | 1175 | config GPIO_PCA953X |
eb32b5aa | 1176 | tristate "PCA95[357]x, PCA9698, TCA64xx, and MAX7310 I/O ports" |
4bc16f9d | 1177 | select REGMAP_I2C |
9e60fdcf | 1178 | help |
7059d4b0 DB |
1179 | Say yes here to provide access to several register-oriented |
1180 | SMBus I/O expanders, made mostly by NXP or TI. Compatible | |
1181 | models include: | |
1182 | ||
c42e34c9 | 1183 | 4 bits: pca9536, pca9537 |
7059d4b0 | 1184 | |
c42e34c9 EWI |
1185 | 8 bits: max7310, max7315, pca6107, pca9534, pca9538, pca9554, |
1186 | pca9556, pca9557, pca9574, tca6408, tca9554, xra1202 | |
7059d4b0 | 1187 | |
c42e34c9 EWI |
1188 | 16 bits: max7312, max7313, pca9535, pca9539, pca9555, pca9575, |
1189 | tca6416 | |
9e60fdcf | 1190 | |
c42e34c9 | 1191 | 24 bits: tca6424 |
1e191695 | 1192 | |
c42e34c9 | 1193 | 40 bits: pca9505, pca9698 |
1e191695 | 1194 | |
89ea8bbe MZ |
1195 | config GPIO_PCA953X_IRQ |
1196 | bool "Interrupt controller support for PCA953x" | |
e33a58a2 | 1197 | depends on GPIO_PCA953X |
7bcbce55 | 1198 | select GPIOLIB_IRQCHIP |
89ea8bbe MZ |
1199 | help |
1200 | Say yes here to enable the pca953x to be used as an interrupt | |
dd1695a2 | 1201 | controller. |
89ea8bbe | 1202 | |
16d44b60 SE |
1203 | config GPIO_PCA9570 |
1204 | tristate "PCA9570 4-Bit I2C GPO expander" | |
1205 | help | |
1206 | Say yes here to enable the GPO driver for the NXP PCA9570 chip. | |
1207 | ||
1208 | To compile this driver as a module, choose M here: the module will | |
1209 | be called gpio-pca9570. | |
1210 | ||
15fae37d | 1211 | config GPIO_PCF857X |
1673ad52 | 1212 | tristate "PCF857x, PCA{85,96}7x, and MAX732[89] I2C GPIO expanders" |
a39294bd | 1213 | select GPIOLIB_IRQCHIP |
901acf5b | 1214 | select IRQ_DOMAIN |
15fae37d DB |
1215 | help |
1216 | Say yes here to provide access to most "quasi-bidirectional" I2C | |
1217 | GPIO expanders used for additional digital outputs or inputs. | |
1218 | Most of these parts are from NXP, though TI is a second source for | |
1219 | some of them. Compatible models include: | |
1220 | ||
1221 | 8 bits: pcf8574, pcf8574a, pca8574, pca8574a, | |
1673ad52 | 1222 | pca9670, pca9672, pca9674, pca9674a, |
c42e34c9 | 1223 | max7328, max7329 |
15fae37d DB |
1224 | |
1225 | 16 bits: pcf8575, pcf8575c, pca8575, | |
1226 | pca9671, pca9673, pca9675 | |
1227 | ||
1228 | Your board setup code will need to declare the expanders in | |
1229 | use, and assign numbers to the GPIOs they expose. Those GPIOs | |
1230 | can then be used from drivers and other kernel code, just like | |
1231 | other GPIOs, but only accessible from task contexts. | |
1232 | ||
1233 | This driver provides an in-kernel interface to those GPIOs using | |
1234 | platform-neutral GPIO calls. | |
1235 | ||
b866526d AD |
1236 | config GPIO_TPIC2810 |
1237 | tristate "TPIC2810 8-Bit I2C GPO expander" | |
1238 | help | |
1239 | Say yes here to enable the GPO driver for the TI TPIC2810 chip. | |
1240 | ||
1241 | To compile this driver as a module, choose M here: the module will | |
1242 | be called gpio-tpic2810. | |
1243 | ||
9c668632 LQ |
1244 | config GPIO_TS4900 |
1245 | tristate "Technologic Systems FPGA I2C GPIO" | |
4c5f15b7 | 1246 | depends on SOC_IMX6 || COMPILE_TEST |
9c668632 LQ |
1247 | select REGMAP_I2C |
1248 | help | |
1249 | Say yes here to enabled the GPIO driver for Technologic's FPGA core. | |
1250 | Series supported include TS-4100, TS-4900, TS-7970 and TS-7990. | |
1251 | ||
177b0381 LW |
1252 | endmenu |
1253 | ||
1254 | menu "MFD GPIO expanders" | |
be9cab5b LW |
1255 | |
1256 | config GPIO_ADP5520 | |
1257 | tristate "GPIO Support for ADP5520 PMIC" | |
1258 | depends on PMIC_ADP5520 | |
1259 | help | |
1260 | This option enables support for on-chip GPIO found | |
1261 | on Analog Devices ADP5520 PMICs. | |
1262 | ||
738bbc66 HC |
1263 | config GPIO_ADP5585 |
1264 | tristate "GPIO Support for ADP5585" | |
1265 | depends on MFD_ADP5585 | |
1266 | help | |
1267 | This option enables support for the GPIO function found in the Analog | |
1268 | Devices ADP5585. | |
1269 | ||
26a48c4c TT |
1270 | config GPIO_ALTERA_A10SR |
1271 | tristate "Altera Arria10 System Resource GPIO" | |
1272 | depends on MFD_ALTERA_A10SR | |
1273 | help | |
1274 | Driver for Arria10 Development Kit GPIO expansion which | |
1275 | includes reads of pushbuttons and DIP switches as well | |
1276 | as writes to LEDs. | |
1277 | ||
be9cab5b LW |
1278 | config GPIO_ARIZONA |
1279 | tristate "Wolfson Microelectronics Arizona class devices" | |
1280 | depends on MFD_ARIZONA | |
1281 | help | |
1282 | Support for GPIOs on Wolfson Arizona class devices. | |
1283 | ||
703b288f MV |
1284 | config GPIO_BD71815 |
1285 | tristate "ROHM BD71815 PMIC GPIO support" | |
1286 | depends on MFD_ROHM_BD71828 | |
1287 | help | |
1288 | Support for GPO(s) on ROHM BD71815 PMIC. There are two GPOs | |
1289 | available on the ROHM PMIC. | |
1290 | ||
1291 | This driver can also be built as a module. If so, the module | |
1292 | will be called gpio-bd71815. | |
1293 | ||
c31f625d MV |
1294 | config GPIO_BD71828 |
1295 | tristate "ROHM BD71828 GPIO support" | |
1296 | depends on MFD_ROHM_BD71828 | |
1297 | help | |
1298 | Support for GPIOs on ROHM BD71828 PMIC. There are three GPIOs | |
1299 | available on the ROHM PMIC in total. The GPIOs are limited to | |
1300 | outputs only and pins must be configured to GPIO outputs by | |
1301 | OTP. Enable this only if you want to use these pins as outputs. | |
1302 | ||
1303 | This driver can also be built as a module. If so, the module | |
1304 | will be called gpio-bd71828. | |
1305 | ||
93847930 MV |
1306 | config GPIO_BD9571MWV |
1307 | tristate "ROHM BD9571 GPIO support" | |
1308 | depends on MFD_BD9571MWV | |
1309 | help | |
1310 | Support for GPIOs on ROHM BD9571 PMIC. There are two GPIOs | |
1311 | available on the ROHM PMIC in total, both of which can also | |
1312 | generate interrupts. | |
1313 | ||
1314 | This driver can also be built as a module. If so, the module | |
1315 | will be called gpio-bd9571mwv. | |
1316 | ||
4342bf63 TR |
1317 | config GPIO_CGBC |
1318 | tristate "Congatec Board Controller GPIO support" | |
1319 | depends on MFD_CGBC | |
1320 | help | |
1321 | Select this option to enable GPIO support for the Congatec Board | |
1322 | Controller. | |
1323 | ||
1324 | This driver can also be built as a module. If so, the module will be | |
1325 | called gpio-cgbc. | |
1326 | ||
f837fe1b SB |
1327 | config GPIO_CROS_EC |
1328 | tristate "ChromeOS EC GPIO support" | |
1329 | depends on CROS_EC | |
1330 | help | |
1331 | GPIO driver for the ChromeOS Embedded Controller (EC). GPIOs | |
1332 | cannot be set unless the system is unlocked. | |
1333 | ||
1334 | This driver can also be built as a module. If so, the module | |
1335 | will be called gpio-cros-ec. | |
1336 | ||
be9cab5b LW |
1337 | config GPIO_CRYSTAL_COVE |
1338 | tristate "GPIO support for Crystal Cove PMIC" | |
72aba2e2 | 1339 | depends on (X86 || COMPILE_TEST) && INTEL_SOC_PMIC |
be9cab5b LW |
1340 | select GPIOLIB_IRQCHIP |
1341 | help | |
1342 | Support for GPIO pins on Crystal Cove PMIC. | |
1343 | ||
dd1695a2 | 1344 | Say Yes if you have a Intel SoC-based tablet with Crystal Cove PMIC |
be9cab5b LW |
1345 | inside. |
1346 | ||
1347 | This driver can also be built as a module. If so, the module will be | |
1348 | called gpio-crystalcove. | |
1349 | ||
1350 | config GPIO_CS5535 | |
1351 | tristate "AMD CS5535/CS5536 GPIO support" | |
72aba2e2 | 1352 | depends on X86 || MIPS || COMPILE_TEST |
be9cab5b LW |
1353 | depends on MFD_CS5535 |
1354 | help | |
1355 | The AMD CS5535 and CS5536 southbridges support 28 GPIO pins that | |
1356 | can be used for quite a number of things. The CS5535/6 is found on | |
1357 | AMD Geode and Lemote Yeeloong devices. | |
1358 | ||
1359 | If unsure, say N. | |
1360 | ||
1361 | config GPIO_DA9052 | |
1362 | tristate "Dialog DA9052 GPIO" | |
1363 | depends on PMIC_DA9052 | |
1364 | help | |
1365 | Say yes here to enable the GPIO driver for the DA9052 chip. | |
1366 | ||
1367 | config GPIO_DA9055 | |
1368 | tristate "Dialog Semiconductor DA9055 GPIO" | |
1369 | depends on MFD_DA9055 | |
1370 | help | |
1371 | Say yes here to enable the GPIO driver for the DA9055 chip. | |
1372 | ||
1373 | The Dialog DA9055 PMIC chip has 3 GPIO pins that can be | |
dd1695a2 | 1374 | be controlled by this driver. |
be9cab5b LW |
1375 | |
1376 | If driver is built as a module it will be called gpio-da9055. | |
1377 | ||
1378 | config GPIO_DLN2 | |
1379 | tristate "Diolan DLN2 GPIO support" | |
1380 | depends on MFD_DLN2 | |
1381 | select GPIOLIB_IRQCHIP | |
1382 | ||
1383 | help | |
1384 | Select this option to enable GPIO driver for the Diolan DLN2 | |
1385 | board. | |
1386 | ||
1387 | This driver can also be built as a module. If so, the module | |
1388 | will be called gpio-dln2. | |
1389 | ||
3c6e8d05 LW |
1390 | config HTC_EGPIO |
1391 | bool "HTC EGPIO support" | |
1791226b | 1392 | depends on ARM || COMPILE_TEST |
3c6e8d05 | 1393 | help |
c42e34c9 EWI |
1394 | This driver supports the CPLD egpio chip present on |
1395 | several HTC phones. It provides basic support for input | |
dd1695a2 | 1396 | pins, output pins, and IRQs. |
3c6e8d05 | 1397 | |
9409d8cf P |
1398 | config GPIO_ELKHARTLAKE |
1399 | tristate "Intel Elkhart Lake PSE GPIO support" | |
1400 | depends on X86 || COMPILE_TEST | |
1401 | select GPIO_TANGIER | |
1402 | help | |
1403 | Select this option to enable GPIO support for Intel Elkhart Lake | |
1404 | PSE GPIO IP. | |
1405 | ||
1406 | To compile this driver as a module, choose M here: the module will | |
1407 | be called gpio-elkhartlake. | |
1408 | ||
be9cab5b LW |
1409 | config GPIO_JANZ_TTL |
1410 | tristate "Janz VMOD-TTL Digital IO Module" | |
1411 | depends on MFD_JANZ_CMODIO | |
1412 | help | |
1413 | This enables support for the Janz VMOD-TTL Digital IO module. | |
1414 | This driver provides support for driving the pins in output | |
1415 | mode only. Input mode is not supported. | |
1416 | ||
1417 | config GPIO_KEMPLD | |
1418 | tristate "Kontron ETX / COMexpress GPIO" | |
1419 | depends on MFD_KEMPLD | |
1420 | help | |
1421 | This enables support for the PLD GPIO interface on some Kontron ETX | |
1422 | and COMexpress (ETXexpress) modules. | |
1423 | ||
1424 | This driver can also be built as a module. If so, the module will be | |
1425 | called gpio-kempld. | |
1426 | ||
c5a4b6fd YX |
1427 | config GPIO_LJCA |
1428 | tristate "INTEL La Jolla Cove Adapter GPIO support" | |
1034cc42 | 1429 | depends on USB_LJCA |
c5a4b6fd | 1430 | select GPIOLIB_IRQCHIP |
1034cc42 | 1431 | default USB_LJCA |
c5a4b6fd YX |
1432 | help |
1433 | Select this option to enable GPIO driver for the INTEL | |
1434 | La Jolla Cove Adapter (LJCA) board. | |
1435 | ||
1436 | This driver can also be built as a module. If so, the module | |
1437 | will be called gpio-ljca. | |
1438 | ||
be9cab5b LW |
1439 | config GPIO_LP3943 |
1440 | tristate "TI/National Semiconductor LP3943 GPIO expander" | |
1441 | depends on MFD_LP3943 | |
1442 | help | |
1443 | GPIO driver for LP3943 MFD. | |
1444 | LP3943 can be used as a GPIO expander which provides up to 16 GPIOs. | |
1445 | Open drain outputs are required for this usage. | |
1446 | ||
83f14103 K |
1447 | config GPIO_LP873X |
1448 | tristate "TI LP873X GPO" | |
1449 | depends on MFD_TI_LP873X | |
1450 | help | |
1451 | This driver supports the GPO on TI Lp873x PMICs. 2 GPOs are present | |
1452 | on LP873X PMICs. | |
1453 | ||
1454 | This driver can also be built as a module. If so, the module will be | |
c42e34c9 | 1455 | called gpio-lp873x. |
83f14103 | 1456 | |
5c7f2c76 K |
1457 | config GPIO_LP87565 |
1458 | tristate "TI LP87565 GPIO" | |
1459 | depends on MFD_TI_LP87565 | |
1460 | help | |
1461 | This driver supports the GPIO on TI Lp873565 PMICs. 3 GPIOs are present | |
1462 | on LP87565 PMICs. | |
1463 | ||
1464 | This driver can also be built as a module. If so, the module will be | |
1465 | called gpio-lp87565. | |
1466 | ||
aca429ff RF |
1467 | config GPIO_MADERA |
1468 | tristate "Cirrus Logic Madera class codecs" | |
1469 | depends on PINCTRL_MADERA | |
1470 | help | |
1471 | Support for GPIOs on Cirrus Logic Madera class codecs. | |
1472 | ||
02c5ba1e LD |
1473 | config GPIO_MAX77620 |
1474 | tristate "GPIO support for PMIC MAX77620 and MAX20024" | |
1475 | depends on MFD_MAX77620 | |
c5706c7d | 1476 | select GPIOLIB_IRQCHIP |
02c5ba1e LD |
1477 | help |
1478 | GPIO driver for MAX77620 and MAX20024 PMIC from Maxim Semiconductor. | |
1479 | MAX77620 PMIC has 8 pins that can be configured as GPIOs. The | |
dd1695a2 RD |
1480 | driver also provides interrupt support for each of the GPIOs. |
1481 | Say yes here to enable the max77620 to be used as GPIO controller. | |
02c5ba1e | 1482 | |
72b5135b BG |
1483 | config GPIO_MAX77650 |
1484 | tristate "Maxim MAX77650/77651 GPIO support" | |
1485 | depends on MFD_MAX77650 | |
1486 | help | |
1487 | GPIO driver for MAX77650/77651 PMIC from Maxim Semiconductor. | |
1488 | These chips have a single pin that can be configured as GPIO. | |
1489 | ||
89a796b9 AD |
1490 | config GPIO_MAX77759 |
1491 | tristate "Maxim Integrated MAX77759 GPIO support" | |
1492 | depends on MFD_MAX77759 | |
1493 | default MFD_MAX77759 | |
1494 | select GPIOLIB_IRQCHIP | |
1495 | help | |
1496 | GPIO driver for MAX77759 PMIC from Maxim Integrated. | |
1497 | There are two GPIOs available on these chips in total, both of | |
1498 | which can also generate interrupts. | |
1499 | ||
1500 | This driver can also be built as a module. If so, the module will be | |
1501 | called gpio-max77759. | |
1502 | ||
be9cab5b LW |
1503 | config GPIO_PALMAS |
1504 | bool "TI PALMAS series PMICs GPIO" | |
1505 | depends on MFD_PALMAS | |
1506 | help | |
1507 | Select this option to enable GPIO driver for the TI PALMAS | |
1508 | series chip family. | |
1509 | ||
63de20ca LW |
1510 | config GPIO_PMIC_EIC_SPRD |
1511 | tristate "Spreadtrum PMIC EIC support" | |
1512 | depends on MFD_SC27XX_PMIC || COMPILE_TEST | |
1513 | depends on OF_GPIO | |
1514 | select GPIOLIB_IRQCHIP | |
1515 | help | |
1516 | Say yes here to support Spreadtrum PMIC EIC device. | |
1517 | ||
e9fe32bc LD |
1518 | config GPIO_RC5T583 |
1519 | bool "RICOH RC5T583 GPIO" | |
1520 | depends on MFD_RC5T583 | |
1521 | help | |
1522 | Select this option to enable GPIO driver for the Ricoh RC5T583 | |
1523 | chip family. | |
dd1695a2 RD |
1524 | This driver provides the support for driving/reading the GPIO pins |
1525 | of RC5T583 device through standard GPIO library. | |
e9fe32bc | 1526 | |
b7536d87 MW |
1527 | config GPIO_SL28CPLD |
1528 | tristate "Kontron sl28cpld GPIO support" | |
1529 | depends on MFD_SL28CPLD || COMPILE_TEST | |
1530 | select GPIO_REGMAP | |
1531 | select GPIOLIB_IRQCHIP | |
1532 | select REGMAP_IRQ | |
1533 | help | |
1534 | This enables support for the GPIOs found on the Kontron sl28 CPLD. | |
1535 | ||
1536 | This driver can also be built as a module. If so, the module will be | |
1537 | called gpio-sl28cpld. | |
1538 | ||
03f822f5 RV |
1539 | config GPIO_STMPE |
1540 | bool "STMPE GPIOs" | |
1541 | depends on MFD_STMPE | |
1dfb4a0d | 1542 | depends on OF_GPIO |
fe44e70d | 1543 | select GPIOLIB_IRQCHIP |
03f822f5 RV |
1544 | help |
1545 | This enables support for the GPIOs found on the STMPE I/O | |
1546 | Expanders. | |
1547 | ||
f4e8afdc SI |
1548 | config GPIO_TC3589X |
1549 | bool "TC3589X GPIOs" | |
1550 | depends on MFD_TC3589X | |
1422731d | 1551 | depends on OF_GPIO |
cf42f1cf | 1552 | select GPIOLIB_IRQCHIP |
d88b25be | 1553 | help |
f4e8afdc | 1554 | This enables support for the GPIOs found on the TC3589X |
d88b25be RV |
1555 | I/O Expander. |
1556 | ||
be9cab5b LW |
1557 | config GPIO_TIMBERDALE |
1558 | bool "Support for timberdale GPIO IP" | |
1559 | depends on MFD_TIMBERDALE | |
8b8ef309 | 1560 | select GPIOLIB_IRQCHIP |
a7f7f624 | 1561 | help |
be9cab5b LW |
1562 | Add support for the GPIO IP in the timberdale FPGA. |
1563 | ||
b3dcb5de RM |
1564 | config GPIO_TN48M_CPLD |
1565 | tristate "Delta Networks TN48M switch CPLD GPIO driver" | |
4e8a72f9 | 1566 | depends on MFD_TN48M_CPLD || COMPILE_TEST |
b3dcb5de RM |
1567 | select GPIO_REGMAP |
1568 | help | |
1569 | This enables support for the GPIOs found on the Delta | |
1570 | Networks TN48M switch Lattice CPLD. It provides 12 pins in total, | |
1571 | they are input-only or output-only type. | |
1572 | ||
1573 | This driver can also be built as a module. If so, the | |
1574 | module will be called gpio-tn48m. | |
1575 | ||
99f0fd54 AD |
1576 | config GPIO_TPS65086 |
1577 | tristate "TI TPS65086 GPO" | |
1578 | depends on MFD_TPS65086 | |
1579 | help | |
1580 | This driver supports the GPO on TI TPS65086x PMICs. | |
1581 | ||
c366c76a NSJ |
1582 | config GPIO_TPS65218 |
1583 | tristate "TPS65218 GPIO" | |
1584 | depends on MFD_TPS65218 | |
1585 | help | |
1586 | Select this option to enable GPIO driver for the TPS65218 | |
1587 | chip family. | |
1588 | ||
57e30e00 JN |
1589 | config GPIO_TPS65219 |
1590 | tristate "TPS65219 GPIO" | |
1591 | depends on MFD_TPS65219 | |
1592 | default MFD_TPS65219 | |
1593 | help | |
1594 | Select this option to enable GPIO driver for the TPS65219 chip | |
1595 | family. | |
1596 | GPIO0 is statically configured as either input or output prior to | |
1597 | Linux boot. It is used for MULTI_DEVICE_ENABLE function. This setting | |
1598 | is statically configured by NVM. GPIO0 can't be used as a generic | |
1599 | GPIO. It's either a GPO when MULTI_DEVICE_EN=0 or a GPI when | |
1600 | MULTI_DEVICE_EN=1. | |
1601 | ||
1602 | This driver can also be built as a module. If so, the module will be | |
1603 | called gpio_tps65219. | |
1604 | ||
be9cab5b LW |
1605 | config GPIO_TPS6586X |
1606 | bool "TPS6586X GPIO" | |
1607 | depends on MFD_TPS6586X | |
1608 | help | |
1609 | Select this option to enable GPIO driver for the TPS6586X | |
1610 | chip family. | |
1611 | ||
1612 | config GPIO_TPS65910 | |
1613 | bool "TPS65910 GPIO" | |
1614 | depends on MFD_TPS65910 | |
1615 | help | |
1616 | Select this option to enable GPIO driver for the TPS65910 | |
1617 | chip family. | |
1618 | ||
668a6cc7 MO |
1619 | config GPIO_TPS65912 |
1620 | tristate "TI TPS65912 GPIO" | |
ca801a22 | 1621 | depends on MFD_TPS65912 |
668a6cc7 | 1622 | help |
dd1695a2 | 1623 | This driver supports TPS65912 GPIO chip. |
668a6cc7 | 1624 | |
275b13a6 | 1625 | config GPIO_TPS68470 |
a1ce76e8 | 1626 | tristate "TPS68470 GPIO" |
24700e1f | 1627 | depends on INTEL_SKL_INT3472 |
275b13a6 RM |
1628 | help |
1629 | Select this option to enable GPIO driver for the TPS68470 | |
1630 | chip family. | |
dd1695a2 | 1631 | There are 7 GPIOs and few sensor-related GPIOs supported |
275b13a6 RM |
1632 | by the TPS68470. While the 7 GPIOs can be configured as |
1633 | input or output as appropriate, the sensor related GPIOs | |
1634 | are "output only" GPIOs. | |
1635 | ||
b868db94 | 1636 | config GPIO_TQMX86 |
8c219e52 | 1637 | tristate "TQ-Systems TQMx86 GPIO" |
b868db94 | 1638 | depends on MFD_TQMX86 || COMPILE_TEST |
c6414e1a | 1639 | depends on HAS_IOPORT_MAP |
b868db94 AL |
1640 | select GPIOLIB_IRQCHIP |
1641 | help | |
1642 | This driver supports GPIO on the TQMX86 IO controller. | |
1643 | ||
e9d35947 DB |
1644 | config GPIO_TWL4030 |
1645 | tristate "TWL4030, TWL5030, and TPS659x0 GPIOs" | |
1646 | depends on TWL4030_CORE | |
1647 | help | |
1648 | Say yes here to access the GPIO signals of various multi-function | |
1649 | power management chips from Texas Instruments. | |
1650 | ||
70ffd691 PU |
1651 | config GPIO_TWL6040 |
1652 | tristate "TWL6040 GPO" | |
1653 | depends on TWL6040_CORE | |
1654 | help | |
1655 | Say yes here to access the GPO signals of twl6040 | |
1656 | audio chip from Texas Instruments. | |
1657 | ||
0ba19cfc BG |
1658 | config GPIO_WHISKEY_COVE |
1659 | tristate "GPIO support for Whiskey Cove PMIC" | |
b5238b41 | 1660 | depends on (X86 || COMPILE_TEST) && INTEL_SOC_PMIC_BXTWC |
0ba19cfc BG |
1661 | select GPIOLIB_IRQCHIP |
1662 | help | |
1663 | Support for GPIO pins on Whiskey Cove PMIC. | |
1664 | ||
dd1695a2 | 1665 | Say Yes if you have an Intel SoC-based tablet with Whiskey Cove PMIC |
0ba19cfc BG |
1666 | inside. |
1667 | ||
1668 | This driver can also be built as a module. If so, the module will be | |
1669 | called gpio-wcove. | |
1670 | ||
e4b736f1 MB |
1671 | config GPIO_WM831X |
1672 | tristate "WM831x GPIOs" | |
1673 | depends on MFD_WM831X | |
1674 | help | |
1675 | Say yes here to access the GPIO signals of WM831x power management | |
1676 | chips from Wolfson Microelectronics. | |
1677 | ||
38f6ce45 MB |
1678 | config GPIO_WM8350 |
1679 | tristate "WM8350 GPIOs" | |
1680 | depends on MFD_WM8350 | |
1681 | help | |
1682 | Say yes here to access the GPIO signals of WM8350 power management | |
1683 | chips from Wolfson Microelectronics. | |
1684 | ||
2955c309 MB |
1685 | config GPIO_WM8994 |
1686 | tristate "WM8994 GPIOs" | |
1687 | depends on MFD_WM8994 | |
1688 | help | |
1689 | Say yes here to access the GPIO signals of WM8994 audio hub | |
1690 | CODECs from Wolfson Microelectronics. | |
1691 | ||
177b0381 | 1692 | endmenu |
ef72af40 | 1693 | |
177b0381 LW |
1694 | menu "PCI GPIO expanders" |
1695 | depends on PCI | |
459773ae | 1696 | |
92c33ef7 LW |
1697 | config GPIO_AMD8111 |
1698 | tristate "AMD 8111 GPIO driver" | |
72aba2e2 | 1699 | depends on X86 || COMPILE_TEST |
c6414e1a | 1700 | depends on HAS_IOPORT_MAP |
5e969a40 | 1701 | help |
dd1695a2 | 1702 | The AMD 8111 southbridge contains 32 GPIO pins which can be used. |
ff1d5c2f | 1703 | |
dd1695a2 RD |
1704 | Note that usually system firmware/ACPI handles GPIO pins on their |
1705 | own and users might easily break their systems with uncareful usage | |
92c33ef7 | 1706 | of this driver! |
5f0a96b0 | 1707 | |
92c33ef7 | 1708 | If unsure, say N |
5f0a96b0 | 1709 | |
ff1d5c2f MB |
1710 | config GPIO_BT8XX |
1711 | tristate "BT8XX GPIO abuser" | |
c948feea | 1712 | depends on VIDEO_BT848=n || COMPILE_TEST |
ff1d5c2f | 1713 | help |
22520edc | 1714 | The BT8xx frame grabber chip has 24 GPIO pins that can be abused |
ff1d5c2f MB |
1715 | as a cheap PCI GPIO card. |
1716 | ||
1717 | This chip can be found on Miro, Hauppauge and STB TV-cards. | |
1718 | ||
1719 | The card needs to be physically altered for using it as a | |
1720 | GPIO card. For more information on how to build a GPIO card | |
1721 | from a BT8xx TV card, see the documentation file at | |
5f07224e | 1722 | Documentation/driver-api/gpio/bt8xxgpio.rst |
ff1d5c2f MB |
1723 | |
1724 | If unsure, say N. | |
1725 | ||
ccf6fd6d AS |
1726 | config GPIO_MERRIFIELD |
1727 | tristate "Intel Merrifield GPIO support" | |
1728 | depends on X86_INTEL_MID | |
34840be5 | 1729 | select GPIO_TANGIER |
8bf02617 | 1730 | help |
ccf6fd6d | 1731 | Say Y here to support Intel Merrifield GPIO. |
8bf02617 | 1732 | |
c78c42d7 SKR |
1733 | config GPIO_MLXBF |
1734 | tristate "Mellanox BlueField SoC GPIO" | |
cbe706b0 | 1735 | depends on (MELLANOX_PLATFORM && ARM64 && ACPI) || (64BIT && COMPILE_TEST) |
c78c42d7 SKR |
1736 | select GPIO_GENERIC |
1737 | help | |
1738 | Say Y here if you want GPIO support on Mellanox BlueField SoC. | |
1739 | ||
bc0ae0e7 AM |
1740 | config GPIO_MLXBF2 |
1741 | tristate "Mellanox BlueField 2 SoC GPIO" | |
1742 | depends on (MELLANOX_PLATFORM && ARM64 && ACPI) || (64BIT && COMPILE_TEST) | |
1743 | select GPIO_GENERIC | |
2f43f602 | 1744 | select GPIOLIB_IRQCHIP |
bc0ae0e7 AM |
1745 | help |
1746 | Say Y here if you want GPIO support on Mellanox BlueField 2 SoC. | |
1747 | ||
cd33f216 AM |
1748 | config GPIO_MLXBF3 |
1749 | tristate "Mellanox BlueField 3 SoC GPIO" | |
1750 | depends on (MELLANOX_PLATFORM && ARM64) || COMPILE_TEST | |
1751 | select GPIO_GENERIC | |
1752 | select GPIOLIB_IRQCHIP | |
1753 | help | |
1754 | Say Y if you want GPIO support on Mellanox BlueField 3 SoC. | |
1755 | This GPIO controller supports interrupt handling and enables the | |
1756 | manipulation of certain GPIO pins. | |
1757 | This controller should be used in parallel with pinctrl-mlxbf3 to | |
1758 | control the desired GPIOs. | |
1759 | This driver can also be built as a module called mlxbf3-gpio. | |
1760 | ||
92c33ef7 LW |
1761 | config GPIO_ML_IOH |
1762 | tristate "OKI SEMICONDUCTOR ML7213 IOH GPIO support" | |
72aba2e2 | 1763 | depends on X86 || COMPILE_TEST |
92c33ef7 LW |
1764 | select GENERIC_IRQ_CHIP |
1765 | help | |
1766 | ML7213 is companion chip for Intel Atom E6xx series. | |
dd1695a2 RD |
1767 | This driver can be used for OKI SEMICONDUCTOR ML7213 IOH (Input/Output |
1768 | Hub) which is for IVI (In-Vehicle Infotainment) use. | |
92c33ef7 LW |
1769 | This driver can access the IOH's GPIO device. |
1770 | ||
04c17aa8 | 1771 | config GPIO_PCH |
dd1695a2 | 1772 | tristate "Intel EG20T PCH/LAPIS Semiconductor IOH (ML7223/ML7831) GPIO" |
03744529 | 1773 | depends on X86_32 || MIPS || COMPILE_TEST |
38eb18a6 | 1774 | select GENERIC_IRQ_CHIP |
04c17aa8 | 1775 | help |
dd1695a2 RD |
1776 | This driver is for PCH (Platform Controller Hub) GPIO of Intel Topcliff, |
1777 | which is an IOH (Input/Output Hub) for x86 embedded processor. | |
04c17aa8 TM |
1778 | This driver can access PCH GPIO device. |
1779 | ||
dd1695a2 | 1780 | This driver also can be used for LAPIS Semiconductor IOH (Input/ |
868fea05 | 1781 | Output Hub), ML7223 and ML7831. |
dd1695a2 | 1782 | ML7223 IOH is for MP (Media Phone) use. |
868fea05 TM |
1783 | ML7831 IOH is for general purpose use. |
1784 | ML7223/ML7831 is companion chip for Intel Atom E6xx series. | |
1785 | ML7223/ML7831 is completely compatible for Intel EG20T PCH. | |
bc786cce | 1786 | |
02e74fc0 WBG |
1787 | config GPIO_PCI_IDIO_16 |
1788 | tristate "ACCES PCI-IDIO-16 GPIO support" | |
73d8f3ef | 1789 | select REGMAP_MMIO |
e7f758fa | 1790 | select GPIO_IDIO_16 |
02e74fc0 WBG |
1791 | help |
1792 | Enables GPIO support for the ACCES PCI-IDIO-16. An interrupt is | |
1793 | generated when any of the inputs change state (low to high or high to | |
1794 | low). Input filter control is not supported by this driver, and the | |
1795 | input filters are deactivated by this driver. | |
1796 | ||
58556204 WBG |
1797 | config GPIO_PCIE_IDIO_24 |
1798 | tristate "ACCES PCIe-IDIO-24 GPIO support" | |
1a200a39 WBG |
1799 | select REGMAP_IRQ |
1800 | select REGMAP_MMIO | |
58556204 | 1801 | select GPIOLIB_IRQCHIP |
1a200a39 | 1802 | select GPIO_REGMAP |
58556204 WBG |
1803 | help |
1804 | Enables GPIO support for the ACCES PCIe-IDIO-24 family (PCIe-IDIO-24, | |
1805 | PCIe-IDI-24, PCIe-IDO-24, PCIe-IDIO-12). An interrupt is generated | |
1806 | when any of the inputs change state (low to high or high to low). | |
1807 | Input filter control is not supported by this driver, and the input | |
1808 | filters are deactivated by this driver. | |
1809 | ||
92c33ef7 LW |
1810 | config GPIO_RDC321X |
1811 | tristate "RDC R-321x GPIO support" | |
92c33ef7 LW |
1812 | select MFD_CORE |
1813 | select MFD_RDC321X | |
49a36793 | 1814 | help |
92c33ef7 LW |
1815 | Support for the RDC R321x SoC GPIOs over southbridge |
1816 | PCI configuration space. | |
49a36793 | 1817 | |
b43ab901 SAS |
1818 | config GPIO_SODAVILLE |
1819 | bool "Intel Sodaville GPIO support" | |
03744529 | 1820 | depends on X86 && OF |
b43ab901 SAS |
1821 | select GPIO_GENERIC |
1822 | select GENERIC_IRQ_CHIP | |
1823 | help | |
1824 | Say Y here to support Intel Sodaville GPIO. | |
1825 | ||
177b0381 | 1826 | endmenu |
35570ac6 | 1827 | |
177b0381 LW |
1828 | menu "SPI GPIO expanders" |
1829 | depends on SPI_MASTER | |
9956d02d | 1830 | |
a7ec2e7f LW |
1831 | config GPIO_74X164 |
1832 | tristate "74x164 serial-in/parallel-out 8-bits shift register" | |
a7ec2e7f LW |
1833 | help |
1834 | Driver for 74x164 compatible serial-in/parallel-out 8-outputs | |
1835 | shift registers. This driver can be used to provide access | |
dd1695a2 | 1836 | to more GPIO outputs. |
a9c5fff5 | 1837 | |
b2f68edf LW |
1838 | config GPIO_MAX3191X |
1839 | tristate "Maxim MAX3191x industrial serializer" | |
1840 | select CRC8 | |
1841 | help | |
1842 | GPIO driver for Maxim MAX31910, MAX31911, MAX31912, MAX31913, | |
1843 | MAX31953 and MAX31963 industrial serializer, a daisy-chainable | |
1844 | chip to make 8 digital 24V inputs available via SPI. Supports | |
1845 | CRC checksums to guard against electromagnetic interference, | |
1846 | as well as undervoltage and overtemperature detection. | |
1847 | ||
0c36ec31 JB |
1848 | config GPIO_MAX7301 |
1849 | tristate "Maxim MAX7301 GPIO expander" | |
e952805d | 1850 | select GPIO_MAX730X |
0c36ec31 | 1851 | help |
e952805d | 1852 | GPIO driver for Maxim MAX7301 SPI-based GPIO expander. |
0c36ec31 | 1853 | |
1e5db006 RR |
1854 | config GPIO_MC33880 |
1855 | tristate "Freescale MC33880 high-side/low-side switch" | |
1e5db006 RR |
1856 | help |
1857 | SPI driver for Freescale MC33880 high-side/low-side switch. | |
1858 | This provides GPIO interface supporting inputs and outputs. | |
1859 | ||
df6df93c AD |
1860 | config GPIO_PISOSR |
1861 | tristate "Generic parallel-in/serial-out shift register" | |
1862 | help | |
1863 | GPIO driver for SPI compatible parallel-in/serial-out shift | |
1864 | registers. These are input only devices. | |
1865 | ||
5704520d NH |
1866 | config GPIO_XRA1403 |
1867 | tristate "EXAR XRA1403 16-bit GPIO expander" | |
665dff99 | 1868 | select REGMAP_SPI |
5704520d NH |
1869 | help |
1870 | GPIO driver for EXAR XRA1403 16-bit SPI-based GPIO expander. | |
1871 | ||
856ed97a MB |
1872 | config GPIO_MOXTET |
1873 | tristate "Turris Mox Moxtet bus GPIO expander" | |
1874 | depends on MOXTET | |
1875 | help | |
1876 | Say yes here if you are building for the Turris Mox router. | |
1877 | This is the driver needed for configuring the GPIOs via the Moxtet | |
1878 | bus. For example the Mox module with SFP cage needs this driver | |
1879 | so that phylink can use corresponding GPIOs. | |
1880 | ||
0963670a LW |
1881 | endmenu |
1882 | ||
177b0381 LW |
1883 | menu "USB GPIO expanders" |
1884 | depends on USB | |
9d5b72de LP |
1885 | |
1886 | config GPIO_VIPERBOARD | |
1887 | tristate "Viperboard GPIO a & b support" | |
03744529 | 1888 | depends on MFD_VIPERBOARD |
9d5b72de LP |
1889 | help |
1890 | Say yes here to access the GPIO signals of Nano River | |
1891 | Technologies Viperboard. There are two GPIO chips on the | |
1892 | board: gpioa and gpiob. | |
c42e34c9 EWI |
1893 | See viperboard API specification and Nano |
1894 | River Tech's viperboard.h for detailed meaning | |
1895 | of the module parameters. | |
9d5b72de | 1896 | |
c46a74ff MS |
1897 | config GPIO_MPSSE |
1898 | tristate "FTDI MPSSE GPIO support" | |
1899 | select GPIOLIB_IRQCHIP | |
1900 | help | |
1901 | GPIO driver for FTDI's MPSSE interface. These can do input and | |
1902 | output. Each MPSSE provides 16 IO pins. | |
1903 | ||
177b0381 | 1904 | endmenu |
6732127f | 1905 | |
b5252196 EWI |
1906 | menu "Virtual GPIO drivers" |
1907 | ||
828546e2 GU |
1908 | config GPIO_AGGREGATOR |
1909 | tristate "GPIO Aggregator" | |
86f162e7 KD |
1910 | select CONFIGFS_FS |
1911 | select DEV_SYNC_PROBE | |
828546e2 GU |
1912 | help |
1913 | Say yes here to enable the GPIO Aggregator, which provides a way to | |
1914 | aggregate existing GPIO lines into a new virtual GPIO chip. | |
1915 | This can serve the following purposes: | |
1916 | - Assign permissions for a collection of GPIO lines to a user, | |
1917 | - Export a collection of GPIO lines to a virtual machine, | |
1918 | - Provide a generic driver for a GPIO-operated device in an | |
1919 | industrial control context, to be operated from userspace using | |
1920 | the GPIO chardev interface. | |
1921 | ||
1454a928 SH |
1922 | config GPIO_LATCH |
1923 | tristate "GPIO latch driver" | |
1924 | help | |
1925 | Say yes here to enable a driver for GPIO multiplexers based on latches | |
1926 | connected to other GPIOs. | |
1927 | ||
6e4484ee | 1928 | config GPIO_MOCKUP |
9790222d | 1929 | tristate "GPIO Testing Driver (DEPRECATED)" |
6e4484ee BG |
1930 | select IRQ_SIM |
1931 | help | |
9790222d BG |
1932 | This module is DEPRECATED. Please consider using gpio-sim instead. |
1933 | ||
6e4484ee | 1934 | This enables GPIO Testing driver, which provides a way to test GPIO |
4bf24261 | 1935 | subsystem through sysfs (or char device) and debugfs. |
6e4484ee BG |
1936 | User could use it through the script in |
1937 | tools/testing/selftests/gpio/gpio-mockup.sh. Reference the usage in | |
1938 | it. | |
1939 | ||
3a29355a VK |
1940 | config GPIO_VIRTIO |
1941 | tristate "VirtIO GPIO support" | |
1942 | depends on VIRTIO | |
eff5cdd7 | 1943 | select GPIOLIB_IRQCHIP |
3a29355a VK |
1944 | help |
1945 | Say Y here to enable guest support for virtio-based GPIO controllers. | |
1946 | ||
1947 | These virtual GPIOs can be routed to real GPIOs or attached to | |
1948 | simulators on the host (like QEMU). | |
1949 | ||
cb8c474e BG |
1950 | config GPIO_SIM |
1951 | tristate "GPIO Simulator Module" | |
1952 | select IRQ_SIM | |
1953 | select CONFIGFS_FS | |
2f41dbf9 | 1954 | select DEV_SYNC_PROBE |
cb8c474e BG |
1955 | help |
1956 | This enables the GPIO simulator - a configfs-based GPIO testing | |
1957 | driver. | |
1958 | ||
b5252196 EWI |
1959 | endmenu |
1960 | ||
7828b7bb WS |
1961 | menu "GPIO Debugging utilities" |
1962 | ||
1963 | config GPIO_SLOPPY_LOGIC_ANALYZER | |
1964 | tristate "Sloppy GPIO logic analyzer" | |
1965 | depends on (GPIOLIB || COMPILE_TEST) && CPUSETS && DEBUG_FS && EXPERT | |
1966 | help | |
1967 | This option enables support for a sloppy logic analyzer using polled | |
1968 | GPIOs. Use the 'tools/gpio/gpio-sloppy-logic-analyzer' script with | |
1969 | this driver. The script will make it easier to use and will also | |
1970 | isolate a CPU for the polling task. Note that this is a last resort | |
1971 | analyzer which can be affected by latencies, non-deterministic code | |
1972 | paths, or NMIs. However, for e.g. remote development, it may be useful | |
1973 | to get a first view and aid further debugging. | |
1974 | ||
1975 | If this driver is built as a module it will be called | |
1976 | 'gpio-sloppy-logic-analyzer'. | |
1977 | ||
91581c4b BG |
1978 | config GPIO_VIRTUSER |
1979 | tristate "GPIO Virtual User Testing Module" | |
1980 | select DEBUG_FS | |
1981 | select CONFIGFS_FS | |
1982 | select IRQ_WORK | |
45af02f0 | 1983 | select DEV_SYNC_PROBE |
91581c4b BG |
1984 | help |
1985 | Say Y here to enable the configurable, configfs-based virtual GPIO | |
1986 | consumer testing driver. | |
1987 | ||
1988 | This driver is aimed as a helper in spotting any regressions in | |
1989 | hot-unplug handling in GPIOLIB. | |
1990 | ||
7828b7bb WS |
1991 | endmenu |
1992 | ||
7444a72e | 1993 | endif |
eb5ab6ff KD |
1994 | |
1995 | config DEV_SYNC_PROBE | |
1996 | tristate |