Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

dt-bindings: gpio: uniphier: add UniPhier GPIO binding

This GPIO controller is used on UniPhier SoC family.

The vendor specific property "socionext,interrupt-ranges" is for
specifying interrupt mapping to the parent interrupt controller
because the mapping is not contiguous. It works like "ranges",
but transforms "interrupts" instead of "reg".

Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
Acked-by: Rob Herring <robh@kernel.org>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>

authored by

Masahiro Yamada and committed by
Linus Walleij
1c59d045 2cbfca66

+71
+52
Documentation/devicetree/bindings/gpio/gpio-uniphier.txt
··· 1 + UniPhier GPIO controller 2 + 3 + Required properties: 4 + - compatible: Should be "socionext,uniphier-gpio". 5 + - reg: Specifies offset and length of the register set for the device. 6 + - gpio-controller: Marks the device node as a GPIO controller. 7 + - #gpio-cells: Should be 2. The first cell is the pin number and the second 8 + cell is used to specify optional parameters. 9 + - interrupt-parent: Specifies the parent interrupt controller. 10 + - interrupt-controller: Marks the device node as an interrupt controller. 11 + - #interrupt-cells: Should be 2. The first cell defines the interrupt number. 12 + The second cell bits[3:0] is used to specify trigger type as follows: 13 + 1 = low-to-high edge triggered 14 + 2 = high-to-low edge triggered 15 + 4 = active high level-sensitive 16 + 8 = active low level-sensitive 17 + Valid combinations are 1, 2, 3, 4, 8. 18 + - ngpios: Specifies the number of GPIO lines. 19 + - gpio-ranges: Mapping to pin controller pins (as described in gpio.txt) 20 + - socionext,interrupt-ranges: Specifies an interrupt number mapping between 21 + this GPIO controller and its interrupt parent, in the form of arbitrary 22 + number of <child-interrupt-base parent-interrupt-base length> triplets. 23 + 24 + Optional properties: 25 + - gpio-ranges-group-names: Used for named gpio ranges (as described in gpio.txt) 26 + 27 + Example: 28 + gpio: gpio@55000000 { 29 + compatible = "socionext,uniphier-gpio"; 30 + reg = <0x55000000 0x200>; 31 + interrupt-parent = <&aidet>; 32 + interrupt-controller; 33 + #interrupt-cells = <2>; 34 + gpio-controller; 35 + #gpio-cells = <2>; 36 + gpio-ranges = <&pinctrl 0 0 0>; 37 + gpio-ranges-group-names = "gpio_range"; 38 + ngpios = <248>; 39 + socionext,interrupt-ranges = <0 48 16>, <16 154 5>, <21 217 3>; 40 + }; 41 + 42 + Consumer Example: 43 + 44 + sdhci0_pwrseq { 45 + compatible = "mmc-pwrseq-emmc"; 46 + reset-gpios = <&gpio UNIPHIER_GPIO_PORT(29, 4) GPIO_ACTIVE_LOW>; 47 + }; 48 + 49 + Please note UNIPHIER_GPIO_PORT(29, 4) represents PORT294 in the SoC document. 50 + Unfortunately, only the one's place is octal in the port numbering. (That is, 51 + PORT 8, 9, 18, 19, 28, 29, ... are missing.) UNIPHIER_GPIO_PORT() is a helper 52 + macro to calculate 29 * 8 + 4.
+1
MAINTAINERS
··· 2017 2017 L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers) 2018 2018 T: git git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-uniphier.git 2019 2019 S: Maintained 2020 + F: Documentation/devicetree/bindings/gpio/gpio-uniphier.txt 2020 2021 F: arch/arm/boot/dts/uniphier* 2021 2022 F: arch/arm/include/asm/hardware/cache-uniphier.h 2022 2023 F: arch/arm/mach-uniphier/
+18
include/dt-bindings/gpio/uniphier-gpio.h
··· 1 + /* 2 + * Copyright (C) 2017 Socionext Inc. 3 + * Author: Masahiro Yamada <yamada.masahiro@socionext.com> 4 + */ 5 + 6 + #ifndef _DT_BINDINGS_GPIO_UNIPHIER_H 7 + #define _DT_BINDINGS_GPIO_UNIPHIER_H 8 + 9 + #define UNIPHIER_GPIO_LINES_PER_BANK 8 10 + 11 + #define UNIPHIER_GPIO_IRQ_OFFSET ((UNIPHIER_GPIO_LINES_PER_BANK) * 15) 12 + 13 + #define UNIPHIER_GPIO_PORT(bank, line) \ 14 + ((UNIPHIER_GPIO_LINES_PER_BANK) * (bank) + (line)) 15 + 16 + #define UNIPHIER_GPIO_IRQ(n) ((UNIPHIER_GPIO_IRQ_OFFSET) + (n)) 17 + 18 + #endif /* _DT_BINDINGS_GPIO_UNIPHIER_H */