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/pinctrl/mediatek,mt7620-pinctrl.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: MediaTek MT7620 Pin Controller
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - Arınç ÜNAL <arinc.unal@arinc9.com>
1162306a36Sopenharmony_ci  - Sergio Paracuellos <sergio.paracuellos@gmail.com>
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_cidescription: |
1462306a36Sopenharmony_ci  MediaTek MT7620 pin controller for MT7620 SoC.
1562306a36Sopenharmony_ci  The pin controller can only set the muxing of pin groups. Muxing individual
1662306a36Sopenharmony_ci  pins is not supported. There is no pinconf support.
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_ciproperties:
1962306a36Sopenharmony_ci  compatible:
2062306a36Sopenharmony_ci    const: ralink,mt7620-pinctrl
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_cipatternProperties:
2362306a36Sopenharmony_ci  '-pins$':
2462306a36Sopenharmony_ci    type: object
2562306a36Sopenharmony_ci    additionalProperties: false
2662306a36Sopenharmony_ci
2762306a36Sopenharmony_ci    patternProperties:
2862306a36Sopenharmony_ci      '^(.*-)?pinmux$':
2962306a36Sopenharmony_ci        type: object
3062306a36Sopenharmony_ci        description: node for pinctrl.
3162306a36Sopenharmony_ci        $ref: pinmux-node.yaml#
3262306a36Sopenharmony_ci        additionalProperties: false
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_ci        properties:
3562306a36Sopenharmony_ci          function:
3662306a36Sopenharmony_ci            description:
3762306a36Sopenharmony_ci              A string containing the name of the function to mux to the group.
3862306a36Sopenharmony_ci            enum: [ephy, gpio, gpio i2s, gpio uartf, i2c, i2s uartf, mdio, nand,
3962306a36Sopenharmony_ci                   pa, pcie refclk, pcie rst, pcm gpio, pcm i2s, pcm uartf,
4062306a36Sopenharmony_ci                   refclk, rgmii1, rgmii2, sd, spi, spi refclk, uartf, uartlite,
4162306a36Sopenharmony_ci                   wdt refclk, wdt rst, wled]
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_ci          groups:
4462306a36Sopenharmony_ci            description:
4562306a36Sopenharmony_ci              An array of strings. Each string contains the name of a group.
4662306a36Sopenharmony_ci            maxItems: 1
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_ci        required:
4962306a36Sopenharmony_ci          - groups
5062306a36Sopenharmony_ci          - function
5162306a36Sopenharmony_ci
5262306a36Sopenharmony_ci        allOf:
5362306a36Sopenharmony_ci          - if:
5462306a36Sopenharmony_ci              properties:
5562306a36Sopenharmony_ci                function:
5662306a36Sopenharmony_ci                  const: ephy
5762306a36Sopenharmony_ci            then:
5862306a36Sopenharmony_ci              properties:
5962306a36Sopenharmony_ci                groups:
6062306a36Sopenharmony_ci                  enum: [ephy]
6162306a36Sopenharmony_ci
6262306a36Sopenharmony_ci          - if:
6362306a36Sopenharmony_ci              properties:
6462306a36Sopenharmony_ci                function:
6562306a36Sopenharmony_ci                  const: gpio
6662306a36Sopenharmony_ci            then:
6762306a36Sopenharmony_ci              properties:
6862306a36Sopenharmony_ci                groups:
6962306a36Sopenharmony_ci                  enum: [ephy, i2c, mdio, nd_sd, pa, pcie, rgmii1, rgmii2, spi,
7062306a36Sopenharmony_ci                         spi refclk, uartf, uartlite, wdt, wled]
7162306a36Sopenharmony_ci
7262306a36Sopenharmony_ci          - if:
7362306a36Sopenharmony_ci              properties:
7462306a36Sopenharmony_ci                function:
7562306a36Sopenharmony_ci                  const: gpio i2s
7662306a36Sopenharmony_ci            then:
7762306a36Sopenharmony_ci              properties:
7862306a36Sopenharmony_ci                groups:
7962306a36Sopenharmony_ci                  enum: [uartf]
8062306a36Sopenharmony_ci
8162306a36Sopenharmony_ci          - if:
8262306a36Sopenharmony_ci              properties:
8362306a36Sopenharmony_ci                function:
8462306a36Sopenharmony_ci                  const: gpio uartf
8562306a36Sopenharmony_ci            then:
8662306a36Sopenharmony_ci              properties:
8762306a36Sopenharmony_ci                groups:
8862306a36Sopenharmony_ci                  enum: [uartf]
8962306a36Sopenharmony_ci
9062306a36Sopenharmony_ci          - if:
9162306a36Sopenharmony_ci              properties:
9262306a36Sopenharmony_ci                function:
9362306a36Sopenharmony_ci                  const: i2c
9462306a36Sopenharmony_ci            then:
9562306a36Sopenharmony_ci              properties:
9662306a36Sopenharmony_ci                groups:
9762306a36Sopenharmony_ci                  enum: [i2c]
9862306a36Sopenharmony_ci
9962306a36Sopenharmony_ci          - if:
10062306a36Sopenharmony_ci              properties:
10162306a36Sopenharmony_ci                function:
10262306a36Sopenharmony_ci                  const: i2s uartf
10362306a36Sopenharmony_ci            then:
10462306a36Sopenharmony_ci              properties:
10562306a36Sopenharmony_ci                groups:
10662306a36Sopenharmony_ci                  enum: [uartf]
10762306a36Sopenharmony_ci
10862306a36Sopenharmony_ci          - if:
10962306a36Sopenharmony_ci              properties:
11062306a36Sopenharmony_ci                function:
11162306a36Sopenharmony_ci                  const: mdio
11262306a36Sopenharmony_ci            then:
11362306a36Sopenharmony_ci              properties:
11462306a36Sopenharmony_ci                groups:
11562306a36Sopenharmony_ci                  enum: [mdio]
11662306a36Sopenharmony_ci
11762306a36Sopenharmony_ci          - if:
11862306a36Sopenharmony_ci              properties:
11962306a36Sopenharmony_ci                function:
12062306a36Sopenharmony_ci                  const: nand
12162306a36Sopenharmony_ci            then:
12262306a36Sopenharmony_ci              properties:
12362306a36Sopenharmony_ci                groups:
12462306a36Sopenharmony_ci                  enum: [nd_sd]
12562306a36Sopenharmony_ci
12662306a36Sopenharmony_ci          - if:
12762306a36Sopenharmony_ci              properties:
12862306a36Sopenharmony_ci                function:
12962306a36Sopenharmony_ci                  const: pa
13062306a36Sopenharmony_ci            then:
13162306a36Sopenharmony_ci              properties:
13262306a36Sopenharmony_ci                groups:
13362306a36Sopenharmony_ci                  enum: [pa]
13462306a36Sopenharmony_ci
13562306a36Sopenharmony_ci          - if:
13662306a36Sopenharmony_ci              properties:
13762306a36Sopenharmony_ci                function:
13862306a36Sopenharmony_ci                  const: pcie refclk
13962306a36Sopenharmony_ci            then:
14062306a36Sopenharmony_ci              properties:
14162306a36Sopenharmony_ci                groups:
14262306a36Sopenharmony_ci                  enum: [pcie]
14362306a36Sopenharmony_ci
14462306a36Sopenharmony_ci          - if:
14562306a36Sopenharmony_ci              properties:
14662306a36Sopenharmony_ci                function:
14762306a36Sopenharmony_ci                  const: pcie rst
14862306a36Sopenharmony_ci            then:
14962306a36Sopenharmony_ci              properties:
15062306a36Sopenharmony_ci                groups:
15162306a36Sopenharmony_ci                  enum: [pcie]
15262306a36Sopenharmony_ci
15362306a36Sopenharmony_ci          - if:
15462306a36Sopenharmony_ci              properties:
15562306a36Sopenharmony_ci                function:
15662306a36Sopenharmony_ci                  const: pcm gpio
15762306a36Sopenharmony_ci            then:
15862306a36Sopenharmony_ci              properties:
15962306a36Sopenharmony_ci                groups:
16062306a36Sopenharmony_ci                  enum: [uartf]
16162306a36Sopenharmony_ci
16262306a36Sopenharmony_ci          - if:
16362306a36Sopenharmony_ci              properties:
16462306a36Sopenharmony_ci                function:
16562306a36Sopenharmony_ci                  const: pcm i2s
16662306a36Sopenharmony_ci            then:
16762306a36Sopenharmony_ci              properties:
16862306a36Sopenharmony_ci                groups:
16962306a36Sopenharmony_ci                  enum: [uartf]
17062306a36Sopenharmony_ci
17162306a36Sopenharmony_ci          - if:
17262306a36Sopenharmony_ci              properties:
17362306a36Sopenharmony_ci                function:
17462306a36Sopenharmony_ci                  const: pcm uartf
17562306a36Sopenharmony_ci            then:
17662306a36Sopenharmony_ci              properties:
17762306a36Sopenharmony_ci                groups:
17862306a36Sopenharmony_ci                  enum: [uartf]
17962306a36Sopenharmony_ci
18062306a36Sopenharmony_ci          - if:
18162306a36Sopenharmony_ci              properties:
18262306a36Sopenharmony_ci                function:
18362306a36Sopenharmony_ci                  const: refclk
18462306a36Sopenharmony_ci            then:
18562306a36Sopenharmony_ci              properties:
18662306a36Sopenharmony_ci                groups:
18762306a36Sopenharmony_ci                  enum: [mdio]
18862306a36Sopenharmony_ci
18962306a36Sopenharmony_ci          - if:
19062306a36Sopenharmony_ci              properties:
19162306a36Sopenharmony_ci                function:
19262306a36Sopenharmony_ci                  const: rgmii1
19362306a36Sopenharmony_ci            then:
19462306a36Sopenharmony_ci              properties:
19562306a36Sopenharmony_ci                groups:
19662306a36Sopenharmony_ci                  enum: [rgmii1]
19762306a36Sopenharmony_ci
19862306a36Sopenharmony_ci          - if:
19962306a36Sopenharmony_ci              properties:
20062306a36Sopenharmony_ci                function:
20162306a36Sopenharmony_ci                  const: rgmii2
20262306a36Sopenharmony_ci            then:
20362306a36Sopenharmony_ci              properties:
20462306a36Sopenharmony_ci                groups:
20562306a36Sopenharmony_ci                  enum: [rgmii2]
20662306a36Sopenharmony_ci
20762306a36Sopenharmony_ci          - if:
20862306a36Sopenharmony_ci              properties:
20962306a36Sopenharmony_ci                function:
21062306a36Sopenharmony_ci                  const: sd
21162306a36Sopenharmony_ci            then:
21262306a36Sopenharmony_ci              properties:
21362306a36Sopenharmony_ci                groups:
21462306a36Sopenharmony_ci                  enum: [nd_sd]
21562306a36Sopenharmony_ci
21662306a36Sopenharmony_ci          - if:
21762306a36Sopenharmony_ci              properties:
21862306a36Sopenharmony_ci                function:
21962306a36Sopenharmony_ci                  const: spi
22062306a36Sopenharmony_ci            then:
22162306a36Sopenharmony_ci              properties:
22262306a36Sopenharmony_ci                groups:
22362306a36Sopenharmony_ci                  enum: [spi]
22462306a36Sopenharmony_ci
22562306a36Sopenharmony_ci          - if:
22662306a36Sopenharmony_ci              properties:
22762306a36Sopenharmony_ci                function:
22862306a36Sopenharmony_ci                  const: spi refclk
22962306a36Sopenharmony_ci            then:
23062306a36Sopenharmony_ci              properties:
23162306a36Sopenharmony_ci                groups:
23262306a36Sopenharmony_ci                  enum: [spi refclk]
23362306a36Sopenharmony_ci
23462306a36Sopenharmony_ci          - if:
23562306a36Sopenharmony_ci              properties:
23662306a36Sopenharmony_ci                function:
23762306a36Sopenharmony_ci                  const: uartf
23862306a36Sopenharmony_ci            then:
23962306a36Sopenharmony_ci              properties:
24062306a36Sopenharmony_ci                groups:
24162306a36Sopenharmony_ci                  enum: [uartf]
24262306a36Sopenharmony_ci
24362306a36Sopenharmony_ci          - if:
24462306a36Sopenharmony_ci              properties:
24562306a36Sopenharmony_ci                function:
24662306a36Sopenharmony_ci                  const: uartlite
24762306a36Sopenharmony_ci            then:
24862306a36Sopenharmony_ci              properties:
24962306a36Sopenharmony_ci                groups:
25062306a36Sopenharmony_ci                  enum: [uartlite]
25162306a36Sopenharmony_ci
25262306a36Sopenharmony_ci          - if:
25362306a36Sopenharmony_ci              properties:
25462306a36Sopenharmony_ci                function:
25562306a36Sopenharmony_ci                  const: wdt refclk
25662306a36Sopenharmony_ci            then:
25762306a36Sopenharmony_ci              properties:
25862306a36Sopenharmony_ci                groups:
25962306a36Sopenharmony_ci                  enum: [wdt]
26062306a36Sopenharmony_ci
26162306a36Sopenharmony_ci          - if:
26262306a36Sopenharmony_ci              properties:
26362306a36Sopenharmony_ci                function:
26462306a36Sopenharmony_ci                  const: wdt rst
26562306a36Sopenharmony_ci            then:
26662306a36Sopenharmony_ci              properties:
26762306a36Sopenharmony_ci                groups:
26862306a36Sopenharmony_ci                  enum: [wdt]
26962306a36Sopenharmony_ci
27062306a36Sopenharmony_ci          - if:
27162306a36Sopenharmony_ci              properties:
27262306a36Sopenharmony_ci                function:
27362306a36Sopenharmony_ci                  const: wled
27462306a36Sopenharmony_ci            then:
27562306a36Sopenharmony_ci              properties:
27662306a36Sopenharmony_ci                groups:
27762306a36Sopenharmony_ci                  enum: [wled]
27862306a36Sopenharmony_ci
27962306a36Sopenharmony_ciallOf:
28062306a36Sopenharmony_ci  - $ref: pinctrl.yaml#
28162306a36Sopenharmony_ci
28262306a36Sopenharmony_cirequired:
28362306a36Sopenharmony_ci  - compatible
28462306a36Sopenharmony_ci
28562306a36Sopenharmony_ciadditionalProperties: false
28662306a36Sopenharmony_ci
28762306a36Sopenharmony_ciexamples:
28862306a36Sopenharmony_ci  - |
28962306a36Sopenharmony_ci    pinctrl {
29062306a36Sopenharmony_ci      compatible = "ralink,mt7620-pinctrl";
29162306a36Sopenharmony_ci
29262306a36Sopenharmony_ci      i2c_pins: i2c0-pins {
29362306a36Sopenharmony_ci        pinmux {
29462306a36Sopenharmony_ci          groups = "i2c";
29562306a36Sopenharmony_ci          function = "i2c";
29662306a36Sopenharmony_ci        };
29762306a36Sopenharmony_ci      };
29862306a36Sopenharmony_ci    };
299