11c571187SAnson Huang# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
21c571187SAnson Huang%YAML 1.2
31c571187SAnson Huang---
41c571187SAnson Huang$id: http://devicetree.org/schemas/gpio/gpio-vf610.yaml#
51c571187SAnson Huang$schema: http://devicetree.org/meta-schemas/core.yaml#
61c571187SAnson Huang
71c571187SAnson Huangtitle: Freescale VF610 PORT/GPIO module
81c571187SAnson Huang
91c571187SAnson Huangmaintainers:
101c571187SAnson Huang  - Stefan Agner <stefan@agner.ch>
111c571187SAnson Huang
121c571187SAnson Huangdescription: |
131c571187SAnson Huang  The Freescale PORT/GPIO modules are two adjacent modules providing GPIO
141c571187SAnson Huang  functionality. Each pair serves 32 GPIOs. The VF610 has 5 instances of
151c571187SAnson Huang  each, and each PORT module has its own interrupt.
161c571187SAnson Huang
171c571187SAnson Huang  Note: Each GPIO port should have an alias correctly numbered in "aliases"
181c571187SAnson Huang  node.
191c571187SAnson Huang
201c571187SAnson Huangproperties:
211c571187SAnson Huang  compatible:
221c36e50fSKrzysztof Kozlowski    oneOf:
231c36e50fSKrzysztof Kozlowski      - const: fsl,vf610-gpio
241c36e50fSKrzysztof Kozlowski      - items:
251c36e50fSKrzysztof Kozlowski          - const: fsl,imx7ulp-gpio
261c36e50fSKrzysztof Kozlowski          - const: fsl,vf610-gpio
27c61d8b57SJacky Bai      - items:
284f351eddSPeng Fan          - enum:
294f351eddSPeng Fan              - fsl,imx93-gpio
304f351eddSPeng Fan              - fsl,imx8ulp-gpio
31c61d8b57SJacky Bai          - const: fsl,imx7ulp-gpio
321c571187SAnson Huang
331c571187SAnson Huang  reg:
341c571187SAnson Huang    description: The first reg tuple represents the PORT module, the second tuple
351c571187SAnson Huang      represents the GPIO module.
361c571187SAnson Huang    maxItems: 2
371c571187SAnson Huang
381c571187SAnson Huang  interrupts:
391c571187SAnson Huang    maxItems: 1
401c571187SAnson Huang
411c571187SAnson Huang  interrupt-controller: true
421c571187SAnson Huang
431c571187SAnson Huang  "#interrupt-cells":
441c571187SAnson Huang    const: 2
451c571187SAnson Huang
461c571187SAnson Huang  "#gpio-cells":
471c571187SAnson Huang    const: 2
481c571187SAnson Huang
491c571187SAnson Huang  gpio-controller: true
501c571187SAnson Huang
511c571187SAnson Huang  clocks:
521c571187SAnson Huang    items:
531c571187SAnson Huang      - description: SoC GPIO clock
541c571187SAnson Huang      - description: SoC PORT clock
551c571187SAnson Huang
561c571187SAnson Huang  clock-names:
571c571187SAnson Huang    items:
581c571187SAnson Huang      - const: gpio
591c571187SAnson Huang      - const: port
601c571187SAnson Huang
611c571187SAnson Huang  gpio-ranges:
621c571187SAnson Huang    maxItems: 1
631c571187SAnson Huang
64*0ea22c46SAlexander SteinpatternProperties:
65*0ea22c46SAlexander Stein  "^.+-hog(-[0-9]+)?$":
66*0ea22c46SAlexander Stein    type: object
67*0ea22c46SAlexander Stein
68*0ea22c46SAlexander Stein    required:
69*0ea22c46SAlexander Stein      - gpio-hog
70*0ea22c46SAlexander Stein
711c571187SAnson Huangrequired:
721c571187SAnson Huang  - compatible
731c571187SAnson Huang  - reg
741c571187SAnson Huang  - interrupts
751c571187SAnson Huang  - interrupt-controller
761c571187SAnson Huang  - "#interrupt-cells"
771c571187SAnson Huang  - "#gpio-cells"
781c571187SAnson Huang  - gpio-controller
791c571187SAnson Huang
801c571187SAnson HuangadditionalProperties: false
811c571187SAnson Huang
821c571187SAnson Huangexamples:
831c571187SAnson Huang  - |
841c571187SAnson Huang    #include <dt-bindings/interrupt-controller/arm-gic.h>
851c571187SAnson Huang
861c571187SAnson Huang    gpio1: gpio@40049000 {
871c571187SAnson Huang        compatible = "fsl,vf610-gpio";
881c571187SAnson Huang        reg = <0x40049000 0x1000>, <0x400ff000 0x40>;
891c571187SAnson Huang        interrupts = <0 107 IRQ_TYPE_LEVEL_HIGH>;
901c571187SAnson Huang        gpio-controller;
911c571187SAnson Huang        #gpio-cells = <2>;
921c571187SAnson Huang        interrupt-controller;
931c571187SAnson Huang        #interrupt-cells = <2>;
941c571187SAnson Huang        gpio-ranges = <&iomuxc 0 0 32>;
951c571187SAnson Huang    };
96