162306a36Sopenharmony_ci# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
262306a36Sopenharmony_ci%YAML 1.2
362306a36Sopenharmony_ci---
462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/gpio/renesas,rcar-gpio.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Renesas R-Car General-Purpose Input/Output Ports (GPIO)
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - Geert Uytterhoeven <geert+renesas@glider.be>
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_ciproperties:
1362306a36Sopenharmony_ci  compatible:
1462306a36Sopenharmony_ci    oneOf:
1562306a36Sopenharmony_ci      - items:
1662306a36Sopenharmony_ci          - enum:
1762306a36Sopenharmony_ci              - renesas,gpio-r8a7778      # R-Car M1
1862306a36Sopenharmony_ci              - renesas,gpio-r8a7779      # R-Car H1
1962306a36Sopenharmony_ci          - const: renesas,rcar-gen1-gpio # R-Car Gen1
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_ci      - items:
2262306a36Sopenharmony_ci          - enum:
2362306a36Sopenharmony_ci              - renesas,gpio-r8a7742      # RZ/G1H
2462306a36Sopenharmony_ci              - renesas,gpio-r8a7743      # RZ/G1M
2562306a36Sopenharmony_ci              - renesas,gpio-r8a7744      # RZ/G1N
2662306a36Sopenharmony_ci              - renesas,gpio-r8a7745      # RZ/G1E
2762306a36Sopenharmony_ci              - renesas,gpio-r8a77470     # RZ/G1C
2862306a36Sopenharmony_ci              - renesas,gpio-r8a7790      # R-Car H2
2962306a36Sopenharmony_ci              - renesas,gpio-r8a7791      # R-Car M2-W
3062306a36Sopenharmony_ci              - renesas,gpio-r8a7792      # R-Car V2H
3162306a36Sopenharmony_ci              - renesas,gpio-r8a7793      # R-Car M2-N
3262306a36Sopenharmony_ci              - renesas,gpio-r8a7794      # R-Car E2
3362306a36Sopenharmony_ci          - const: renesas,rcar-gen2-gpio # R-Car Gen2 or RZ/G1
3462306a36Sopenharmony_ci
3562306a36Sopenharmony_ci      - items:
3662306a36Sopenharmony_ci          - enum:
3762306a36Sopenharmony_ci              - renesas,gpio-r8a774a1     # RZ/G2M
3862306a36Sopenharmony_ci              - renesas,gpio-r8a774b1     # RZ/G2N
3962306a36Sopenharmony_ci              - renesas,gpio-r8a774c0     # RZ/G2E
4062306a36Sopenharmony_ci              - renesas,gpio-r8a774e1     # RZ/G2H
4162306a36Sopenharmony_ci              - renesas,gpio-r8a7795      # R-Car H3
4262306a36Sopenharmony_ci              - renesas,gpio-r8a7796      # R-Car M3-W
4362306a36Sopenharmony_ci              - renesas,gpio-r8a77961     # R-Car M3-W+
4462306a36Sopenharmony_ci              - renesas,gpio-r8a77965     # R-Car M3-N
4562306a36Sopenharmony_ci              - renesas,gpio-r8a77970     # R-Car V3M
4662306a36Sopenharmony_ci              - renesas,gpio-r8a77980     # R-Car V3H
4762306a36Sopenharmony_ci              - renesas,gpio-r8a77990     # R-Car E3
4862306a36Sopenharmony_ci              - renesas,gpio-r8a77995     # R-Car D3
4962306a36Sopenharmony_ci          - const: renesas,rcar-gen3-gpio # R-Car Gen3 or RZ/G2
5062306a36Sopenharmony_ci
5162306a36Sopenharmony_ci      - items:
5262306a36Sopenharmony_ci          - enum:
5362306a36Sopenharmony_ci              - renesas,gpio-r8a779a0     # R-Car V3U
5462306a36Sopenharmony_ci              - renesas,gpio-r8a779f0     # R-Car S4-8
5562306a36Sopenharmony_ci              - renesas,gpio-r8a779g0     # R-Car V4H
5662306a36Sopenharmony_ci          - const: renesas,rcar-gen4-gpio # R-Car Gen4
5762306a36Sopenharmony_ci
5862306a36Sopenharmony_ci  reg:
5962306a36Sopenharmony_ci    maxItems: 1
6062306a36Sopenharmony_ci
6162306a36Sopenharmony_ci  interrupts:
6262306a36Sopenharmony_ci    maxItems: 1
6362306a36Sopenharmony_ci
6462306a36Sopenharmony_ci  clocks:
6562306a36Sopenharmony_ci    maxItems: 1
6662306a36Sopenharmony_ci
6762306a36Sopenharmony_ci  power-domains:
6862306a36Sopenharmony_ci    maxItems: 1
6962306a36Sopenharmony_ci
7062306a36Sopenharmony_ci  resets:
7162306a36Sopenharmony_ci    maxItems: 1
7262306a36Sopenharmony_ci
7362306a36Sopenharmony_ci  gpio-controller: true
7462306a36Sopenharmony_ci
7562306a36Sopenharmony_ci  '#gpio-cells':
7662306a36Sopenharmony_ci    const: 2
7762306a36Sopenharmony_ci
7862306a36Sopenharmony_ci  interrupt-controller: true
7962306a36Sopenharmony_ci
8062306a36Sopenharmony_ci  '#interrupt-cells':
8162306a36Sopenharmony_ci    const: 2
8262306a36Sopenharmony_ci
8362306a36Sopenharmony_ci  gpio-ranges:
8462306a36Sopenharmony_ci    maxItems: 1
8562306a36Sopenharmony_ci
8662306a36Sopenharmony_ci  gpio-reserved-ranges:
8762306a36Sopenharmony_ci    minItems: 1
8862306a36Sopenharmony_ci    maxItems: 8
8962306a36Sopenharmony_ci
9062306a36Sopenharmony_cipatternProperties:
9162306a36Sopenharmony_ci  "^.*$":
9262306a36Sopenharmony_ci    if:
9362306a36Sopenharmony_ci      type: object
9462306a36Sopenharmony_ci    then:
9562306a36Sopenharmony_ci      properties:
9662306a36Sopenharmony_ci        gpio-hog: true
9762306a36Sopenharmony_ci        gpios: true
9862306a36Sopenharmony_ci        input: true
9962306a36Sopenharmony_ci        output-high: true
10062306a36Sopenharmony_ci        output-low: true
10162306a36Sopenharmony_ci        line-name: true
10262306a36Sopenharmony_ci
10362306a36Sopenharmony_ci      required:
10462306a36Sopenharmony_ci        - gpio-hog
10562306a36Sopenharmony_ci        - gpios
10662306a36Sopenharmony_ci
10762306a36Sopenharmony_ci      additionalProperties: false
10862306a36Sopenharmony_ci
10962306a36Sopenharmony_cirequired:
11062306a36Sopenharmony_ci  - compatible
11162306a36Sopenharmony_ci  - reg
11262306a36Sopenharmony_ci  - interrupts
11362306a36Sopenharmony_ci  - gpio-controller
11462306a36Sopenharmony_ci  - '#gpio-cells'
11562306a36Sopenharmony_ci  - gpio-ranges
11662306a36Sopenharmony_ci  - interrupt-controller
11762306a36Sopenharmony_ci  - '#interrupt-cells'
11862306a36Sopenharmony_ci
11962306a36Sopenharmony_ciif:
12062306a36Sopenharmony_ci  not:
12162306a36Sopenharmony_ci    properties:
12262306a36Sopenharmony_ci      compatible:
12362306a36Sopenharmony_ci        contains:
12462306a36Sopenharmony_ci          enum:
12562306a36Sopenharmony_ci            - renesas,rcar-gen1-gpio
12662306a36Sopenharmony_cithen:
12762306a36Sopenharmony_ci  required:
12862306a36Sopenharmony_ci    - clocks
12962306a36Sopenharmony_ci    - power-domains
13062306a36Sopenharmony_ci    - resets
13162306a36Sopenharmony_ci
13262306a36Sopenharmony_ciadditionalProperties: false
13362306a36Sopenharmony_ci
13462306a36Sopenharmony_ciexamples:
13562306a36Sopenharmony_ci  - |
13662306a36Sopenharmony_ci    #include <dt-bindings/clock/r8a77470-cpg-mssr.h>
13762306a36Sopenharmony_ci    #include <dt-bindings/interrupt-controller/arm-gic.h>
13862306a36Sopenharmony_ci    #include <dt-bindings/power/r8a77470-sysc.h>
13962306a36Sopenharmony_ci    gpio3: gpio@e6053000 {
14062306a36Sopenharmony_ci            compatible = "renesas,gpio-r8a77470", "renesas,rcar-gen2-gpio";
14162306a36Sopenharmony_ci            reg = <0xe6053000 0x50>;
14262306a36Sopenharmony_ci            interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
14362306a36Sopenharmony_ci            clocks = <&cpg CPG_MOD 909>;
14462306a36Sopenharmony_ci            power-domains = <&sysc R8A77470_PD_ALWAYS_ON>;
14562306a36Sopenharmony_ci            resets = <&cpg 909>;
14662306a36Sopenharmony_ci            gpio-controller;
14762306a36Sopenharmony_ci            #gpio-cells = <2>;
14862306a36Sopenharmony_ci            gpio-ranges = <&pfc 0 96 30>;
14962306a36Sopenharmony_ci            gpio-reserved-ranges = <17 10>;
15062306a36Sopenharmony_ci            interrupt-controller;
15162306a36Sopenharmony_ci            #interrupt-cells = <2>;
15262306a36Sopenharmony_ci     };
153