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