forked from torvalds/linux
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge tag 'gpio-v4.9-1' of git://git.kernel.org/pub/scm/linux/kernel/…
…git/linusw/linux-gpio Pull GPIO updates from Linus Walleij: "This is the bulk of GPIO changes for the v4.9 series: Subsystem improvements: - do away with the last users of the obsolete Kconfig options ARCH_REQUIRE_GPIOLIB and ARCH_WANT_OPTIONAL_GPIOLIB (the latter always sounded like an item on a wishlist to Santa Claus to me). We can now select GPIOLIB and be done with it, for all archs. After some struggle it even work on UM. Not that it has GPIO, but if it wants to, it can select the library. - continued efforts to make drivers properly either tristate or bool. - introduce a warning for drivers assigning default triggers to their irqchip lines when probed from device tree, so we find and fix these ambigous drivers. It is agreed that in the OF config path, the device tree defines trigger characteristics. - the same warning, mutatis mutandis, for ACPI-probed GPIO irqchips. - we introduce the ability to mark certain IRQ lines as "unusable" as they can be taken by BIOS/firmware, unrouted in silicon and generally nasty if you use them, and such things. This is put to good use in the STMPE driver and also in the Cherryview pin control driver. - a new "mockup" virtual GPIO device that can be used for testing. The plan is to add unit tests under tools/* for exercising this device and verify that the kernel code paths are working as they should. - make memory-mapped I/O-drivers depend on HAS_IOMEM. This was implicit all the time, but when people started building UM with allyesconfig or allmodconfig it exploded in their face. - move some stray bits of device tree and ACPI HW description callbacks down into their respective implementation silo. These were causing issues when compiling on !HAS_IOMEM as well, so now eventually UM compiles the GPIOLIB library if it wants to. New drivers: - new driver for the Aspeed GPIO front-end companion to the pin controller merged through the pin control tree. - new driver for the LP873x PMIC GPIO portions. - new driver for Technologic Systems' I2C FPGA GPIO such as TS4900, TS-7970, TS-7990 and TS-4100. - new driver for the Broadcom BCM63xx series including BCM6338 and BCM6345. - new driver for the Intel WhiskeyCove PMIC GPIO. - new driver for the Allwinner AXP209 PMIC GPIO portions. - new driver for Diamond Systems 48 line GPIO-MM, another of these port-mapped I/O expansion cards. - support the STMicroelectronics STMPE1600 variant in the STMPE driver. Driver improvements: - the STMPE driver now supports rising/falling edge detection properly for IRQs. - the PCA954x will now fetch and enable its VCC regulator properly. - major rework of the PCA953x driver with the goal of eventually switching it over to use regmap and thus modernize it even more. - switch the IOP driver to use the generic MMIO GPIO library. - move the ages old HTC EGPIO (extended GPIO) GPIO expander driver over to this subsystem from MFD, achieveing some separation of concerns" * tag 'gpio-v4.9-1' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-gpio: (81 commits) gpio: add missing static inline gpio: OF: localize some gpiochip init functions gpio: acpi: separation of concerns gpio: OF: separation of concerns gpio: make memory-mapped drivers depend on HAS_IOMEM gpio: stmpe: use BIT() macro gpio: stmpe: forbid unused lines to be mapped as IRQs mfd/gpio: Move HTC GPIO driver to GPIO subsystem gpio: MAINTAINERS: Add an entry for GPIO mockup driver gpio/mockup: add virtual gpio device gpio: Added zynq specific check for special pins on bank zero gpio: axp209: Implement get_direction gpio: aspeed: remove redundant return value check gpio: loongson1: remove redundant return value check ARM: omap2: fix missing include gpio: tc3589x: fix up complaints on unsigned gpio: tc3589x: add .get_direction() and small cleanup gpio: f7188x: use gpiochip_get_data instead of container_of gpio: tps65218: use devm_gpiochip_add_data() for gpio registration gpio: aspeed: fix return value check in aspeed_gpio_probe() ...
- Loading branch information
Showing
84 changed files
with
3,459 additions
and
688 deletions.
There are no files selected for viewing
46 changes: 46 additions & 0 deletions
46
Documentation/devicetree/bindings/gpio/brcm,bcm6345-gpio.txt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
Bindings for the Broadcom's brcm,bcm6345-gpio memory-mapped GPIO controllers. | ||
|
||
These bindings can be used on any BCM63xx SoC. However, BCM6338 and BCM6345 | ||
are the only ones which don't need a pinctrl driver. | ||
BCM6338 have 8-bit data and dirout registers, where GPIO state can be read | ||
and/or written, and the direction changed from input to output. | ||
BCM6345 have 16-bit data and dirout registers, where GPIO state can be read | ||
and/or written, and the direction changed from input to output. | ||
|
||
Required properties: | ||
- compatible: should be "brcm,bcm6345-gpio" | ||
- reg-names: must contain | ||
"dat" - data register | ||
"dirout" - direction (output) register | ||
- reg: address + size pairs describing the GPIO register sets; | ||
order must correspond with the order of entries in reg-names | ||
- #gpio-cells: must be set to 2. The first cell is the pin number and | ||
the second cell is used to specify the gpio polarity: | ||
0 = active high | ||
1 = active low | ||
- gpio-controller: Marks the device node as a gpio controller. | ||
|
||
Optional properties: | ||
- native-endian: use native endian memory. | ||
|
||
Examples: | ||
- BCM6338: | ||
gpio: gpio-controller@fffe0407 { | ||
compatible = "brcm,bcm6345-gpio"; | ||
reg-names = "dirout", "dat"; | ||
reg = <0xfffe0407 1>, <0xfffe040f 1>; | ||
|
||
#gpio-cells = <2>; | ||
gpio-controller; | ||
}; | ||
|
||
- BCM6345: | ||
gpio: gpio-controller@fffe0406 { | ||
compatible = "brcm,bcm6345-gpio"; | ||
reg-names = "dirout", "dat"; | ||
reg = <0xfffe0406 2>, <0xfffe040a 2>; | ||
native-endian; | ||
|
||
#gpio-cells = <2>; | ||
gpio-controller; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
Aspeed GPIO controller Device Tree Bindings | ||
------------------------------------------- | ||
|
||
Required properties: | ||
- compatible : Either "aspeed,ast2400-gpio" or "aspeed,ast2500-gpio" | ||
|
||
- #gpio-cells : Should be two | ||
- First cell is the GPIO line number | ||
- Second cell is used to specify optional | ||
parameters (unused) | ||
|
||
- reg : Address and length of the register set for the device | ||
- gpio-controller : Marks the device node as a GPIO controller. | ||
- interrupts : Interrupt specifier (see interrupt bindings for | ||
details) | ||
- interrupt-controller : Mark the GPIO controller as an interrupt-controller | ||
|
||
Optional properties: | ||
|
||
- interrupt-parent : The parent interrupt controller, optional if inherited | ||
|
||
The gpio and interrupt properties are further described in their respective | ||
bindings documentation: | ||
|
||
- Documentation/devicetree/bindings/gpio/gpio.txt | ||
- Documentation/devicetree/bindings/interrupt-controller/interrupts.txt | ||
|
||
Example: | ||
gpio@1e780000 { | ||
#gpio-cells = <2>; | ||
compatible = "aspeed,ast2400-gpio"; | ||
gpio-controller; | ||
interrupts = <20>; | ||
reg = <0x1e780000 0x1000>; | ||
interrupt-controller; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
AXP209 GPIO controller | ||
|
||
This driver follows the usual GPIO bindings found in | ||
Documentation/devicetree/bindings/gpio/gpio.txt | ||
|
||
Required properties: | ||
- compatible: Should be "x-powers,axp209-gpio" | ||
- #gpio-cells: Should be two. The first cell is the pin number and the | ||
second is the GPIO flags. | ||
- gpio-controller: Marks the device node as a GPIO controller. | ||
|
||
This node must be a subnode of the axp20x PMIC, documented in | ||
Documentation/devicetree/bindings/mfd/axp20x.txt | ||
|
||
Example: | ||
|
||
axp209: pmic@34 { | ||
compatible = "x-powers,axp209"; | ||
reg = <0x34>; | ||
interrupt-parent = <&nmi_intc>; | ||
interrupts = <0 IRQ_TYPE_LEVEL_LOW>; | ||
interrupt-controller; | ||
#interrupt-cells = <1>; | ||
|
||
axp_gpio: gpio { | ||
compatible = "x-powers,axp209-gpio"; | ||
gpio-controller; | ||
#gpio-cells = <2>; | ||
}; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
TPIC2810 GPIO controller bindings | ||
|
||
Required properties: | ||
- compatible : Should be "ti,tpic2810". | ||
- reg : The I2C address of the device | ||
- gpio-controller : Marks the device node as a GPIO controller. | ||
- #gpio-cells : Should be two. For consumer use see gpio.txt. | ||
|
||
Example: | ||
|
||
gpio@60 { | ||
compatible = "ti,tpic2810"; | ||
reg = <0x60>; | ||
gpio-controller; | ||
#gpio-cells = <2>; | ||
}; |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
* Technologic Systems I2C-FPGA's GPIO controller bindings | ||
|
||
This bindings describes the GPIO controller for Technologic's FPGA core. | ||
TS-4900's FPGA encodes the GPIO state on 3 bits, whereas the TS-7970's FPGA | ||
uses 2 bits: it doesn't use a dedicated input bit. | ||
|
||
Required properties: | ||
- compatible: Should be one of the following | ||
"technologic,ts4900-gpio" | ||
"technologic,ts7970-gpio" | ||
- reg: Physical base address of the controller and length | ||
of memory mapped region. | ||
- #gpio-cells: Should be two. The first cell is the pin number. | ||
- gpio-controller: Marks the device node as a gpio controller. | ||
|
||
Optional property: | ||
- ngpios: Number of GPIOs this controller is instantiated with, | ||
the default is 32. See gpio.txt for more details. | ||
|
||
Example: | ||
|
||
&i2c2 { | ||
gpio8: gpio@28 { | ||
compatible = "technologic,ts4900-gpio"; | ||
reg = <0x28>; | ||
#gpio-cells = <2>; | ||
gpio-controller; | ||
ngpios = <32>; | ||
}; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -3794,6 +3794,12 @@ F: include/linux/regulator/da9211.h | |
F: include/sound/da[79]*.h | ||
F: sound/soc/codecs/da[79]*.[ch] | ||
|
||
DIAMOND SYSTEMS GPIO-MM GPIO DRIVER | ||
M: William Breathitt Gray <[email protected]> | ||
L: [email protected] | ||
S: Maintained | ||
F: drivers/gpio/gpio-gpio-mm.c | ||
|
||
DIGI NEO AND CLASSIC PCI PRODUCTS | ||
M: Lidza Louina <[email protected]> | ||
M: Mark Hounschell <[email protected]> | ||
|
@@ -5274,6 +5280,13 @@ L: [email protected] | |
S: Maintained | ||
F: drivers/input/touchscreen/goodix.c | ||
|
||
GPIO MOCKUP DRIVER | ||
M: Bamvor Jian Zhang <[email protected]> | ||
L: [email protected] | ||
S: Maintained | ||
F: drivers/gpio/gpio-mockup.c | ||
F: tools/testing/selftests/gpio/ | ||
|
||
GPIO SUBSYSTEM | ||
M: Linus Walleij <[email protected]> | ||
M: Alexandre Courbot <[email protected]> | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.