2008-02-05 13:28:17 +07:00
|
|
|
#
|
2011-05-20 13:40:19 +07:00
|
|
|
# GPIO infrastructure and drivers
|
2008-02-05 13:28:17 +07:00
|
|
|
#
|
|
|
|
|
2012-04-15 16:52:54 +07:00
|
|
|
config ARCH_HAVE_CUSTOM_GPIO_H
|
|
|
|
bool
|
|
|
|
help
|
|
|
|
Selecting this config option from the architecture Kconfig allows
|
|
|
|
the architecture to provide a custom asm/gpio.h implementation
|
|
|
|
overriding the default implementations. New uses of this are
|
|
|
|
strongly discouraged.
|
|
|
|
|
2008-07-25 15:46:11 +07:00
|
|
|
config ARCH_WANT_OPTIONAL_GPIOLIB
|
2008-02-05 13:28:17 +07:00
|
|
|
bool
|
2008-07-25 15:46:11 +07:00
|
|
|
help
|
|
|
|
Select this config option from the architecture Kconfig, if
|
|
|
|
it is possible to use gpiolib on the architecture, but let the
|
|
|
|
user decide whether to actually build it or not.
|
|
|
|
Select this instead of ARCH_REQUIRE_GPIOLIB, if your architecture does
|
|
|
|
not depend on GPIOs being available, but rather let the user
|
|
|
|
decide whether he needs it or not.
|
|
|
|
|
|
|
|
config ARCH_REQUIRE_GPIOLIB
|
|
|
|
bool
|
|
|
|
select GPIOLIB
|
2008-02-05 13:28:17 +07:00
|
|
|
help
|
|
|
|
Platforms select gpiolib if they use this infrastructure
|
|
|
|
for all their GPIOs, usually starting with ones integrated
|
|
|
|
into SOC processors.
|
2008-07-25 15:46:11 +07:00
|
|
|
Selecting this from the architecture code will cause the gpiolib
|
|
|
|
code to always get built in.
|
|
|
|
|
|
|
|
|
|
|
|
menuconfig GPIOLIB
|
|
|
|
bool "GPIO Support"
|
|
|
|
depends on ARCH_WANT_OPTIONAL_GPIOLIB || ARCH_REQUIRE_GPIOLIB
|
|
|
|
help
|
|
|
|
This enables GPIO support through the generic GPIO library.
|
|
|
|
You only need to enable this, if you also want to enable
|
2011-05-20 13:40:19 +07:00
|
|
|
one or more of the GPIO drivers below.
|
2008-07-25 15:46:11 +07:00
|
|
|
|
|
|
|
If unsure, say N.
|
2008-02-05 13:28:17 +07:00
|
|
|
|
2008-07-25 15:46:11 +07:00
|
|
|
if GPIOLIB
|
2008-02-05 13:28:17 +07:00
|
|
|
|
2013-10-21 05:14:59 +07:00
|
|
|
config GPIO_DEVRES
|
|
|
|
def_bool y
|
|
|
|
depends on HAS_IOMEM
|
|
|
|
|
2012-04-08 03:31:33 +07:00
|
|
|
config OF_GPIO
|
|
|
|
def_bool y
|
2012-11-07 06:33:33 +07:00
|
|
|
depends on OF
|
2012-04-08 03:31:33 +07:00
|
|
|
|
2012-11-30 18:37:36 +07:00
|
|
|
config GPIO_ACPI
|
|
|
|
def_bool y
|
|
|
|
depends on ACPI
|
|
|
|
|
2014-03-25 16:40:18 +07:00
|
|
|
config GPIOLIB_IRQCHIP
|
2014-05-29 21:52:46 +07:00
|
|
|
select IRQ_DOMAIN
|
2014-03-25 16:40:18 +07:00
|
|
|
bool
|
|
|
|
|
2008-02-05 13:28:17 +07:00
|
|
|
config DEBUG_GPIO
|
|
|
|
bool "Debug GPIO calls"
|
|
|
|
depends on DEBUG_KERNEL
|
|
|
|
help
|
|
|
|
Say Y here to add some extra checks and diagnostics to GPIO calls.
|
2009-01-26 17:12:25 +07:00
|
|
|
These checks help ensure that GPIOs have been properly initialized
|
|
|
|
before they are used, and that sleeping calls are not made from
|
|
|
|
non-sleeping contexts. They can make bitbanged serial protocols
|
2008-02-05 13:28:17 +07:00
|
|
|
slower. The diagnostics help catch the type of setup errors
|
|
|
|
that are most common when setting up new platforms or boards.
|
|
|
|
|
gpio: sysfs interface
This adds a simple sysfs interface for GPIOs.
/sys/class/gpio
/export ... asks the kernel to export a GPIO to userspace
/unexport ... to return a GPIO to the kernel
/gpioN ... for each exported GPIO #N
/value ... always readable, writes fail for input GPIOs
/direction ... r/w as: in, out (default low); write high, low
/gpiochipN ... for each gpiochip; #N is its first GPIO
/base ... (r/o) same as N
/label ... (r/o) descriptive, not necessarily unique
/ngpio ... (r/o) number of GPIOs; numbered N .. N+(ngpio - 1)
GPIOs claimed by kernel code may be exported by its owner using a new
gpio_export() call, which should be most useful for driver debugging.
Such exports may optionally be done without a "direction" attribute.
Userspace may ask to take over a GPIO by writing to a sysfs control file,
helping to cope with incomplete board support or other "one-off"
requirements that don't merit full kernel support:
echo 23 > /sys/class/gpio/export
... will gpio_request(23, "sysfs") and gpio_export(23);
use /sys/class/gpio/gpio-23/direction to (re)configure it,
when that GPIO can be used as both input and output.
echo 23 > /sys/class/gpio/unexport
... will gpio_free(23), when it was exported as above
The extra D-space footprint is a few hundred bytes, except for the sysfs
resources associated with each exported GPIO. The additional I-space
footprint is about two thirds of the current size of gpiolib (!). Since
no /dev node creation is involved, no "udev" support is needed.
Related changes:
* This adds a device pointer to "struct gpio_chip". When GPIO
providers initialize that, sysfs gpio class devices become children of
that device instead of being "virtual" devices.
* The (few) gpio_chip providers which have such a device node have
been updated.
* Some gpio_chip drivers also needed to update their module "owner"
field ... for which missing kerneldoc was added.
* Some gpio_chips don't support input GPIOs. Those GPIOs are now
flagged appropriately when the chip is registered.
Based on previous patches, and discussion both on and off LKML.
A Documentation/ABI/testing/sysfs-gpio update is ready to submit once this
merges to mainline.
[akpm@linux-foundation.org: a few maintenance build fixes]
Signed-off-by: David Brownell <dbrownell@users.sourceforge.net>
Cc: Guennadi Liakhovetski <g.liakhovetski@pengutronix.de>
Cc: Greg KH <greg@kroah.com>
Cc: Kay Sievers <kay.sievers@vrfy.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2008-07-25 15:46:07 +07:00
|
|
|
config GPIO_SYSFS
|
|
|
|
bool "/sys/class/gpio/... (sysfs interface)"
|
2013-01-17 09:53:32 +07:00
|
|
|
depends on SYSFS
|
gpio: sysfs interface
This adds a simple sysfs interface for GPIOs.
/sys/class/gpio
/export ... asks the kernel to export a GPIO to userspace
/unexport ... to return a GPIO to the kernel
/gpioN ... for each exported GPIO #N
/value ... always readable, writes fail for input GPIOs
/direction ... r/w as: in, out (default low); write high, low
/gpiochipN ... for each gpiochip; #N is its first GPIO
/base ... (r/o) same as N
/label ... (r/o) descriptive, not necessarily unique
/ngpio ... (r/o) number of GPIOs; numbered N .. N+(ngpio - 1)
GPIOs claimed by kernel code may be exported by its owner using a new
gpio_export() call, which should be most useful for driver debugging.
Such exports may optionally be done without a "direction" attribute.
Userspace may ask to take over a GPIO by writing to a sysfs control file,
helping to cope with incomplete board support or other "one-off"
requirements that don't merit full kernel support:
echo 23 > /sys/class/gpio/export
... will gpio_request(23, "sysfs") and gpio_export(23);
use /sys/class/gpio/gpio-23/direction to (re)configure it,
when that GPIO can be used as both input and output.
echo 23 > /sys/class/gpio/unexport
... will gpio_free(23), when it was exported as above
The extra D-space footprint is a few hundred bytes, except for the sysfs
resources associated with each exported GPIO. The additional I-space
footprint is about two thirds of the current size of gpiolib (!). Since
no /dev node creation is involved, no "udev" support is needed.
Related changes:
* This adds a device pointer to "struct gpio_chip". When GPIO
providers initialize that, sysfs gpio class devices become children of
that device instead of being "virtual" devices.
* The (few) gpio_chip providers which have such a device node have
been updated.
* Some gpio_chip drivers also needed to update their module "owner"
field ... for which missing kerneldoc was added.
* Some gpio_chips don't support input GPIOs. Those GPIOs are now
flagged appropriately when the chip is registered.
Based on previous patches, and discussion both on and off LKML.
A Documentation/ABI/testing/sysfs-gpio update is ready to submit once this
merges to mainline.
[akpm@linux-foundation.org: a few maintenance build fixes]
Signed-off-by: David Brownell <dbrownell@users.sourceforge.net>
Cc: Guennadi Liakhovetski <g.liakhovetski@pengutronix.de>
Cc: Greg KH <greg@kroah.com>
Cc: Kay Sievers <kay.sievers@vrfy.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2008-07-25 15:46:07 +07:00
|
|
|
help
|
|
|
|
Say Y here to add a sysfs interface for GPIOs.
|
|
|
|
|
|
|
|
This is mostly useful to work around omissions in a system's
|
|
|
|
kernel support. Those are common in custom and semicustom
|
|
|
|
hardware assembled using standard kernels with a minimum of
|
|
|
|
custom patches. In those cases, userspace code may import
|
|
|
|
a given GPIO from the kernel, if no kernel driver requested it.
|
|
|
|
|
|
|
|
Kernel drivers may also request that a particular GPIO be
|
|
|
|
exported to userspace; this can be useful when debugging.
|
|
|
|
|
2011-06-05 07:38:28 +07:00
|
|
|
config GPIO_GENERIC
|
|
|
|
tristate
|
|
|
|
|
2011-05-20 13:40:19 +07:00
|
|
|
# put drivers in the right section, in alphabetical order
|
2008-02-05 13:28:17 +07:00
|
|
|
|
2011-07-06 17:32:13 +07:00
|
|
|
config GPIO_DA9052
|
|
|
|
tristate "Dialog DA9052 GPIO"
|
2012-08-29 13:57:46 +07:00
|
|
|
depends on PMIC_DA9052
|
2011-07-06 17:32:13 +07:00
|
|
|
help
|
|
|
|
Say yes here to enable the GPIO driver for the DA9052 chip.
|
|
|
|
|
2012-09-14 20:30:16 +07:00
|
|
|
config GPIO_DA9055
|
|
|
|
tristate "Dialog Semiconductor DA9055 GPIO"
|
|
|
|
depends on MFD_DA9055
|
|
|
|
help
|
|
|
|
Say yes here to enable the GPIO driver for the DA9055 chip.
|
|
|
|
|
|
|
|
The Dialog DA9055 PMIC chip has 3 GPIO pins that can be
|
|
|
|
be controller by this driver.
|
|
|
|
|
|
|
|
If driver is built as a module it will be called gpio-da9055.
|
|
|
|
|
2010-03-06 04:44:33 +07:00
|
|
|
config GPIO_MAX730X
|
|
|
|
tristate
|
|
|
|
|
2011-05-20 13:40:19 +07:00
|
|
|
comment "Memory mapped GPIO drivers:"
|
2008-11-13 04:25:38 +07:00
|
|
|
|
2012-10-09 23:05:56 +07:00
|
|
|
config GPIO_CLPS711X
|
2013-04-26 22:47:28 +07:00
|
|
|
tristate "CLPS711X GPIO support"
|
2013-12-24 21:08:54 +07:00
|
|
|
depends on ARCH_CLPS711X || COMPILE_TEST
|
2013-04-26 22:47:28 +07:00
|
|
|
select GPIO_GENERIC
|
|
|
|
help
|
|
|
|
Say yes here to support GPIO on CLPS711X SoCs.
|
2012-10-09 23:05:56 +07:00
|
|
|
|
2013-11-21 22:34:36 +07:00
|
|
|
config GPIO_DAVINCI
|
|
|
|
bool "TI Davinci/Keystone GPIO support"
|
|
|
|
default y if ARCH_DAVINCI
|
|
|
|
depends on ARM && (ARCH_DAVINCI || ARCH_KEYSTONE)
|
|
|
|
help
|
|
|
|
Say yes here to enable GPIO support for TI Davinci/Keystone SoCs.
|
|
|
|
|
2011-06-05 07:38:28 +07:00
|
|
|
config GPIO_GENERIC_PLATFORM
|
|
|
|
tristate "Generic memory-mapped GPIO controller support (MMIO platform device)"
|
|
|
|
select GPIO_GENERIC
|
2010-10-28 05:33:15 +07:00
|
|
|
help
|
2011-06-05 07:38:28 +07:00
|
|
|
Say yes here to support basic platform_device memory-mapped GPIO controllers.
|
2010-10-28 05:33:15 +07:00
|
|
|
|
2014-02-26 06:01:01 +07:00
|
|
|
config GPIO_DWAPB
|
|
|
|
tristate "Synopsys DesignWare APB GPIO driver"
|
|
|
|
select GPIO_GENERIC
|
|
|
|
select GENERIC_IRQ_CHIP
|
2014-03-07 02:29:40 +07:00
|
|
|
depends on OF_GPIO
|
2014-02-26 06:01:01 +07:00
|
|
|
help
|
|
|
|
Say Y or M here to build support for the Synopsys DesignWare APB
|
|
|
|
GPIO block.
|
|
|
|
|
2010-03-06 04:44:39 +07:00
|
|
|
config GPIO_IT8761E
|
|
|
|
tristate "IT8761E GPIO support"
|
2012-01-12 01:03:41 +07:00
|
|
|
depends on X86 # unconditional access to IO space.
|
2010-03-06 04:44:39 +07:00
|
|
|
help
|
|
|
|
Say yes here to support GPIO functionality of IT8761E super I/O chip.
|
|
|
|
|
2012-05-17 13:22:23 +07:00
|
|
|
config GPIO_EM
|
|
|
|
tristate "Emma Mobile GPIO"
|
2013-09-02 22:44:55 +07:00
|
|
|
depends on ARM && OF_GPIO
|
2012-05-17 13:22:23 +07:00
|
|
|
help
|
|
|
|
Say yes here to support GPIO on Renesas Emma Mobile SoCs.
|
|
|
|
|
2011-06-02 00:09:19 +07:00
|
|
|
config GPIO_EP93XX
|
|
|
|
def_bool y
|
|
|
|
depends on ARCH_EP93XX
|
2011-06-09 04:35:33 +07:00
|
|
|
select GPIO_GENERIC
|
2011-06-02 00:09:19 +07:00
|
|
|
|
2014-02-25 02:54:58 +07:00
|
|
|
config GPIO_ZEVIO
|
|
|
|
bool "LSI ZEVIO SoC memory mapped GPIOs"
|
2014-03-06 09:25:36 +07:00
|
|
|
depends on ARM && OF_GPIO
|
2014-02-25 02:54:58 +07:00
|
|
|
help
|
|
|
|
Say yes here to support the GPIO controller in LSI ZEVIO SoCs.
|
|
|
|
|
2012-05-11 23:48:39 +07:00
|
|
|
config GPIO_MM_LANTIQ
|
|
|
|
bool "Lantiq Memory mapped GPIOs"
|
|
|
|
depends on LANTIQ && SOC_XWAY
|
|
|
|
help
|
|
|
|
This enables support for memory mapped GPIOs on the External Bus Unit
|
|
|
|
(EBU) found on Lantiq SoCs. The gpios are output only as they are
|
|
|
|
created by attaching a 16bit latch to the bus.
|
|
|
|
|
2013-08-30 03:56:56 +07:00
|
|
|
config GPIO_F7188X
|
|
|
|
tristate "F71882FG and F71889F GPIO support"
|
|
|
|
depends on X86
|
|
|
|
help
|
|
|
|
This option enables support for GPIOs found on Fintek Super-I/O
|
|
|
|
chips F71882FG and F71889F.
|
|
|
|
|
|
|
|
To compile this driver as a module, choose M here: the module will
|
|
|
|
be called f7188x-gpio.
|
|
|
|
|
2013-11-29 18:11:34 +07:00
|
|
|
config GPIO_MOXART
|
|
|
|
bool "MOXART GPIO support"
|
|
|
|
depends on ARCH_MOXART
|
|
|
|
help
|
|
|
|
Select this option to enable GPIO driver for
|
|
|
|
MOXA ART SoC devices.
|
|
|
|
|
2011-07-07 00:54:19 +07:00
|
|
|
config GPIO_MPC5200
|
|
|
|
def_bool y
|
|
|
|
depends on PPC_MPC52xx
|
|
|
|
|
2011-09-21 17:49:20 +07:00
|
|
|
config GPIO_MPC8XXX
|
|
|
|
bool "MPC512x/MPC8xxx GPIO support"
|
|
|
|
depends on PPC_MPC512x || PPC_MPC831x || PPC_MPC834x || PPC_MPC837x || \
|
|
|
|
FSL_SOC_BOOKE || PPC_86xx
|
|
|
|
help
|
|
|
|
Say Y here if you're going to use hardware that connects to the
|
|
|
|
MPC512x/831x/834x/837x/8572/8610 GPIOs.
|
|
|
|
|
2011-05-17 03:57:39 +07:00
|
|
|
config GPIO_MSM_V1
|
|
|
|
tristate "Qualcomm MSM GPIO v1"
|
2012-05-31 18:12:57 +07:00
|
|
|
depends on GPIOLIB && ARCH_MSM && (ARCH_MSM7X00A || ARCH_MSM7X30 || ARCH_QSD8X50)
|
2011-05-17 03:57:39 +07:00
|
|
|
help
|
|
|
|
Say yes here to support the GPIO interface on ARM v6 based
|
|
|
|
Qualcomm MSM chips. Most of the pins on the MSM can be
|
|
|
|
selected for GPIO, and are controlled by this driver.
|
|
|
|
|
2011-05-17 05:53:38 +07:00
|
|
|
config GPIO_MSM_V2
|
|
|
|
tristate "Qualcomm MSM GPIO v2"
|
2014-02-12 03:08:06 +07:00
|
|
|
depends on GPIOLIB && OF && ARCH_QCOM
|
2011-05-17 05:53:38 +07:00
|
|
|
help
|
|
|
|
Say yes here to support the GPIO interface on ARM v7 based
|
|
|
|
Qualcomm MSM chips. Most of the pins on the MSM can be
|
|
|
|
selected for GPIO, and are controlled by this driver.
|
|
|
|
|
2012-09-20 03:52:58 +07:00
|
|
|
config GPIO_MVEBU
|
|
|
|
def_bool y
|
2012-11-17 23:00:43 +07:00
|
|
|
depends on PLAT_ORION
|
2012-12-19 18:31:11 +07:00
|
|
|
depends on OF
|
2012-09-20 03:52:58 +07:00
|
|
|
select GPIO_GENERIC
|
|
|
|
select GENERIC_IRQ_CHIP
|
|
|
|
|
2011-06-05 23:07:54 +07:00
|
|
|
config GPIO_MXC
|
|
|
|
def_bool y
|
|
|
|
depends on ARCH_MXC
|
2011-06-05 07:38:28 +07:00
|
|
|
select GPIO_GENERIC
|
2011-06-07 15:25:37 +07:00
|
|
|
select GENERIC_IRQ_CHIP
|
2011-06-05 07:38:28 +07:00
|
|
|
|
|
|
|
config GPIO_MXS
|
|
|
|
def_bool y
|
|
|
|
depends on ARCH_MXS
|
2011-06-06 21:31:29 +07:00
|
|
|
select GPIO_GENERIC
|
2011-06-07 21:00:54 +07:00
|
|
|
select GENERIC_IRQ_CHIP
|
2011-06-05 23:07:54 +07:00
|
|
|
|
2013-07-30 04:29:10 +07:00
|
|
|
config GPIO_OCTEON
|
|
|
|
tristate "Cavium OCTEON GPIO"
|
|
|
|
depends on GPIOLIB && CAVIUM_OCTEON_SOC
|
|
|
|
default y
|
|
|
|
help
|
|
|
|
Say yes here to support the on-chip GPIO lines on the OCTEON
|
|
|
|
family of SOCs.
|
|
|
|
|
2014-04-06 21:58:15 +07:00
|
|
|
config GPIO_OMAP
|
2014-04-28 16:07:03 +07:00
|
|
|
bool "TI OMAP GPIO support" if COMPILE_TEST && !ARCH_OMAP2PLUS
|
2014-04-06 21:58:15 +07:00
|
|
|
default y if ARCH_OMAP
|
2014-04-28 16:07:03 +07:00
|
|
|
depends on ARM
|
|
|
|
select GENERIC_IRQ_CHIP
|
2014-04-06 21:58:16 +07:00
|
|
|
select GPIOLIB_IRQCHIP
|
2014-04-06 21:58:15 +07:00
|
|
|
help
|
|
|
|
Say yes here to enable GPIO support for TI OMAP SoCs.
|
|
|
|
|
2009-06-19 06:48:58 +07:00
|
|
|
config GPIO_PL061
|
|
|
|
bool "PrimeCell PL061 GPIO support"
|
2013-11-06 10:27:02 +07:00
|
|
|
depends on ARM_AMBA
|
2014-02-04 19:39:01 +07:00
|
|
|
select IRQ_DOMAIN
|
2014-03-25 16:42:35 +07:00
|
|
|
select GPIOLIB_IRQCHIP
|
2009-06-19 06:48:58 +07:00
|
|
|
help
|
|
|
|
Say yes here to support the PrimeCell PL061 GPIO device
|
|
|
|
|
2011-10-17 19:37:52 +07:00
|
|
|
config GPIO_PXA
|
|
|
|
bool "PXA GPIO support"
|
|
|
|
depends on ARCH_PXA || ARCH_MMP
|
|
|
|
help
|
|
|
|
Say yes here to support the PXA GPIO device
|
|
|
|
|
2013-03-13 18:32:13 +07:00
|
|
|
config GPIO_RCAR
|
|
|
|
tristate "Renesas R-Car GPIO"
|
2014-05-23 18:42:14 +07:00
|
|
|
depends on ARM && (ARCH_SHMOBILE || COMPILE_TEST)
|
2013-03-13 18:32:13 +07:00
|
|
|
help
|
|
|
|
Say yes here to support GPIO on Renesas R-Car SoCs.
|
|
|
|
|
2013-06-18 23:22:20 +07:00
|
|
|
config GPIO_SAMSUNG
|
|
|
|
bool
|
|
|
|
depends on PLAT_SAMSUNG
|
|
|
|
help
|
|
|
|
Legacy GPIO support. Use only for platforms without support for
|
|
|
|
pinctrl.
|
|
|
|
|
2013-12-05 06:56:43 +07:00
|
|
|
config GPIO_SCH311X
|
|
|
|
tristate "SMSC SCH311x SuperI/O GPIO"
|
|
|
|
help
|
|
|
|
Driver to enable the GPIOs found on SMSC SMSC SCH3112, SCH3114 and
|
|
|
|
SCH3116 "Super I/O" chipsets.
|
|
|
|
|
|
|
|
To compile this driver as a module, choose M here: the module will
|
|
|
|
be called gpio-sch311x.
|
|
|
|
|
2012-11-16 12:15:25 +07:00
|
|
|
config GPIO_SPEAR_SPICS
|
|
|
|
bool "ST SPEAr13xx SPI Chip Select as GPIO support"
|
|
|
|
depends on PLAT_SPEAR
|
|
|
|
select GENERIC_IRQ_CHIP
|
|
|
|
help
|
|
|
|
Say yes here to support ST SPEAr SPI Chip Select as GPIO device
|
|
|
|
|
2012-04-12 15:48:55 +07:00
|
|
|
config GPIO_STA2X11
|
|
|
|
bool "STA2x11/ConneXt GPIO support"
|
|
|
|
depends on MFD_STA2X11
|
|
|
|
select GENERIC_IRQ_CHIP
|
|
|
|
help
|
|
|
|
Say yes here to support the STA2x11/ConneXt GPIO device.
|
|
|
|
The GPIO module has 128 GPIO pins with alternate functions.
|
|
|
|
|
2014-03-12 00:55:14 +07:00
|
|
|
config GPIO_SYSCON
|
|
|
|
tristate "GPIO based on SYSCON"
|
|
|
|
depends on MFD_SYSCON && OF
|
|
|
|
help
|
|
|
|
Say yes here to support GPIO functionality though SYSCON driver.
|
|
|
|
|
2012-12-08 09:36:34 +07:00
|
|
|
config GPIO_TS5500
|
|
|
|
tristate "TS-5500 DIO blocks and compatibles"
|
2014-02-14 17:32:14 +07:00
|
|
|
depends on TS5500 || COMPILE_TEST
|
2012-12-08 09:36:34 +07:00
|
|
|
help
|
|
|
|
This driver supports Digital I/O exposed by pin blocks found on some
|
|
|
|
Technologic Systems platforms. It includes, but is not limited to, 3
|
|
|
|
blocks of the TS-5500: DIO1, DIO2 and the LCD port, and the TS-5600
|
|
|
|
LCD port.
|
|
|
|
|
2013-06-25 21:27:43 +07:00
|
|
|
config GPIO_TZ1090
|
|
|
|
bool "Toumaz Xenif TZ1090 GPIO support"
|
|
|
|
depends on SOC_TZ1090
|
2013-06-25 21:27:45 +07:00
|
|
|
select GENERIC_IRQ_CHIP
|
2013-06-25 21:27:43 +07:00
|
|
|
default y
|
|
|
|
help
|
|
|
|
Say yes here to support Toumaz Xenif TZ1090 GPIOs.
|
|
|
|
|
2013-06-25 21:27:44 +07:00
|
|
|
config GPIO_TZ1090_PDC
|
|
|
|
bool "Toumaz Xenif TZ1090 PDC GPIO support"
|
|
|
|
depends on SOC_TZ1090
|
|
|
|
default y
|
|
|
|
help
|
|
|
|
Say yes here to support Toumaz Xenif TZ1090 PDC GPIOs.
|
|
|
|
|
2008-11-13 04:25:38 +07:00
|
|
|
config GPIO_XILINX
|
|
|
|
bool "Xilinx GPIO support"
|
2013-06-03 19:31:20 +07:00
|
|
|
depends on PPC_OF || MICROBLAZE || ARCH_ZYNQ
|
2008-11-13 04:25:38 +07:00
|
|
|
help
|
|
|
|
Say yes here to support the Xilinx FPGA GPIO device
|
|
|
|
|
2013-12-12 16:18:41 +07:00
|
|
|
config GPIO_XTENSA
|
|
|
|
bool "Xtensa GPIO32 support"
|
|
|
|
depends on XTENSA
|
2013-12-18 14:10:29 +07:00
|
|
|
depends on HAVE_XTENSA_GPIO32
|
2013-12-12 16:18:41 +07:00
|
|
|
depends on !SMP
|
|
|
|
help
|
|
|
|
Say yes here to support the Xtensa internal GPIO32 IMPWIRE (input)
|
|
|
|
and EXPSTATE (output) ports
|
|
|
|
|
2009-06-29 09:11:05 +07:00
|
|
|
config GPIO_VR41XX
|
|
|
|
tristate "NEC VR4100 series General-purpose I/O Uint support"
|
|
|
|
depends on CPU_VR41XX
|
|
|
|
help
|
|
|
|
Say yes here to support the NEC VR4100 series General-purpose I/O Uint
|
|
|
|
|
2010-03-02 16:48:55 +07:00
|
|
|
config GPIO_SCH
|
2012-05-23 03:54:20 +07:00
|
|
|
tristate "Intel SCH/TunnelCreek/Centerton GPIO"
|
2011-05-20 13:40:17 +07:00
|
|
|
depends on PCI && X86
|
2010-03-06 00:43:06 +07:00
|
|
|
select MFD_CORE
|
2010-03-02 16:48:55 +07:00
|
|
|
select LPC_SCH
|
|
|
|
help
|
2012-05-23 03:54:20 +07:00
|
|
|
Say yes here to support GPIO interface on Intel Poulsbo SCH,
|
|
|
|
Intel Tunnel Creek processor or Intel Centerton processor.
|
2010-03-02 16:48:55 +07:00
|
|
|
The Intel SCH contains a total of 14 GPIO pins. Ten GPIOs are
|
|
|
|
powered by the core power rail and are turned off during sleep
|
|
|
|
modes (S3 and higher). The remaining four GPIOs are powered by
|
|
|
|
the Intel SCH suspend power supply. These GPIOs remain
|
|
|
|
active during S3. The suspend powered GPIOs can be used to wake the
|
|
|
|
system from the Suspend-to-RAM state.
|
2011-03-14 17:53:05 +07:00
|
|
|
The Intel Tunnel Creek processor has 5 GPIOs powered by the
|
|
|
|
core power rail and 9 from suspend power supply.
|
2012-05-23 03:54:20 +07:00
|
|
|
The Intel Centerton processor has a total of 30 GPIO pins.
|
|
|
|
Twenty-one are powered by the core power rail and 9 from the
|
|
|
|
suspend power supply.
|
2010-03-02 16:48:55 +07:00
|
|
|
|
gpio: Add support for Intel ICHx/3100/Series[56] GPIO
This driver works on many Intel chipsets, including the ICH6, ICH7,
ICH8, ICH9, ICH10, 3100, Series 5/3400 (Ibex Peak), Series 6/C200
(Cougar Point), and NM10 (Tiger Point).
Additional Intel chipsets should be easily supported if needed, eg the
ICH1-5, EP80579, etc.
Tested on QM67 (Cougar Point), QM57 (Ibex Peak), 3100 (Whitmore Lake),
and NM10 (Tiger Point).
Includes work from Jean Delvare:
- Resource leak removal during module load/unload
- GPIO API bit value enforcement
Also includes code cleanup from Guenter Roeck and Grant Likely.
Signed-off-by: Peter Tyser <ptyser@xes-inc.com>
Signed-off-by: Aaron Sierra <asierra@xes-inc.com>
Acked-by: Grant Likely <grant.likely@secretlab.ca>
Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
2012-04-18 21:48:24 +07:00
|
|
|
config GPIO_ICH
|
|
|
|
tristate "Intel ICH GPIO"
|
|
|
|
depends on PCI && X86
|
|
|
|
select MFD_CORE
|
|
|
|
select LPC_ICH
|
|
|
|
help
|
|
|
|
Say yes here to support the GPIO functionality of a number of Intel
|
|
|
|
ICH-based chipsets. Currently supported devices: ICH6, ICH7, ICH8
|
|
|
|
ICH9, ICH10, Series 5/3400 (eg Ibex Peak), Series 6/C200 (eg
|
|
|
|
Cougar Point), NM10 (Tiger Point), and 3100 (Whitmore Lake).
|
|
|
|
|
|
|
|
If unsure, say N.
|
2010-03-02 16:48:55 +07:00
|
|
|
|
2013-09-09 16:59:51 +07:00
|
|
|
config GPIO_IOP
|
|
|
|
tristate "Intel IOP GPIO"
|
|
|
|
depends on ARM && (ARCH_IOP32X || ARCH_IOP33X)
|
|
|
|
help
|
|
|
|
Say yes here to support the GPIO functionality of a number of Intel
|
|
|
|
IOP32X or IOP33X.
|
|
|
|
|
|
|
|
If unsure, say N.
|
2010-03-02 16:48:55 +07:00
|
|
|
|
2010-10-01 03:55:48 +07:00
|
|
|
config GPIO_VX855
|
|
|
|
tristate "VIA VX855/VX875 GPIO"
|
2013-08-30 14:39:53 +07:00
|
|
|
depends on PCI
|
2010-10-01 03:55:48 +07:00
|
|
|
select MFD_CORE
|
|
|
|
select MFD_VX855
|
|
|
|
help
|
|
|
|
Support access to the VX855/VX875 GPIO lines through the gpio library.
|
|
|
|
|
|
|
|
This driver provides common support for accessing the device,
|
|
|
|
additional drivers must be enabled in order to use the
|
|
|
|
functionality of the device.
|
|
|
|
|
2012-03-13 00:12:58 +07:00
|
|
|
config GPIO_GE_FPGA
|
|
|
|
bool "GE FPGA based GPIO"
|
|
|
|
depends on GE_FPGA
|
|
|
|
help
|
|
|
|
Support for common GPIO functionality provided on some GE Single Board
|
|
|
|
Computers.
|
|
|
|
|
|
|
|
This driver provides basic support (configure as input or output, read
|
|
|
|
and write pin state) for GPIO implemented in a number of GE single
|
|
|
|
board computers.
|
|
|
|
|
2012-12-12 22:42:38 +07:00
|
|
|
config GPIO_LYNXPOINT
|
2013-11-27 21:46:06 +07:00
|
|
|
tristate "Intel Lynxpoint GPIO support"
|
2013-03-08 19:38:12 +07:00
|
|
|
depends on ACPI && X86
|
2012-12-12 22:42:38 +07:00
|
|
|
select IRQ_DOMAIN
|
|
|
|
help
|
|
|
|
driver for GPIO functionality on Intel Lynxpoint PCH chipset
|
|
|
|
Requires ACPI device enumeration code to set up a platform device.
|
|
|
|
|
2013-04-17 19:36:50 +07:00
|
|
|
config GPIO_GRGPIO
|
|
|
|
tristate "Aeroflex Gaisler GRGPIO support"
|
|
|
|
depends on OF
|
|
|
|
select GPIO_GENERIC
|
|
|
|
select IRQ_DOMAIN
|
|
|
|
help
|
|
|
|
Select this to support Aeroflex Gaisler GRGPIO cores from the GRLIB
|
|
|
|
VHDL IP core library.
|
|
|
|
|
2013-10-08 19:25:22 +07:00
|
|
|
config GPIO_TB10X
|
|
|
|
bool
|
2014-02-04 17:59:41 +07:00
|
|
|
select GENERIC_IRQ_CHIP
|
2013-10-08 19:25:22 +07:00
|
|
|
select OF_GPIO
|
|
|
|
|
2008-02-05 13:28:17 +07:00
|
|
|
comment "I2C GPIO expanders:"
|
|
|
|
|
2012-06-23 19:29:25 +07:00
|
|
|
config GPIO_ARIZONA
|
|
|
|
tristate "Wolfson Microelectronics Arizona class devices"
|
|
|
|
depends on MFD_ARIZONA
|
|
|
|
help
|
|
|
|
Support for GPIOs on Wolfson Arizona class devices.
|
|
|
|
|
gpio: add LP3943 I2C GPIO expander driver
This is one of LP3943 MFD driver.
LP3943 is configurable as a GPIO expander, up to 16 GPIOs.
* Application note: how to configure LP3943 as a GPIO expander
http://www.ti.com/lit/an/snva287a/snva287a.pdf
* Supported GPIO controller operations
request, free, direction_input, direction_output, get and set
* GPIO direction register not supported
LP3943 doesn't have the GPIO direction register. It only provides input and
output status registers.
So, private data for the direction should be handled manually.
This variable is updated whenever the direction is changed and
used in 'get' operation.
* Pin assignment
A driver data, 'pin_used' is checked when a GPIO is requested.
If the GPIO is already assigned, then returns as failure.
If the GPIO is available, 'pin_used' is set.
When the GPIO is not used anymore, then it is cleared.
It is defined as unsigned long type for atomic bit operation APIs,
but only LSB 16bits are used because LP3943 has 16 outputs.
Signed-off-by: Milo Kim <milo.kim@ti.com>
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
2013-12-06 09:18:42 +07:00
|
|
|
config GPIO_LP3943
|
|
|
|
tristate "TI/National Semiconductor LP3943 GPIO expander"
|
|
|
|
depends on MFD_LP3943
|
|
|
|
help
|
|
|
|
GPIO driver for LP3943 MFD.
|
|
|
|
LP3943 can be used as a GPIO expander which provides up to 16 GPIOs.
|
|
|
|
Open drain outputs are required for this usage.
|
|
|
|
|
2010-03-06 04:44:33 +07:00
|
|
|
config GPIO_MAX7300
|
|
|
|
tristate "Maxim MAX7300 GPIO expander"
|
|
|
|
depends on I2C
|
|
|
|
select GPIO_MAX730X
|
|
|
|
help
|
2013-05-19 13:25:48 +07:00
|
|
|
GPIO driver for Maxim MAX7300 I2C-based GPIO expander.
|
2010-03-06 04:44:33 +07:00
|
|
|
|
2008-07-25 15:46:14 +07:00
|
|
|
config GPIO_MAX732X
|
|
|
|
tristate "MAX7319, MAX7320-7327 I2C Port Expanders"
|
|
|
|
depends on I2C
|
|
|
|
help
|
|
|
|
Say yes here to support the MAX7319, MAX7320-7327 series of I2C
|
|
|
|
Port Expanders. Each IO port on these chips has a fixed role of
|
|
|
|
Input (designated by 'I'), Push-Pull Output ('O'), or Open-Drain
|
|
|
|
Input and Output (designed by 'P'). The combinations are listed
|
|
|
|
below:
|
|
|
|
|
|
|
|
8 bits: max7319 (8I), max7320 (8O), max7321 (8P),
|
|
|
|
max7322 (4I4O), max7323 (4P4O)
|
|
|
|
|
|
|
|
16 bits: max7324 (8I8O), max7325 (8P8O),
|
|
|
|
max7326 (4I12O), max7327 (4P12O)
|
|
|
|
|
|
|
|
Board setup code must specify the model to use, and the start
|
|
|
|
number for these GPIOs.
|
|
|
|
|
2010-05-27 04:42:16 +07:00
|
|
|
config GPIO_MAX732X_IRQ
|
|
|
|
bool "Interrupt controller support for MAX732x"
|
2013-08-30 14:39:53 +07:00
|
|
|
depends on GPIO_MAX732X=y
|
2010-05-27 04:42:16 +07:00
|
|
|
help
|
|
|
|
Say yes here to enable the max732x to be used as an interrupt
|
|
|
|
controller. It requires the driver to be built in the kernel.
|
|
|
|
|
2012-01-30 13:31:20 +07:00
|
|
|
config GPIO_MC9S08DZ60
|
|
|
|
bool "MX35 3DS BOARD MC9S08DZ60 GPIO functions"
|
2012-08-29 08:35:24 +07:00
|
|
|
depends on I2C=y && MACH_MX35_3DS
|
2012-01-30 13:31:20 +07:00
|
|
|
help
|
|
|
|
Select this to enable the MC9S08DZ60 GPIO driver
|
|
|
|
|
2008-02-06 16:39:03 +07:00
|
|
|
config GPIO_PCA953X
|
2014-02-13 19:59:23 +07:00
|
|
|
tristate "PCA95[357]x, PCA9698, TCA64xx, and MAX7310 I/O ports"
|
2008-02-05 13:28:26 +07:00
|
|
|
depends on I2C
|
|
|
|
help
|
2008-07-04 23:59:37 +07:00
|
|
|
Say yes here to provide access to several register-oriented
|
|
|
|
SMBus I/O expanders, made mostly by NXP or TI. Compatible
|
|
|
|
models include:
|
|
|
|
|
|
|
|
4 bits: pca9536, pca9537
|
|
|
|
|
2012-04-06 16:11:46 +07:00
|
|
|
8 bits: max7310, max7315, pca6107, pca9534, pca9538, pca9554,
|
2014-02-08 05:36:21 +07:00
|
|
|
pca9556, pca9557, pca9574, tca6408, xra1202
|
2008-07-04 23:59:37 +07:00
|
|
|
|
2012-04-06 16:11:46 +07:00
|
|
|
16 bits: max7312, max7313, pca9535, pca9539, pca9555, pca9575,
|
|
|
|
tca6416
|
2008-02-05 13:28:26 +07:00
|
|
|
|
2014-02-08 05:35:48 +07:00
|
|
|
24 bits: tca6424
|
|
|
|
|
2014-02-13 19:59:23 +07:00
|
|
|
40 bits: pca9505, pca9698
|
2014-02-08 05:35:48 +07:00
|
|
|
|
2010-03-06 04:44:36 +07:00
|
|
|
config GPIO_PCA953X_IRQ
|
|
|
|
bool "Interrupt controller support for PCA953x"
|
|
|
|
depends on GPIO_PCA953X=y
|
2014-05-09 18:27:57 +07:00
|
|
|
select GPIOLIB_IRQCHIP
|
2010-03-06 04:44:36 +07:00
|
|
|
help
|
|
|
|
Say yes here to enable the pca953x to be used as an interrupt
|
|
|
|
controller. It requires the driver to be built in the kernel.
|
|
|
|
|
2008-02-05 13:28:24 +07:00
|
|
|
config GPIO_PCF857X
|
2008-07-22 04:21:34 +07:00
|
|
|
tristate "PCF857x, PCA{85,96}7x, and MAX732[89] I2C GPIO expanders"
|
2008-02-05 13:28:24 +07:00
|
|
|
depends on I2C
|
2012-09-29 04:36:15 +07:00
|
|
|
select IRQ_DOMAIN
|
2008-02-05 13:28:24 +07:00
|
|
|
help
|
|
|
|
Say yes here to provide access to most "quasi-bidirectional" I2C
|
|
|
|
GPIO expanders used for additional digital outputs or inputs.
|
|
|
|
Most of these parts are from NXP, though TI is a second source for
|
|
|
|
some of them. Compatible models include:
|
|
|
|
|
|
|
|
8 bits: pcf8574, pcf8574a, pca8574, pca8574a,
|
2008-07-22 04:21:34 +07:00
|
|
|
pca9670, pca9672, pca9674, pca9674a,
|
|
|
|
max7328, max7329
|
2008-02-05 13:28:24 +07:00
|
|
|
|
|
|
|
16 bits: pcf8575, pcf8575c, pca8575,
|
|
|
|
pca9671, pca9673, pca9675
|
|
|
|
|
|
|
|
Your board setup code will need to declare the expanders in
|
|
|
|
use, and assign numbers to the GPIOs they expose. Those GPIOs
|
|
|
|
can then be used from drivers and other kernel code, just like
|
|
|
|
other GPIOs, but only accessible from task contexts.
|
|
|
|
|
|
|
|
This driver provides an in-kernel interface to those GPIOs using
|
|
|
|
platform-neutral GPIO calls.
|
|
|
|
|
2012-05-14 14:16:12 +07:00
|
|
|
config GPIO_RC5T583
|
|
|
|
bool "RICOH RC5T583 GPIO"
|
|
|
|
depends on MFD_RC5T583
|
|
|
|
help
|
|
|
|
Select this option to enable GPIO driver for the Ricoh RC5T583
|
|
|
|
chip family.
|
|
|
|
This driver provides the support for driving/reading the gpio pins
|
|
|
|
of RC5T583 device through standard gpio library.
|
|
|
|
|
2010-08-11 08:02:27 +07:00
|
|
|
config GPIO_SX150X
|
|
|
|
bool "Semtech SX150x I2C GPIO expander"
|
|
|
|
depends on I2C=y
|
|
|
|
default n
|
|
|
|
help
|
|
|
|
Say yes here to provide support for Semtech SX150-series I2C
|
|
|
|
GPIO expanders. Compatible models include:
|
|
|
|
|
|
|
|
8 bits: sx1508q
|
|
|
|
16 bits: sx1509q
|
|
|
|
|
2010-07-02 18:22:09 +07:00
|
|
|
config GPIO_STMPE
|
|
|
|
bool "STMPE GPIOs"
|
|
|
|
depends on MFD_STMPE
|
|
|
|
help
|
|
|
|
This enables support for the GPIOs found on the STMPE I/O
|
|
|
|
Expanders.
|
|
|
|
|
2012-05-11 23:48:39 +07:00
|
|
|
config GPIO_STP_XWAY
|
|
|
|
bool "XWAY STP GPIOs"
|
|
|
|
depends on SOC_XWAY
|
|
|
|
help
|
|
|
|
This enables support for the Serial To Parallel (STP) unit found on
|
|
|
|
XWAY SoC. The STP allows the SoC to drive a shift registers cascade,
|
|
|
|
that can be up to 24 bit. This peripheral is aimed at driving leds.
|
|
|
|
Some of the gpios/leds can be auto updated by the soc with dsl and
|
|
|
|
phy status.
|
|
|
|
|
2010-12-13 11:03:13 +07:00
|
|
|
config GPIO_TC3589X
|
|
|
|
bool "TC3589X GPIOs"
|
|
|
|
depends on MFD_TC3589X
|
2014-04-09 18:38:33 +07:00
|
|
|
select GPIOLIB_IRQCHIP
|
2010-05-11 04:43:47 +07:00
|
|
|
help
|
2010-12-13 11:03:13 +07:00
|
|
|
This enables support for the GPIOs found on the TC3589X
|
2010-05-11 04:43:47 +07:00
|
|
|
I/O Expander.
|
|
|
|
|
2011-06-10 02:50:19 +07:00
|
|
|
config GPIO_TPS65912
|
|
|
|
tristate "TI TPS65912 GPIO"
|
|
|
|
depends on (MFD_TPS65912_I2C || MFD_TPS65912_SPI)
|
|
|
|
help
|
|
|
|
This driver supports TPS65912 gpio chip
|
|
|
|
|
2008-10-21 04:51:46 +07:00
|
|
|
config GPIO_TWL4030
|
|
|
|
tristate "TWL4030, TWL5030, and TPS659x0 GPIOs"
|
|
|
|
depends on TWL4030_CORE
|
|
|
|
help
|
|
|
|
Say yes here to access the GPIO signals of various multi-function
|
|
|
|
power management chips from Texas Instruments.
|
|
|
|
|
2012-08-16 19:13:15 +07:00
|
|
|
config GPIO_TWL6040
|
|
|
|
tristate "TWL6040 GPO"
|
|
|
|
depends on TWL6040_CORE
|
|
|
|
help
|
|
|
|
Say yes here to access the GPO signals of twl6040
|
|
|
|
audio chip from Texas Instruments.
|
|
|
|
|
2009-07-27 20:46:00 +07:00
|
|
|
config GPIO_WM831X
|
|
|
|
tristate "WM831x GPIOs"
|
|
|
|
depends on MFD_WM831X
|
|
|
|
help
|
|
|
|
Say yes here to access the GPIO signals of WM831x power management
|
|
|
|
chips from Wolfson Microelectronics.
|
|
|
|
|
2010-01-07 23:10:08 +07:00
|
|
|
config GPIO_WM8350
|
|
|
|
tristate "WM8350 GPIOs"
|
|
|
|
depends on MFD_WM8350
|
|
|
|
help
|
|
|
|
Say yes here to access the GPIO signals of WM8350 power management
|
|
|
|
chips from Wolfson Microelectronics.
|
|
|
|
|
2010-01-30 01:20:30 +07:00
|
|
|
config GPIO_WM8994
|
|
|
|
tristate "WM8994 GPIOs"
|
|
|
|
depends on MFD_WM8994
|
|
|
|
help
|
|
|
|
Say yes here to access the GPIO signals of WM8994 audio hub
|
|
|
|
CODECs from Wolfson Microelectronics.
|
|
|
|
|
2009-09-23 06:46:39 +07:00
|
|
|
config GPIO_ADP5520
|
|
|
|
tristate "GPIO Support for ADP5520 PMIC"
|
|
|
|
depends on PMIC_ADP5520
|
|
|
|
help
|
|
|
|
This option enables support for on-chip GPIO found
|
|
|
|
on Analog Devices ADP5520 PMICs.
|
|
|
|
|
2010-01-09 05:43:08 +07:00
|
|
|
config GPIO_ADP5588
|
|
|
|
tristate "ADP5588 I2C GPIO expander"
|
|
|
|
depends on I2C
|
|
|
|
help
|
|
|
|
This option enables support for 18 GPIOs found
|
|
|
|
on Analog Devices ADP5588 GPIO Expanders.
|
|
|
|
|
2010-10-28 05:33:19 +07:00
|
|
|
config GPIO_ADP5588_IRQ
|
|
|
|
bool "Interrupt controller support for ADP5588"
|
|
|
|
depends on GPIO_ADP5588=y
|
|
|
|
help
|
|
|
|
Say yes here to enable the adp5588 to be used as an interrupt
|
|
|
|
controller. It requires the driver to be built in the kernel.
|
|
|
|
|
2012-09-18 15:57:10 +07:00
|
|
|
config GPIO_ADNP
|
|
|
|
tristate "Avionic Design N-bit GPIO expander"
|
2012-11-01 17:22:11 +07:00
|
|
|
depends on I2C && OF_GPIO
|
2012-09-18 15:57:10 +07:00
|
|
|
help
|
|
|
|
This option enables support for N GPIOs found on Avionic Design
|
|
|
|
I2C GPIO expanders. The register space will be extended by powers
|
2012-11-30 14:44:39 +07:00
|
|
|
of two, so the controller will need to accommodate for that. For
|
2012-09-18 15:57:10 +07:00
|
|
|
example: if a controller provides 48 pins, 6 registers will be
|
|
|
|
enough to represent all pins, but the driver will assume a
|
|
|
|
register layout for 64 pins (8 registers).
|
|
|
|
|
2008-07-25 15:46:10 +07:00
|
|
|
comment "PCI GPIO expanders:"
|
|
|
|
|
2009-12-15 09:00:32 +07:00
|
|
|
config GPIO_CS5535
|
|
|
|
tristate "AMD CS5535/CS5536 GPIO support"
|
2014-03-08 04:11:37 +07:00
|
|
|
depends on MFD_CS5535
|
2009-12-15 09:00:32 +07:00
|
|
|
help
|
|
|
|
The AMD CS5535 and CS5536 southbridges support 28 GPIO pins that
|
|
|
|
can be used for quite a number of things. The CS5535/6 is found on
|
|
|
|
AMD Geode and Lemote Yeeloong devices.
|
|
|
|
|
|
|
|
If unsure, say N.
|
|
|
|
|
2008-07-25 15:46:10 +07:00
|
|
|
config GPIO_BT8XX
|
|
|
|
tristate "BT8XX GPIO abuser"
|
|
|
|
depends on PCI && VIDEO_BT848=n
|
|
|
|
help
|
2014-03-11 17:23:44 +07:00
|
|
|
The BT8xx frame grabber chip has 24 GPIO pins that can be abused
|
2008-07-25 15:46:10 +07:00
|
|
|
as a cheap PCI GPIO card.
|
|
|
|
|
|
|
|
This chip can be found on Miro, Hauppauge and STB TV-cards.
|
|
|
|
|
|
|
|
The card needs to be physically altered for using it as a
|
|
|
|
GPIO card. For more information on how to build a GPIO card
|
|
|
|
from a BT8xx TV card, see the documentation file at
|
|
|
|
Documentation/bt8xxgpio.txt
|
|
|
|
|
|
|
|
If unsure, say N.
|
|
|
|
|
2012-06-01 20:36:31 +07:00
|
|
|
config GPIO_AMD8111
|
|
|
|
tristate "AMD 8111 GPIO driver"
|
|
|
|
depends on PCI
|
|
|
|
help
|
|
|
|
The AMD 8111 south bridge contains 32 GPIO pins which can be used.
|
|
|
|
|
|
|
|
Note, that usually system firmware/ACPI handles GPIO pins on their
|
|
|
|
own and users might easily break their systems with uncarefull usage
|
|
|
|
of this driver!
|
|
|
|
|
|
|
|
If unsure, say N
|
|
|
|
|
2013-10-05 03:01:41 +07:00
|
|
|
config GPIO_INTEL_MID
|
|
|
|
bool "Intel Mid GPIO support"
|
2011-03-18 02:32:46 +07:00
|
|
|
depends on PCI && X86
|
2014-05-29 21:52:46 +07:00
|
|
|
select GPIOLIB_IRQCHIP
|
2009-09-23 06:46:36 +07:00
|
|
|
help
|
2013-10-05 03:01:41 +07:00
|
|
|
Say Y here to support Intel Mid GPIO.
|
2009-09-23 06:46:36 +07:00
|
|
|
|
2010-10-28 05:33:21 +07:00
|
|
|
config GPIO_PCH
|
2011-10-28 07:23:32 +07:00
|
|
|
tristate "Intel EG20T PCH/LAPIS Semiconductor IOH(ML7223/ML7831) GPIO"
|
2014-05-16 16:59:14 +07:00
|
|
|
depends on PCI && (X86_32 || COMPILE_TEST)
|
2011-07-21 07:19:59 +07:00
|
|
|
select GENERIC_IRQ_CHIP
|
2010-10-28 05:33:21 +07:00
|
|
|
help
|
|
|
|
This driver is for PCH(Platform controller Hub) GPIO of Intel Topcliff
|
|
|
|
which is an IOH(Input/Output Hub) for x86 embedded processor.
|
|
|
|
This driver can access PCH GPIO device.
|
|
|
|
|
2011-10-28 07:23:32 +07:00
|
|
|
This driver also can be used for LAPIS Semiconductor IOH(Input/
|
|
|
|
Output Hub), ML7223 and ML7831.
|
2011-05-09 17:58:49 +07:00
|
|
|
ML7223 IOH is for MP(Media Phone) use.
|
2011-10-28 07:23:32 +07:00
|
|
|
ML7831 IOH is for general purpose use.
|
|
|
|
ML7223/ML7831 is companion chip for Intel Atom E6xx series.
|
|
|
|
ML7223/ML7831 is completely compatible for Intel EG20T PCH.
|
2011-05-09 17:58:49 +07:00
|
|
|
|
2011-01-13 08:00:22 +07:00
|
|
|
config GPIO_ML_IOH
|
|
|
|
tristate "OKI SEMICONDUCTOR ML7213 IOH GPIO support"
|
|
|
|
depends on PCI
|
2011-08-05 11:04:21 +07:00
|
|
|
select GENERIC_IRQ_CHIP
|
2011-01-13 08:00:22 +07:00
|
|
|
help
|
|
|
|
ML7213 is companion chip for Intel Atom E6xx series.
|
|
|
|
This driver can be used for OKI SEMICONDUCTOR ML7213 IOH(Input/Output
|
|
|
|
Hub) which is for IVI(In-Vehicle Infotainment) use.
|
|
|
|
This driver can access the IOH's GPIO device.
|
|
|
|
|
2011-06-27 14:26:23 +07:00
|
|
|
config GPIO_SODAVILLE
|
|
|
|
bool "Intel Sodaville GPIO support"
|
2012-03-29 03:55:04 +07:00
|
|
|
depends on X86 && PCI && OF
|
2011-06-27 14:26:23 +07:00
|
|
|
select GPIO_GENERIC
|
|
|
|
select GENERIC_IRQ_CHIP
|
|
|
|
help
|
|
|
|
Say Y here to support Intel Sodaville GPIO.
|
|
|
|
|
2009-12-16 07:46:18 +07:00
|
|
|
config GPIO_TIMBERDALE
|
|
|
|
bool "Support for timberdale GPIO IP"
|
2014-04-03 16:33:31 +07:00
|
|
|
depends on MFD_TIMBERDALE
|
2009-12-16 07:46:18 +07:00
|
|
|
---help---
|
|
|
|
Add support for the GPIO IP in the timberdale FPGA.
|
|
|
|
|
2010-03-21 07:06:09 +07:00
|
|
|
config GPIO_RDC321X
|
|
|
|
tristate "RDC R-321x GPIO support"
|
2013-08-30 14:39:53 +07:00
|
|
|
depends on PCI
|
2010-05-12 03:24:20 +07:00
|
|
|
select MFD_CORE
|
2010-03-21 07:06:09 +07:00
|
|
|
select MFD_RDC321X
|
|
|
|
help
|
|
|
|
Support for the RDC R321x SoC GPIOs over southbridge
|
|
|
|
PCI configuration space.
|
|
|
|
|
2008-02-05 13:28:17 +07:00
|
|
|
comment "SPI GPIO expanders:"
|
|
|
|
|
2008-07-22 04:21:34 +07:00
|
|
|
config GPIO_MAX7301
|
|
|
|
tristate "Maxim MAX7301 GPIO expander"
|
|
|
|
depends on SPI_MASTER
|
2010-03-06 04:44:33 +07:00
|
|
|
select GPIO_MAX730X
|
2008-07-22 04:21:34 +07:00
|
|
|
help
|
2010-03-06 04:44:33 +07:00
|
|
|
GPIO driver for Maxim MAX7301 SPI-based GPIO expander.
|
2008-07-22 04:21:34 +07:00
|
|
|
|
2008-02-05 13:28:25 +07:00
|
|
|
config GPIO_MCP23S08
|
mcp23s08: add i2c support
Add i2c bindings for the mcp230xx devices. This is quite a lot simpler
than the spi one as there's no funky sub addressing done (one struct
i2c_client per struct gpio_chip).
The mcp23s08_platform_data structure is reused for i2c, even though
only a single mcp23s08_chip_info structure is needed.
To use, simply fill out a platform_data structure and pass it in
i2c_board_info, E.G.:
static const struct mcp23s08_platform_data mcp23017_data = {
.chip[0] = {
.pullups = 0x00ff,
},
.base = 240,
};
static struct i2c_board_info __initdata i2c_devs[] = {
{ I2C_BOARD_INFO("mcp23017", 0x20),
.platform_data = &smartview_mcp23017_data, },
...
};
Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk>
Signed-off-by: Grant Likely <grant.likely@secretlab.ca>
2011-07-15 15:25:32 +07:00
|
|
|
tristate "Microchip MCP23xxx I/O expander"
|
GPIO tree bulk changes for v3.14
A big set this merge window, as we have much going on in
this subsystem. Major changes this time:
- Some core improvements and cleanups to the new GPIO
descriptor API. This seems to be working now so we can
start the exodus to this API, moving gradually away from
the global GPIO numberspace.
- Incremental improvements to the ACPI GPIO core, and move
the few GPIO ACPI clients we have to the GPIO descriptor
API right *now* before we go any further. We actually
managed to contain this *before* we started to litter
the kernel with yet another hackish global numberspace for
the ACPI GPIOs, which is a big win.
- The RFkill GPIO driver and all platforms using it have
been migrated to use the GPIO descriptors rather than
fixed number assignments. Tegra machine has been migrated
as part of this.
- New drivers for MOXA ART, Xtensa GPIO32 and SMSC SCH311x.
Those should be really good examples of how I expect a
nice GPIO driver to look these days.
- Do away with custom GPIO implementations on a major
part of the ARM machines: ks8695, lpc32xx, mv78xx0.
Make a first step towards the same in the horribly
convoluted Samsung S3C include forest. We expect to
continue to clean this up as we move forward.
- Flag GPIO lines used for IRQ on adnp, bcm-kona, em,
intel-mid and lynxpoint.
This makes the GPIOlib core aware that a certain GPIO line
is used for IRQs and can then enforce some semantics such
as disallowing a GPIO line marked as in use for IRQ to be
switched to output mode.
- Drop all use of irq_set_chip_and_handler_name().
The name provided in these cases were just unhelpful
tags like "mux" or "demux".
- Extend the MCP23s08 driver to handle interrupts.
- Minor incremental improvements for rcar, lynxpoint, em
74x164 and msm drivers.
- Some non-urgent bug fixes here and there, duplicate
#includes and that usual kind of cleanups.
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1
iQIcBAABAgAGBQJS3i/MAAoJEEEQszewGV1zVB8P/Rjzgx8To0gQPn49M4u/A1Mk
mAzpUoKa05ILTKBm/bpWPYZPpg9PDqUxOYPsIDEAkc70BKMPTXxrYiE+LSfIzwaJ
a8IRwOzNL7Iwc+zPNS/GrmRJyxymb4lmMD/fypk/YaumZ6j4Hbo+9R8Zct9gbZ5Q
ZbKtz6kLhbkbNCc71bVMgk6yacSBx1ak8Xpd12HlW85NgOCoBj7/DI1Lb61x1ImY
NYpSpmtfGGTkQLtBl5dTLefZOvL1dKSct9TMOsA2jzNqf3zA1YA6XOxPGHK/qtjq
3s9cN1sIVF/g7sm1+qoKXe0OTQrXHT7SX8BH9/tb3MiKO8ItactlQUJlYNR3WFSN
zm1PNe5zWr+GWzV0iUrqoMN4XX8nThiFDOxZpOwBTZcUD6qtDFIZp41M3qxwFTbJ
hCtSQ8gUO1Ce+xtOQYYOwEkRS7FZa1Z+p/lendTFuGDh6DcXy97SrKkTktM4Q98B
LhqrwUzCdES0ecNDi2+P5y4Fc7M0cMMn9SnFvbSBObLB89TF9uzMIn8jUBCZMvrM
eAeZlRBYk8F+6F12higaWqZyiBKIEubXo/Z8T0L2KEDm/z/ddJvhQgBKvWlf3rqi
RToD446rda+RhFBnxLZ3mTui5nZ2WyKTOqhVqeBuriJhE/cTUaQHUBUrbOwx20kE
Xb9mQ2n3GRk2157n1CLY
=lW2i
-----END PGP SIGNATURE-----
Merge tag 'gpio-v3.14-1' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-gpio
Pull GPIO tree bulk changes from Linus Walleij:
"A big set this merge window, as we have much going on in this
subsystem. The changes to other subsystems (notably a slew of ARM
machines as I am doing away with their custom APIs) have all been
ACKed to the extent possible.
Major changes this time:
- Some core improvements and cleanups to the new GPIO descriptor API.
This seems to be working now so we can start the exodus to this
API, moving gradually away from the global GPIO numberspace.
- Incremental improvements to the ACPI GPIO core, and move the few
GPIO ACPI clients we have to the GPIO descriptor API right *now*
before we go any further. We actually managed to contain this
*before* we started to litter the kernel with yet another hackish
global numberspace for the ACPI GPIOs, which is a big win.
- The RFkill GPIO driver and all platforms using it have been
migrated to use the GPIO descriptors rather than fixed number
assignments. Tegra machine has been migrated as part of this.
- New drivers for MOXA ART, Xtensa GPIO32 and SMSC SCH311x. Those
should be really good examples of how I expect a nice GPIO driver
to look these days.
- Do away with custom GPIO implementations on a major part of the ARM
machines: ks8695, lpc32xx, mv78xx0. Make a first step towards the
same in the horribly convoluted Samsung S3C include forest. We
expect to continue to clean this up as we move forward.
- Flag GPIO lines used for IRQ on adnp, bcm-kona, em, intel-mid and
lynxpoint.
This makes the GPIOlib core aware that a certain GPIO line is used
for IRQs and can then enforce some semantics such as disallowing a
GPIO line marked as in use for IRQ to be switched to output mode.
- Drop all use of irq_set_chip_and_handler_name(). The name provided
in these cases were just unhelpful tags like "mux" or "demux".
- Extend the MCP23s08 driver to handle interrupts.
- Minor incremental improvements for rcar, lynxpoint, em 74x164 and
msm drivers.
- Some non-urgent bug fixes here and there, duplicate #includes and
that usual kind of cleanups"
Fix up broken Kconfig file manually to make this all compile.
* tag 'gpio-v3.14-1' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-gpio: (71 commits)
gpio: mcp23s08: fix casting caused build warning
gpio: mcp23s08: depend on OF_GPIO
gpio: mcp23s08: Add irq functionality for i2c chips
ARM: S5P[v210|c100|64x0]: Fix build error
gpio: pxa: clamp gpio get value to [0,1]
ARM: s3c24xx: explicit dependency on <plat/gpio-cfg.h>
ARM: S3C[24|64]xx: move includes back under <mach/> scope
Documentation / ACPI: update to GPIO descriptor API
gpio / ACPI: get rid of acpi_gpio.h
gpio / ACPI: register to ACPI events automatically
mmc: sdhci-acpi: convert to use GPIO descriptor API
ARM: s3c24xx: fix build error
gpio: f7188x: set can_sleep attribute
gpio: samsung: Update documentation
gpio: samsung: Remove hardware.h inclusion
gpio: xtensa: depend on HAVE_XTENSA_GPIO32
gpio: clps711x: Enable driver compilation with COMPILE_TEST
gpio: clps711x: Use of_match_ptr()
net: rfkill: gpio: convert to descriptor-based GPIO interface
leds: s3c24xx: Fix build failure
...
2014-01-22 00:40:46 +07:00
|
|
|
depends on OF_GPIO
|
2013-05-19 18:11:54 +07:00
|
|
|
depends on (SPI_MASTER && !I2C) || I2C
|
2008-02-05 13:28:25 +07:00
|
|
|
help
|
mcp23s08: add i2c support
Add i2c bindings for the mcp230xx devices. This is quite a lot simpler
than the spi one as there's no funky sub addressing done (one struct
i2c_client per struct gpio_chip).
The mcp23s08_platform_data structure is reused for i2c, even though
only a single mcp23s08_chip_info structure is needed.
To use, simply fill out a platform_data structure and pass it in
i2c_board_info, E.G.:
static const struct mcp23s08_platform_data mcp23017_data = {
.chip[0] = {
.pullups = 0x00ff,
},
.base = 240,
};
static struct i2c_board_info __initdata i2c_devs[] = {
{ I2C_BOARD_INFO("mcp23017", 0x20),
.platform_data = &smartview_mcp23017_data, },
...
};
Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk>
Signed-off-by: Grant Likely <grant.likely@secretlab.ca>
2011-07-15 15:25:32 +07:00
|
|
|
SPI/I2C driver for Microchip MCP23S08/MCP23S17/MCP23008/MCP23017
|
|
|
|
I/O expanders.
|
2011-03-09 23:56:30 +07:00
|
|
|
This provides a GPIO interface supporting inputs and outputs.
|
2014-01-16 17:44:15 +07:00
|
|
|
The I2C versions of the chips can be used as interrupt-controller.
|
2008-02-05 13:28:25 +07:00
|
|
|
|
2009-09-23 06:46:34 +07:00
|
|
|
config GPIO_MC33880
|
|
|
|
tristate "Freescale MC33880 high-side/low-side switch"
|
|
|
|
depends on SPI_MASTER
|
|
|
|
help
|
|
|
|
SPI driver for Freescale MC33880 high-side/low-side switch.
|
|
|
|
This provides GPIO interface supporting inputs and outputs.
|
|
|
|
|
2010-10-28 05:33:18 +07:00
|
|
|
config GPIO_74X164
|
|
|
|
tristate "74x164 serial-in/parallel-out 8-bits shift register"
|
2013-12-07 17:08:22 +07:00
|
|
|
depends on SPI_MASTER && OF
|
2010-10-28 05:33:18 +07:00
|
|
|
help
|
2013-12-07 17:08:22 +07:00
|
|
|
Driver for 74x164 compatible serial-in/parallel-out 8-outputs
|
|
|
|
shift registers. This driver can be used to provide access
|
2010-10-28 05:33:18 +07:00
|
|
|
to more gpio outputs.
|
|
|
|
|
2009-09-23 06:46:35 +07:00
|
|
|
comment "AC97 GPIO expanders:"
|
|
|
|
|
|
|
|
config GPIO_UCB1400
|
2013-09-14 02:41:48 +07:00
|
|
|
tristate "Philips UCB1400 GPIO"
|
2009-09-23 06:46:35 +07:00
|
|
|
depends on UCB1400_CORE
|
|
|
|
help
|
|
|
|
This enables support for the Philips UCB1400 GPIO pins.
|
|
|
|
The UCB1400 is an AC97 audio codec.
|
|
|
|
|
2013-06-24 11:00:05 +07:00
|
|
|
comment "LPC GPIO expanders:"
|
|
|
|
|
|
|
|
config GPIO_KEMPLD
|
|
|
|
tristate "Kontron ETX / COMexpress GPIO"
|
|
|
|
depends on MFD_KEMPLD
|
|
|
|
help
|
|
|
|
This enables support for the PLD GPIO interface on some Kontron ETX
|
|
|
|
and COMexpress (ETXexpress) modules.
|
|
|
|
|
|
|
|
This driver can also be built as a module. If so, the module will be
|
|
|
|
called gpio-kempld.
|
|
|
|
|
2010-04-07 15:08:01 +07:00
|
|
|
comment "MODULbus GPIO expanders:"
|
|
|
|
|
|
|
|
config GPIO_JANZ_TTL
|
|
|
|
tristate "Janz VMOD-TTL Digital IO Module"
|
|
|
|
depends on MFD_JANZ_CMODIO
|
|
|
|
help
|
|
|
|
This enables support for the Janz VMOD-TTL Digital IO module.
|
|
|
|
This driver provides support for driving the pins in output
|
|
|
|
mode only. Input mode is not supported.
|
|
|
|
|
2013-01-03 17:46:59 +07:00
|
|
|
config GPIO_PALMAS
|
|
|
|
bool "TI PALMAS series PMICs GPIO"
|
|
|
|
depends on MFD_PALMAS
|
|
|
|
help
|
|
|
|
Select this option to enable GPIO driver for the TI PALMAS
|
|
|
|
series chip family.
|
|
|
|
|
2012-07-18 13:20:48 +07:00
|
|
|
config GPIO_TPS6586X
|
|
|
|
bool "TPS6586X GPIO"
|
|
|
|
depends on MFD_TPS6586X
|
|
|
|
help
|
|
|
|
Select this option to enable GPIO driver for the TPS6586X
|
|
|
|
chip family.
|
|
|
|
|
2011-05-17 06:35:37 +07:00
|
|
|
config GPIO_TPS65910
|
|
|
|
bool "TPS65910 GPIO"
|
|
|
|
depends on MFD_TPS65910
|
|
|
|
help
|
|
|
|
Select this option to enable GPIO driver for the TPS65910
|
|
|
|
chip family.
|
2012-04-24 17:02:49 +07:00
|
|
|
|
|
|
|
config GPIO_MSIC
|
|
|
|
bool "Intel MSIC mixed signal gpio support"
|
|
|
|
depends on MFD_INTEL_MSIC
|
|
|
|
help
|
|
|
|
Enable support for GPIO on intel MSIC controllers found in
|
|
|
|
intel MID devices
|
|
|
|
|
2013-09-11 01:07:01 +07:00
|
|
|
config GPIO_BCM_KONA
|
|
|
|
bool "Broadcom Kona GPIO"
|
|
|
|
depends on OF_GPIO
|
|
|
|
help
|
|
|
|
Turn on GPIO support for Broadcom "Kona" chips.
|
|
|
|
|
2012-11-05 21:48:24 +07:00
|
|
|
comment "USB GPIO expanders:"
|
|
|
|
|
|
|
|
config GPIO_VIPERBOARD
|
|
|
|
tristate "Viperboard GPIO a & b support"
|
|
|
|
depends on MFD_VIPERBOARD && USB
|
|
|
|
help
|
|
|
|
Say yes here to access the GPIO signals of Nano River
|
|
|
|
Technologies Viperboard. There are two GPIO chips on the
|
|
|
|
board: gpioa and gpiob.
|
|
|
|
See viperboard API specification and Nano
|
|
|
|
River Tech's viperboard.h for detailed meaning
|
|
|
|
of the module parameters.
|
|
|
|
|
2008-07-25 15:46:11 +07:00
|
|
|
endif
|