xref: /linux/drivers/gpio/Kconfig (revision 91581c4b3f29e2e22aeb1a62e842d529ca638b2d)
1ec8f24b7SThomas Gleixner# SPDX-License-Identifier: GPL-2.0-only
2a9c5fff5SDavid Brownell#
3e849dc04SLinus Walleij# GPIO infrastructure and drivers
4a9c5fff5SDavid Brownell#
5a9c5fff5SDavid Brownell
67444a72eSMichael Bueschmenuconfig GPIOLIB
77444a72eSMichael Buesch	bool "GPIO Support"
87444a72eSMichael Buesch	help
97444a72eSMichael Buesch	  This enables GPIO support through the generic GPIO library.
10dd1695a2SRandy Dunlap	  You only need to enable this if you also want to enable
11e849dc04SLinus Walleij	  one or more of the GPIO drivers below.
127444a72eSMichael Buesch
137444a72eSMichael Buesch	  If unsure, say N.
147444a72eSMichael Buesch
157444a72eSMichael Bueschif GPIOLIB
16a9c5fff5SDavid Brownell
173027743fSLaura Abbottconfig GPIOLIB_FASTPATH_LIMIT
183027743fSLaura Abbott	int "Maximum number of GPIOs for fast path"
193027743fSLaura Abbott	range 32 512
203027743fSLaura Abbott	default 512
213027743fSLaura Abbott	help
223027743fSLaura Abbott	  This adjusts the point at which certain APIs will switch from
233027743fSLaura Abbott	  using a stack allocated buffer to a dynamically allocated buffer.
243027743fSLaura Abbott
253027743fSLaura Abbott	  You shouldn't need to change this unless you really need to
263027743fSLaura Abbott	  optimize either stack space or performance. Change this carefully
273027743fSLaura Abbott	  since setting an incorrect value could cause stack corruption.
283027743fSLaura Abbott
29f141ed65SGrant Likelyconfig OF_GPIO
30f141ed65SGrant Likely	def_bool y
3192c74bceSLinus Walleij	depends on OF
322527ecc9SLinus Walleij	depends on HAS_IOMEM
33f141ed65SGrant Likely
34e29482e8SMathias Nymanconfig GPIO_ACPI
35e29482e8SMathias Nyman	def_bool y
36e29482e8SMathias Nyman	depends on ACPI
37e29482e8SMathias Nyman
3814250520SLinus Walleijconfig GPIOLIB_IRQCHIP
39fc346270SLinus Walleij	select IRQ_DOMAIN
4014250520SLinus Walleij	bool
4114250520SLinus Walleij
42a99cc668SArnd Bergmannconfig OF_GPIO_MM_GPIOCHIP
43a99cc668SArnd Bergmann	bool
44a99cc668SArnd Bergmann	help
45a99cc668SArnd Bergmann	  This adds support for the legacy 'struct of_mm_gpio_chip' interface
46a99cc668SArnd Bergmann	  from PowerPC. Existing drivers using this interface need to select
47a99cc668SArnd Bergmann	  this symbol, but new drivers should use the generic gpio-regmap
48a99cc668SArnd Bergmann	  infrastructure instead.
49a99cc668SArnd Bergmann
50a9c5fff5SDavid Brownellconfig DEBUG_GPIO
51a9c5fff5SDavid Brownell	bool "Debug GPIO calls"
52a9c5fff5SDavid Brownell	depends on DEBUG_KERNEL
53a9c5fff5SDavid Brownell	help
54a9c5fff5SDavid Brownell	  Say Y here to add some extra checks and diagnostics to GPIO calls.
55692105b8SMatt LaPlante	  These checks help ensure that GPIOs have been properly initialized
56692105b8SMatt LaPlante	  before they are used, and that sleeping calls are not made from
57692105b8SMatt LaPlante	  non-sleeping contexts.  They can make bitbanged serial protocols
58a9c5fff5SDavid Brownell	  slower.  The diagnostics help catch the type of setup errors
59a9c5fff5SDavid Brownell	  that are most common when setting up new platforms or boards.
60a9c5fff5SDavid Brownell
61d8f388d8SDavid Brownellconfig GPIO_SYSFS
623b4feb21SLinus Walleij	bool "/sys/class/gpio/... (sysfs interface)" if EXPERT
634c0ea233SKees Cook	depends on SYSFS
643b4feb21SLinus Walleij	select GPIO_CDEV # We need to encourage the new ABI
65d8f388d8SDavid Brownell	help
66db9477f8SLinus Walleij	  Say Y here to add the legacy sysfs interface for GPIOs.
67d8f388d8SDavid Brownell
68db9477f8SLinus Walleij	  This ABI is deprecated. If you want to use GPIO from userspace,
69db9477f8SLinus Walleij	  use the character device /dev/gpiochipN with the appropriate
70d143493cSKent Gibson	  ioctl() operations instead.
71d143493cSKent Gibson
72d143493cSKent Gibsonconfig GPIO_CDEV
73d143493cSKent Gibson	bool
74d143493cSKent Gibson	prompt "Character device (/dev/gpiochipN) support" if EXPERT
75d143493cSKent Gibson	default y
76d143493cSKent Gibson	help
77d143493cSKent Gibson	  Say Y here to add the character device /dev/gpiochipN interface
78d143493cSKent Gibson	  for GPIOs. The character device allows userspace to control GPIOs
79d143493cSKent Gibson	  using ioctl() operations.
80d143493cSKent Gibson
81d143493cSKent Gibson	  Only say N if you are sure that the GPIO character device is not
82d143493cSKent Gibson	  required.
83d143493cSKent Gibson
84d143493cSKent Gibson	  If unsure, say Y.
85d8f388d8SDavid Brownell
86957ebb61SKent Gibsonconfig GPIO_CDEV_V1
87957ebb61SKent Gibson	bool "Support GPIO ABI Version 1"
88957ebb61SKent Gibson	default y
89957ebb61SKent Gibson	depends on GPIO_CDEV
90957ebb61SKent Gibson	help
91957ebb61SKent Gibson	  Say Y here to support version 1 of the GPIO CDEV ABI.
92957ebb61SKent Gibson
93957ebb61SKent Gibson	  This ABI version is deprecated.
94957ebb61SKent Gibson	  Please use the latest ABI for new developments.
95957ebb61SKent Gibson
96957ebb61SKent Gibson	  If unsure, say Y.
97957ebb61SKent Gibson
98c103de24SGrant Likelyconfig GPIO_GENERIC
993085a4a4SLinus Walleij	depends on HAS_IOMEM # Only for IOMEM drivers
100c103de24SGrant Likely	tristate
101c103de24SGrant Likely
102ebe36319SMichael Walleconfig GPIO_REGMAP
103d49765b5SRandy Dunlap	select REGMAP
104ebe36319SMichael Walle	tristate
105ebe36319SMichael Walle
1069d50f95bSCharles Keepaxconfig GPIO_SWNODE_UNDEFINED
1079d50f95bSCharles Keepax	bool
1089d50f95bSCharles Keepax	help
1099d50f95bSCharles Keepax	  This adds a special place holder for software nodes to contain an
1109d50f95bSCharles Keepax	  undefined GPIO reference, this is primarily used by SPI to allow a
1119d50f95bSCharles Keepax	  list of GPIO chip selects to mark a certain chip select as being
1129d50f95bSCharles Keepax	  controlled the SPI device's internal chip select mechanism and not
1139d50f95bSCharles Keepax	  a GPIO.
1149d50f95bSCharles Keepax
115e849dc04SLinus Walleij# put drivers in the right section, in alphabetical order
116a9c5fff5SDavid Brownell
117177b0381SLinus Walleij# This symbol is selected by both I2C and SPI expanders
118e952805dSWolfram Sangconfig GPIO_MAX730X
119e952805dSWolfram Sang	tristate
120e952805dSWolfram Sang
121b9b1fc1aSWilliam Breathitt Grayconfig GPIO_IDIO_16
122b9b1fc1aSWilliam Breathitt Gray	tristate
123db022478SWilliam Breathitt Gray	select REGMAP_IRQ
124db022478SWilliam Breathitt Gray	select GPIOLIB_IRQCHIP
125db022478SWilliam Breathitt Gray	select GPIO_REGMAP
126b9b1fc1aSWilliam Breathitt Gray	help
127b9b1fc1aSWilliam Breathitt Gray	  Enables support for the idio-16 library functions. The idio-16 library
128b9b1fc1aSWilliam Breathitt Gray	  provides functions to facilitate communication with devices within the
129b9b1fc1aSWilliam Breathitt Gray	  ACCES IDIO-16 family such as the 104-IDIO-16 and the PCI-IDIO-16.
130b9b1fc1aSWilliam Breathitt Gray
131b9b1fc1aSWilliam Breathitt Gray	  If built as a module its name will be gpio-idio-16.
132b9b1fc1aSWilliam Breathitt Gray
133177b0381SLinus Walleijmenu "Memory mapped GPIO drivers"
1343085a4a4SLinus Walleij	depends on HAS_IOMEM
1350bcb6069SJohn Linn
136af0a33e2SAlexander Shiyanconfig GPIO_74XX_MMIO
137af0a33e2SAlexander Shiyan	tristate "GPIO driver for 74xx-ICs with MMIO access"
138af0a33e2SAlexander Shiyan	depends on OF_GPIO
139af0a33e2SAlexander Shiyan	select GPIO_GENERIC
140af0a33e2SAlexander Shiyan	help
141af0a33e2SAlexander Shiyan	  Say yes here to support GPIO functionality for 74xx-compatible ICs
142af0a33e2SAlexander Shiyan	  with MMIO access. Compatible models include:
143af0a33e2SAlexander Shiyan	    1 bit:	741G125 (Input), 741G74 (Output)
144af0a33e2SAlexander Shiyan	    2 bits:	742G125 (Input), 7474 (Output)
145af0a33e2SAlexander Shiyan	    4 bits:	74125 (Input), 74175 (Output)
146af0a33e2SAlexander Shiyan	    6 bits:	74365 (Input), 74174 (Output)
147af0a33e2SAlexander Shiyan	    8 bits:	74244 (Input), 74273 (Output)
148af0a33e2SAlexander Shiyan	    16 bits:	741624 (Input), 7416374 (Output)
149af0a33e2SAlexander Shiyan
150223fa272SLinus Walleijconfig GPIO_ALTERA
151223fa272SLinus Walleij	tristate "Altera GPIO"
152223fa272SLinus Walleij	depends on OF_GPIO
153223fa272SLinus Walleij	select GPIOLIB_IRQCHIP
154a99cc668SArnd Bergmann	select OF_GPIO_MM_GPIOCHIP
155223fa272SLinus Walleij	help
156223fa272SLinus Walleij	  Say Y or M here to build support for the Altera PIO device.
157223fa272SLinus Walleij
158223fa272SLinus Walleij	  If driver is built as a module it will be called gpio-altera.
159223fa272SLinus Walleij
1606057d40fSYD Tsengconfig GPIO_AMDPT
1616057d40fSYD Tseng	tristate "AMD Promontory GPIO support"
1626057d40fSYD Tseng	depends on ACPI
163574b782eSAxel Lin	select GPIO_GENERIC
1646057d40fSYD Tseng	help
165dd1695a2SRandy Dunlap	  Driver for GPIO functionality on Promontory IOHub.
166dd1695a2SRandy Dunlap	  Requires ACPI ASL code to enumerate as a platform device.
1676057d40fSYD Tseng
168361b7911SJoel Stanleyconfig GPIO_ASPEED
169361b7911SJoel Stanley	tristate "Aspeed GPIO support"
170361b7911SJoel Stanley	depends on (ARCH_ASPEED || COMPILE_TEST) && OF_GPIO
171361b7911SJoel Stanley	select GPIOLIB_IRQCHIP
172361b7911SJoel Stanley	help
173361b7911SJoel Stanley	  Say Y here to support Aspeed AST2400 and AST2500 GPIO controllers.
174361b7911SJoel Stanley
175f8b410e3SLinus Walleijconfig GPIO_ASPEED_SGPIO
176f8b410e3SLinus Walleij	bool "Aspeed SGPIO support"
177f8b410e3SLinus Walleij	depends on (ARCH_ASPEED || COMPILE_TEST) && OF_GPIO
178f8b410e3SLinus Walleij	select GPIO_GENERIC
179f8b410e3SLinus Walleij	select GPIOLIB_IRQCHIP
180f8b410e3SLinus Walleij	help
181f8b410e3SLinus Walleij	  Say Y here to support Aspeed AST2500 SGPIO functionality.
182f8b410e3SLinus Walleij
183ab32770eSAlban Bedelconfig GPIO_ATH79
184ab32770eSAlban Bedel	tristate "Atheros AR71XX/AR724X/AR913X GPIO support"
185ab32770eSAlban Bedel	default y if ATH79
186409d8783SAlban Bedel	depends on ATH79 || COMPILE_TEST
187ab32770eSAlban Bedel	select GPIO_GENERIC
1882b8f89e1SAlban Bedel	select GPIOLIB_IRQCHIP
189ab32770eSAlban Bedel	help
190ab32770eSAlban Bedel	  Select this option to enable GPIO driver for
191ab32770eSAlban Bedel	  Atheros AR71XX/AR724X/AR913X SoC devices.
192ab32770eSAlban Bedel
193a98d90e7SDave Stevensonconfig GPIO_RASPBERRYPI_EXP
194a98d90e7SDave Stevenson	tristate "Raspberry Pi 3 GPIO Expander"
195a98d90e7SDave Stevenson	default RASPBERRYPI_FIRMWARE
196a98d90e7SDave Stevenson	depends on OF_GPIO
19794337b72SBaruch Siach	# Make sure not 'y' when RASPBERRYPI_FIRMWARE is 'm'. This can only
19894337b72SBaruch Siach	# happen when COMPILE_TEST=y, hence the added !RASPBERRYPI_FIRMWARE.
1997ed91505SArnd Bergmann	depends on (ARCH_BCM2835 && RASPBERRYPI_FIRMWARE) || (COMPILE_TEST && !RASPBERRYPI_FIRMWARE)
200a98d90e7SDave Stevenson	help
201a98d90e7SDave Stevenson	  Turn on GPIO support for the expander on Raspberry Pi 3 boards, using
202a98d90e7SDave Stevenson	  the firmware mailbox to communicate with VideoCore on BCM283x chips.
203a98d90e7SDave Stevenson
204ea948cffSLinus Walleijconfig GPIO_BCM_KONA
205ea948cffSLinus Walleij	bool "Broadcom Kona GPIO"
206c9ab610eSAndy Shevchenko	depends on ARCH_BCM_MOBILE || COMPILE_TEST
207ea948cffSLinus Walleij	help
208ea948cffSLinus Walleij	  Turn on GPIO support for Broadcom "Kona" chips.
209ea948cffSLinus Walleij
2106a41b6c5SChris Packhamconfig GPIO_BCM_XGS_IPROC
2116a41b6c5SChris Packham	tristate "BRCM XGS iProc GPIO support"
2126a41b6c5SChris Packham	depends on OF_GPIO && (ARCH_BCM_IPROC || COMPILE_TEST)
2136a41b6c5SChris Packham	select GPIO_GENERIC
2146a41b6c5SChris Packham	select GPIOLIB_IRQCHIP
2156a41b6c5SChris Packham	default ARCH_BCM_IPROC
2166a41b6c5SChris Packham	help
2176a41b6c5SChris Packham	  Say yes here to enable GPIO support for Broadcom XGS iProc SoCs.
2186a41b6c5SChris Packham
2193b0213d5SGregory Fongconfig GPIO_BRCMSTB
2203b0213d5SGregory Fong	tristate "BRCMSTB GPIO support"
221a02588a0SFlorian Fainelli	default y if (ARCH_BRCMSTB || BMIPS_GENERIC)
222e7ba9d11SPeter Robinson	depends on OF_GPIO && (ARCH_BRCMSTB || ARCH_BCM2835 || BMIPS_GENERIC || COMPILE_TEST)
2233b0213d5SGregory Fong	select GPIO_GENERIC
2240ba31dc2SDoug Berger	select IRQ_DOMAIN
2253b0213d5SGregory Fong	help
2263b0213d5SGregory Fong	  Say yes here to enable GPIO support for Broadcom STB (BCM7XXX) SoCs.
2273b0213d5SGregory Fong
22872ab2f76SJan Kotasconfig GPIO_CADENCE
22972ab2f76SJan Kotas	tristate "Cadence GPIO support"
23072ab2f76SJan Kotas	depends on OF_GPIO
23172ab2f76SJan Kotas	select GPIO_GENERIC
23272ab2f76SJan Kotas	select GPIOLIB_IRQCHIP
23372ab2f76SJan Kotas	help
23472ab2f76SJan Kotas	  Say yes here to enable support for Cadence GPIO controller.
23572ab2f76SJan Kotas
236a3b8d4a5SAlexander Shiyanconfig GPIO_CLPS711X
23755fe14abSAlexander Shiyan	tristate "CLPS711X GPIO support"
238ffd4bf1aSAlexander Shiyan	depends on ARCH_CLPS711X || COMPILE_TEST
23955fe14abSAlexander Shiyan	select GPIO_GENERIC
24055fe14abSAlexander Shiyan	help
24155fe14abSAlexander Shiyan	  Say yes here to support GPIO on CLPS711X SoCs.
242a3b8d4a5SAlexander Shiyan
243ee89cf63SGrygorii Strashkoconfig GPIO_DAVINCI
2448dab99c9SGuillaume La Roque	tristate "TI Davinci/Keystone GPIO support"
245ee89cf63SGrygorii Strashko	default y if ARCH_DAVINCI
2466eeea326SKeerthy	depends on (ARM || ARM64) && (ARCH_DAVINCI || ARCH_KEYSTONE || ARCH_K3)
247ee89cf63SGrygorii Strashko	help
248ee89cf63SGrygorii Strashko	  Say yes here to enable GPIO support for TI Davinci/Keystone SoCs.
249ee89cf63SGrygorii Strashko
2507779b345SJamie Ilesconfig GPIO_DWAPB
2517779b345SJamie Iles	tristate "Synopsys DesignWare APB GPIO driver"
2527779b345SJamie Iles	select GPIO_GENERIC
2530ea68393SSerge Semin	select GPIOLIB_IRQCHIP
2547779b345SJamie Iles	help
2557779b345SJamie Iles	  Say Y or M here to build support for the Synopsys DesignWare APB
2567779b345SJamie Iles	  GPIO block.
2577779b345SJamie Iles
25825518e02SBaolin Wangconfig GPIO_EIC_SPRD
25925518e02SBaolin Wang	tristate "Spreadtrum EIC support"
26025518e02SBaolin Wang	depends on ARCH_SPRD || COMPILE_TEST
26125518e02SBaolin Wang	depends on OF_GPIO
26225518e02SBaolin Wang	select GPIOLIB_IRQCHIP
26325518e02SBaolin Wang	help
26425518e02SBaolin Wang	  Say yes here to support Spreadtrum EIC device.
26525518e02SBaolin Wang
266a07e103eSMagnus Dammconfig GPIO_EM
267a07e103eSMagnus Damm	tristate "Emma Mobile GPIO"
26822eaf13cSPeter Robinson	depends on (ARCH_EMEV2 || COMPILE_TEST) && OF_GPIO
269a07e103eSMagnus Damm	help
270a07e103eSMagnus Damm	  Say yes here to support GPIO on Renesas Emma Mobile SoCs.
271a07e103eSMagnus Damm
2720868ad38SJohn Crispinconfig GPIO_EN7523
2730868ad38SJohn Crispin	tristate "Airoha GPIO support"
2740868ad38SJohn Crispin	depends on ARCH_AIROHA
2750868ad38SJohn Crispin	default ARCH_AIROHA
2760868ad38SJohn Crispin	select GPIO_GENERIC
2770868ad38SJohn Crispin	select GPIOLIB_IRQCHIP
2780868ad38SJohn Crispin	help
2790868ad38SJohn Crispin	  Say Y or M here to support the GPIO controller block on the
2800868ad38SJohn Crispin	  Airoha EN7523 SoC. It supports two banks of 32 GPIOs.
2810868ad38SJohn Crispin
282c6b52c13SH Hartley Sweetenconfig GPIO_EP93XX
283c6b52c13SH Hartley Sweeten	def_bool y
284c6b52c13SH Hartley Sweeten	depends on ARCH_EP93XX
2851e4c8842SH Hartley Sweeten	select GPIO_GENERIC
286a419a3d9SLinus Walleij	select GPIOLIB_IRQCHIP
287c6b52c13SH Hartley Sweeten
2886596e59eSSudip Mukherjeeconfig GPIO_EXAR
2896596e59eSSudip Mukherjee	tristate "Support for GPIO pins on XR17V352/354/358"
2906596e59eSSudip Mukherjee	depends on SERIAL_8250_EXAR
29136fb7218SBartosz Golaszewski	select REGMAP_MMIO
2926596e59eSSudip Mukherjee	help
2936596e59eSSudip Mukherjee	  Selecting this option will enable handling of GPIO pins present
2946596e59eSSudip Mukherjee	  on Exar XR17V352/354/358 chips.
2956596e59eSSudip Mukherjee
296223fa272SLinus Walleijconfig GPIO_GE_FPGA
297223fa272SLinus Walleij	bool "GE FPGA based GPIO"
29855b47353SAndy Shevchenko	depends on GE_FPGA || COMPILE_TEST
299223fa272SLinus Walleij	select GPIO_GENERIC
300223fa272SLinus Walleij	help
301223fa272SLinus Walleij	  Support for common GPIO functionality provided on some GE Single Board
302223fa272SLinus Walleij	  Computers.
303223fa272SLinus Walleij
304223fa272SLinus Walleij	  This driver provides basic support (configure as input or output, read
305223fa272SLinus Walleij	  and write pin state) for GPIO implemented in a number of GE single
306223fa272SLinus Walleij	  board computers.
307223fa272SLinus Walleij
3089d3a15aaSLinus Walleijconfig GPIO_FTGPIO010
3099d3a15aaSLinus Walleij	bool "Faraday FTGPIO010 GPIO"
31049cec4d8SLinus Walleij	depends on OF_GPIO
31149cec4d8SLinus Walleij	select GPIO_GENERIC
31249cec4d8SLinus Walleij	select GPIOLIB_IRQCHIP
313d8307c09SLinus Walleij	default (ARCH_GEMINI || ARCH_MOXART)
31449cec4d8SLinus Walleij	help
3159d3a15aaSLinus Walleij	  Support for common GPIOs from the Faraday FTGPIO010 IP core, found in
3169d3a15aaSLinus Walleij	  Cortina systems Gemini platforms, Moxa ART and others.
31749cec4d8SLinus Walleij
318223fa272SLinus Walleijconfig GPIO_GENERIC_PLATFORM
319223fa272SLinus Walleij	tristate "Generic memory-mapped GPIO controller support (MMIO platform device)"
320223fa272SLinus Walleij	select GPIO_GENERIC
321223fa272SLinus Walleij	help
322223fa272SLinus Walleij	  Say yes here to support basic platform_device memory-mapped GPIO controllers.
323223fa272SLinus Walleij
324ecc4b141SAapo Vienamoconfig GPIO_GRANITERAPIDS
325ecc4b141SAapo Vienamo	tristate "Intel Granite Rapids-D vGPIO support"
326ecc4b141SAapo Vienamo	depends on X86 || COMPILE_TEST
327ecc4b141SAapo Vienamo	select GPIOLIB_IRQCHIP
328ecc4b141SAapo Vienamo	help
329ecc4b141SAapo Vienamo	  Select this to enable virtual GPIO support on platforms with the
330ecc4b141SAapo Vienamo	  following SoCs:
331ecc4b141SAapo Vienamo
332ecc4b141SAapo Vienamo	  - Intel Granite Rapids-D
333ecc4b141SAapo Vienamo
334ecc4b141SAapo Vienamo	  The driver enables basic GPIO functionality and implements interrupt
335ecc4b141SAapo Vienamo	  support. The virtual GPIO driver controls GPIO lines via a firmware
336ecc4b141SAapo Vienamo	  interface. The physical GPIO pins reside on device that is external
337ecc4b141SAapo Vienamo	  from the main SoC package, such as a BMC or a CPLD.
338ecc4b141SAapo Vienamo
339ecc4b141SAapo Vienamo	  To compile this driver as a module, choose M here: the module will
340ecc4b141SAapo Vienamo	  be called gpio-graniterapids.
341ecc4b141SAapo Vienamo
342223fa272SLinus Walleijconfig GPIO_GRGPIO
343223fa272SLinus Walleij	tristate "Aeroflex Gaisler GRGPIO support"
344048c28c9SLinus Walleij	depends on OF_GPIO
345223fa272SLinus Walleij	select GPIO_GENERIC
346223fa272SLinus Walleij	select IRQ_DOMAIN
347223fa272SLinus Walleij	help
348223fa272SLinus Walleij	  Select this to support Aeroflex Gaisler GRGPIO cores from the GRLIB
349223fa272SLinus Walleij	  VHDL IP core library.
350223fa272SLinus Walleij
351356b01a9SLuo Jiaxingconfig GPIO_HISI
352356b01a9SLuo Jiaxing	tristate "HiSilicon GPIO controller driver"
35380280df7SWeilong Chen	depends on ARM64 || COMPILE_TEST
354356b01a9SLuo Jiaxing	select GPIO_GENERIC
355356b01a9SLuo Jiaxing	select GPIOLIB_IRQCHIP
356356b01a9SLuo Jiaxing	help
357356b01a9SLuo Jiaxing	  Say Y or M here to build support for the HiSilicon GPIO controller
358356b01a9SLuo Jiaxing	  driver GPIO block.
359dd1695a2SRandy Dunlap	  This GPIO controller supports double-edge interrupt and multi-core
360356b01a9SLuo Jiaxing	  concurrent access.
361356b01a9SLuo Jiaxing
3628f55fed3SJonathan Neuschäferconfig GPIO_HLWD
3638f55fed3SJonathan Neuschäfer	tristate "Nintendo Wii (Hollywood) GPIO"
3648f55fed3SJonathan Neuschäfer	depends on OF_GPIO
3658f55fed3SJonathan Neuschäfer	select GPIO_GENERIC
366588de43cSJonathan Neuschäfer	select GPIOLIB_IRQCHIP
3678f55fed3SJonathan Neuschäfer	help
3688f55fed3SJonathan Neuschäfer	  Select this to support the GPIO controller of the Nintendo Wii.
3698f55fed3SJonathan Neuschäfer
3708f55fed3SJonathan Neuschäfer	  If unsure, say N.
3718f55fed3SJonathan Neuschäfer
372223fa272SLinus Walleijconfig GPIO_ICH
373223fa272SLinus Walleij	tristate "Intel ICH GPIO"
374ba134d29SAndy Shevchenko	depends on X86
375ba134d29SAndy Shevchenko	depends on LPC_ICH
376223fa272SLinus Walleij	help
377223fa272SLinus Walleij	  Say yes here to support the GPIO functionality of a number of Intel
378223fa272SLinus Walleij	  ICH-based chipsets.  Currently supported devices: ICH6, ICH7, ICH8
379dd1695a2SRandy Dunlap	  ICH9, ICH10, Series 5/3400 (e.g. Ibex Peak), Series 6/C200 (e.g.
380223fa272SLinus Walleij	  Cougar Point), NM10 (Tiger Point), and 3100 (Whitmore Lake).
381223fa272SLinus Walleij
382223fa272SLinus Walleij	  If unsure, say N.
383223fa272SLinus Walleij
3840bd459ddSShenwei Wangconfig GPIO_IMX_SCU
3850bd459ddSShenwei Wang       def_bool y
3860bd459ddSShenwei Wang       depends on IMX_SCU
3870bd459ddSShenwei Wang
388813e7d36SLinus Walleijconfig GPIO_IXP4XX
389813e7d36SLinus Walleij	bool "Intel IXP4xx GPIO"
390813e7d36SLinus Walleij	depends on ARCH_IXP4XX
391c83227a5SLinus Walleij	depends on OF
392813e7d36SLinus Walleij	select GPIO_GENERIC
393aa7d618aSLinus Walleij	select GPIOLIB_IRQCHIP
394813e7d36SLinus Walleij	select IRQ_DOMAIN_HIERARCHY
395813e7d36SLinus Walleij	help
396813e7d36SLinus Walleij	  Say yes here to support the GPIO functionality of a number of Intel
397813e7d36SLinus Walleij	  IXP4xx series of chips.
398813e7d36SLinus Walleij
399813e7d36SLinus Walleij	  If unsure, say N.
400c83227a5SLinus Walleij
401c16485adSPaul Kocialkowskiconfig GPIO_LOGICVC
402c16485adSPaul Kocialkowski	tristate "Xylon LogiCVC GPIO support"
403c16485adSPaul Kocialkowski	depends on MFD_SYSCON && OF
404c16485adSPaul Kocialkowski	help
405c16485adSPaul Kocialkowski	  Say yes here to support GPIO functionality of the Xylon LogiCVC
406c16485adSPaul Kocialkowski	  programmable logic block.
407813e7d36SLinus Walleij
408223fa272SLinus Walleijconfig GPIO_LOONGSON
409223fa272SLinus Walleij	bool "Loongson-2/3 GPIO support"
410268a2d60SJiaxun Yang	depends on CPU_LOONGSON2EF || CPU_LOONGSON64
411223fa272SLinus Walleij	help
412dd1695a2SRandy Dunlap	  Driver for GPIO functionality on Loongson-2F/3A/3B processors.
413223fa272SLinus Walleij
4147944d3b7SYinbo Zhuconfig GPIO_LOONGSON_64BIT
4157944d3b7SYinbo Zhu	tristate "Loongson 64 bit GPIO support"
4167944d3b7SYinbo Zhu	depends on LOONGARCH || COMPILE_TEST
417b96eb88fSYinbo Zhu	depends on OF_GPIO
4187944d3b7SYinbo Zhu	select GPIO_GENERIC
4197944d3b7SYinbo Zhu	help
4207944d3b7SYinbo Zhu	  Say yes here to support the GPIO functionality of a number of
4217944d3b7SYinbo Zhu	  Loongson series of chips. The Loongson GPIO controller supports
4227944d3b7SYinbo Zhu	  up to 60 GPIOS in total, 4 of which are dedicated GPIO pins, and
4237944d3b7SYinbo Zhu	  the remaining 56 are reused with other functions, with edge or
4247944d3b7SYinbo Zhu	  level triggered interrupts.
4257944d3b7SYinbo Zhu
42613a43fd9SJoachim Eastwoodconfig GPIO_LPC18XX
42754b72998SPaul Gortmaker	tristate "NXP LPC18XX/43XX GPIO support"
42813a43fd9SJoachim Eastwood	default y if ARCH_LPC18XX
42913a43fd9SJoachim Eastwood	depends on OF_GPIO && (ARCH_LPC18XX || COMPILE_TEST)
4305ddabfe8SVladimir Zapolskiy	select IRQ_DOMAIN_HIERARCHY
43113a43fd9SJoachim Eastwood	help
43213a43fd9SJoachim Eastwood	  Select this option to enable GPIO driver for
43313a43fd9SJoachim Eastwood	  NXP LPC18XX/43XX devices.
43413a43fd9SJoachim Eastwood
435f2ee7314SArnd Bergmannconfig GPIO_LPC32XX
436f2ee7314SArnd Bergmann	tristate "NXP LPC32XX GPIO support"
437f2ee7314SArnd Bergmann	depends on OF_GPIO && (ARCH_LPC32XX || COMPILE_TEST)
438f2ee7314SArnd Bergmann	help
439f2ee7314SArnd Bergmann	  Select this option to enable GPIO driver for
440f2ee7314SArnd Bergmann	  NXP LPC32XX devices.
441f2ee7314SArnd Bergmann
4420da094d8SJassi Brarconfig GPIO_MB86S7X
443e1289dbaSArd Biesheuvel	tristate "GPIO support for Fujitsu MB86S7x Platforms"
4440da094d8SJassi Brar	help
4450da094d8SJassi Brar	  Say yes here to support the GPIO controller in Fujitsu MB86S70 SoCs.
4469af4d80bSFabian Vogt
447f436bc27SAndreas Wernerconfig GPIO_MENZ127
448f436bc27SAndreas Werner	tristate "MEN 16Z127 GPIO support"
449f436bc27SAndreas Werner	depends on MCB
450f436bc27SAndreas Werner	select GPIO_GENERIC
451f436bc27SAndreas Werner	help
452dd1695a2SRandy Dunlap	  Say yes here to support the MEN 16Z127 GPIO Controller.
453f436bc27SAndreas Werner
4545238f7bcSJohn Crispinconfig GPIO_MM_LANTIQ
4555238f7bcSJohn Crispin	bool "Lantiq Memory mapped GPIOs"
4565238f7bcSJohn Crispin	depends on LANTIQ && SOC_XWAY
457a99cc668SArnd Bergmann	select OF_GPIO_MM_GPIOCHIP
4585238f7bcSJohn Crispin	help
4595238f7bcSJohn Crispin	  This enables support for memory mapped GPIOs on the External Bus Unit
460dd1695a2SRandy Dunlap	  (EBU) found on Lantiq SoCs. The GPIOs are output only as they are
461dd1695a2SRandy Dunlap	  created by attaching a 16-bit latch to the bus.
4625238f7bcSJohn Crispin
4636eae1aceSGrant Likelyconfig GPIO_MPC5200
4646eae1aceSGrant Likely	def_bool y
4656eae1aceSGrant Likely	depends on PPC_MPC52xx
466a99cc668SArnd Bergmann	select OF_GPIO_MM_GPIOCHIP
4676eae1aceSGrant Likely
468c68308ddSWolfram Sangconfig GPIO_MPC8XXX
4695df7fd46SLiu Gang	bool "MPC512x/MPC8xxx/QorIQ GPIO support"
470c68308ddSWolfram Sang	depends on PPC_MPC512x || PPC_MPC831x || PPC_MPC834x || PPC_MPC837x || \
4715df7fd46SLiu Gang		   FSL_SOC_BOOKE || PPC_86xx || ARCH_LAYERSCAPE || ARM || \
4725df7fd46SLiu Gang		   COMPILE_TEST
4735df7fd46SLiu Gang	select GPIO_GENERIC
474a8fa91a7SArnd Bergmann	select IRQ_DOMAIN
475c68308ddSWolfram Sang	help
476c68308ddSWolfram Sang	  Say Y here if you're going to use hardware that connects to the
4775df7fd46SLiu Gang	  MPC512x/831x/834x/837x/8572/8610/QorIQ GPIOs.
478c68308ddSWolfram Sang
4794ba9c3afSSergio Paracuellosconfig GPIO_MT7621
4804ba9c3afSSergio Paracuellos	bool "Mediatek MT7621 GPIO Support"
4814ba9c3afSSergio Paracuellos	depends on SOC_MT7620 || SOC_MT7621 || COMPILE_TEST
4827a9a5df0SArnd Bergmann	depends on OF_GPIO
4834ba9c3afSSergio Paracuellos	select GPIO_GENERIC
4844ba9c3afSSergio Paracuellos	select GPIOLIB_IRQCHIP
4854ba9c3afSSergio Paracuellos	help
486dd1695a2SRandy Dunlap	  Say yes here to support the Mediatek MT7621 SoC GPIO device.
4874ba9c3afSSergio Paracuellos
488fefe7b09SThomas Petazzoniconfig GPIO_MVEBU
489fefe7b09SThomas Petazzoni	def_bool y
4903b4c94bbSGregory CLEMENT	depends on PLAT_ORION || ARCH_MVEBU
491048c28c9SLinus Walleij	depends on OF_GPIO
492fefe7b09SThomas Petazzoni	select GENERIC_IRQ_CHIP
493f37e335fSGregory CLEMENT	select REGMAP_MMIO
494fefe7b09SThomas Petazzoni
495d37a65bbSShawn Guoconfig GPIO_MXC
49612d16b39SAnson Huang	tristate "i.MX GPIO support"
497d4e93614SAnson Huang	depends on ARCH_MXC || COMPILE_TEST
498c103de24SGrant Likely	select GPIO_GENERIC
499e4ea9333SShawn Guo	select GENERIC_IRQ_CHIP
500c103de24SGrant Likely
501c103de24SGrant Likelyconfig GPIO_MXS
50297c6e28dSGeert Uytterhoeven	bool "Freescale MXS GPIO support" if COMPILE_TEST
5036876ca31SAnson Huang	depends on ARCH_MXS || COMPILE_TEST
50497c6e28dSGeert Uytterhoeven	default y if ARCH_MXS
50506f88a8aSShawn Guo	select GPIO_GENERIC
506498c17cfSShawn Guo	select GENERIC_IRQ_CHIP
507d37a65bbSShawn Guo
508966942aeSThéo Lebrunconfig GPIO_NOMADIK
509966942aeSThéo Lebrun	bool "Nomadik GPIO driver"
5103c30cc26SThéo Lebrun	depends on ARCH_U8500 || ARCH_NOMADIK || MACH_EYEQ5 || COMPILE_TEST
511966942aeSThéo Lebrun	select GPIOLIB_IRQCHIP
512966942aeSThéo Lebrun	help
5133c30cc26SThéo Lebrun	  Say yes here to support the Nomadik SoC GPIO block. This block is also
5143c30cc26SThéo Lebrun	  used by the Mobileye EyeQ5 SoC.
515966942aeSThéo Lebrun
516966942aeSThéo Lebrun	  It handles up to 32 GPIOs per bank, that can all be interrupt sources.
517966942aeSThéo Lebrun	  It is deeply interconnected with the associated pinctrl driver as GPIO
518966942aeSThéo Lebrun	  registers handle muxing ("alternate functions") as well.
519966942aeSThéo Lebrun
520c4f8457dSJim Liuconfig GPIO_NPCM_SGPIO
521c4f8457dSJim Liu	bool "Nuvoton SGPIO support"
522c4f8457dSJim Liu	depends on ARCH_NPCM || COMPILE_TEST
523c4f8457dSJim Liu	select GPIOLIB_IRQCHIP
524c4f8457dSJim Liu	help
525c4f8457dSJim Liu	  Say Y here to support Nuvoton NPCM7XX/NPCM8XX SGPIO functionality.
526c4f8457dSJim Liu
527aca58a66SDavid Daneyconfig GPIO_OCTEON
528aca58a66SDavid Daney	tristate "Cavium OCTEON GPIO"
529e4c6a52cSGeert Uytterhoeven	depends on CAVIUM_OCTEON_SOC
530aca58a66SDavid Daney	default y
531aca58a66SDavid Daney	help
532aca58a66SDavid Daney	  Say yes here to support the on-chip GPIO lines on the OCTEON
533aca58a66SDavid Daney	  family of SOCs.
534aca58a66SDavid Daney
535cd0a3748SJavier Martinez Canillasconfig GPIO_OMAP
536cac089f9STony Lindgren	tristate "TI OMAP GPIO support" if ARCH_OMAP2PLUS || COMPILE_TEST
537cd0a3748SJavier Martinez Canillas	default y if ARCH_OMAP
5389d5d96efSArnd Bergmann	depends on ARM
5399d5d96efSArnd Bergmann	select GENERIC_IRQ_CHIP
540fb655f57SJavier Martinez Canillas	select GPIOLIB_IRQCHIP
541cd0a3748SJavier Martinez Canillas	help
542cd0a3748SJavier Martinez Canillas	  Say yes here to enable GPIO support for TI OMAP SoCs.
543cd0a3748SJavier Martinez Canillas
5441e9c2859SBaruch Siachconfig GPIO_PL061
54561684440SRob Herring	tristate "PrimeCell PL061 GPIO support"
5468a242842SRob Herring	depends on ARM_AMBA
547a5d6d271SAxel Lin	select IRQ_DOMAIN
5488d5b24bdSLinus Walleij	select GPIOLIB_IRQCHIP
5491e9c2859SBaruch Siach	help
550dd1695a2SRandy Dunlap	  Say yes here to support the PrimeCell PL061 GPIO device.
5511e9c2859SBaruch Siach
552157d2644SHaojian Zhuangconfig GPIO_PXA
553157d2644SHaojian Zhuang	bool "PXA GPIO support"
55422e4ebd0STiezhu Yang	depends on ARCH_PXA || ARCH_MMP || COMPILE_TEST
555157d2644SHaojian Zhuang	help
556dd1695a2SRandy Dunlap	  Say yes here to support the PXA GPIO device.
557157d2644SHaojian Zhuang
558119f5e44SMagnus Dammconfig GPIO_RCAR
559032653efSLad Prabhakar	tristate "Renesas R-Car and RZ/G GPIO support"
5602af66e1dSSimon Horman	depends on ARCH_RENESAS || COMPILE_TEST
561c7f3c5d3SGeert Uytterhoeven	select GPIOLIB_IRQCHIP
562119f5e44SMagnus Damm	help
563032653efSLad Prabhakar	  Say yes here to support GPIO on Renesas R-Car or RZ/G SoCs.
564119f5e44SMagnus Damm
565d57eb825SManivannan Sadhasivamconfig GPIO_RDA
566d57eb825SManivannan Sadhasivam	bool "RDA Micro GPIO controller support"
567d57eb825SManivannan Sadhasivam	depends on ARCH_RDA || COMPILE_TEST
568d57eb825SManivannan Sadhasivam	depends on OF_GPIO
569d57eb825SManivannan Sadhasivam	select GPIO_GENERIC
570d57eb825SManivannan Sadhasivam	select GPIOLIB_IRQCHIP
571d57eb825SManivannan Sadhasivam	help
572d57eb825SManivannan Sadhasivam	  Say Y here to support RDA Micro GPIO controller.
573d57eb825SManivannan Sadhasivam
5740d82fb11SSander Vanheuleconfig GPIO_REALTEK_OTTO
5750d82fb11SSander Vanheule	tristate "Realtek Otto GPIO support"
5760d82fb11SSander Vanheule	depends on MACH_REALTEK_RTL
5770d82fb11SSander Vanheule	default MACH_REALTEK_RTL
5780d82fb11SSander Vanheule	select GPIO_GENERIC
5790d82fb11SSander Vanheule	select GPIOLIB_IRQCHIP
5800d82fb11SSander Vanheule	help
5810d82fb11SSander Vanheule	  The GPIO controller on the Otto MIPS platform supports up to two
5820d82fb11SSander Vanheule	  banks of 32 GPIOs, with edge triggered interrupts. The 32 GPIOs
5830d82fb11SSander Vanheule	  are grouped in four 8-bit wide ports.
5840d82fb11SSander Vanheule
5850d82fb11SSander Vanheule	  When built as a module, the module will be called realtek_otto_gpio.
5860d82fb11SSander Vanheule
587380639c7SRussell Kingconfig GPIO_REG
588380639c7SRussell King	bool
589380639c7SRussell King	help
590380639c7SRussell King	  A 32-bit single register GPIO fixed in/out implementation.  This
591380639c7SRussell King	  can be used to represent any register as a set of GPIO signals.
592380639c7SRussell King
593936ee267SJianqun Xuconfig GPIO_ROCKCHIP
594936ee267SJianqun Xu	tristate "Rockchip GPIO support"
595936ee267SJianqun Xu	depends on ARCH_ROCKCHIP || COMPILE_TEST
596d6912b12SRandy Dunlap	select GENERIC_IRQ_CHIP
597936ee267SJianqun Xu	select GPIOLIB_IRQCHIP
598936ee267SJianqun Xu	default ARCH_ROCKCHIP
599936ee267SJianqun Xu	help
600936ee267SJianqun Xu	  Say yes here to support GPIO on Rockchip SoCs.
601936ee267SJianqun Xu
602eee636bfSTzuyi Changconfig GPIO_RTD
603eee636bfSTzuyi Chang	tristate "Realtek DHC GPIO support"
604eee636bfSTzuyi Chang	depends on ARCH_REALTEK
605eee636bfSTzuyi Chang	default y
606eee636bfSTzuyi Chang	select GPIOLIB_IRQCHIP
607eee636bfSTzuyi Chang	help
608eee636bfSTzuyi Chang	  This option enables support for GPIOs found on Realtek DHC(Digital
609eee636bfSTzuyi Chang	  Home Center) SoCs family, including RTD1295, RTD1315E, RTD1319,
610eee636bfSTzuyi Chang	  RTD1319D, RTD1395, RTD1619 and RTD1619B.
611eee636bfSTzuyi Chang
612eee636bfSTzuyi Chang	  Say yes here to support GPIO functionality and GPIO interrupt on
613eee636bfSTzuyi Chang	  Realtek DHC SoCs.
614eee636bfSTzuyi Chang
615fb0b35d3SAndrei.Stefanescu@microchip.comconfig GPIO_SAMA5D2_PIOBU
616fb0b35d3SAndrei.Stefanescu@microchip.com	tristate "SAMA5D2 PIOBU GPIO support"
617fb0b35d3SAndrei.Stefanescu@microchip.com	depends on MFD_SYSCON
618a7c23f8dSLinus Walleij	depends on OF_GPIO
619b06d7b45SGeert Uytterhoeven	depends on ARCH_AT91 || COMPILE_TEST
620fb0b35d3SAndrei.Stefanescu@microchip.com	select GPIO_SYSCON
621fb0b35d3SAndrei.Stefanescu@microchip.com	help
622fb0b35d3SAndrei.Stefanescu@microchip.com	  Say yes here to use the PIOBU pins as GPIOs.
623fb0b35d3SAndrei.Stefanescu@microchip.com
624fb0b35d3SAndrei.Stefanescu@microchip.com	  PIOBU pins on the SAMA5D2 can be used as GPIOs.
625fb0b35d3SAndrei.Stefanescu@microchip.com	  The difference from regular GPIOs is that they
626fb0b35d3SAndrei.Stefanescu@microchip.com	  maintain their value during backup/self-refresh.
627fb0b35d3SAndrei.Stefanescu@microchip.com
62896868dceSYash Shahconfig GPIO_SIFIVE
6296b4c76deSSamuel Holland	tristate "SiFive GPIO support"
63018eedf2bSRandy Dunlap	depends on OF_GPIO
63118eedf2bSRandy Dunlap	select IRQ_DOMAIN_HIERARCHY
63296868dceSYash Shah	select GPIO_GENERIC
63396868dceSYash Shah	select GPIOLIB_IRQCHIP
63496868dceSYash Shah	select REGMAP_MMIO
63596868dceSYash Shah	help
63696868dceSYash Shah	  Say yes here to support the GPIO device on SiFive SoCs.
63796868dceSYash Shah
638be8c8facSUwe Kleine-Königconfig GPIO_SIOX
639be8c8facSUwe Kleine-König	tristate "SIOX GPIO support"
640be8c8facSUwe Kleine-König	depends on SIOX
641be8c8facSUwe Kleine-König	select GPIOLIB_IRQCHIP
642be8c8facSUwe Kleine-König	help
643be8c8facSUwe Kleine-König	  Say yes here to support SIOX I/O devices. These are units connected
644be8c8facSUwe Kleine-König	  via a SIOX bus and have a number of fixed-direction I/O lines.
645be8c8facSUwe Kleine-König
6462505c7b0SEugeniy Paltsevconfig GPIO_SNPS_CREG
6472505c7b0SEugeniy Paltsev	bool "Synopsys GPIO via CREG (Control REGisters) driver"
6482505c7b0SEugeniy Paltsev	depends on ARC || COMPILE_TEST
649a7c0b4b8SRandy Dunlap	depends on OF_GPIO
6502505c7b0SEugeniy Paltsev	help
6512505c7b0SEugeniy Paltsev	  This driver supports GPIOs via CREG on various Synopsys SoCs.
6522505c7b0SEugeniy Paltsev	  This is a single-register MMIO GPIO driver for complex cases
6532505c7b0SEugeniy Paltsev	  where only several fields in register belong to GPIO lines and
6542505c7b0SEugeniy Paltsev	  each GPIO line owns a field with different length and on/off value.
6552505c7b0SEugeniy Paltsev
656b53bc281SShiraz Hashimconfig GPIO_SPEAR_SPICS
657b53bc281SShiraz Hashim	bool "ST SPEAr13xx SPI Chip Select as GPIO support"
658b53bc281SShiraz Hashim	depends on PLAT_SPEAR
659b53bc281SShiraz Hashim	select GENERIC_IRQ_CHIP
660b53bc281SShiraz Hashim	help
661dd1695a2SRandy Dunlap	  Say yes here to support ST SPEAr SPI Chip Select as GPIO device.
662b53bc281SShiraz Hashim
6639a3821c2SBaolin Wangconfig GPIO_SPRD
6649a3821c2SBaolin Wang	tristate "Spreadtrum GPIO support"
6659a3821c2SBaolin Wang	depends on ARCH_SPRD || COMPILE_TEST
6669a3821c2SBaolin Wang	depends on OF_GPIO
6679a3821c2SBaolin Wang	select GPIOLIB_IRQCHIP
6689a3821c2SBaolin Wang	help
6699a3821c2SBaolin Wang	  Say yes here to support Spreadtrum GPIO device.
6709a3821c2SBaolin Wang
671be9cab5bSLinus Walleijconfig GPIO_STP_XWAY
672be9cab5bSLinus Walleij	bool "XWAY STP GPIOs"
6735099837dSMartin Blumenstingl	depends on SOC_XWAY || COMPILE_TEST
6745099837dSMartin Blumenstingl	depends on OF_GPIO
675be9cab5bSLinus Walleij	help
676be9cab5bSLinus Walleij	  This enables support for the Serial To Parallel (STP) unit found on
677be9cab5bSLinus Walleij	  XWAY SoC. The STP allows the SoC to drive a shift registers cascade,
678dd1695a2SRandy Dunlap	  that can be up to 24 bits. This peripheral is aimed at driving LEDs.
679dd1695a2SRandy Dunlap	  Some of the GPIOs/LEDs can be auto updated by the SoC with DSL and
680be9cab5bSLinus Walleij	  phy status.
681be9cab5bSLinus Walleij
6826a8a0c1dSAlexander Shiyanconfig GPIO_SYSCON
6836a8a0c1dSAlexander Shiyan	tristate "GPIO based on SYSCON"
6846a8a0c1dSAlexander Shiyan	depends on MFD_SYSCON && OF
6856a8a0c1dSAlexander Shiyan	help
6866a8a0c1dSAlexander Shiyan	  Say yes here to support GPIO functionality though SYSCON driver.
6876a8a0c1dSAlexander Shiyan
688d2c19e89SPandith Nconfig GPIO_TANGIER
689d2c19e89SPandith N	tristate
690d2c19e89SPandith N	select GPIOLIB_IRQCHIP
691d2c19e89SPandith N	help
692d2c19e89SPandith N	  GPIO support for Intel Tangier and compatible platforms.
69334840be5SPandith N	  Currently supported:
6949409d8cfSPandith N	   - Elkhart Lake
69534840be5SPandith N	   - Merrifield
696d2c19e89SPandith N
697d2c19e89SPandith N	  If built as a module its name will be gpio-tangier.
698d2c19e89SPandith N
699223fa272SLinus Walleijconfig GPIO_TB10X
700223fa272SLinus Walleij	bool
7010d1e31abSLinus Walleij	select GPIO_GENERIC
702223fa272SLinus Walleij	select GENERIC_IRQ_CHIP
703223fa272SLinus Walleij	select OF_GPIO
704223fa272SLinus Walleij
7054dd4dd1dSAlexander Steinconfig GPIO_TEGRA
7064a6eac2bSDmitry Osipenko	tristate "NVIDIA Tegra GPIO support"
7070bfb85c6SArnd Bergmann	default ARCH_TEGRA
7084dd4dd1dSAlexander Stein	depends on ARCH_TEGRA || COMPILE_TEST
709048c28c9SLinus Walleij	depends on OF_GPIO
710298d75c9SThierry Reding	select GPIOLIB_IRQCHIP
711298d75c9SThierry Reding	select IRQ_DOMAIN_HIERARCHY
7120bfb85c6SArnd Bergmann	help
7130bfb85c6SArnd Bergmann	  Say yes here to support GPIO pins on NVIDIA Tegra SoCs.
7144dd4dd1dSAlexander Stein
7155b2b135aSThierry Redingconfig GPIO_TEGRA186
7165b2b135aSThierry Reding	tristate "NVIDIA Tegra186 GPIO support"
717286e7beaSThierry Reding	default ARCH_TEGRA_186_SOC || ARCH_TEGRA_194_SOC
718286e7beaSThierry Reding	depends on ARCH_TEGRA_186_SOC || ARCH_TEGRA_194_SOC || COMPILE_TEST
7195b2b135aSThierry Reding	depends on OF_GPIO
7205b2b135aSThierry Reding	select GPIOLIB_IRQCHIP
7212a365505SThierry Reding	select IRQ_DOMAIN_HIERARCHY
7225b2b135aSThierry Reding	help
7235b2b135aSThierry Reding	  Say yes here to support GPIO pins on NVIDIA Tegra186 SoCs.
7245b2b135aSThierry Reding
7255041e791SJulien Grossholtzconfig GPIO_TS4800
7265041e791SJulien Grossholtz	tristate "TS-4800 DIO blocks and compatibles"
7275041e791SJulien Grossholtz	depends on OF_GPIO
7286dcfd729SJulien Grossholtz	depends on SOC_IMX51 || COMPILE_TEST
7295041e791SJulien Grossholtz	select GPIO_GENERIC
7305041e791SJulien Grossholtz	help
7315041e791SJulien Grossholtz	  This driver support TS-4800 FPGA GPIO controllers.
7325041e791SJulien Grossholtz
7335a2a3002SDavid Daneyconfig GPIO_THUNDERX
7345a2a3002SDavid Daney	tristate "Cavium ThunderX/OCTEON-TX GPIO"
7355a2a3002SDavid Daney	depends on ARCH_THUNDER || (64BIT && COMPILE_TEST)
736311de3ceSMasahiro Yamada	depends on PCI_MSI
737a7fc89f9SLinus Walleij	select GPIOLIB_IRQCHIP
738311de3ceSMasahiro Yamada	select IRQ_DOMAIN_HIERARCHY
7395a2a3002SDavid Daney	select IRQ_FASTEOI_HIERARCHY_HANDLERS
7405a2a3002SDavid Daney	help
7415a2a3002SDavid Daney	  Say yes here to support the on-chip GPIO lines on the ThunderX
7425a2a3002SDavid Daney	  and OCTEON-TX families of SoCs.
7435a2a3002SDavid Daney
744dbe776c2SMasahiro Yamadaconfig GPIO_UNIPHIER
745dbe776c2SMasahiro Yamada	tristate "UniPhier GPIO support"
746dbe776c2SMasahiro Yamada	depends on ARCH_UNIPHIER || COMPILE_TEST
747dbe776c2SMasahiro Yamada	depends on OF_GPIO
748dbe776c2SMasahiro Yamada	select IRQ_DOMAIN_HIERARCHY
749dbe776c2SMasahiro Yamada	help
750dbe776c2SMasahiro Yamada	  Say yes here to support UniPhier GPIOs.
751dbe776c2SMasahiro Yamada
7527f2691a1SStefan Agnerconfig GPIO_VF610
753f5759578SMartin Kaiser	bool "VF610 GPIO support"
754f5759578SMartin Kaiser	default y if SOC_VF610
7553eac8bbeSMartin Kaiser	depends on ARCH_MXC || COMPILE_TEST
7567f2691a1SStefan Agner	select GPIOLIB_IRQCHIP
7577f2691a1SStefan Agner	help
75830a35c07SPeng Fan	  Say yes here to support i.MX or Vybrid vf610 GPIOs.
7597f2691a1SStefan Agner
7602ad74f40SNobuhiro Iwamatsuconfig GPIO_VISCONTI
7612ad74f40SNobuhiro Iwamatsu	tristate "Toshiba Visconti GPIO support"
7622ad74f40SNobuhiro Iwamatsu	depends on ARCH_VISCONTI || COMPILE_TEST
7632ad74f40SNobuhiro Iwamatsu	depends on OF_GPIO
7642ad74f40SNobuhiro Iwamatsu	select GPIOLIB_IRQCHIP
7652ad74f40SNobuhiro Iwamatsu	select GPIO_GENERIC
7662ad74f40SNobuhiro Iwamatsu	select IRQ_DOMAIN_HIERARCHY
7672ad74f40SNobuhiro Iwamatsu	help
7682ad74f40SNobuhiro Iwamatsu	  Say yes here to support GPIO on Tohisba Visconti.
7692ad74f40SNobuhiro Iwamatsu
77059c32468SSrinivas Kandagatlaconfig GPIO_WCD934X
771dd1695a2SRandy Dunlap	tristate "Qualcomm Technologies Inc WCD9340/WCD9341 GPIO controller driver"
77259c32468SSrinivas Kandagatla	depends on MFD_WCD934X && OF_GPIO
77359c32468SSrinivas Kandagatla	help
7740bb8e80bSColin Ian King         This driver is to support GPIO block found on the Qualcomm Technologies
77559c32468SSrinivas Kandagatla	 Inc WCD9340/WCD9341 Audio Codec.
77659c32468SSrinivas Kandagatla
77729cbf458SFeng Kanconfig GPIO_XGENE
77829cbf458SFeng Kan	bool "APM X-Gene GPIO controller support"
77929cbf458SFeng Kan	depends on ARM64 && OF_GPIO
78029cbf458SFeng Kan	help
78129cbf458SFeng Kan	  This driver is to support the GPIO block within the APM X-Gene SoC
78229cbf458SFeng Kan	  platform's generic flash controller. The GPIO pins are muxed with
78329cbf458SFeng Kan	  the generic flash controller's address and data pins. Say yes
78429cbf458SFeng Kan	  here to enable the GFC GPIO functionality.
78529cbf458SFeng Kan
786b2b35e10SY Voconfig GPIO_XGENE_SB
787b2b35e10SY Vo	tristate "APM X-Gene GPIO standby controller support"
788b24bc583SAndy Shevchenko	depends on (ARCH_XGENE || COMPILE_TEST)
789b2b35e10SY Vo	select GPIO_GENERIC
790e5f7e312SMatthias Brugger	select GPIOLIB_IRQCHIP
791c23d200fSMasahiro Yamada	select IRQ_DOMAIN_HIERARCHY
792b2b35e10SY Vo	help
793b2b35e10SY Vo	  This driver supports the GPIO block within the APM X-Gene
794b2b35e10SY Vo	  Standby Domain. Say yes here to enable the GPIO functionality.
795b2b35e10SY Vo
7960bcb6069SJohn Linnconfig GPIO_XILINX
797c54c58baSRicardo Ribalda Delgado	tristate "Xilinx GPIO support"
798a32c7caeSSrinivas Neeli	select GPIOLIB_IRQCHIP
799a32c7caeSSrinivas Neeli	depends on OF_GPIO
8000bcb6069SJohn Linn	help
801dd1695a2SRandy Dunlap	  Say yes here to support the Xilinx FPGA GPIO device.
8020bcb6069SJohn Linn
803ff718800SKamlakant Patelconfig GPIO_XLP
804ea708ac5SRob Herring	tristate "Cavium ThunderX2 GPIO support"
805ea708ac5SRob Herring	depends on ARCH_THUNDER2 || COMPILE_TEST
806ff718800SKamlakant Patel	select GPIOLIB_IRQCHIP
807ff718800SKamlakant Patel	help
808ea708ac5SRob Herring	  This driver provides support for GPIO interface on Cavium's ThunderX2
809ea708ac5SRob Herring	  CN99XX SoCs (Originally from Netlogic XLP).
810ff718800SKamlakant Patel
811ff718800SKamlakant Patel	  If unsure, say N.
812ff718800SKamlakant Patel
8133b31d0ecSBaruch Siachconfig GPIO_XTENSA
8143b31d0ecSBaruch Siach	bool "Xtensa GPIO32 support"
8153b31d0ecSBaruch Siach	depends on XTENSA
816a1a2bdecSBaruch Siach	depends on HAVE_XTENSA_GPIO32
8173b31d0ecSBaruch Siach	depends on !SMP
8183b31d0ecSBaruch Siach	help
8193b31d0ecSBaruch Siach	  Say yes here to support the Xtensa internal GPIO32 IMPWIRE (input)
820dd1695a2SRandy Dunlap	  and EXPSTATE (output) ports.
8213b31d0ecSBaruch Siach
822223fa272SLinus Walleijconfig GPIO_ZEVIO
823223fa272SLinus Walleij	bool "LSI ZEVIO SoC memory mapped GPIOs"
8249c8224d0SAndy Shevchenko	depends on ARM
82527fdd325SYoichi Yuasa	help
826223fa272SLinus Walleij	  Say yes here to support the GPIO controller in LSI ZEVIO SoCs.
82727fdd325SYoichi Yuasa
828223fa272SLinus Walleijconfig GPIO_ZYNQ
829223fa272SLinus Walleij	tristate "Xilinx Zynq GPIO support"
830bdf7a4aeSAnurag Kumar Vulisha	depends on ARCH_ZYNQ || ARCH_ZYNQMP
8317f87210eSMika Westerberg	select GPIOLIB_IRQCHIP
8321d09aaa6SMathias Nyman	help
833223fa272SLinus Walleij	  Say yes here to support Xilinx Zynq GPIO controller.
8341d09aaa6SMathias Nyman
8357687a5b0SPiyush Mehtaconfig GPIO_ZYNQMP_MODEPIN
836dd1695a2SRandy Dunlap	tristate "ZynqMP ps-mode pin GPIO configuration driver"
8377687a5b0SPiyush Mehta	depends on ZYNQMP_FIRMWARE
8387687a5b0SPiyush Mehta	default ZYNQMP_FIRMWARE
8397687a5b0SPiyush Mehta	help
840dd1695a2SRandy Dunlap	  Say yes here to support the ZynqMP ps-mode pin GPIO configuration
8417687a5b0SPiyush Mehta	  driver.
8427687a5b0SPiyush Mehta
843dd1695a2SRandy Dunlap	  This ps-mode pin GPIO driver is based on GPIO framework. PS_MODE
8447687a5b0SPiyush Mehta	  is 4-bits boot mode pins. It sets and gets the status of
8457687a5b0SPiyush Mehta	  the ps-mode pin. Every pin can be configured as input/output.
8467687a5b0SPiyush Mehta
847bd37c999SKelvin Cheungconfig GPIO_LOONGSON1
848bd37c999SKelvin Cheung	tristate "Loongson1 GPIO support"
849bd37c999SKelvin Cheung	depends on MACH_LOONGSON32
850bd37c999SKelvin Cheung	select GPIO_GENERIC
851bd37c999SKelvin Cheung	help
852bd37c999SKelvin Cheung	  Say Y or M here to support GPIO on Loongson1 SoCs.
853bd37c999SKelvin Cheung
854e09d168fSEnrico Weigelt, metux IT consultconfig GPIO_AMD_FCH
855e09d168fSEnrico Weigelt, metux IT consult	tristate "GPIO support for AMD Fusion Controller Hub (G-series SOCs)"
856e09d168fSEnrico Weigelt, metux IT consult	help
857dd1695a2SRandy Dunlap	  This option enables driver for GPIO on AMD's Fusion Controller Hub,
858dd1695a2SRandy Dunlap	  as found on G-series SOCs (e.g. GX-412TC).
859e09d168fSEnrico Weigelt, metux IT consult
860dd1695a2SRandy Dunlap	  Note: This driver doesn't register itself automatically, as it
861dd1695a2SRandy Dunlap	  needs to be provided with platform-specific configuration.
862dd1695a2SRandy Dunlap	  (See e.g. CONFIG_PCENGINES_APU2.)
86393224edfSDaniel Palmer
86493224edfSDaniel Palmerconfig GPIO_MSC313
86593224edfSDaniel Palmer	bool "MStar MSC313 GPIO support"
86693224edfSDaniel Palmer	depends on ARCH_MSTARV7
86793224edfSDaniel Palmer	default ARCH_MSTARV7
86893224edfSDaniel Palmer	select GPIOLIB_IRQCHIP
86993224edfSDaniel Palmer	select IRQ_DOMAIN_HIERARCHY
87093224edfSDaniel Palmer	help
87193224edfSDaniel Palmer	  Say Y here to support the main GPIO block on MStar/SigmaStar
872dd1695a2SRandy Dunlap	  ARMv7-based SoCs.
87393224edfSDaniel Palmer
8744195926aSThomas Bogendoerferconfig GPIO_IDT3243X
8754195926aSThomas Bogendoerfer	tristate "IDT 79RC3243X GPIO support"
8764195926aSThomas Bogendoerfer	depends on MIKROTIK_RB532 || COMPILE_TEST
8774195926aSThomas Bogendoerfer	select GPIO_GENERIC
8784195926aSThomas Bogendoerfer	select GPIOLIB_IRQCHIP
8794195926aSThomas Bogendoerfer	help
8804195926aSThomas Bogendoerfer	  Select this option to enable GPIO driver for
881dd1695a2SRandy Dunlap	  IDT 79RC3243X-based devices like Mikrotik RB532.
8824195926aSThomas Bogendoerfer
8834195926aSThomas Bogendoerfer	  To compile this driver as a module, choose M here: the module will
8844195926aSThomas Bogendoerfer	  be called gpio-idt3243x.
8854195926aSThomas Bogendoerfer
886177b0381SLinus Walleijendmenu
887177b0381SLinus Walleij
888bc6a73bbSLinus Walleijmenu "Port-mapped I/O GPIO drivers"
8892c99754eSNiklas Schnelle	depends on X86 && HAS_IOPORT # I/O space access
8902c99754eSNiklas Schnelle
8912c99754eSNiklas Schnelleconfig GPIO_VX855
8922c99754eSNiklas Schnelle	tristate "VIA VX855/VX875 GPIO"
8932c99754eSNiklas Schnelle	depends on PCI
8942c99754eSNiklas Schnelle	select MFD_CORE
8952c99754eSNiklas Schnelle	select MFD_VX855
8962c99754eSNiklas Schnelle	help
8972c99754eSNiklas Schnelle	  Support access to the VX855/VX875 GPIO lines through the GPIO library.
8982c99754eSNiklas Schnelle
8992c99754eSNiklas Schnelle	  This driver provides common support for accessing the device.
9002c99754eSNiklas Schnelle	  Additional drivers must be enabled in order to use the
9012c99754eSNiklas Schnelle	  functionality of the device.
902bc6a73bbSLinus Walleij
903fb38af4aSWilliam Breathitt Grayconfig GPIO_I8255
904fb38af4aSWilliam Breathitt Gray	tristate
9050b7c490dSWilliam Breathitt Gray	select GPIO_REGMAP
906fb38af4aSWilliam Breathitt Gray	help
907fb38af4aSWilliam Breathitt Gray	  Enables support for the i8255 interface library functions. The i8255
908fb38af4aSWilliam Breathitt Gray	  interface library provides functions to facilitate communication with
909fb38af4aSWilliam Breathitt Gray	  interfaces compatible with the venerable Intel 8255 Programmable
910fb38af4aSWilliam Breathitt Gray	  Peripheral Interface (PPI). The Intel 8255 PPI chip was first released
911fb38af4aSWilliam Breathitt Gray	  in the early 1970s but compatible interfaces are nowadays typically
912fb38af4aSWilliam Breathitt Gray	  found embedded in larger VLSI processing chips and FPGA components.
913fb38af4aSWilliam Breathitt Gray
914fb38af4aSWilliam Breathitt Gray	  If built as a module its name will be gpio-i8255.
915fb38af4aSWilliam Breathitt Gray
9161b06d64fSWilliam Breathitt Grayconfig GPIO_104_DIO_48E
9171b06d64fSWilliam Breathitt Gray	tristate "ACCES 104-DIO-48E GPIO support"
91835decc80SWilliam Breathitt Gray	depends on PC104
91935decc80SWilliam Breathitt Gray	select ISA_BUS_API
9202f7e845fSWilliam Breathitt Gray	select REGMAP_MMIO
9212f7e845fSWilliam Breathitt Gray	select REGMAP_IRQ
9221b06d64fSWilliam Breathitt Gray	select GPIOLIB_IRQCHIP
92371b7b397SWilliam Breathitt Gray	select GPIO_I8255
92492f7a358SWilliam Breathitt Gray	select I8254
9251b06d64fSWilliam Breathitt Gray	help
9264c23db0fSWilliam Breathitt Gray	  Enables GPIO support for the ACCES 104-DIO-48E series (104-DIO-48E,
9274c23db0fSWilliam Breathitt Gray	  104-DIO-24E). The base port addresses for the devices may be
9284c23db0fSWilliam Breathitt Gray	  configured via the base module parameter. The interrupt line numbers
9294c23db0fSWilliam Breathitt Gray	  for the devices may be configured via the irq module parameter.
9301b06d64fSWilliam Breathitt Gray
931bc6a73bbSLinus Walleijconfig GPIO_104_IDIO_16
932bc6a73bbSLinus Walleij	tristate "ACCES 104-IDIO-16 GPIO support"
93335decc80SWilliam Breathitt Gray	depends on PC104
93435decc80SWilliam Breathitt Gray	select ISA_BUS_API
9352c210c9aSWilliam Breathitt Gray	select REGMAP_MMIO
936c4ec384cSWilliam Breathitt Gray	select GPIO_IDIO_16
937bc6a73bbSLinus Walleij	help
93886ea8a95SWilliam Breathitt Gray	  Enables GPIO support for the ACCES 104-IDIO-16 family (104-IDIO-16,
93986ea8a95SWilliam Breathitt Gray	  104-IDIO-16E, 104-IDO-16, 104-IDIO-8, 104-IDIO-8E, 104-IDO-8). The
94086ea8a95SWilliam Breathitt Gray	  base port addresses for the devices may be configured via the base
94186ea8a95SWilliam Breathitt Gray	  module parameter. The interrupt line numbers for the devices may be
94286ea8a95SWilliam Breathitt Gray	  configured via the irq module parameter.
943bc6a73bbSLinus Walleij
9446ddcf9b4SWilliam Breathitt Grayconfig GPIO_104_IDI_48
9456ddcf9b4SWilliam Breathitt Gray	tristate "ACCES 104-IDI-48 GPIO support"
94635decc80SWilliam Breathitt Gray	depends on PC104
94735decc80SWilliam Breathitt Gray	select ISA_BUS_API
948e28432a7SWilliam Breathitt Gray	select REGMAP_MMIO
949e28432a7SWilliam Breathitt Gray	select REGMAP_IRQ
9506ddcf9b4SWilliam Breathitt Gray	select GPIOLIB_IRQCHIP
95159e2131aSWilliam Breathitt Gray	select GPIO_REGMAP
9526ddcf9b4SWilliam Breathitt Gray	help
95372bf7443SWilliam Breathitt Gray	  Enables GPIO support for the ACCES 104-IDI-48 family (104-IDI-48A,
95472bf7443SWilliam Breathitt Gray	  104-IDI-48AC, 104-IDI-48B, 104-IDI-48BC). The base port addresses for
95572bf7443SWilliam Breathitt Gray	  the devices may be configured via the base module parameter. The
95672bf7443SWilliam Breathitt Gray	  interrupt line numbers for the devices may be configured via the irq
95772bf7443SWilliam Breathitt Gray	  module parameter.
9586ddcf9b4SWilliam Breathitt Gray
959bc6a73bbSLinus Walleijconfig GPIO_F7188X
960d0918a84SHenning Schild	tristate "Fintek and Nuvoton Super-I/O GPIO support"
961bc6a73bbSLinus Walleij	help
962bc6a73bbSLinus Walleij	  This option enables support for GPIOs found on Fintek Super-I/O
9631920906fSPeter Hung	  chips F71869, F71869A, F71882FG, F71889F and F81866.
9643002b864SHenning Schild	  As well as Nuvoton Super-I/O chip NCT6126D.
965bc6a73bbSLinus Walleij
966bc6a73bbSLinus Walleij	  To compile this driver as a module, choose M here: the module will
967bc6a73bbSLinus Walleij	  be called f7188x-gpio.
968bc6a73bbSLinus Walleij
9696ea5dcdfSWilliam Breathitt Grayconfig GPIO_GPIO_MM
9706ea5dcdfSWilliam Breathitt Gray	tristate "Diamond Systems GPIO-MM GPIO support"
97135decc80SWilliam Breathitt Gray	depends on PC104
97235decc80SWilliam Breathitt Gray	select ISA_BUS_API
9731c05004fSWilliam Breathitt Gray	select REGMAP_MMIO
974949506dcSWilliam Breathitt Gray	select GPIO_I8255
9756ea5dcdfSWilliam Breathitt Gray	help
9766ea5dcdfSWilliam Breathitt Gray	  Enables GPIO support for the Diamond Systems GPIO-MM and GPIO-MM-12.
9776ea5dcdfSWilliam Breathitt Gray
9786ea5dcdfSWilliam Breathitt Gray	  The Diamond Systems GPIO-MM device features 48 lines of digital I/O
9796ea5dcdfSWilliam Breathitt Gray	  via the emulation of dual 82C55A PPI chips. This driver provides GPIO
9806ea5dcdfSWilliam Breathitt Gray	  support for these 48 channels of digital I/O.
9816ea5dcdfSWilliam Breathitt Gray
9826ea5dcdfSWilliam Breathitt Gray	  The base port addresses for the devices may be configured via the base
9836ea5dcdfSWilliam Breathitt Gray	  array module parameter.
9846ea5dcdfSWilliam Breathitt Gray
985bc6a73bbSLinus Walleijconfig GPIO_IT87
986bc6a73bbSLinus Walleij	tristate "IT87xx GPIO support"
987bc6a73bbSLinus Walleij	help
988bc6a73bbSLinus Walleij	  Say yes here to support GPIO functionality of IT87xx Super I/O chips.
989bc6a73bbSLinus Walleij
990bc6a73bbSLinus Walleij	  This driver is tested with ITE IT8728 and IT8732 Super I/O chips, and
991a5ec96ddSLeonid Bloch	  supports the IT8761E, IT8613, IT8620E, and IT8628E Super I/O chips as
992a5ec96ddSLeonid Bloch	  well.
993bc6a73bbSLinus Walleij
994bc6a73bbSLinus Walleij	  To compile this driver as a module, choose M here: the module will
995dd1695a2SRandy Dunlap	  be called gpio_it87.
996bc6a73bbSLinus Walleij
997bc6a73bbSLinus Walleijconfig GPIO_SCH
998bc6a73bbSLinus Walleij	tristate "Intel SCH/TunnelCreek/Centerton/Quark X1000 GPIO"
999fdc1f5dfSAndy Shevchenko	depends on (X86 || COMPILE_TEST) && ACPI
100071cf76d4SRandy Dunlap	depends on LPC_SCH
10017a816384SJan Kiszka	select GPIOLIB_IRQCHIP
1002bc6a73bbSLinus Walleij	help
1003bc6a73bbSLinus Walleij	  Say yes here to support GPIO interface on Intel Poulsbo SCH,
1004bc6a73bbSLinus Walleij	  Intel Tunnel Creek processor, Intel Centerton processor or
1005bc6a73bbSLinus Walleij	  Intel Quark X1000 SoC.
1006bc6a73bbSLinus Walleij
1007bc6a73bbSLinus Walleij	  The Intel SCH contains a total of 14 GPIO pins. Ten GPIOs are
1008bc6a73bbSLinus Walleij	  powered by the core power rail and are turned off during sleep
1009bc6a73bbSLinus Walleij	  modes (S3 and higher). The remaining four GPIOs are powered by
1010bc6a73bbSLinus Walleij	  the Intel SCH suspend power supply. These GPIOs remain
1011dd1695a2SRandy Dunlap	  active during S3. The suspend-powered GPIOs can be used to wake the
1012bc6a73bbSLinus Walleij	  system from the Suspend-to-RAM state.
1013bc6a73bbSLinus Walleij
1014bc6a73bbSLinus Walleij	  The Intel Tunnel Creek processor has 5 GPIOs powered by the
1015bc6a73bbSLinus Walleij	  core power rail and 9 from suspend power supply.
1016bc6a73bbSLinus Walleij
1017bc6a73bbSLinus Walleij	  The Intel Centerton processor has a total of 30 GPIO pins.
1018bc6a73bbSLinus Walleij	  Twenty-one are powered by the core power rail and 9 from the
1019bc6a73bbSLinus Walleij	  suspend power supply.
1020bc6a73bbSLinus Walleij
1021bc6a73bbSLinus Walleij	  The Intel Quark X1000 SoC has 2 GPIOs powered by the core
1022bc6a73bbSLinus Walleij	  power well and 6 from the suspend power well.
1023bc6a73bbSLinus Walleij
1024bc6a73bbSLinus Walleijconfig GPIO_SCH311X
1025bc6a73bbSLinus Walleij	tristate "SMSC SCH311x SuperI/O GPIO"
1026bc6a73bbSLinus Walleij	help
1027bc6a73bbSLinus Walleij	  Driver to enable the GPIOs found on SMSC SMSC SCH3112, SCH3114 and
1028bc6a73bbSLinus Walleij	  SCH3116 "Super I/O" chipsets.
1029bc6a73bbSLinus Walleij
1030bc6a73bbSLinus Walleij	  To compile this driver as a module, choose M here: the module will
1031bc6a73bbSLinus Walleij	  be called gpio-sch311x.
1032bc6a73bbSLinus Walleij
1033bc6a73bbSLinus Walleijconfig GPIO_TS5500
1034bc6a73bbSLinus Walleij	tristate "TS-5500 DIO blocks and compatibles"
1035bc6a73bbSLinus Walleij	depends on TS5500 || COMPILE_TEST
1036bc6a73bbSLinus Walleij	help
1037bc6a73bbSLinus Walleij	  This driver supports Digital I/O exposed by pin blocks found on some
1038bc6a73bbSLinus Walleij	  Technologic Systems platforms. It includes, but is not limited to, 3
1039bc6a73bbSLinus Walleij	  blocks of the TS-5500: DIO1, DIO2 and the LCD port, and the TS-5600
1040bc6a73bbSLinus Walleij	  LCD port.
1041bc6a73bbSLinus Walleij
1042a0d65009SMaciej S. Szmigieroconfig GPIO_WINBOND
1043a0d65009SMaciej S. Szmigiero	tristate "Winbond Super I/O GPIO support"
1044b995ff3bSMaciej S. Szmigiero	select ISA_BUS_API
1045a0d65009SMaciej S. Szmigiero	help
1046a0d65009SMaciej S. Szmigiero	  This option enables support for GPIOs found on Winbond Super I/O
1047a0d65009SMaciej S. Szmigiero	  chips.
1048a0d65009SMaciej S. Szmigiero	  Currently, only W83627UHG (also known as Nuvoton NCT6627UD) is
1049a0d65009SMaciej S. Szmigiero	  supported.
1050a0d65009SMaciej S. Szmigiero
1051a0d65009SMaciej S. Szmigiero	  You will need to provide a module parameter "gpios", or a
1052a0d65009SMaciej S. Szmigiero	  boot-time parameter "gpio_winbond.gpios" with a bitmask of GPIO
1053a0d65009SMaciej S. Szmigiero	  ports to enable (bit 0 is GPIO1, bit 1 is GPIO2, etc.).
1054a0d65009SMaciej S. Szmigiero
1055a0d65009SMaciej S. Szmigiero	  To compile this driver as a module, choose M here: the module will
1056a0d65009SMaciej S. Szmigiero	  be called gpio-winbond.
1057a0d65009SMaciej S. Szmigiero
10589c26df9bSWilliam Breathitt Grayconfig GPIO_WS16C48
10599c26df9bSWilliam Breathitt Gray	tristate "WinSystems WS16C48 GPIO support"
106035decc80SWilliam Breathitt Gray	select ISA_BUS_API
10610988ffa0SWilliam Breathitt Gray	select REGMAP_IRQ
10620988ffa0SWilliam Breathitt Gray	select REGMAP_MMIO
10639c26df9bSWilliam Breathitt Gray	select GPIOLIB_IRQCHIP
10640988ffa0SWilliam Breathitt Gray	select GPIO_REGMAP
10659c26df9bSWilliam Breathitt Gray	help
1066cc736607SWilliam Breathitt Gray	  Enables GPIO support for the WinSystems WS16C48. The base port
1067cc736607SWilliam Breathitt Gray	  addresses for the devices may be configured via the base module
1068cc736607SWilliam Breathitt Gray	  parameter. The interrupt line numbers for the devices may be
1069cc736607SWilliam Breathitt Gray	  configured via the irq module parameter.
10709c26df9bSWilliam Breathitt Gray
1071bc6a73bbSLinus Walleijendmenu
1072bc6a73bbSLinus Walleij
1073177b0381SLinus Walleijmenu "I2C GPIO expanders"
1074177b0381SLinus Walleij	depends on I2C
1075a9c5fff5SDavid Brownell
1076bf5a16baSLinus Walleijconfig GPIO_ADNP
1077bf5a16baSLinus Walleij	tristate "Avionic Design N-bit GPIO expander"
1078269a46f8SLinus Walleij	depends on OF_GPIO
1079104fb1d5SZhu, Lejun	select GPIOLIB_IRQCHIP
1080104fb1d5SZhu, Lejun	help
1081bf5a16baSLinus Walleij	  This option enables support for N GPIOs found on Avionic Design
1082bf5a16baSLinus Walleij	  I2C GPIO expanders. The register space will be extended by powers
1083bf5a16baSLinus Walleij	  of two, so the controller will need to accommodate for that. For
1084bf5a16baSLinus Walleij	  example: if a controller provides 48 pins, 6 registers will be
1085bf5a16baSLinus Walleij	  enough to represent all pins, but the driver will assume a
1086bf5a16baSLinus Walleij	  register layout for 64 pins (8 registers).
10870cc59b9dSMilo Kim
108803810031SEmanuele Ghidoliconfig GPIO_FXL6408
108903810031SEmanuele Ghidoli	tristate "FXL6408 I2C GPIO expander"
109003810031SEmanuele Ghidoli	select GPIO_REGMAP
109103810031SEmanuele Ghidoli	select REGMAP_I2C
109203810031SEmanuele Ghidoli	help
109303810031SEmanuele Ghidoli	  GPIO driver for Fairchild Semiconductor FXL6408 GPIO expander.
109403810031SEmanuele Ghidoli
109503810031SEmanuele Ghidoli	  To compile this driver as a module, choose M here: the module will
109603810031SEmanuele Ghidoli	  be called gpio-fxl6408.
109703810031SEmanuele Ghidoli
1098659ad5f7SOkan Sahinconfig GPIO_DS4520
1099659ad5f7SOkan Sahin	tristate "DS4520 I2C GPIO expander"
1100659ad5f7SOkan Sahin	select REGMAP_I2C
1101659ad5f7SOkan Sahin	select GPIO_REGMAP
1102659ad5f7SOkan Sahin	help
1103659ad5f7SOkan Sahin	  GPIO driver for ADI DS4520 I2C-based GPIO expander.
1104659ad5f7SOkan Sahin	  Say yes here to enable the GPIO driver for the ADI DS4520 chip.
1105659ad5f7SOkan Sahin
1106659ad5f7SOkan Sahin	  To compile this driver as a module, choose M here: the module will
1107659ad5f7SOkan Sahin	  be called gpio-ds4520.
1108659ad5f7SOkan Sahin
11092a0b0a57SLinus Walleijconfig GPIO_GW_PLD
11102a0b0a57SLinus Walleij	tristate "Gateworks PLD GPIO Expander"
11112a0b0a57SLinus Walleij	depends on OF_GPIO
11122a0b0a57SLinus Walleij	help
11132a0b0a57SLinus Walleij	  Say yes here to provide access to the Gateworks I2C PLD GPIO
11142a0b0a57SLinus Walleij	  Expander. This is used at least on the Cambria GW2358-4.
11152a0b0a57SLinus Walleij
1116e952805dSWolfram Sangconfig GPIO_MAX7300
1117e952805dSWolfram Sang	tristate "Maxim MAX7300 GPIO expander"
1118e952805dSWolfram Sang	select GPIO_MAX730X
1119e952805dSWolfram Sang	help
11202b861f4bSAxel Lin	  GPIO driver for Maxim MAX7300 I2C-based GPIO expander.
1121e952805dSWolfram Sang
1122bbcd6d54SEric Miaoconfig GPIO_MAX732X
1123bbcd6d54SEric Miao	tristate "MAX7319, MAX7320-7327 I2C Port Expanders"
1124bbcd6d54SEric Miao	help
1125bbcd6d54SEric Miao	  Say yes here to support the MAX7319, MAX7320-7327 series of I2C
1126bbcd6d54SEric Miao	  Port Expanders. Each IO port on these chips has a fixed role of
1127bbcd6d54SEric Miao	  Input (designated by 'I'), Push-Pull Output ('O'), or Open-Drain
1128bbcd6d54SEric Miao	  Input and Output (designed by 'P'). The combinations are listed
1129bbcd6d54SEric Miao	  below:
1130bbcd6d54SEric Miao
1131bbcd6d54SEric Miao	  8 bits:       max7319 (8I), max7320 (8O), max7321 (8P),
1132bbcd6d54SEric Miao	                max7322 (4I4O), max7323 (4P4O)
1133bbcd6d54SEric Miao
1134bbcd6d54SEric Miao	  16 bits:      max7324 (8I8O), max7325 (8P8O),
1135bbcd6d54SEric Miao	                max7326 (4I12O), max7327 (4P12O)
1136bbcd6d54SEric Miao
1137bbcd6d54SEric Miao	  Board setup code must specify the model to use, and the start
1138bbcd6d54SEric Miao	  number for these GPIOs.
1139bbcd6d54SEric Miao
1140a80a0bbeSMarc Zyngierconfig GPIO_MAX732X_IRQ
1141a80a0bbeSMarc Zyngier	bool "Interrupt controller support for MAX732x"
11420244ad00SMartin Schwidefsky	depends on GPIO_MAX732X=y
1143984f6643SLinus Walleij	select GPIOLIB_IRQCHIP
1144a80a0bbeSMarc Zyngier	help
1145a80a0bbeSMarc Zyngier	  Say yes here to enable the max732x to be used as an interrupt
1146a80a0bbeSMarc Zyngier	  controller. It requires the driver to be built in the kernel.
1147a80a0bbeSMarc Zyngier
1148f3dc3630SGuennadi Liakhovetskiconfig GPIO_PCA953X
1149eb32b5aaSAaron Sierra	tristate "PCA95[357]x, PCA9698, TCA64xx, and MAX7310 I/O ports"
11504bc16f9dSMarek Vasut	select REGMAP_I2C
11519e60fdcfSeric miao	help
11527059d4b0SDavid Brownell	  Say yes here to provide access to several register-oriented
11537059d4b0SDavid Brownell	  SMBus I/O expanders, made mostly by NXP or TI.  Compatible
11547059d4b0SDavid Brownell	  models include:
11557059d4b0SDavid Brownell
11567059d4b0SDavid Brownell	  4 bits:       pca9536, pca9537
11577059d4b0SDavid Brownell
1158c29985ddSAxel Lin	  8 bits:       max7310, max7315, pca6107, pca9534, pca9538, pca9554,
11591b9a0c25SAnders Darander	                pca9556, pca9557, pca9574, tca6408, tca9554, xra1202
11607059d4b0SDavid Brownell
1161c29985ddSAxel Lin	  16 bits:      max7312, max7313, pca9535, pca9539, pca9555, pca9575,
1162c29985ddSAxel Lin	                tca6416
11639e60fdcfSeric miao
11641e191695SAaron Sierra	  24 bits:      tca6424
11651e191695SAaron Sierra
1166eb32b5aaSAaron Sierra	  40 bits:      pca9505, pca9698
11671e191695SAaron Sierra
116889ea8bbeSMarc Zyngierconfig GPIO_PCA953X_IRQ
116989ea8bbeSMarc Zyngier	bool "Interrupt controller support for PCA953x"
1170e33a58a2SAndy Shevchenko	depends on GPIO_PCA953X
11717bcbce55SLinus Walleij	select GPIOLIB_IRQCHIP
117289ea8bbeSMarc Zyngier	help
117389ea8bbeSMarc Zyngier	  Say yes here to enable the pca953x to be used as an interrupt
1174dd1695a2SRandy Dunlap	  controller.
117589ea8bbeSMarc Zyngier
117616d44b60SSungbo Eoconfig GPIO_PCA9570
117716d44b60SSungbo Eo	tristate "PCA9570 4-Bit I2C GPO expander"
117816d44b60SSungbo Eo	help
117916d44b60SSungbo Eo	  Say yes here to enable the GPO driver for the NXP PCA9570 chip.
118016d44b60SSungbo Eo
118116d44b60SSungbo Eo	  To compile this driver as a module, choose M here: the module will
118216d44b60SSungbo Eo	  be called gpio-pca9570.
118316d44b60SSungbo Eo
118415fae37dSDavid Brownellconfig GPIO_PCF857X
11851673ad52SDavid Brownell	tristate "PCF857x, PCA{85,96}7x, and MAX732[89] I2C GPIO expanders"
1186a39294bdSGeert Uytterhoeven	select GPIOLIB_IRQCHIP
1187901acf5bSArnd Bergmann	select IRQ_DOMAIN
118815fae37dSDavid Brownell	help
118915fae37dSDavid Brownell	  Say yes here to provide access to most "quasi-bidirectional" I2C
119015fae37dSDavid Brownell	  GPIO expanders used for additional digital outputs or inputs.
119115fae37dSDavid Brownell	  Most of these parts are from NXP, though TI is a second source for
119215fae37dSDavid Brownell	  some of them.  Compatible models include:
119315fae37dSDavid Brownell
119415fae37dSDavid Brownell	  8 bits:   pcf8574, pcf8574a, pca8574, pca8574a,
11951673ad52SDavid Brownell	            pca9670, pca9672, pca9674, pca9674a,
11961673ad52SDavid Brownell	            max7328, max7329
119715fae37dSDavid Brownell
119815fae37dSDavid Brownell	  16 bits:  pcf8575, pcf8575c, pca8575,
119915fae37dSDavid Brownell	            pca9671, pca9673, pca9675
120015fae37dSDavid Brownell
120115fae37dSDavid Brownell	  Your board setup code will need to declare the expanders in
120215fae37dSDavid Brownell	  use, and assign numbers to the GPIOs they expose.  Those GPIOs
120315fae37dSDavid Brownell	  can then be used from drivers and other kernel code, just like
120415fae37dSDavid Brownell	  other GPIOs, but only accessible from task contexts.
120515fae37dSDavid Brownell
120615fae37dSDavid Brownell	  This driver provides an in-kernel interface to those GPIOs using
120715fae37dSDavid Brownell	  platform-neutral GPIO calls.
120815fae37dSDavid Brownell
1209b866526dSAndrew F. Davisconfig GPIO_TPIC2810
1210b866526dSAndrew F. Davis	tristate "TPIC2810 8-Bit I2C GPO expander"
1211b866526dSAndrew F. Davis	help
1212b866526dSAndrew F. Davis	  Say yes here to enable the GPO driver for the TI TPIC2810 chip.
1213b866526dSAndrew F. Davis
1214b866526dSAndrew F. Davis	  To compile this driver as a module, choose M here: the module will
1215b866526dSAndrew F. Davis	  be called gpio-tpic2810.
1216b866526dSAndrew F. Davis
12179c668632SLucile Quirionconfig GPIO_TS4900
12189c668632SLucile Quirion	tristate "Technologic Systems FPGA I2C GPIO"
12194c5f15b7SJean Delvare	depends on SOC_IMX6 || COMPILE_TEST
12209c668632SLucile Quirion	select REGMAP_I2C
12219c668632SLucile Quirion	help
12229c668632SLucile Quirion	  Say yes here to enabled the GPIO driver for Technologic's FPGA core.
12239c668632SLucile Quirion	  Series supported include TS-4100, TS-4900, TS-7970 and TS-7990.
12249c668632SLucile Quirion
1225177b0381SLinus Walleijendmenu
1226177b0381SLinus Walleij
1227177b0381SLinus Walleijmenu "MFD GPIO expanders"
1228be9cab5bSLinus Walleij
1229be9cab5bSLinus Walleijconfig GPIO_ADP5520
1230be9cab5bSLinus Walleij	tristate "GPIO Support for ADP5520 PMIC"
1231be9cab5bSLinus Walleij	depends on PMIC_ADP5520
1232be9cab5bSLinus Walleij	help
1233be9cab5bSLinus Walleij	  This option enables support for on-chip GPIO found
1234be9cab5bSLinus Walleij	  on Analog Devices ADP5520 PMICs.
1235be9cab5bSLinus Walleij
123626a48c4cSThor Thayerconfig GPIO_ALTERA_A10SR
123726a48c4cSThor Thayer	tristate "Altera Arria10 System Resource GPIO"
123826a48c4cSThor Thayer	depends on MFD_ALTERA_A10SR
123926a48c4cSThor Thayer	help
124026a48c4cSThor Thayer	  Driver for Arria10 Development Kit GPIO expansion which
124126a48c4cSThor Thayer	  includes reads of pushbuttons and DIP switches as well
124226a48c4cSThor Thayer	  as writes to LEDs.
124326a48c4cSThor Thayer
1244be9cab5bSLinus Walleijconfig GPIO_ARIZONA
1245be9cab5bSLinus Walleij	tristate "Wolfson Microelectronics Arizona class devices"
1246be9cab5bSLinus Walleij	depends on MFD_ARIZONA
1247be9cab5bSLinus Walleij	help
1248be9cab5bSLinus Walleij	  Support for GPIOs on Wolfson Arizona class devices.
1249be9cab5bSLinus Walleij
1250703b288fSMatti Vaittinenconfig GPIO_BD71815
1251703b288fSMatti Vaittinen	tristate "ROHM BD71815 PMIC GPIO support"
1252703b288fSMatti Vaittinen	depends on MFD_ROHM_BD71828
1253703b288fSMatti Vaittinen	help
1254703b288fSMatti Vaittinen	  Support for GPO(s) on ROHM BD71815 PMIC. There are two GPOs
1255703b288fSMatti Vaittinen	  available on the ROHM PMIC.
1256703b288fSMatti Vaittinen
1257703b288fSMatti Vaittinen	  This driver can also be built as a module. If so, the module
1258703b288fSMatti Vaittinen	  will be called gpio-bd71815.
1259703b288fSMatti Vaittinen
1260c31f625dSMatti Vaittinenconfig GPIO_BD71828
1261c31f625dSMatti Vaittinen	tristate "ROHM BD71828 GPIO support"
1262c31f625dSMatti Vaittinen	depends on MFD_ROHM_BD71828
1263c31f625dSMatti Vaittinen	help
1264c31f625dSMatti Vaittinen	  Support for GPIOs on ROHM BD71828 PMIC. There are three GPIOs
1265c31f625dSMatti Vaittinen	  available on the ROHM PMIC in total. The GPIOs are limited to
1266c31f625dSMatti Vaittinen	  outputs only and pins must be configured to GPIO outputs by
1267c31f625dSMatti Vaittinen	  OTP. Enable this only if you want to use these pins as outputs.
1268c31f625dSMatti Vaittinen
1269c31f625dSMatti Vaittinen	  This driver can also be built as a module. If so, the module
1270c31f625dSMatti Vaittinen	  will be called gpio-bd71828.
1271c31f625dSMatti Vaittinen
127293847930SMarek Vasutconfig GPIO_BD9571MWV
127393847930SMarek Vasut	tristate "ROHM BD9571 GPIO support"
127493847930SMarek Vasut	depends on MFD_BD9571MWV
127593847930SMarek Vasut	help
127693847930SMarek Vasut	  Support for GPIOs on ROHM BD9571 PMIC. There are two GPIOs
127793847930SMarek Vasut	  available on the ROHM PMIC in total, both of which can also
127893847930SMarek Vasut	  generate interrupts.
127993847930SMarek Vasut
128093847930SMarek Vasut	  This driver can also be built as a module. If so, the module
128193847930SMarek Vasut	  will be called gpio-bd9571mwv.
128293847930SMarek Vasut
1283f837fe1bSStephen Boydconfig GPIO_CROS_EC
1284f837fe1bSStephen Boyd	tristate "ChromeOS EC GPIO support"
1285f837fe1bSStephen Boyd	depends on CROS_EC
1286f837fe1bSStephen Boyd	help
1287f837fe1bSStephen Boyd	  GPIO driver for the ChromeOS Embedded Controller (EC). GPIOs
1288f837fe1bSStephen Boyd	  cannot be set unless the system is unlocked.
1289f837fe1bSStephen Boyd
1290f837fe1bSStephen Boyd	  This driver can also be built as a module. If so, the module
1291f837fe1bSStephen Boyd	  will be called gpio-cros-ec.
1292f837fe1bSStephen Boyd
1293be9cab5bSLinus Walleijconfig GPIO_CRYSTAL_COVE
1294be9cab5bSLinus Walleij	tristate "GPIO support for Crystal Cove PMIC"
129572aba2e2SPeter Robinson	depends on (X86 || COMPILE_TEST) && INTEL_SOC_PMIC
1296be9cab5bSLinus Walleij	select GPIOLIB_IRQCHIP
1297be9cab5bSLinus Walleij	help
1298be9cab5bSLinus Walleij	  Support for GPIO pins on Crystal Cove PMIC.
1299be9cab5bSLinus Walleij
1300dd1695a2SRandy Dunlap	  Say Yes if you have a Intel SoC-based tablet with Crystal Cove PMIC
1301be9cab5bSLinus Walleij	  inside.
1302be9cab5bSLinus Walleij
1303be9cab5bSLinus Walleij	  This driver can also be built as a module. If so, the module will be
1304be9cab5bSLinus Walleij	  called gpio-crystalcove.
1305be9cab5bSLinus Walleij
1306be9cab5bSLinus Walleijconfig GPIO_CS5535
1307be9cab5bSLinus Walleij	tristate "AMD CS5535/CS5536 GPIO support"
130872aba2e2SPeter Robinson	depends on X86 || MIPS || COMPILE_TEST
1309be9cab5bSLinus Walleij	depends on MFD_CS5535
1310be9cab5bSLinus Walleij	help
1311be9cab5bSLinus Walleij	  The AMD CS5535 and CS5536 southbridges support 28 GPIO pins that
1312be9cab5bSLinus Walleij	  can be used for quite a number of things.  The CS5535/6 is found on
1313be9cab5bSLinus Walleij	  AMD Geode and Lemote Yeeloong devices.
1314be9cab5bSLinus Walleij
1315be9cab5bSLinus Walleij	  If unsure, say N.
1316be9cab5bSLinus Walleij
1317be9cab5bSLinus Walleijconfig GPIO_DA9052
1318be9cab5bSLinus Walleij	tristate "Dialog DA9052 GPIO"
1319be9cab5bSLinus Walleij	depends on PMIC_DA9052
1320be9cab5bSLinus Walleij	help
1321be9cab5bSLinus Walleij	  Say yes here to enable the GPIO driver for the DA9052 chip.
1322be9cab5bSLinus Walleij
1323be9cab5bSLinus Walleijconfig GPIO_DA9055
1324be9cab5bSLinus Walleij	tristate "Dialog Semiconductor DA9055 GPIO"
1325be9cab5bSLinus Walleij	depends on MFD_DA9055
1326be9cab5bSLinus Walleij	help
1327be9cab5bSLinus Walleij	  Say yes here to enable the GPIO driver for the DA9055 chip.
1328be9cab5bSLinus Walleij
1329be9cab5bSLinus Walleij	  The Dialog DA9055 PMIC chip has 3 GPIO pins that can be
1330dd1695a2SRandy Dunlap	  be controlled by this driver.
1331be9cab5bSLinus Walleij
1332be9cab5bSLinus Walleij	  If driver is built as a module it will be called gpio-da9055.
1333be9cab5bSLinus Walleij
1334be9cab5bSLinus Walleijconfig GPIO_DLN2
1335be9cab5bSLinus Walleij	tristate "Diolan DLN2 GPIO support"
1336be9cab5bSLinus Walleij	depends on MFD_DLN2
1337be9cab5bSLinus Walleij	select GPIOLIB_IRQCHIP
1338be9cab5bSLinus Walleij
1339be9cab5bSLinus Walleij	help
1340be9cab5bSLinus Walleij	  Select this option to enable GPIO driver for the Diolan DLN2
1341be9cab5bSLinus Walleij	  board.
1342be9cab5bSLinus Walleij
1343be9cab5bSLinus Walleij	  This driver can also be built as a module. If so, the module
1344be9cab5bSLinus Walleij	  will be called gpio-dln2.
1345be9cab5bSLinus Walleij
13463c6e8d05SLinus Walleijconfig HTC_EGPIO
13473c6e8d05SLinus Walleij	bool "HTC EGPIO support"
1348e4c6a52cSGeert Uytterhoeven	depends on ARM
13493c6e8d05SLinus Walleij	help
13503c6e8d05SLinus Walleij	  This driver supports the CPLD egpio chip present on
13513c6e8d05SLinus Walleij	  several HTC phones.  It provides basic support for input
1352dd1695a2SRandy Dunlap	  pins, output pins, and IRQs.
13533c6e8d05SLinus Walleij
13549409d8cfSPandith Nconfig GPIO_ELKHARTLAKE
13559409d8cfSPandith N	tristate "Intel Elkhart Lake PSE GPIO support"
13569409d8cfSPandith N	depends on X86 || COMPILE_TEST
13579409d8cfSPandith N	select GPIO_TANGIER
13589409d8cfSPandith N	help
13599409d8cfSPandith N	  Select this option to enable GPIO support for Intel Elkhart Lake
13609409d8cfSPandith N	  PSE GPIO IP.
13619409d8cfSPandith N
13629409d8cfSPandith N	  To compile this driver as a module, choose M here: the module will
13639409d8cfSPandith N	  be called gpio-elkhartlake.
13649409d8cfSPandith N
1365be9cab5bSLinus Walleijconfig GPIO_JANZ_TTL
1366be9cab5bSLinus Walleij	tristate "Janz VMOD-TTL Digital IO Module"
1367be9cab5bSLinus Walleij	depends on MFD_JANZ_CMODIO
1368be9cab5bSLinus Walleij	help
1369be9cab5bSLinus Walleij	  This enables support for the Janz VMOD-TTL Digital IO module.
1370be9cab5bSLinus Walleij	  This driver provides support for driving the pins in output
1371be9cab5bSLinus Walleij	  mode only. Input mode is not supported.
1372be9cab5bSLinus Walleij
1373be9cab5bSLinus Walleijconfig GPIO_KEMPLD
1374be9cab5bSLinus Walleij	tristate "Kontron ETX / COMexpress GPIO"
1375be9cab5bSLinus Walleij	depends on MFD_KEMPLD
1376be9cab5bSLinus Walleij	help
1377be9cab5bSLinus Walleij	  This enables support for the PLD GPIO interface on some Kontron ETX
1378be9cab5bSLinus Walleij	  and COMexpress (ETXexpress) modules.
1379be9cab5bSLinus Walleij
1380be9cab5bSLinus Walleij	  This driver can also be built as a module. If so, the module will be
1381be9cab5bSLinus Walleij	  called gpio-kempld.
1382be9cab5bSLinus Walleij
1383c5a4b6fdSYe Xiangconfig GPIO_LJCA
1384c5a4b6fdSYe Xiang	tristate "INTEL La Jolla Cove Adapter GPIO support"
13851034cc42SWentong Wu	depends on USB_LJCA
1386c5a4b6fdSYe Xiang	select GPIOLIB_IRQCHIP
13871034cc42SWentong Wu	default USB_LJCA
1388c5a4b6fdSYe Xiang	help
1389c5a4b6fdSYe Xiang	  Select this option to enable GPIO driver for the INTEL
1390c5a4b6fdSYe Xiang	  La Jolla Cove Adapter (LJCA) board.
1391c5a4b6fdSYe Xiang
1392c5a4b6fdSYe Xiang	  This driver can also be built as a module. If so, the module
1393c5a4b6fdSYe Xiang	  will be called gpio-ljca.
1394c5a4b6fdSYe Xiang
1395be9cab5bSLinus Walleijconfig GPIO_LP3943
1396be9cab5bSLinus Walleij	tristate "TI/National Semiconductor LP3943 GPIO expander"
1397be9cab5bSLinus Walleij	depends on MFD_LP3943
1398be9cab5bSLinus Walleij	help
1399be9cab5bSLinus Walleij	  GPIO driver for LP3943 MFD.
1400be9cab5bSLinus Walleij	  LP3943 can be used as a GPIO expander which provides up to 16 GPIOs.
1401be9cab5bSLinus Walleij	  Open drain outputs are required for this usage.
1402be9cab5bSLinus Walleij
140383f14103SKeerthyconfig GPIO_LP873X
140483f14103SKeerthy	tristate "TI LP873X GPO"
140583f14103SKeerthy	depends on MFD_TI_LP873X
140683f14103SKeerthy	help
140783f14103SKeerthy	  This driver supports the GPO on TI Lp873x PMICs. 2 GPOs are present
140883f14103SKeerthy	  on LP873X PMICs.
140983f14103SKeerthy
141083f14103SKeerthy	  This driver can also be built as a module. If so, the module will be
141183f14103SKeerthy	  called gpio-lp873x.
141283f14103SKeerthy
14135c7f2c76SKeerthyconfig GPIO_LP87565
14145c7f2c76SKeerthy	tristate "TI LP87565 GPIO"
14155c7f2c76SKeerthy	depends on MFD_TI_LP87565
14165c7f2c76SKeerthy	help
14175c7f2c76SKeerthy	  This driver supports the GPIO on TI Lp873565 PMICs. 3 GPIOs are present
14185c7f2c76SKeerthy	  on LP87565 PMICs.
14195c7f2c76SKeerthy
14205c7f2c76SKeerthy	  This driver can also be built as a module. If so, the module will be
14215c7f2c76SKeerthy	  called gpio-lp87565.
14225c7f2c76SKeerthy
1423aca429ffSRichard Fitzgeraldconfig GPIO_MADERA
1424aca429ffSRichard Fitzgerald	tristate "Cirrus Logic Madera class codecs"
1425aca429ffSRichard Fitzgerald	depends on PINCTRL_MADERA
1426aca429ffSRichard Fitzgerald	help
1427aca429ffSRichard Fitzgerald	  Support for GPIOs on Cirrus Logic Madera class codecs.
1428aca429ffSRichard Fitzgerald
142902c5ba1eSLaxman Dewanganconfig GPIO_MAX77620
143002c5ba1eSLaxman Dewangan	tristate "GPIO support for PMIC MAX77620 and MAX20024"
143102c5ba1eSLaxman Dewangan	depends on MFD_MAX77620
1432c5706c7dSDmitry Osipenko	select GPIOLIB_IRQCHIP
143302c5ba1eSLaxman Dewangan	help
143402c5ba1eSLaxman Dewangan	  GPIO driver for MAX77620 and MAX20024 PMIC from Maxim Semiconductor.
143502c5ba1eSLaxman Dewangan	  MAX77620 PMIC has 8 pins that can be configured as GPIOs. The
1436dd1695a2SRandy Dunlap	  driver also provides interrupt support for each of the GPIOs.
1437dd1695a2SRandy Dunlap	  Say yes here to enable the max77620 to be used as GPIO controller.
143802c5ba1eSLaxman Dewangan
143972b5135bSBartosz Golaszewskiconfig GPIO_MAX77650
144072b5135bSBartosz Golaszewski	tristate "Maxim MAX77650/77651 GPIO support"
144172b5135bSBartosz Golaszewski	depends on MFD_MAX77650
144272b5135bSBartosz Golaszewski	help
144372b5135bSBartosz Golaszewski	  GPIO driver for MAX77650/77651 PMIC from Maxim Semiconductor.
144472b5135bSBartosz Golaszewski	  These chips have a single pin that can be configured as GPIO.
144572b5135bSBartosz Golaszewski
1446be9cab5bSLinus Walleijconfig GPIO_PALMAS
1447be9cab5bSLinus Walleij	bool "TI PALMAS series PMICs GPIO"
1448be9cab5bSLinus Walleij	depends on MFD_PALMAS
1449be9cab5bSLinus Walleij	help
1450be9cab5bSLinus Walleij	  Select this option to enable GPIO driver for the TI PALMAS
1451be9cab5bSLinus Walleij	  series chip family.
1452be9cab5bSLinus Walleij
145363de20caSLinus Walleijconfig GPIO_PMIC_EIC_SPRD
145463de20caSLinus Walleij	tristate "Spreadtrum PMIC EIC support"
145563de20caSLinus Walleij	depends on MFD_SC27XX_PMIC || COMPILE_TEST
145663de20caSLinus Walleij	depends on OF_GPIO
145763de20caSLinus Walleij	select GPIOLIB_IRQCHIP
145863de20caSLinus Walleij	help
145963de20caSLinus Walleij	  Say yes here to support Spreadtrum PMIC EIC device.
146063de20caSLinus Walleij
1461e9fe32bcSLaxman Dewanganconfig GPIO_RC5T583
1462e9fe32bcSLaxman Dewangan	bool "RICOH RC5T583 GPIO"
1463e9fe32bcSLaxman Dewangan	depends on MFD_RC5T583
1464e9fe32bcSLaxman Dewangan	help
1465e9fe32bcSLaxman Dewangan	  Select this option to enable GPIO driver for the Ricoh RC5T583
1466e9fe32bcSLaxman Dewangan	  chip family.
1467dd1695a2SRandy Dunlap	  This driver provides the support for driving/reading the GPIO pins
1468dd1695a2SRandy Dunlap	  of RC5T583 device through standard GPIO library.
1469e9fe32bcSLaxman Dewangan
1470b7536d87SMichael Walleconfig GPIO_SL28CPLD
1471b7536d87SMichael Walle	tristate "Kontron sl28cpld GPIO support"
1472b7536d87SMichael Walle	depends on MFD_SL28CPLD || COMPILE_TEST
1473b7536d87SMichael Walle	select GPIO_REGMAP
1474b7536d87SMichael Walle	select GPIOLIB_IRQCHIP
1475b7536d87SMichael Walle	select REGMAP_IRQ
1476b7536d87SMichael Walle	help
1477b7536d87SMichael Walle	  This enables support for the GPIOs found on the Kontron sl28 CPLD.
1478b7536d87SMichael Walle
1479b7536d87SMichael Walle	  This driver can also be built as a module. If so, the module will be
1480b7536d87SMichael Walle	  called gpio-sl28cpld.
1481b7536d87SMichael Walle
148203f822f5SRabin Vincentconfig GPIO_STMPE
148303f822f5SRabin Vincent	bool "STMPE GPIOs"
148403f822f5SRabin Vincent	depends on MFD_STMPE
14851dfb4a0dSLinus Walleij	depends on OF_GPIO
1486fe44e70dSLinus Walleij	select GPIOLIB_IRQCHIP
148703f822f5SRabin Vincent	help
148803f822f5SRabin Vincent	  This enables support for the GPIOs found on the STMPE I/O
148903f822f5SRabin Vincent	  Expanders.
149003f822f5SRabin Vincent
1491f4e8afdcSSundar Iyerconfig GPIO_TC3589X
1492f4e8afdcSSundar Iyer	bool "TC3589X GPIOs"
1493f4e8afdcSSundar Iyer	depends on MFD_TC3589X
14941422731dSLinus Walleij	depends on OF_GPIO
1495cf42f1cfSLinus Walleij	select GPIOLIB_IRQCHIP
1496d88b25beSRabin Vincent	help
1497f4e8afdcSSundar Iyer	  This enables support for the GPIOs found on the TC3589X
1498d88b25beSRabin Vincent	  I/O Expander.
1499d88b25beSRabin Vincent
1500be9cab5bSLinus Walleijconfig GPIO_TIMBERDALE
1501be9cab5bSLinus Walleij	bool "Support for timberdale GPIO IP"
1502be9cab5bSLinus Walleij	depends on MFD_TIMBERDALE
1503a7f7f624SMasahiro Yamada	help
1504be9cab5bSLinus Walleij	Add support for the GPIO IP in the timberdale FPGA.
1505be9cab5bSLinus Walleij
1506b3dcb5deSRobert Markoconfig GPIO_TN48M_CPLD
1507b3dcb5deSRobert Marko	tristate "Delta Networks TN48M switch CPLD GPIO driver"
1508b3dcb5deSRobert Marko	depends on MFD_TN48M_CPLD
1509b3dcb5deSRobert Marko	select GPIO_REGMAP
1510b3dcb5deSRobert Marko	help
1511b3dcb5deSRobert Marko	  This enables support for the GPIOs found on the Delta
1512b3dcb5deSRobert Marko	  Networks TN48M switch Lattice CPLD. It provides 12 pins in total,
1513b3dcb5deSRobert Marko	  they are input-only or output-only type.
1514b3dcb5deSRobert Marko
1515b3dcb5deSRobert Marko	  This driver can also be built as a module. If so, the
1516b3dcb5deSRobert Marko	  module will be called gpio-tn48m.
1517b3dcb5deSRobert Marko
151899f0fd54SAndrew F. Davisconfig GPIO_TPS65086
151999f0fd54SAndrew F. Davis	tristate "TI TPS65086 GPO"
152099f0fd54SAndrew F. Davis	depends on MFD_TPS65086
152199f0fd54SAndrew F. Davis	help
152299f0fd54SAndrew F. Davis	  This driver supports the GPO on TI TPS65086x PMICs.
152399f0fd54SAndrew F. Davis
1524c366c76aSNicolas Saenz Julienneconfig GPIO_TPS65218
1525c366c76aSNicolas Saenz Julienne	tristate "TPS65218 GPIO"
1526c366c76aSNicolas Saenz Julienne	depends on MFD_TPS65218
1527c366c76aSNicolas Saenz Julienne	help
1528c366c76aSNicolas Saenz Julienne	  Select this option to enable GPIO driver for the TPS65218
1529c366c76aSNicolas Saenz Julienne	  chip family.
1530c366c76aSNicolas Saenz Julienne
153157e30e00SJerome Neanneconfig GPIO_TPS65219
153257e30e00SJerome Neanne	tristate "TPS65219 GPIO"
153357e30e00SJerome Neanne	depends on MFD_TPS65219
153457e30e00SJerome Neanne	default MFD_TPS65219
153557e30e00SJerome Neanne	help
153657e30e00SJerome Neanne	  Select this option to enable GPIO driver for the TPS65219 chip
153757e30e00SJerome Neanne	  family.
153857e30e00SJerome Neanne	  GPIO0 is statically configured as either input or output prior to
153957e30e00SJerome Neanne	  Linux boot. It is used for MULTI_DEVICE_ENABLE function. This setting
154057e30e00SJerome Neanne	  is statically configured by NVM. GPIO0 can't be used as a generic
154157e30e00SJerome Neanne	  GPIO. It's either a GPO when MULTI_DEVICE_EN=0 or a GPI when
154257e30e00SJerome Neanne	  MULTI_DEVICE_EN=1.
154357e30e00SJerome Neanne
154457e30e00SJerome Neanne	  This driver can also be built as a module. If so, the module will be
154557e30e00SJerome Neanne	  called gpio_tps65219.
154657e30e00SJerome Neanne
1547be9cab5bSLinus Walleijconfig GPIO_TPS6586X
1548be9cab5bSLinus Walleij	bool "TPS6586X GPIO"
1549be9cab5bSLinus Walleij	depends on MFD_TPS6586X
1550be9cab5bSLinus Walleij	help
1551be9cab5bSLinus Walleij	  Select this option to enable GPIO driver for the TPS6586X
1552be9cab5bSLinus Walleij	  chip family.
1553be9cab5bSLinus Walleij
1554be9cab5bSLinus Walleijconfig GPIO_TPS65910
1555be9cab5bSLinus Walleij	bool "TPS65910 GPIO"
1556be9cab5bSLinus Walleij	depends on MFD_TPS65910
1557be9cab5bSLinus Walleij	help
1558be9cab5bSLinus Walleij	  Select this option to enable GPIO driver for the TPS65910
1559be9cab5bSLinus Walleij	  chip family.
1560be9cab5bSLinus Walleij
1561668a6cc7SMargarita Olayaconfig GPIO_TPS65912
1562668a6cc7SMargarita Olaya	tristate "TI TPS65912 GPIO"
1563ca801a22SAndrew F. Davis	depends on MFD_TPS65912
1564668a6cc7SMargarita Olaya	help
1565dd1695a2SRandy Dunlap	  This driver supports TPS65912 GPIO chip.
1566668a6cc7SMargarita Olaya
1567275b13a6SRajmohan Maniconfig GPIO_TPS68470
1568a1ce76e8SHans de Goede	tristate "TPS68470 GPIO"
156924700e1fSDaniel Scally	depends on INTEL_SKL_INT3472
1570275b13a6SRajmohan Mani	help
1571275b13a6SRajmohan Mani	  Select this option to enable GPIO driver for the TPS68470
1572275b13a6SRajmohan Mani	  chip family.
1573dd1695a2SRandy Dunlap	  There are 7 GPIOs and few sensor-related GPIOs supported
1574275b13a6SRajmohan Mani	  by the TPS68470. While the 7 GPIOs can be configured as
1575275b13a6SRajmohan Mani	  input or output as appropriate, the sensor related GPIOs
1576275b13a6SRajmohan Mani	  are "output only" GPIOs.
1577275b13a6SRajmohan Mani
1578b868db94SAndrew Lunnconfig GPIO_TQMX86
1579b868db94SAndrew Lunn	tristate "TQ-Systems QTMX86 GPIO"
1580b868db94SAndrew Lunn	depends on MFD_TQMX86 || COMPILE_TEST
1581c6414e1aSJohannes Berg	depends on HAS_IOPORT_MAP
1582b868db94SAndrew Lunn	select GPIOLIB_IRQCHIP
1583b868db94SAndrew Lunn	help
1584b868db94SAndrew Lunn	  This driver supports GPIO on the TQMX86 IO controller.
1585b868db94SAndrew Lunn
1586e9d35947SDavid Brownellconfig GPIO_TWL4030
1587e9d35947SDavid Brownell	tristate "TWL4030, TWL5030, and TPS659x0 GPIOs"
1588e9d35947SDavid Brownell	depends on TWL4030_CORE
1589e9d35947SDavid Brownell	help
1590e9d35947SDavid Brownell	  Say yes here to access the GPIO signals of various multi-function
1591e9d35947SDavid Brownell	  power management chips from Texas Instruments.
1592e9d35947SDavid Brownell
159370ffd691SPeter Ujfalusiconfig GPIO_TWL6040
159470ffd691SPeter Ujfalusi	tristate "TWL6040 GPO"
159570ffd691SPeter Ujfalusi	depends on TWL6040_CORE
159670ffd691SPeter Ujfalusi	help
159770ffd691SPeter Ujfalusi	  Say yes here to access the GPO signals of twl6040
159870ffd691SPeter Ujfalusi	  audio chip from Texas Instruments.
159970ffd691SPeter Ujfalusi
16000ba19cfcSBin Gaoconfig GPIO_WHISKEY_COVE
16010ba19cfcSBin Gao	tristate "GPIO support for Whiskey Cove PMIC"
1602b5238b41SAndy Shevchenko	depends on (X86 || COMPILE_TEST) && INTEL_SOC_PMIC_BXTWC
16030ba19cfcSBin Gao	select GPIOLIB_IRQCHIP
16040ba19cfcSBin Gao	help
16050ba19cfcSBin Gao	  Support for GPIO pins on Whiskey Cove PMIC.
16060ba19cfcSBin Gao
1607dd1695a2SRandy Dunlap	  Say Yes if you have an Intel SoC-based tablet with Whiskey Cove PMIC
16080ba19cfcSBin Gao	  inside.
16090ba19cfcSBin Gao
16100ba19cfcSBin Gao	  This driver can also be built as a module. If so, the module will be
16110ba19cfcSBin Gao	  called gpio-wcove.
16120ba19cfcSBin Gao
1613e4b736f1SMark Brownconfig GPIO_WM831X
1614e4b736f1SMark Brown	tristate "WM831x GPIOs"
1615e4b736f1SMark Brown	depends on MFD_WM831X
1616e4b736f1SMark Brown	help
1617e4b736f1SMark Brown	  Say yes here to access the GPIO signals of WM831x power management
1618e4b736f1SMark Brown	  chips from Wolfson Microelectronics.
1619e4b736f1SMark Brown
162038f6ce45SMark Brownconfig GPIO_WM8350
162138f6ce45SMark Brown	tristate "WM8350 GPIOs"
162238f6ce45SMark Brown	depends on MFD_WM8350
162338f6ce45SMark Brown	help
162438f6ce45SMark Brown	  Say yes here to access the GPIO signals of WM8350 power management
162538f6ce45SMark Brown	  chips from Wolfson Microelectronics.
162638f6ce45SMark Brown
16272955c309SMark Brownconfig GPIO_WM8994
16282955c309SMark Brown	tristate "WM8994 GPIOs"
16292955c309SMark Brown	depends on MFD_WM8994
16302955c309SMark Brown	help
16312955c309SMark Brown	  Say yes here to access the GPIO signals of WM8994 audio hub
16322955c309SMark Brown	  CODECs from Wolfson Microelectronics.
16332955c309SMark Brown
1634177b0381SLinus Walleijendmenu
1635177b0381SLinus Walleij
1636177b0381SLinus Walleijmenu "PCI GPIO expanders"
1637177b0381SLinus Walleij	depends on PCI
1638ff1d5c2fSMichael Buesch
163992c33ef7SLinus Walleijconfig GPIO_AMD8111
164092c33ef7SLinus Walleij	tristate "AMD 8111 GPIO driver"
164172aba2e2SPeter Robinson	depends on X86 || COMPILE_TEST
1642c6414e1aSJohannes Berg	depends on HAS_IOPORT_MAP
1643ff1d5c2fSMichael Buesch	help
164492c33ef7SLinus Walleij	  The AMD 8111 southbridge contains 32 GPIO pins which can be used.
16455f0a96b0SAndres Salomon
1646dd1695a2SRandy Dunlap	  Note that usually system firmware/ACPI handles GPIO pins on their
1647dd1695a2SRandy Dunlap	  own and users might easily break their systems with uncareful usage
164892c33ef7SLinus Walleij	  of this driver!
1649ff1d5c2fSMichael Buesch
165092c33ef7SLinus Walleij	  If unsure, say N
16515f0a96b0SAndres Salomon
1652ff1d5c2fSMichael Bueschconfig GPIO_BT8XX
1653ff1d5c2fSMichael Buesch	tristate "BT8XX GPIO abuser"
165403744529SAndrew F. Davis	depends on VIDEO_BT848=n
1655ff1d5c2fSMichael Buesch	help
165622520edcSGeert Uytterhoeven	  The BT8xx frame grabber chip has 24 GPIO pins that can be abused
1657ff1d5c2fSMichael Buesch	  as a cheap PCI GPIO card.
1658ff1d5c2fSMichael Buesch
1659ff1d5c2fSMichael Buesch	  This chip can be found on Miro, Hauppauge and STB TV-cards.
1660ff1d5c2fSMichael Buesch
1661ff1d5c2fSMichael Buesch	  The card needs to be physically altered for using it as a
1662ff1d5c2fSMichael Buesch	  GPIO card. For more information on how to build a GPIO card
1663ff1d5c2fSMichael Buesch	  from a BT8xx TV card, see the documentation file at
16645f07224eSJonathan Neuschäfer	  Documentation/driver-api/gpio/bt8xxgpio.rst
1665ff1d5c2fSMichael Buesch
1666ff1d5c2fSMichael Buesch	  If unsure, say N.
1667ff1d5c2fSMichael Buesch
1668ccf6fd6dSAndy Shevchenkoconfig GPIO_MERRIFIELD
1669ccf6fd6dSAndy Shevchenko	tristate "Intel Merrifield GPIO support"
1670ccf6fd6dSAndy Shevchenko	depends on X86_INTEL_MID
167134840be5SPandith N	select GPIO_TANGIER
1672ccf6fd6dSAndy Shevchenko	help
1673ccf6fd6dSAndy Shevchenko	  Say Y here to support Intel Merrifield GPIO.
16748bf02617SAlek Du
1675c78c42d7SShravan Kumar Ramaniconfig GPIO_MLXBF
1676c78c42d7SShravan Kumar Ramani	tristate "Mellanox BlueField SoC GPIO"
1677cbe706b0SShravan Kumar Ramani	depends on (MELLANOX_PLATFORM && ARM64 && ACPI) || (64BIT && COMPILE_TEST)
1678c78c42d7SShravan Kumar Ramani	select GPIO_GENERIC
1679c78c42d7SShravan Kumar Ramani	help
1680c78c42d7SShravan Kumar Ramani	  Say Y here if you want GPIO support on Mellanox BlueField SoC.
1681c78c42d7SShravan Kumar Ramani
1682bc0ae0e7SAsmaa Mnebhiconfig GPIO_MLXBF2
1683bc0ae0e7SAsmaa Mnebhi	tristate "Mellanox BlueField 2 SoC GPIO"
1684bc0ae0e7SAsmaa Mnebhi	depends on (MELLANOX_PLATFORM && ARM64 && ACPI) || (64BIT && COMPILE_TEST)
1685bc0ae0e7SAsmaa Mnebhi	select GPIO_GENERIC
16862f43f602SLinus Walleij	select GPIOLIB_IRQCHIP
1687bc0ae0e7SAsmaa Mnebhi	help
1688bc0ae0e7SAsmaa Mnebhi	  Say Y here if you want GPIO support on Mellanox BlueField 2 SoC.
1689bc0ae0e7SAsmaa Mnebhi
1690cd33f216SAsmaa Mnebhiconfig GPIO_MLXBF3
1691cd33f216SAsmaa Mnebhi	tristate "Mellanox BlueField 3 SoC GPIO"
1692cd33f216SAsmaa Mnebhi	depends on (MELLANOX_PLATFORM && ARM64) || COMPILE_TEST
1693cd33f216SAsmaa Mnebhi	select GPIO_GENERIC
1694cd33f216SAsmaa Mnebhi	select GPIOLIB_IRQCHIP
1695cd33f216SAsmaa Mnebhi	help
1696cd33f216SAsmaa Mnebhi	  Say Y if you want GPIO support on Mellanox BlueField 3 SoC.
1697cd33f216SAsmaa Mnebhi	  This GPIO controller supports interrupt handling and enables the
1698cd33f216SAsmaa Mnebhi	  manipulation of certain GPIO pins.
1699cd33f216SAsmaa Mnebhi	  This controller should be used in parallel with pinctrl-mlxbf3 to
1700cd33f216SAsmaa Mnebhi	  control the desired GPIOs.
1701cd33f216SAsmaa Mnebhi	  This driver can also be built as a module called mlxbf3-gpio.
1702cd33f216SAsmaa Mnebhi
170392c33ef7SLinus Walleijconfig GPIO_ML_IOH
170492c33ef7SLinus Walleij	tristate "OKI SEMICONDUCTOR ML7213 IOH GPIO support"
170572aba2e2SPeter Robinson	depends on X86 || COMPILE_TEST
170692c33ef7SLinus Walleij	select GENERIC_IRQ_CHIP
170792c33ef7SLinus Walleij	help
170892c33ef7SLinus Walleij	  ML7213 is companion chip for Intel Atom E6xx series.
170992c33ef7SLinus Walleij	  This driver can be used for OKI SEMICONDUCTOR ML7213 IOH (Input/Output
171092c33ef7SLinus Walleij	  Hub) which is for IVI (In-Vehicle Infotainment) use.
171192c33ef7SLinus Walleij	  This driver can access the IOH's GPIO device.
171292c33ef7SLinus Walleij
171304c17aa8STomoya MORINAGAconfig GPIO_PCH
1714868fea05STomoya MORINAGA	tristate "Intel EG20T PCH/LAPIS Semiconductor IOH (ML7223/ML7831) GPIO"
171503744529SAndrew F. Davis	depends on X86_32 || MIPS || COMPILE_TEST
171638eb18a6STomoya MORINAGA	select GENERIC_IRQ_CHIP
171704c17aa8STomoya MORINAGA	help
1718dd1695a2SRandy Dunlap	  This driver is for PCH (Platform Controller Hub) GPIO of Intel Topcliff,
171904c17aa8STomoya MORINAGA	  which is an IOH (Input/Output Hub) for x86 embedded processor.
172004c17aa8STomoya MORINAGA	  This driver can access PCH GPIO device.
172104c17aa8STomoya MORINAGA
1722868fea05STomoya MORINAGA	  This driver also can be used for LAPIS Semiconductor IOH (Input/
1723868fea05STomoya MORINAGA	  Output Hub), ML7223 and ML7831.
1724bc786cceSTomoya MORINAGA	  ML7223 IOH is for MP (Media Phone) use.
1725868fea05STomoya MORINAGA	  ML7831 IOH is for general purpose use.
1726868fea05STomoya MORINAGA	  ML7223/ML7831 is companion chip for Intel Atom E6xx series.
1727868fea05STomoya MORINAGA	  ML7223/ML7831 is completely compatible for Intel EG20T PCH.
1728bc786cceSTomoya MORINAGA
172902e74fc0SWilliam Breathitt Grayconfig GPIO_PCI_IDIO_16
173002e74fc0SWilliam Breathitt Gray	tristate "ACCES PCI-IDIO-16 GPIO support"
173173d8f3efSWilliam Breathitt Gray	select REGMAP_MMIO
1732e7f758faSWilliam Breathitt Gray	select GPIO_IDIO_16
173302e74fc0SWilliam Breathitt Gray	help
173402e74fc0SWilliam Breathitt Gray	  Enables GPIO support for the ACCES PCI-IDIO-16. An interrupt is
173502e74fc0SWilliam Breathitt Gray	  generated when any of the inputs change state (low to high or high to
173602e74fc0SWilliam Breathitt Gray	  low). Input filter control is not supported by this driver, and the
173702e74fc0SWilliam Breathitt Gray	  input filters are deactivated by this driver.
173802e74fc0SWilliam Breathitt Gray
173958556204SWilliam Breathitt Grayconfig GPIO_PCIE_IDIO_24
174058556204SWilliam Breathitt Gray	tristate "ACCES PCIe-IDIO-24 GPIO support"
17411a200a39SWilliam Breathitt Gray	select REGMAP_IRQ
17421a200a39SWilliam Breathitt Gray	select REGMAP_MMIO
174358556204SWilliam Breathitt Gray	select GPIOLIB_IRQCHIP
17441a200a39SWilliam Breathitt Gray	select GPIO_REGMAP
174558556204SWilliam Breathitt Gray	help
174658556204SWilliam Breathitt Gray	  Enables GPIO support for the ACCES PCIe-IDIO-24 family (PCIe-IDIO-24,
174758556204SWilliam Breathitt Gray	  PCIe-IDI-24, PCIe-IDO-24, PCIe-IDIO-12). An interrupt is generated
174858556204SWilliam Breathitt Gray	  when any of the inputs change state (low to high or high to low).
174958556204SWilliam Breathitt Gray	  Input filter control is not supported by this driver, and the input
175058556204SWilliam Breathitt Gray	  filters are deactivated by this driver.
175158556204SWilliam Breathitt Gray
17529956d02dSFlorian Fainelliconfig GPIO_RDC321X
17539956d02dSFlorian Fainelli	tristate "RDC R-321x GPIO support"
1754e4be3cb7SRandy Dunlap	select MFD_CORE
17559956d02dSFlorian Fainelli	select MFD_RDC321X
17569956d02dSFlorian Fainelli	help
17579956d02dSFlorian Fainelli	  Support for the RDC R321x SoC GPIOs over southbridge
17589956d02dSFlorian Fainelli	  PCI configuration space.
17599956d02dSFlorian Fainelli
176035570ac6SRichard Röjforsconfig GPIO_SODAVILLE
1761a9c5fff5SDavid Brownell	bool "Intel Sodaville GPIO support"
176203744529SAndrew F. Davis	depends on X86 && OF
17630c36ec31SJuergen Beisert	select GPIO_GENERIC
17640c36ec31SJuergen Beisert	select GENERIC_IRQ_CHIP
1765e952805dSWolfram Sang	help
17660c36ec31SJuergen Beisert	  Say Y here to support Intel Sodaville GPIO.
1767e952805dSWolfram Sang
1768177b0381SLinus Walleijendmenu
1769e58b9e27SDavid Brownell
1770177b0381SLinus Walleijmenu "SPI GPIO expanders"
1771177b0381SLinus Walleij	depends on SPI_MASTER
1772e58b9e27SDavid Brownell
1773a7ec2e7fSLinus Walleijconfig GPIO_74X164
1774a7ec2e7fSLinus Walleij	tristate "74x164 serial-in/parallel-out 8-bits shift register"
1775048c28c9SLinus Walleij	depends on OF_GPIO
1776a7ec2e7fSLinus Walleij	help
1777a7ec2e7fSLinus Walleij	  Driver for 74x164 compatible serial-in/parallel-out 8-outputs
1778a7ec2e7fSLinus Walleij	  shift registers. This driver can be used to provide access
1779dd1695a2SRandy Dunlap	  to more GPIO outputs.
1780e58b9e27SDavid Brownell
1781b2f68edfSLukas Wunnerconfig GPIO_MAX3191X
1782b2f68edfSLukas Wunner	tristate "Maxim MAX3191x industrial serializer"
1783b2f68edfSLukas Wunner	select CRC8
1784b2f68edfSLukas Wunner	help
1785b2f68edfSLukas Wunner	  GPIO driver for Maxim MAX31910, MAX31911, MAX31912, MAX31913,
1786b2f68edfSLukas Wunner	  MAX31953 and MAX31963 industrial serializer, a daisy-chainable
1787b2f68edfSLukas Wunner	  chip to make 8 digital 24V inputs available via SPI.  Supports
1788b2f68edfSLukas Wunner	  CRC checksums to guard against electromagnetic interference,
1789b2f68edfSLukas Wunner	  as well as undervoltage and overtemperature detection.
1790b2f68edfSLukas Wunner
1791e58b9e27SDavid Brownellconfig GPIO_MAX7301
1792e58b9e27SDavid Brownell	tristate "Maxim MAX7301 GPIO expander"
17931e5db006SRichard Röjfors	select GPIO_MAX730X
17941e5db006SRichard Röjfors	help
17951e5db006SRichard Röjfors	  GPIO driver for Maxim MAX7301 SPI-based GPIO expander.
17961e5db006SRichard Röjfors
17970963670aSLinus Walleijconfig GPIO_MC33880
17980963670aSLinus Walleij	tristate "Freescale MC33880 high-side/low-side switch"
17990963670aSLinus Walleij	help
18000963670aSLinus Walleij	  SPI driver for Freescale MC33880 high-side/low-side switch.
18010963670aSLinus Walleij	  This provides GPIO interface supporting inputs and outputs.
18020963670aSLinus Walleij
1803df6df93cSAndrew F. Davisconfig GPIO_PISOSR
1804df6df93cSAndrew F. Davis	tristate "Generic parallel-in/serial-out shift register"
1805df6df93cSAndrew F. Davis	help
1806df6df93cSAndrew F. Davis	  GPIO driver for SPI compatible parallel-in/serial-out shift
1807df6df93cSAndrew F. Davis	  registers. These are input only devices.
1808df6df93cSAndrew F. Davis
18095704520dSNandor Hanconfig GPIO_XRA1403
18105704520dSNandor Han	tristate "EXAR XRA1403 16-bit GPIO expander"
1811665dff99SArnd Bergmann	select REGMAP_SPI
18125704520dSNandor Han	help
18135704520dSNandor Han	  GPIO driver for EXAR XRA1403 16-bit SPI-based GPIO expander.
18145704520dSNandor Han
1815856ed97aSMarek Behúnconfig GPIO_MOXTET
1816856ed97aSMarek Behún	tristate "Turris Mox Moxtet bus GPIO expander"
1817856ed97aSMarek Behún	depends on MOXTET
1818856ed97aSMarek Behún	help
1819856ed97aSMarek Behún	  Say yes here if you are building for the Turris Mox router.
1820856ed97aSMarek Behún	  This is the driver needed for configuring the GPIOs via the Moxtet
1821856ed97aSMarek Behún	  bus. For example the Mox module with SFP cage needs this driver
1822856ed97aSMarek Behún	  so that phylink can use corresponding GPIOs.
1823856ed97aSMarek Behún
18240963670aSLinus Walleijendmenu
18250963670aSLinus Walleij
1826177b0381SLinus Walleijmenu "USB GPIO expanders"
1827177b0381SLinus Walleij	depends on USB
18289d5b72deSLars Poeschel
18299d5b72deSLars Poeschelconfig GPIO_VIPERBOARD
18309d5b72deSLars Poeschel	tristate "Viperboard GPIO a & b support"
183103744529SAndrew F. Davis	depends on MFD_VIPERBOARD
18329d5b72deSLars Poeschel	help
18339d5b72deSLars Poeschel	  Say yes here to access the GPIO signals of Nano River
18349d5b72deSLars Poeschel	  Technologies Viperboard. There are two GPIO chips on the
18359d5b72deSLars Poeschel	  board: gpioa and gpiob.
18369d5b72deSLars Poeschel	  See viperboard API specification and Nano
18379d5b72deSLars Poeschel	  River Tech's viperboard.h for detailed meaning
18389d5b72deSLars Poeschel	  of the module parameters.
18399d5b72deSLars Poeschel
1840177b0381SLinus Walleijendmenu
18416732127fSDaniel Baluta
1842b5252196SEnrico Weigelt, metux IT consultmenu "Virtual GPIO drivers"
1843b5252196SEnrico Weigelt, metux IT consult
1844828546e2SGeert Uytterhoevenconfig GPIO_AGGREGATOR
1845828546e2SGeert Uytterhoeven	tristate "GPIO Aggregator"
1846828546e2SGeert Uytterhoeven	help
1847828546e2SGeert Uytterhoeven	  Say yes here to enable the GPIO Aggregator, which provides a way to
1848828546e2SGeert Uytterhoeven	  aggregate existing GPIO lines into a new virtual GPIO chip.
1849828546e2SGeert Uytterhoeven	  This can serve the following purposes:
1850828546e2SGeert Uytterhoeven	    - Assign permissions for a collection of GPIO lines to a user,
1851828546e2SGeert Uytterhoeven	    - Export a collection of GPIO lines to a virtual machine,
1852828546e2SGeert Uytterhoeven	    - Provide a generic driver for a GPIO-operated device in an
1853828546e2SGeert Uytterhoeven	      industrial control context, to be operated from userspace using
1854828546e2SGeert Uytterhoeven	      the GPIO chardev interface.
1855828546e2SGeert Uytterhoeven
18561454a928SSascha Hauerconfig GPIO_LATCH
18571454a928SSascha Hauer	tristate "GPIO latch driver"
18581454a928SSascha Hauer	help
18591454a928SSascha Hauer	  Say yes here to enable a driver for GPIO multiplexers based on latches
18601454a928SSascha Hauer	  connected to other GPIOs.
18611454a928SSascha Hauer
18626e4484eeSBartosz Golaszewskiconfig GPIO_MOCKUP
18639790222dSBartosz Golaszewski	tristate "GPIO Testing Driver (DEPRECATED)"
18646e4484eeSBartosz Golaszewski	select IRQ_SIM
18656e4484eeSBartosz Golaszewski	help
18669790222dSBartosz Golaszewski	  This module is DEPRECATED. Please consider using gpio-sim instead.
18679790222dSBartosz Golaszewski
18686e4484eeSBartosz Golaszewski	  This enables GPIO Testing driver, which provides a way to test GPIO
18694bf24261SBartosz Golaszewski	  subsystem through sysfs (or char device) and debugfs.
18706e4484eeSBartosz Golaszewski	  User could use it through the script in
18716e4484eeSBartosz Golaszewski	  tools/testing/selftests/gpio/gpio-mockup.sh. Reference the usage in
18726e4484eeSBartosz Golaszewski	  it.
18736e4484eeSBartosz Golaszewski
18743a29355aSViresh Kumarconfig GPIO_VIRTIO
18753a29355aSViresh Kumar	tristate "VirtIO GPIO support"
18763a29355aSViresh Kumar	depends on VIRTIO
1877eff5cdd7SViresh Kumar	select GPIOLIB_IRQCHIP
18783a29355aSViresh Kumar	help
18793a29355aSViresh Kumar	  Say Y here to enable guest support for virtio-based GPIO controllers.
18803a29355aSViresh Kumar
18813a29355aSViresh Kumar	  These virtual GPIOs can be routed to real GPIOs or attached to
18823a29355aSViresh Kumar	  simulators on the host (like QEMU).
18833a29355aSViresh Kumar
1884cb8c474eSBartosz Golaszewskiconfig GPIO_SIM
1885cb8c474eSBartosz Golaszewski	tristate "GPIO Simulator Module"
1886cb8c474eSBartosz Golaszewski	select IRQ_SIM
1887cb8c474eSBartosz Golaszewski	select CONFIGFS_FS
1888cb8c474eSBartosz Golaszewski	help
1889cb8c474eSBartosz Golaszewski	  This enables the GPIO simulator - a configfs-based GPIO testing
1890cb8c474eSBartosz Golaszewski	  driver.
1891cb8c474eSBartosz Golaszewski
1892b5252196SEnrico Weigelt, metux IT consultendmenu
1893b5252196SEnrico Weigelt, metux IT consult
18947828b7bbSWolfram Sangmenu "GPIO Debugging utilities"
18957828b7bbSWolfram Sang
18967828b7bbSWolfram Sangconfig GPIO_SLOPPY_LOGIC_ANALYZER
18977828b7bbSWolfram Sang	tristate "Sloppy GPIO logic analyzer"
18987828b7bbSWolfram Sang	depends on (GPIOLIB || COMPILE_TEST) && CPUSETS && DEBUG_FS && EXPERT
18997828b7bbSWolfram Sang	help
19007828b7bbSWolfram Sang	  This option enables support for a sloppy logic analyzer using polled
19017828b7bbSWolfram Sang	  GPIOs. Use the 'tools/gpio/gpio-sloppy-logic-analyzer' script with
19027828b7bbSWolfram Sang	  this driver. The script will make it easier to use and will also
19037828b7bbSWolfram Sang	  isolate a CPU for the polling task. Note that this is a last resort
19047828b7bbSWolfram Sang	  analyzer which can be affected by latencies, non-deterministic code
19057828b7bbSWolfram Sang	  paths, or NMIs. However, for e.g. remote development, it may be useful
19067828b7bbSWolfram Sang	  to get a first view and aid further debugging.
19077828b7bbSWolfram Sang
19087828b7bbSWolfram Sang	  If this driver is built as a module it will be called
19097828b7bbSWolfram Sang	  'gpio-sloppy-logic-analyzer'.
19107828b7bbSWolfram Sang
1911*91581c4bSBartosz Golaszewskiconfig GPIO_VIRTUSER
1912*91581c4bSBartosz Golaszewski	tristate "GPIO Virtual User Testing Module"
1913*91581c4bSBartosz Golaszewski	select DEBUG_FS
1914*91581c4bSBartosz Golaszewski	select CONFIGFS_FS
1915*91581c4bSBartosz Golaszewski	select IRQ_WORK
1916*91581c4bSBartosz Golaszewski	help
1917*91581c4bSBartosz Golaszewski	  Say Y here to enable the configurable, configfs-based virtual GPIO
1918*91581c4bSBartosz Golaszewski	  consumer testing driver.
1919*91581c4bSBartosz Golaszewski
1920*91581c4bSBartosz Golaszewski	  This driver is aimed as a helper in spotting any regressions in
1921*91581c4bSBartosz Golaszewski	  hot-unplug handling in GPIOLIB.
1922*91581c4bSBartosz Golaszewski
19237828b7bbSWolfram Sangendmenu
19247828b7bbSWolfram Sang
19257444a72eSMichael Bueschendif
1926