| # | 
| # GPIO infrastructure and drivers | 
| # | 
|   | 
| menu "GPIO Support" | 
|   | 
| config DM_GPIO | 
|     bool "Enable Driver Model for GPIO drivers" | 
|     depends on DM | 
|     help | 
|       Enable driver model for GPIO access. The standard GPIO | 
|       interface (gpio_get_value(), etc.) is then implemented by | 
|       the GPIO uclass. Drivers provide methods to query the | 
|       particular GPIOs that they provide. The uclass interface | 
|       is defined in include/asm-generic/gpio.h. | 
|   | 
| config GPIO_HOG | 
|     bool "Enable GPIO hog support" | 
|     depends on DM_GPIO | 
|     default n | 
|     help | 
|       Enable gpio hog support | 
|       The GPIO chip may contain GPIO hog definitions. GPIO hogging | 
|       is a mechanism providing automatic GPIO request and config- | 
|       uration as part of the gpio-controller's driver probe function. | 
|   | 
| config GPIO_NO_UC_FLAG_SEQ_ALIAS | 
|     bool "Disable GPIO uclass sequence themselves with aliases" | 
|     depends on USING_KERNEL_DTB | 
|     default n | 
|     help | 
|       Disable GPIO uclass sequence, this is a workaround when kernel | 
|       dtb feature is enabled. Avoid gpio device probe failed when | 
|       alloc req_seq both for gpio devices from U-Boot and kernel dtb. | 
|   | 
| config ALTERA_PIO | 
|     bool "Altera PIO driver" | 
|     depends on DM_GPIO | 
|     help | 
|       Select this to enable PIO for Altera devices. Please find | 
|       details on the "Embedded Peripherals IP User Guide" of Altera. | 
|   | 
| config BCM6345_GPIO | 
|     bool "BCM6345 GPIO driver" | 
|     depends on DM_GPIO && ARCH_BMIPS | 
|     help | 
|       This driver supports the GPIO banks on BCM6345 SoCs. | 
|   | 
| config DWAPB_GPIO | 
|     bool "DWAPB GPIO driver" | 
|     depends on DM && DM_GPIO | 
|     default n | 
|     help | 
|       Support for the Designware APB GPIO driver. | 
|   | 
| config AT91_GPIO | 
|     bool "AT91 PIO GPIO driver" | 
|     depends on DM_GPIO | 
|     default n | 
|     help | 
|       Say yes here to select AT91 PIO GPIO driver. AT91 PIO | 
|       controller manages up to 32 fully programmable input/output | 
|       lines. Each I/O line may be dedicated as a general-purpose | 
|       I/O or be assigned to a function of an embedded peripheral. | 
|       The assignment to a function of an embedded peripheral is | 
|       the responsibility of AT91 Pinctrl driver. This driver is | 
|       responsible for the general-purpose I/O. | 
|   | 
| config ATMEL_PIO4 | 
|     bool "ATMEL PIO4 driver" | 
|     depends on DM_GPIO | 
|     default n | 
|     help | 
|       Say yes here to support the Atmel PIO4 driver. | 
|       The PIO4 is new version of Atmel PIO controller, which manages | 
|       up to 128 fully programmable input/output lines. Each I/O line | 
|       may be dedicated as a general purpose I/O or be assigned to | 
|       a function of an embedded peripheral. | 
|   | 
| config INTEL_BROADWELL_GPIO | 
|     bool "Intel Broadwell GPIO driver" | 
|     depends on DM | 
|     help | 
|       This driver supports Broadwell U devices which have an expanded | 
|       GPIO feature set. The difference is large enough to merit a separate | 
|       driver from the common Intel ICH6 driver. It supports a total of | 
|       95 GPIOs which can be configured from the device tree. | 
|   | 
| config INTEL_ICH6_GPIO | 
|     bool "Intel ICH6 compatible legacy GPIO driver" | 
|     depends on DM_GPIO | 
|     help | 
|       Say yes here to select Intel ICH6 compatible legacy GPIO driver. | 
|   | 
| config IMX_RGPIO2P | 
|     bool "i.MX7ULP RGPIO2P driver" | 
|     depends on DM | 
|     default n | 
|     help | 
|       This driver supports i.MX7ULP Rapid GPIO2P controller. | 
|   | 
| config LPC32XX_GPIO | 
|     bool "LPC32XX GPIO driver" | 
|     depends on DM | 
|     default n | 
|     help | 
|       Support for the LPC32XX GPIO driver. | 
|   | 
| config MSM_GPIO | 
|     bool "Qualcomm GPIO driver" | 
|     depends on DM_GPIO | 
|     default n | 
|     help | 
|       Support GPIO controllers on Qualcomm Snapdragon family of SoCs. | 
|       This controller have single bank (default name "soc"), every | 
|       gpio has it's own set of registers. | 
|       Only simple GPIO operations are supported (get/set, change of | 
|       direction and checking pin function). | 
|       Supported devices: | 
|       - APQ8016 | 
|       - MSM8916 | 
|   | 
| config OMAP_GPIO | 
|     bool "TI OMAP GPIO driver" | 
|     depends on ARCH_OMAP2PLUS | 
|     default y | 
|     help | 
|       Support GPIO controllers on the TI OMAP3/4/5 and related (such as | 
|       AM335x/AM43xx/AM57xx/DRA7xx/etc) families of SoCs. | 
|   | 
| config CMD_PCA953X | 
|     bool "Enable the pca953x command" | 
|     help | 
|       Deprecated: This should be converted to driver model. | 
|   | 
|       This command provides access to a pca953x GPIO device using the | 
|       legacy GPIO interface. Several subcommands are provided which mirror | 
|       the standard 'gpio' command. It should use that instead. | 
|   | 
| config PM8916_GPIO | 
|     bool "Qualcomm PM8916 PMIC GPIO/keypad driver" | 
|     depends on DM_GPIO && PMIC_PM8916 | 
|     help | 
|       Support for GPIO pins and power/reset buttons found on | 
|       Qualcomm PM8916 PMIC. | 
|       Default name for GPIO bank is "pm8916". | 
|       Power and reset buttons are placed in "pm8916_key" bank and | 
|           have gpio numbers 0 and 1 respectively. | 
|   | 
| config PCF8575_GPIO | 
|     bool "PCF8575 I2C GPIO Expander driver" | 
|     depends on DM_GPIO && DM_I2C | 
|     help | 
|      Support for PCF8575 I2C 16-bit GPIO expander. Most of these | 
|      chips are from NXP and TI. | 
|   | 
| config ROCKCHIP_GPIO | 
|     bool "Rockchip GPIO driver" | 
|     depends on DM_GPIO | 
|     help | 
|       Support GPIO access on Rockchip SoCs. The GPIOs are arranged into | 
|       a number of banks (different for each SoC type) each with 32 GPIOs. | 
|       The GPIOs for a device are defined in the device tree with one node | 
|       for each bank. | 
|   | 
| config ROCKCHIP_GPIO_V2 | 
|     bool "Rockchip GPIO driver version 2.0" | 
|     depends on ROCKCHIP_GPIO | 
|     default n | 
|     help | 
|       Support GPIO access on Rockchip SoCs. The GPIOs are arranged into | 
|       a number of banks (different for each SoC type) each with 32 GPIOs. | 
|       The GPIOs for a device are defined in the device tree with one node | 
|       for each bank. | 
|   | 
|       Support version 2.0 GPIO controller, which support write enable bits | 
|       for some registers, such as dr, ddr. | 
|   | 
| config SANDBOX_GPIO | 
|     bool "Enable sandbox GPIO driver" | 
|     depends on SANDBOX && DM && DM_GPIO | 
|     help | 
|       This driver supports some simulated GPIOs which can be adjusted | 
|       using 'back door' functions like sandbox_gpio_set_value(). Then the | 
|       GPIOs can be inspected through the normal get_get_value() | 
|       interface. The purpose of this is to allow GPIOs to be used as | 
|       normal in sandbox, perhaps with test code actually driving the | 
|       behaviour of those GPIOs. | 
|   | 
| config SANDBOX_GPIO_COUNT | 
|     int "Number of sandbox GPIOs" | 
|     depends on SANDBOX_GPIO | 
|     default 128 | 
|     help | 
|       The sandbox driver can support any number of GPIOs. Generally these | 
|       are specified using the device tree. But you can also have a number | 
|       of 'anonymous' GPIOs that do not belong to any device or bank. | 
|       Select a suitable value depending on your needs. | 
|   | 
| config CMD_TCA642X | 
|     bool "tca642x - Command to access tca642x state" | 
|     help | 
|       DEPRECATED - This needs conversion to driver model | 
|   | 
|       This provides a way to looking at the pin state of this device. | 
|       This mirrors the 'gpio' command and that should be used in preference | 
|       to custom code. | 
|   | 
| config TEGRA_GPIO | 
|     bool "Tegra20..210 GPIO driver" | 
|     depends on DM_GPIO | 
|     help | 
|       Support for the GPIO controller contained in NVIDIA Tegra20 through | 
|       Tegra210. | 
|   | 
| config TEGRA186_GPIO | 
|     bool "Tegra186 GPIO driver" | 
|     depends on DM_GPIO | 
|     help | 
|       Support for the GPIO controller contained in NVIDIA Tegra186. This | 
|       covers both the "main" and "AON" controller instances, even though | 
|       they have slightly different register layout. | 
|   | 
| config GPIO_UNIPHIER | 
|     bool "UniPhier GPIO" | 
|     depends on ARCH_UNIPHIER | 
|     help | 
|       Say yes here to support UniPhier GPIOs. | 
|   | 
| config VYBRID_GPIO | 
|     bool "Vybrid GPIO driver" | 
|     depends on DM | 
|     default n | 
|     help | 
|       Say yes here to support Vybrid vf610 GPIOs. | 
|   | 
| config PIC32_GPIO | 
|     bool "Microchip PIC32 GPIO driver" | 
|     depends on DM_GPIO && MACH_PIC32 | 
|     default y | 
|     help | 
|       Say yes here to support Microchip PIC32 GPIOs. | 
|   | 
| config STM32F7_GPIO | 
|     bool "ST STM32 GPIO driver" | 
|     depends on DM_GPIO && STM32 | 
|     default y | 
|     help | 
|       Device model driver support for STM32 GPIO controller. It should be | 
|       usable on many stm32 families like stm32f4 & stm32H7. | 
|       Tested on STM32F7. | 
|   | 
| config MVEBU_GPIO | 
|     bool "Marvell MVEBU GPIO driver" | 
|     depends on DM_GPIO && ARCH_MVEBU | 
|     default y | 
|     help | 
|       Say yes here to support Marvell MVEBU (Armada XP/38x) GPIOs. | 
|   | 
| config ZYNQ_GPIO | 
|     bool "Zynq GPIO driver" | 
|     depends on DM_GPIO && (ARCH_ZYNQ || ARCH_ZYNQMP) | 
|     default y | 
|     help | 
|       Supports GPIO access on Zynq SoC. | 
|   | 
| config DM_74X164 | 
|     bool "74x164 serial-in/parallel-out 8-bits shift register" | 
|     depends on DM_GPIO | 
|     help | 
|       Driver for 74x164 compatible serial-in/parallel-out 8-outputs | 
|       shift registers, such as 74lv165, 74hc595. | 
|       This driver can be used to provide access to more gpio outputs. | 
|   | 
| config DM_PCA953X | 
|     bool "PCA95[357]x, PCA9698, TCA64xx, and MAX7310 I/O ports" | 
|     depends on DM_GPIO | 
|     help | 
|       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 | 
|   | 
|       8 bits:    max7310, max7315, pca6107, pca9534, pca9538, pca9554, | 
|             pca9556, pca9557, pca9574, tca6408, xra1202 | 
|   | 
|       16 bits:    max7312, max7313, pca9535, pca9539, pca9555, pca9575, | 
|             tca6416 | 
|   | 
|       24 bits:    tca6424 | 
|   | 
|       40 bits:    pca9505, pca9698 | 
|   | 
|       Now, max 24 bits chips and PCA953X compatible chips are | 
|       supported | 
|   | 
| config MPC85XX_GPIO | 
|     bool "Freescale MPC85XX GPIO driver" | 
|     depends on DM_GPIO | 
|     help | 
|       This driver supports the built-in GPIO controller of MPC85XX CPUs. | 
|       Each GPIO bank is identified by its own entry in the device tree, | 
|       i.e. | 
|   | 
|       gpio-controller@fc00 { | 
|         #gpio-cells = <2>; | 
|         compatible = "fsl,pq3-gpio"; | 
|         reg = <0xfc00 0x100> | 
|       } | 
|   | 
|       By default, each bank is assumed to have 32 GPIOs, but the ngpios | 
|       setting is honored, so the number of GPIOs for each bank is | 
|       configurable to match the actual GPIO count of the SoC (e.g. the | 
|       32/32/23 banks of the P1022 SoC). | 
|   | 
|       Aside from the standard functions of input/output mode, and output | 
|       value setting, the open-drain feature, which can configure individual | 
|       GPIOs to work as open-drain outputs, is supported. | 
|   | 
|       The driver has been tested on MPC85XX, but it is likely that other | 
|       PowerQUICC III devices will work as well. | 
| endmenu |