1# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
2%YAML 1.2
3---
4$id: http://devicetree.org/schemas/gpio/socionext,uniphier-gpio.yaml#
5$schema: http://devicetree.org/meta-schemas/core.yaml#
6
7title: UniPhier GPIO controller
8
9maintainers:
10  - Masahiro Yamada <yamada.masahiro@socionext.com>
11
12properties:
13  $nodename:
14    pattern: "^gpio@[0-9a-f]+$"
15
16  compatible:
17    const: socionext,uniphier-gpio
18
19  reg:
20    maxItems: 1
21
22  gpio-controller: true
23
24  "#gpio-cells":
25    const: 2
26
27  interrupt-controller: true
28
29  "#interrupt-cells":
30    description: |
31      The first cell defines the interrupt number.
32      The second cell bits[3:0] is used to specify trigger type as follows:
33        1 = low-to-high edge triggered
34        2 = high-to-low edge triggered
35        4 = active high level-sensitive
36        8 = active low level-sensitive
37      Valid combinations are 1, 2, 3, 4, 8.
38    const: 2
39
40  ngpios:
41    minimum: 0
42    maximum: 512
43
44  gpio-ranges: true
45
46  gpio-ranges-group-names: true
47
48  socionext,interrupt-ranges:
49    description: |
50      Specifies an interrupt number mapping between this GPIO controller and
51      its interrupt parent, in the form of arbitrary number of
52      <child-interrupt-base parent-interrupt-base length> triplets.
53    $ref: /schemas/types.yaml#/definitions/uint32-matrix
54
55patternProperties:
56  "^.+-hog(-[0-9]+)?$":
57    type: object
58    required:
59      - gpio-hog
60
61required:
62  - compatible
63  - reg
64  - gpio-controller
65  - "#gpio-cells"
66  - interrupt-controller
67  - "#interrupt-cells"
68  - ngpios
69  - gpio-ranges
70  - socionext,interrupt-ranges
71
72additionalProperties: false
73
74examples:
75  - |
76    #include <dt-bindings/gpio/gpio.h>
77    #include <dt-bindings/gpio/uniphier-gpio.h>
78
79    gpio: gpio@55000000 {
80        compatible = "socionext,uniphier-gpio";
81        reg = <0x55000000 0x200>;
82        interrupt-parent = <&aidet>;
83        interrupt-controller;
84        #interrupt-cells = <2>;
85        gpio-controller;
86        #gpio-cells = <2>;
87        gpio-ranges = <&pinctrl 0 0 0>;
88        gpio-ranges-group-names = "gpio_range";
89        ngpios = <248>;
90        socionext,interrupt-ranges = <0 48 16>, <16 154 5>, <21 217 3>;
91    };
92
93    // Consumer:
94    // Please note UNIPHIER_GPIO_PORT(29, 4) represents PORT294 in the SoC
95    // document. Unfortunately, only the one's place is octal in the port
96    // numbering. (That is, PORT 8, 9, 18, 19, 28, 29, ... do not exist.)
97    // UNIPHIER_GPIO_PORT() is a helper macro to calculate 29 * 8 + 4.
98    sdhci0_pwrseq {
99        compatible = "mmc-pwrseq-emmc";
100        reset-gpios = <&gpio UNIPHIER_GPIO_PORT(29, 4) GPIO_ACTIVE_LOW>;
101    };
102