162306a36Sopenharmony_ci# SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci%YAML 1.2
362306a36Sopenharmony_ci---
462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/pinctrl/allwinner,sun4i-a10-pinctrl.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Allwinner A10 Pin Controller
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - Chen-Yu Tsai <wens@csie.org>
1162306a36Sopenharmony_ci  - Maxime Ripard <mripard@kernel.org>
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ciproperties:
1462306a36Sopenharmony_ci  "#gpio-cells":
1562306a36Sopenharmony_ci    const: 3
1662306a36Sopenharmony_ci    description:
1762306a36Sopenharmony_ci      GPIO consumers must use three arguments, first the number of the
1862306a36Sopenharmony_ci      bank, then the pin number inside that bank, and finally the GPIO
1962306a36Sopenharmony_ci      flags.
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_ci  "#interrupt-cells":
2262306a36Sopenharmony_ci    const: 3
2362306a36Sopenharmony_ci    description:
2462306a36Sopenharmony_ci      Interrupts consumers must use three arguments, first the number
2562306a36Sopenharmony_ci      of the bank, then the pin number inside that bank, and finally
2662306a36Sopenharmony_ci      the interrupts flags.
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_ci  compatible:
2962306a36Sopenharmony_ci    enum:
3062306a36Sopenharmony_ci      - allwinner,sun4i-a10-pinctrl
3162306a36Sopenharmony_ci      - allwinner,sun5i-a10s-pinctrl
3262306a36Sopenharmony_ci      - allwinner,sun5i-a13-pinctrl
3362306a36Sopenharmony_ci      - allwinner,sun6i-a31-pinctrl
3462306a36Sopenharmony_ci      - allwinner,sun6i-a31-r-pinctrl
3562306a36Sopenharmony_ci      - allwinner,sun6i-a31s-pinctrl
3662306a36Sopenharmony_ci      - allwinner,sun7i-a20-pinctrl
3762306a36Sopenharmony_ci      - allwinner,sun8i-a23-pinctrl
3862306a36Sopenharmony_ci      - allwinner,sun8i-a23-r-pinctrl
3962306a36Sopenharmony_ci      - allwinner,sun8i-a33-pinctrl
4062306a36Sopenharmony_ci      - allwinner,sun8i-a83t-pinctrl
4162306a36Sopenharmony_ci      - allwinner,sun8i-a83t-r-pinctrl
4262306a36Sopenharmony_ci      - allwinner,sun8i-h3-pinctrl
4362306a36Sopenharmony_ci      - allwinner,sun8i-h3-r-pinctrl
4462306a36Sopenharmony_ci      - allwinner,sun8i-r40-pinctrl
4562306a36Sopenharmony_ci      - allwinner,sun8i-v3-pinctrl
4662306a36Sopenharmony_ci      - allwinner,sun8i-v3s-pinctrl
4762306a36Sopenharmony_ci      - allwinner,sun9i-a80-pinctrl
4862306a36Sopenharmony_ci      - allwinner,sun9i-a80-r-pinctrl
4962306a36Sopenharmony_ci      - allwinner,sun20i-d1-pinctrl
5062306a36Sopenharmony_ci      - allwinner,sun50i-a64-pinctrl
5162306a36Sopenharmony_ci      - allwinner,sun50i-a64-r-pinctrl
5262306a36Sopenharmony_ci      - allwinner,sun50i-a100-pinctrl
5362306a36Sopenharmony_ci      - allwinner,sun50i-a100-r-pinctrl
5462306a36Sopenharmony_ci      - allwinner,sun50i-h5-pinctrl
5562306a36Sopenharmony_ci      - allwinner,sun50i-h6-pinctrl
5662306a36Sopenharmony_ci      - allwinner,sun50i-h6-r-pinctrl
5762306a36Sopenharmony_ci      - allwinner,sun50i-h616-pinctrl
5862306a36Sopenharmony_ci      - allwinner,sun50i-h616-r-pinctrl
5962306a36Sopenharmony_ci      - allwinner,suniv-f1c100s-pinctrl
6062306a36Sopenharmony_ci      - nextthing,gr8-pinctrl
6162306a36Sopenharmony_ci
6262306a36Sopenharmony_ci  reg:
6362306a36Sopenharmony_ci    maxItems: 1
6462306a36Sopenharmony_ci
6562306a36Sopenharmony_ci  interrupts:
6662306a36Sopenharmony_ci    minItems: 1
6762306a36Sopenharmony_ci    maxItems: 8
6862306a36Sopenharmony_ci    description:
6962306a36Sopenharmony_ci      One interrupt per external interrupt bank supported on the
7062306a36Sopenharmony_ci      controller, sorted by bank number ascending order.
7162306a36Sopenharmony_ci
7262306a36Sopenharmony_ci  clocks:
7362306a36Sopenharmony_ci    items:
7462306a36Sopenharmony_ci      - description: Bus Clock
7562306a36Sopenharmony_ci      - description: High Frequency Oscillator
7662306a36Sopenharmony_ci      - description: Low Frequency Oscillator
7762306a36Sopenharmony_ci
7862306a36Sopenharmony_ci  clock-names:
7962306a36Sopenharmony_ci    items:
8062306a36Sopenharmony_ci      - const: apb
8162306a36Sopenharmony_ci      - const: hosc
8262306a36Sopenharmony_ci      - const: losc
8362306a36Sopenharmony_ci
8462306a36Sopenharmony_ci  gpio-controller: true
8562306a36Sopenharmony_ci  interrupt-controller: true
8662306a36Sopenharmony_ci  gpio-line-names: true
8762306a36Sopenharmony_ci
8862306a36Sopenharmony_ci  input-debounce:
8962306a36Sopenharmony_ci    description:
9062306a36Sopenharmony_ci      Debouncing periods in microseconds, one period per interrupt
9162306a36Sopenharmony_ci      bank found in the controller
9262306a36Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/uint32-array
9362306a36Sopenharmony_ci    minItems: 1
9462306a36Sopenharmony_ci    maxItems: 8
9562306a36Sopenharmony_ci
9662306a36Sopenharmony_cipatternProperties:
9762306a36Sopenharmony_ci  # It's pretty scary, but the basic idea is that:
9862306a36Sopenharmony_ci  #   - One node name can start with either s- or r- for PRCM nodes,
9962306a36Sopenharmony_ci  #   - Then, the name itself can be any repetition of <string>- (to
10062306a36Sopenharmony_ci  #     accommodate with nodes like uart4-rts-cts-pins), where each
10162306a36Sopenharmony_ci  #     string can be either starting with 'p' but in a string longer
10262306a36Sopenharmony_ci  #     than 3, or something that doesn't start with 'p',
10362306a36Sopenharmony_ci  #   - Then, the bank name is optional and will be between pa and pg,
10462306a36Sopenharmony_ci  #     pl or pm. Some pins groups that have several options will have
10562306a36Sopenharmony_ci  #     the pin numbers then,
10662306a36Sopenharmony_ci  #   - Finally, the name will end with either -pin or pins.
10762306a36Sopenharmony_ci
10862306a36Sopenharmony_ci  "^([rs]-)?(([a-z0-9]{3,}|[a-oq-z][a-z0-9]*?)?-)+?(p[a-ilm][0-9]*?-)??pins?$":
10962306a36Sopenharmony_ci    type: object
11062306a36Sopenharmony_ci
11162306a36Sopenharmony_ci    properties:
11262306a36Sopenharmony_ci      pins: true
11362306a36Sopenharmony_ci      function: true
11462306a36Sopenharmony_ci      bias-disable: true
11562306a36Sopenharmony_ci      bias-pull-up: true
11662306a36Sopenharmony_ci      bias-pull-down: true
11762306a36Sopenharmony_ci
11862306a36Sopenharmony_ci      drive-strength:
11962306a36Sopenharmony_ci        $ref: /schemas/types.yaml#/definitions/uint32
12062306a36Sopenharmony_ci        enum: [10, 20, 30, 40]
12162306a36Sopenharmony_ci
12262306a36Sopenharmony_ci    required:
12362306a36Sopenharmony_ci      - pins
12462306a36Sopenharmony_ci      - function
12562306a36Sopenharmony_ci
12662306a36Sopenharmony_ci    additionalProperties: false
12762306a36Sopenharmony_ci
12862306a36Sopenharmony_ci  "^vcc-p[a-ilm]-supply$":
12962306a36Sopenharmony_ci    description:
13062306a36Sopenharmony_ci      Power supplies for pin banks.
13162306a36Sopenharmony_ci
13262306a36Sopenharmony_cirequired:
13362306a36Sopenharmony_ci  - "#gpio-cells"
13462306a36Sopenharmony_ci  - compatible
13562306a36Sopenharmony_ci  - reg
13662306a36Sopenharmony_ci  - clocks
13762306a36Sopenharmony_ci  - clock-names
13862306a36Sopenharmony_ci  - gpio-controller
13962306a36Sopenharmony_ci
14062306a36Sopenharmony_ciallOf:
14162306a36Sopenharmony_ci  # FIXME: We should have the pin bank supplies here, but not a lot of
14262306a36Sopenharmony_ci  # boards are defining it at the moment so it would generate a lot of
14362306a36Sopenharmony_ci  # warnings.
14462306a36Sopenharmony_ci
14562306a36Sopenharmony_ci  - $ref: pinctrl.yaml#
14662306a36Sopenharmony_ci  - if:
14762306a36Sopenharmony_ci      not:
14862306a36Sopenharmony_ci        properties:
14962306a36Sopenharmony_ci          compatible:
15062306a36Sopenharmony_ci            enum:
15162306a36Sopenharmony_ci              - allwinner,sun50i-h616-r-pinctrl
15262306a36Sopenharmony_ci
15362306a36Sopenharmony_ci    then:
15462306a36Sopenharmony_ci      required:
15562306a36Sopenharmony_ci        - "#interrupt-cells"
15662306a36Sopenharmony_ci        - interrupts
15762306a36Sopenharmony_ci        - interrupt-controller
15862306a36Sopenharmony_ci
15962306a36Sopenharmony_ci  - if:
16062306a36Sopenharmony_ci      properties:
16162306a36Sopenharmony_ci        compatible:
16262306a36Sopenharmony_ci          enum:
16362306a36Sopenharmony_ci            - allwinner,sun50i-h616-pinctrl
16462306a36Sopenharmony_ci
16562306a36Sopenharmony_ci    then:
16662306a36Sopenharmony_ci      properties:
16762306a36Sopenharmony_ci        interrupts:
16862306a36Sopenharmony_ci          minItems: 8
16962306a36Sopenharmony_ci
17062306a36Sopenharmony_ci  - if:
17162306a36Sopenharmony_ci      properties:
17262306a36Sopenharmony_ci        compatible:
17362306a36Sopenharmony_ci          enum:
17462306a36Sopenharmony_ci            - allwinner,sun50i-a100-pinctrl
17562306a36Sopenharmony_ci
17662306a36Sopenharmony_ci    then:
17762306a36Sopenharmony_ci      properties:
17862306a36Sopenharmony_ci        interrupts:
17962306a36Sopenharmony_ci          minItems: 7
18062306a36Sopenharmony_ci          maxItems: 7
18162306a36Sopenharmony_ci
18262306a36Sopenharmony_ci  - if:
18362306a36Sopenharmony_ci      properties:
18462306a36Sopenharmony_ci        compatible:
18562306a36Sopenharmony_ci          enum:
18662306a36Sopenharmony_ci            - allwinner,sun20i-d1-pinctrl
18762306a36Sopenharmony_ci
18862306a36Sopenharmony_ci    then:
18962306a36Sopenharmony_ci      properties:
19062306a36Sopenharmony_ci        interrupts:
19162306a36Sopenharmony_ci          minItems: 6
19262306a36Sopenharmony_ci          maxItems: 6
19362306a36Sopenharmony_ci
19462306a36Sopenharmony_ci  - if:
19562306a36Sopenharmony_ci      properties:
19662306a36Sopenharmony_ci        compatible:
19762306a36Sopenharmony_ci          enum:
19862306a36Sopenharmony_ci            - allwinner,sun9i-a80-pinctrl
19962306a36Sopenharmony_ci
20062306a36Sopenharmony_ci    then:
20162306a36Sopenharmony_ci      properties:
20262306a36Sopenharmony_ci        interrupts:
20362306a36Sopenharmony_ci          minItems: 5
20462306a36Sopenharmony_ci          maxItems: 5
20562306a36Sopenharmony_ci
20662306a36Sopenharmony_ci  - if:
20762306a36Sopenharmony_ci      properties:
20862306a36Sopenharmony_ci        compatible:
20962306a36Sopenharmony_ci          enum:
21062306a36Sopenharmony_ci            - allwinner,sun6i-a31-pinctrl
21162306a36Sopenharmony_ci            - allwinner,sun6i-a31s-pinctrl
21262306a36Sopenharmony_ci            - allwinner,sun50i-h6-pinctrl
21362306a36Sopenharmony_ci
21462306a36Sopenharmony_ci    then:
21562306a36Sopenharmony_ci      properties:
21662306a36Sopenharmony_ci        interrupts:
21762306a36Sopenharmony_ci          minItems: 4
21862306a36Sopenharmony_ci          maxItems: 4
21962306a36Sopenharmony_ci
22062306a36Sopenharmony_ci  - if:
22162306a36Sopenharmony_ci      properties:
22262306a36Sopenharmony_ci        compatible:
22362306a36Sopenharmony_ci          enum:
22462306a36Sopenharmony_ci            - allwinner,sun8i-a23-pinctrl
22562306a36Sopenharmony_ci            - allwinner,sun8i-a83t-pinctrl
22662306a36Sopenharmony_ci            - allwinner,sun50i-a64-pinctrl
22762306a36Sopenharmony_ci            - allwinner,sun50i-h5-pinctrl
22862306a36Sopenharmony_ci            - allwinner,suniv-f1c100s-pinctrl
22962306a36Sopenharmony_ci
23062306a36Sopenharmony_ci    then:
23162306a36Sopenharmony_ci      properties:
23262306a36Sopenharmony_ci        interrupts:
23362306a36Sopenharmony_ci          minItems: 3
23462306a36Sopenharmony_ci          maxItems: 3
23562306a36Sopenharmony_ci
23662306a36Sopenharmony_ci  - if:
23762306a36Sopenharmony_ci      properties:
23862306a36Sopenharmony_ci        compatible:
23962306a36Sopenharmony_ci          enum:
24062306a36Sopenharmony_ci            - allwinner,sun6i-a31-r-pinctrl
24162306a36Sopenharmony_ci            - allwinner,sun8i-a33-pinctrl
24262306a36Sopenharmony_ci            - allwinner,sun8i-h3-pinctrl
24362306a36Sopenharmony_ci            - allwinner,sun8i-v3-pinctrl
24462306a36Sopenharmony_ci            - allwinner,sun8i-v3s-pinctrl
24562306a36Sopenharmony_ci            - allwinner,sun9i-a80-r-pinctrl
24662306a36Sopenharmony_ci            - allwinner,sun50i-h6-r-pinctrl
24762306a36Sopenharmony_ci
24862306a36Sopenharmony_ci    then:
24962306a36Sopenharmony_ci      properties:
25062306a36Sopenharmony_ci        interrupts:
25162306a36Sopenharmony_ci          minItems: 2
25262306a36Sopenharmony_ci          maxItems: 2
25362306a36Sopenharmony_ci
25462306a36Sopenharmony_ci  - if:
25562306a36Sopenharmony_ci      properties:
25662306a36Sopenharmony_ci        compatible:
25762306a36Sopenharmony_ci          enum:
25862306a36Sopenharmony_ci            - allwinner,sun4i-a10-pinctrl
25962306a36Sopenharmony_ci            - allwinner,sun5i-a10s-pinctrl
26062306a36Sopenharmony_ci            - allwinner,sun5i-a13-pinctrl
26162306a36Sopenharmony_ci            - allwinner,sun7i-a20-pinctrl
26262306a36Sopenharmony_ci            - allwinner,sun8i-a23-r-pinctrl
26362306a36Sopenharmony_ci            - allwinner,sun8i-a83t-r-pinctrl
26462306a36Sopenharmony_ci            - allwinner,sun8i-h3-r-pinctrl
26562306a36Sopenharmony_ci            - allwinner,sun8i-r40-pinctrl
26662306a36Sopenharmony_ci            - allwinner,sun50i-a64-r-pinctrl
26762306a36Sopenharmony_ci            - allwinner,sun50i-a100-r-pinctrl
26862306a36Sopenharmony_ci            - nextthing,gr8-pinctrl
26962306a36Sopenharmony_ci
27062306a36Sopenharmony_ci    then:
27162306a36Sopenharmony_ci      properties:
27262306a36Sopenharmony_ci        interrupts:
27362306a36Sopenharmony_ci          minItems: 1
27462306a36Sopenharmony_ci          maxItems: 1
27562306a36Sopenharmony_ci
27662306a36Sopenharmony_ciadditionalProperties: false
27762306a36Sopenharmony_ci
27862306a36Sopenharmony_ciexamples:
27962306a36Sopenharmony_ci  - |
28062306a36Sopenharmony_ci    #include <dt-bindings/clock/sun5i-ccu.h>
28162306a36Sopenharmony_ci
28262306a36Sopenharmony_ci    pio: pinctrl@1c20800 {
28362306a36Sopenharmony_ci        compatible = "allwinner,sun5i-a13-pinctrl";
28462306a36Sopenharmony_ci        reg = <0x01c20800 0x400>;
28562306a36Sopenharmony_ci        interrupts = <28>;
28662306a36Sopenharmony_ci        clocks = <&ccu CLK_APB0_PIO>, <&osc24M>, <&osc32k>;
28762306a36Sopenharmony_ci        clock-names = "apb", "hosc", "losc";
28862306a36Sopenharmony_ci        gpio-controller;
28962306a36Sopenharmony_ci        interrupt-controller;
29062306a36Sopenharmony_ci        #interrupt-cells = <3>;
29162306a36Sopenharmony_ci        #gpio-cells = <3>;
29262306a36Sopenharmony_ci
29362306a36Sopenharmony_ci        uart1_pe_pins: uart1-pe-pins {
29462306a36Sopenharmony_ci            pins = "PE10", "PE11";
29562306a36Sopenharmony_ci            function = "uart1";
29662306a36Sopenharmony_ci        };
29762306a36Sopenharmony_ci
29862306a36Sopenharmony_ci        uart1_pg_pins: uart1-pg-pins {
29962306a36Sopenharmony_ci            pins = "PG3", "PG4";
30062306a36Sopenharmony_ci            function = "uart1";
30162306a36Sopenharmony_ci        };
30262306a36Sopenharmony_ci    };
303