18c2ecf20Sopenharmony_ci# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
28c2ecf20Sopenharmony_ci%YAML 1.2
38c2ecf20Sopenharmony_ci---
48c2ecf20Sopenharmony_ci$id: http://devicetree.org/schemas/gpio/renesas,rcar-gpio.yaml#
58c2ecf20Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
68c2ecf20Sopenharmony_ci
78c2ecf20Sopenharmony_cititle: Renesas R-Car General-Purpose Input/Output Ports (GPIO)
88c2ecf20Sopenharmony_ci
98c2ecf20Sopenharmony_cimaintainers:
108c2ecf20Sopenharmony_ci  - Geert Uytterhoeven <geert+renesas@glider.be>
118c2ecf20Sopenharmony_ci
128c2ecf20Sopenharmony_ciproperties:
138c2ecf20Sopenharmony_ci  compatible:
148c2ecf20Sopenharmony_ci    oneOf:
158c2ecf20Sopenharmony_ci      - items:
168c2ecf20Sopenharmony_ci          - enum:
178c2ecf20Sopenharmony_ci              - renesas,gpio-r8a7778      # R-Car M1
188c2ecf20Sopenharmony_ci              - renesas,gpio-r8a7779      # R-Car H1
198c2ecf20Sopenharmony_ci          - const: renesas,rcar-gen1-gpio # R-Car Gen1
208c2ecf20Sopenharmony_ci
218c2ecf20Sopenharmony_ci      - items:
228c2ecf20Sopenharmony_ci          - enum:
238c2ecf20Sopenharmony_ci              - renesas,gpio-r8a7742      # RZ/G1H
248c2ecf20Sopenharmony_ci              - renesas,gpio-r8a7743      # RZ/G1M
258c2ecf20Sopenharmony_ci              - renesas,gpio-r8a7744      # RZ/G1N
268c2ecf20Sopenharmony_ci              - renesas,gpio-r8a7745      # RZ/G1E
278c2ecf20Sopenharmony_ci              - renesas,gpio-r8a77470     # RZ/G1C
288c2ecf20Sopenharmony_ci              - renesas,gpio-r8a7790      # R-Car H2
298c2ecf20Sopenharmony_ci              - renesas,gpio-r8a7791      # R-Car M2-W
308c2ecf20Sopenharmony_ci              - renesas,gpio-r8a7792      # R-Car V2H
318c2ecf20Sopenharmony_ci              - renesas,gpio-r8a7793      # R-Car M2-N
328c2ecf20Sopenharmony_ci              - renesas,gpio-r8a7794      # R-Car E2
338c2ecf20Sopenharmony_ci          - const: renesas,rcar-gen2-gpio # R-Car Gen2 or RZ/G1
348c2ecf20Sopenharmony_ci
358c2ecf20Sopenharmony_ci      - items:
368c2ecf20Sopenharmony_ci          - enum:
378c2ecf20Sopenharmony_ci              - renesas,gpio-r8a774a1     # RZ/G2M
388c2ecf20Sopenharmony_ci              - renesas,gpio-r8a774b1     # RZ/G2N
398c2ecf20Sopenharmony_ci              - renesas,gpio-r8a774c0     # RZ/G2E
408c2ecf20Sopenharmony_ci              - renesas,gpio-r8a774e1     # RZ/G2H
418c2ecf20Sopenharmony_ci              - renesas,gpio-r8a7795      # R-Car H3
428c2ecf20Sopenharmony_ci              - renesas,gpio-r8a7796      # R-Car M3-W
438c2ecf20Sopenharmony_ci              - renesas,gpio-r8a77961     # R-Car M3-W+
448c2ecf20Sopenharmony_ci              - renesas,gpio-r8a77965     # R-Car M3-N
458c2ecf20Sopenharmony_ci              - renesas,gpio-r8a77970     # R-Car V3M
468c2ecf20Sopenharmony_ci              - renesas,gpio-r8a77980     # R-Car V3H
478c2ecf20Sopenharmony_ci              - renesas,gpio-r8a77990     # R-Car E3
488c2ecf20Sopenharmony_ci              - renesas,gpio-r8a77995     # R-Car D3
498c2ecf20Sopenharmony_ci          - const: renesas,rcar-gen3-gpio # R-Car Gen3 or RZ/G2
508c2ecf20Sopenharmony_ci
518c2ecf20Sopenharmony_ci  reg:
528c2ecf20Sopenharmony_ci    maxItems: 1
538c2ecf20Sopenharmony_ci
548c2ecf20Sopenharmony_ci  interrupts:
558c2ecf20Sopenharmony_ci    maxItems: 1
568c2ecf20Sopenharmony_ci
578c2ecf20Sopenharmony_ci  clocks:
588c2ecf20Sopenharmony_ci    maxItems: 1
598c2ecf20Sopenharmony_ci
608c2ecf20Sopenharmony_ci  power-domains:
618c2ecf20Sopenharmony_ci    maxItems: 1
628c2ecf20Sopenharmony_ci
638c2ecf20Sopenharmony_ci  resets:
648c2ecf20Sopenharmony_ci    maxItems: 1
658c2ecf20Sopenharmony_ci
668c2ecf20Sopenharmony_ci  gpio-controller: true
678c2ecf20Sopenharmony_ci
688c2ecf20Sopenharmony_ci  '#gpio-cells':
698c2ecf20Sopenharmony_ci    const: 2
708c2ecf20Sopenharmony_ci
718c2ecf20Sopenharmony_ci  interrupt-controller: true
728c2ecf20Sopenharmony_ci
738c2ecf20Sopenharmony_ci  '#interrupt-cells':
748c2ecf20Sopenharmony_ci    const: 2
758c2ecf20Sopenharmony_ci
768c2ecf20Sopenharmony_ci  gpio-ranges:
778c2ecf20Sopenharmony_ci    maxItems: 1
788c2ecf20Sopenharmony_ci
798c2ecf20Sopenharmony_ci  gpio-reserved-ranges:
808c2ecf20Sopenharmony_ci    minItems: 1
818c2ecf20Sopenharmony_ci    maxItems: 8
828c2ecf20Sopenharmony_ci
838c2ecf20Sopenharmony_cipatternProperties:
848c2ecf20Sopenharmony_ci  "^.*$":
858c2ecf20Sopenharmony_ci    if:
868c2ecf20Sopenharmony_ci      type: object
878c2ecf20Sopenharmony_ci    then:
888c2ecf20Sopenharmony_ci      properties:
898c2ecf20Sopenharmony_ci        gpio-hog: true
908c2ecf20Sopenharmony_ci        gpios: true
918c2ecf20Sopenharmony_ci        input: true
928c2ecf20Sopenharmony_ci        output-high: true
938c2ecf20Sopenharmony_ci        output-low: true
948c2ecf20Sopenharmony_ci        line-name: true
958c2ecf20Sopenharmony_ci
968c2ecf20Sopenharmony_ci      required:
978c2ecf20Sopenharmony_ci        - gpio-hog
988c2ecf20Sopenharmony_ci        - gpios
998c2ecf20Sopenharmony_ci
1008c2ecf20Sopenharmony_ci      additionalProperties: false
1018c2ecf20Sopenharmony_ci
1028c2ecf20Sopenharmony_cirequired:
1038c2ecf20Sopenharmony_ci  - compatible
1048c2ecf20Sopenharmony_ci  - reg
1058c2ecf20Sopenharmony_ci  - interrupts
1068c2ecf20Sopenharmony_ci  - gpio-controller
1078c2ecf20Sopenharmony_ci  - '#gpio-cells'
1088c2ecf20Sopenharmony_ci  - gpio-ranges
1098c2ecf20Sopenharmony_ci  - interrupt-controller
1108c2ecf20Sopenharmony_ci  - '#interrupt-cells'
1118c2ecf20Sopenharmony_ci
1128c2ecf20Sopenharmony_ciif:
1138c2ecf20Sopenharmony_ci  not:
1148c2ecf20Sopenharmony_ci    properties:
1158c2ecf20Sopenharmony_ci      compatible:
1168c2ecf20Sopenharmony_ci        contains:
1178c2ecf20Sopenharmony_ci          enum:
1188c2ecf20Sopenharmony_ci            - renesas,rcar-gen1-gpio
1198c2ecf20Sopenharmony_cithen:
1208c2ecf20Sopenharmony_ci  required:
1218c2ecf20Sopenharmony_ci    - clocks
1228c2ecf20Sopenharmony_ci    - power-domains
1238c2ecf20Sopenharmony_ci    - resets
1248c2ecf20Sopenharmony_ci
1258c2ecf20Sopenharmony_ciadditionalProperties: false
1268c2ecf20Sopenharmony_ci
1278c2ecf20Sopenharmony_ciexamples:
1288c2ecf20Sopenharmony_ci  - |
1298c2ecf20Sopenharmony_ci    #include <dt-bindings/clock/r8a77470-cpg-mssr.h>
1308c2ecf20Sopenharmony_ci    #include <dt-bindings/interrupt-controller/arm-gic.h>
1318c2ecf20Sopenharmony_ci    #include <dt-bindings/power/r8a77470-sysc.h>
1328c2ecf20Sopenharmony_ci    gpio3: gpio@e6053000 {
1338c2ecf20Sopenharmony_ci            compatible = "renesas,gpio-r8a77470", "renesas,rcar-gen2-gpio";
1348c2ecf20Sopenharmony_ci            reg = <0xe6053000 0x50>;
1358c2ecf20Sopenharmony_ci            interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
1368c2ecf20Sopenharmony_ci            clocks = <&cpg CPG_MOD 909>;
1378c2ecf20Sopenharmony_ci            power-domains = <&sysc R8A77470_PD_ALWAYS_ON>;
1388c2ecf20Sopenharmony_ci            resets = <&cpg 909>;
1398c2ecf20Sopenharmony_ci            gpio-controller;
1408c2ecf20Sopenharmony_ci            #gpio-cells = <2>;
1418c2ecf20Sopenharmony_ci            gpio-ranges = <&pfc 0 96 30>;
1428c2ecf20Sopenharmony_ci            gpio-reserved-ranges = <17 10>;
1438c2ecf20Sopenharmony_ci            interrupt-controller;
1448c2ecf20Sopenharmony_ci            #interrupt-cells = <2>;
1458c2ecf20Sopenharmony_ci     };
146