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,mt76x8-pinctrl.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: MediaTek MT76X8 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 MT76X8 pin controller for MT7628 and MT7688 SoCs.
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,mt76x8-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: [antenna, debug, gpio, i2c, i2s, jtag, p0led_an, p0led_kn,
3962306a36Sopenharmony_ci                   p1led_an, p1led_kn, p2led_an, p2led_kn, p3led_an, p3led_kn,
4062306a36Sopenharmony_ci                   p4led_an, p4led_kn, pcie, pcm, perst, pwm, pwm0, pwm1,
4162306a36Sopenharmony_ci                   pwm_uart2, refclk, rsvd, sdxc, sdxc d5 d4, sdxc d6, sdxc d7,
4262306a36Sopenharmony_ci                   spi, spi cs1, spis, sw_r, uart0, uart1, uart2, utif, wdt,
4362306a36Sopenharmony_ci                   wled_an, wled_kn, -]
4462306a36Sopenharmony_ci
4562306a36Sopenharmony_ci          groups:
4662306a36Sopenharmony_ci            description:
4762306a36Sopenharmony_ci              An array of strings. Each string contains the name of a group.
4862306a36Sopenharmony_ci            maxItems: 1
4962306a36Sopenharmony_ci
5062306a36Sopenharmony_ci        required:
5162306a36Sopenharmony_ci          - groups
5262306a36Sopenharmony_ci          - function
5362306a36Sopenharmony_ci
5462306a36Sopenharmony_ci        allOf:
5562306a36Sopenharmony_ci          - if:
5662306a36Sopenharmony_ci              properties:
5762306a36Sopenharmony_ci                function:
5862306a36Sopenharmony_ci                  const: antenna
5962306a36Sopenharmony_ci            then:
6062306a36Sopenharmony_ci              properties:
6162306a36Sopenharmony_ci                groups:
6262306a36Sopenharmony_ci                  enum: [i2s]
6362306a36Sopenharmony_ci
6462306a36Sopenharmony_ci          - if:
6562306a36Sopenharmony_ci              properties:
6662306a36Sopenharmony_ci                function:
6762306a36Sopenharmony_ci                  const: debug
6862306a36Sopenharmony_ci            then:
6962306a36Sopenharmony_ci              properties:
7062306a36Sopenharmony_ci                groups:
7162306a36Sopenharmony_ci                  enum: [i2c]
7262306a36Sopenharmony_ci
7362306a36Sopenharmony_ci          - if:
7462306a36Sopenharmony_ci              properties:
7562306a36Sopenharmony_ci                function:
7662306a36Sopenharmony_ci                  const: gpio
7762306a36Sopenharmony_ci            then:
7862306a36Sopenharmony_ci              properties:
7962306a36Sopenharmony_ci                groups:
8062306a36Sopenharmony_ci                  enum: [gpio, i2c, i2s, p0led_an, p0led_kn, p1led_an, p1led_kn,
8162306a36Sopenharmony_ci                         p2led_an, p2led_kn, p3led_an, p3led_kn, p4led_an,
8262306a36Sopenharmony_ci                         p4led_kn, perst, pwm0, pwm1, refclk, sdmode, spi,
8362306a36Sopenharmony_ci                         spi cs1, spis, uart0, uart1, uart2, wdt, wled_an,
8462306a36Sopenharmony_ci                         wled_kn]
8562306a36Sopenharmony_ci
8662306a36Sopenharmony_ci          - if:
8762306a36Sopenharmony_ci              properties:
8862306a36Sopenharmony_ci                function:
8962306a36Sopenharmony_ci                  const: i2c
9062306a36Sopenharmony_ci            then:
9162306a36Sopenharmony_ci              properties:
9262306a36Sopenharmony_ci                groups:
9362306a36Sopenharmony_ci                  enum: [i2c]
9462306a36Sopenharmony_ci
9562306a36Sopenharmony_ci          - if:
9662306a36Sopenharmony_ci              properties:
9762306a36Sopenharmony_ci                function:
9862306a36Sopenharmony_ci                  const: i2s
9962306a36Sopenharmony_ci            then:
10062306a36Sopenharmony_ci              properties:
10162306a36Sopenharmony_ci                groups:
10262306a36Sopenharmony_ci                  enum: [i2s]
10362306a36Sopenharmony_ci
10462306a36Sopenharmony_ci          - if:
10562306a36Sopenharmony_ci              properties:
10662306a36Sopenharmony_ci                function:
10762306a36Sopenharmony_ci                  const: jtag
10862306a36Sopenharmony_ci            then:
10962306a36Sopenharmony_ci              properties:
11062306a36Sopenharmony_ci                groups:
11162306a36Sopenharmony_ci                  enum: [p0led_an, p0led_kn, p1led_an, p1led_kn, p2led_an,
11262306a36Sopenharmony_ci                         p2led_kn, p3led_an, p3led_kn, p4led_an, p4led_kn,
11362306a36Sopenharmony_ci                         sdmode]
11462306a36Sopenharmony_ci
11562306a36Sopenharmony_ci          - if:
11662306a36Sopenharmony_ci              properties:
11762306a36Sopenharmony_ci                function:
11862306a36Sopenharmony_ci                  const: p0led_an
11962306a36Sopenharmony_ci            then:
12062306a36Sopenharmony_ci              properties:
12162306a36Sopenharmony_ci                groups:
12262306a36Sopenharmony_ci                  enum: [p0led_an]
12362306a36Sopenharmony_ci
12462306a36Sopenharmony_ci          - if:
12562306a36Sopenharmony_ci              properties:
12662306a36Sopenharmony_ci                function:
12762306a36Sopenharmony_ci                  const: p0led_kn
12862306a36Sopenharmony_ci            then:
12962306a36Sopenharmony_ci              properties:
13062306a36Sopenharmony_ci                groups:
13162306a36Sopenharmony_ci                  enum: [p0led_kn]
13262306a36Sopenharmony_ci
13362306a36Sopenharmony_ci          - if:
13462306a36Sopenharmony_ci              properties:
13562306a36Sopenharmony_ci                function:
13662306a36Sopenharmony_ci                  const: p1led_an
13762306a36Sopenharmony_ci            then:
13862306a36Sopenharmony_ci              properties:
13962306a36Sopenharmony_ci                groups:
14062306a36Sopenharmony_ci                  enum: [p1led_an]
14162306a36Sopenharmony_ci
14262306a36Sopenharmony_ci          - if:
14362306a36Sopenharmony_ci              properties:
14462306a36Sopenharmony_ci                function:
14562306a36Sopenharmony_ci                  const: p1led_kn
14662306a36Sopenharmony_ci            then:
14762306a36Sopenharmony_ci              properties:
14862306a36Sopenharmony_ci                groups:
14962306a36Sopenharmony_ci                  enum: [p1led_kn]
15062306a36Sopenharmony_ci
15162306a36Sopenharmony_ci          - if:
15262306a36Sopenharmony_ci              properties:
15362306a36Sopenharmony_ci                function:
15462306a36Sopenharmony_ci                  const: p2led_an
15562306a36Sopenharmony_ci            then:
15662306a36Sopenharmony_ci              properties:
15762306a36Sopenharmony_ci                groups:
15862306a36Sopenharmony_ci                  enum: [p2led_an]
15962306a36Sopenharmony_ci
16062306a36Sopenharmony_ci          - if:
16162306a36Sopenharmony_ci              properties:
16262306a36Sopenharmony_ci                function:
16362306a36Sopenharmony_ci                  const: p2led_kn
16462306a36Sopenharmony_ci            then:
16562306a36Sopenharmony_ci              properties:
16662306a36Sopenharmony_ci                groups:
16762306a36Sopenharmony_ci                  enum: [p2led_kn]
16862306a36Sopenharmony_ci
16962306a36Sopenharmony_ci          - if:
17062306a36Sopenharmony_ci              properties:
17162306a36Sopenharmony_ci                function:
17262306a36Sopenharmony_ci                  const: p3led_an
17362306a36Sopenharmony_ci            then:
17462306a36Sopenharmony_ci              properties:
17562306a36Sopenharmony_ci                groups:
17662306a36Sopenharmony_ci                  enum: [p3led_an]
17762306a36Sopenharmony_ci
17862306a36Sopenharmony_ci          - if:
17962306a36Sopenharmony_ci              properties:
18062306a36Sopenharmony_ci                function:
18162306a36Sopenharmony_ci                  const: p3led_kn
18262306a36Sopenharmony_ci            then:
18362306a36Sopenharmony_ci              properties:
18462306a36Sopenharmony_ci                groups:
18562306a36Sopenharmony_ci                  enum: [p3led_kn]
18662306a36Sopenharmony_ci
18762306a36Sopenharmony_ci          - if:
18862306a36Sopenharmony_ci              properties:
18962306a36Sopenharmony_ci                function:
19062306a36Sopenharmony_ci                  const: p4led_an
19162306a36Sopenharmony_ci            then:
19262306a36Sopenharmony_ci              properties:
19362306a36Sopenharmony_ci                groups:
19462306a36Sopenharmony_ci                  enum: [p4led_an]
19562306a36Sopenharmony_ci
19662306a36Sopenharmony_ci          - if:
19762306a36Sopenharmony_ci              properties:
19862306a36Sopenharmony_ci                function:
19962306a36Sopenharmony_ci                  const: p4led_kn
20062306a36Sopenharmony_ci            then:
20162306a36Sopenharmony_ci              properties:
20262306a36Sopenharmony_ci                groups:
20362306a36Sopenharmony_ci                  enum: [p4led_kn]
20462306a36Sopenharmony_ci
20562306a36Sopenharmony_ci          - if:
20662306a36Sopenharmony_ci              properties:
20762306a36Sopenharmony_ci                function:
20862306a36Sopenharmony_ci                  const: pcie
20962306a36Sopenharmony_ci            then:
21062306a36Sopenharmony_ci              properties:
21162306a36Sopenharmony_ci                groups:
21262306a36Sopenharmony_ci                  enum: [gpio]
21362306a36Sopenharmony_ci
21462306a36Sopenharmony_ci          - if:
21562306a36Sopenharmony_ci              properties:
21662306a36Sopenharmony_ci                function:
21762306a36Sopenharmony_ci                  const: pcm
21862306a36Sopenharmony_ci            then:
21962306a36Sopenharmony_ci              properties:
22062306a36Sopenharmony_ci                groups:
22162306a36Sopenharmony_ci                  enum: [i2s]
22262306a36Sopenharmony_ci
22362306a36Sopenharmony_ci          - if:
22462306a36Sopenharmony_ci              properties:
22562306a36Sopenharmony_ci                function:
22662306a36Sopenharmony_ci                  const: perst
22762306a36Sopenharmony_ci            then:
22862306a36Sopenharmony_ci              properties:
22962306a36Sopenharmony_ci                groups:
23062306a36Sopenharmony_ci                  enum: [perst]
23162306a36Sopenharmony_ci
23262306a36Sopenharmony_ci          - if:
23362306a36Sopenharmony_ci              properties:
23462306a36Sopenharmony_ci                function:
23562306a36Sopenharmony_ci                  const: pwm
23662306a36Sopenharmony_ci            then:
23762306a36Sopenharmony_ci              properties:
23862306a36Sopenharmony_ci                groups:
23962306a36Sopenharmony_ci                  enum: [uart1, uart2]
24062306a36Sopenharmony_ci
24162306a36Sopenharmony_ci          - if:
24262306a36Sopenharmony_ci              properties:
24362306a36Sopenharmony_ci                function:
24462306a36Sopenharmony_ci                  const: pwm0
24562306a36Sopenharmony_ci            then:
24662306a36Sopenharmony_ci              properties:
24762306a36Sopenharmony_ci                groups:
24862306a36Sopenharmony_ci                  enum: [pwm0]
24962306a36Sopenharmony_ci
25062306a36Sopenharmony_ci          - if:
25162306a36Sopenharmony_ci              properties:
25262306a36Sopenharmony_ci                function:
25362306a36Sopenharmony_ci                  const: pwm1
25462306a36Sopenharmony_ci            then:
25562306a36Sopenharmony_ci              properties:
25662306a36Sopenharmony_ci                groups:
25762306a36Sopenharmony_ci                  enum: [pwm1]
25862306a36Sopenharmony_ci
25962306a36Sopenharmony_ci          - if:
26062306a36Sopenharmony_ci              properties:
26162306a36Sopenharmony_ci                function:
26262306a36Sopenharmony_ci                  const: pwm_uart2
26362306a36Sopenharmony_ci            then:
26462306a36Sopenharmony_ci              properties:
26562306a36Sopenharmony_ci                groups:
26662306a36Sopenharmony_ci                  enum: [spis]
26762306a36Sopenharmony_ci
26862306a36Sopenharmony_ci          - if:
26962306a36Sopenharmony_ci              properties:
27062306a36Sopenharmony_ci                function:
27162306a36Sopenharmony_ci                  const: refclk
27262306a36Sopenharmony_ci            then:
27362306a36Sopenharmony_ci              properties:
27462306a36Sopenharmony_ci                groups:
27562306a36Sopenharmony_ci                  enum: [gpio, refclk, spi cs1]
27662306a36Sopenharmony_ci
27762306a36Sopenharmony_ci          - if:
27862306a36Sopenharmony_ci              properties:
27962306a36Sopenharmony_ci                function:
28062306a36Sopenharmony_ci                  const: rsvd
28162306a36Sopenharmony_ci            then:
28262306a36Sopenharmony_ci              properties:
28362306a36Sopenharmony_ci                groups:
28462306a36Sopenharmony_ci                  enum: [p0led_an, p0led_kn, wled_an, wled_kn]
28562306a36Sopenharmony_ci
28662306a36Sopenharmony_ci          - if:
28762306a36Sopenharmony_ci              properties:
28862306a36Sopenharmony_ci                function:
28962306a36Sopenharmony_ci                  const: sdxc
29062306a36Sopenharmony_ci            then:
29162306a36Sopenharmony_ci              properties:
29262306a36Sopenharmony_ci                groups:
29362306a36Sopenharmony_ci                  enum: [sdmode]
29462306a36Sopenharmony_ci
29562306a36Sopenharmony_ci          - if:
29662306a36Sopenharmony_ci              properties:
29762306a36Sopenharmony_ci                function:
29862306a36Sopenharmony_ci                  const: sdxc d5 d4
29962306a36Sopenharmony_ci            then:
30062306a36Sopenharmony_ci              properties:
30162306a36Sopenharmony_ci                groups:
30262306a36Sopenharmony_ci                  enum: [uart2]
30362306a36Sopenharmony_ci
30462306a36Sopenharmony_ci          - if:
30562306a36Sopenharmony_ci              properties:
30662306a36Sopenharmony_ci                function:
30762306a36Sopenharmony_ci                  const: sdxc d6
30862306a36Sopenharmony_ci            then:
30962306a36Sopenharmony_ci              properties:
31062306a36Sopenharmony_ci                groups:
31162306a36Sopenharmony_ci                  enum: [pwm1]
31262306a36Sopenharmony_ci
31362306a36Sopenharmony_ci          - if:
31462306a36Sopenharmony_ci              properties:
31562306a36Sopenharmony_ci                function:
31662306a36Sopenharmony_ci                  const: sdxc d7
31762306a36Sopenharmony_ci            then:
31862306a36Sopenharmony_ci              properties:
31962306a36Sopenharmony_ci                groups:
32062306a36Sopenharmony_ci                  enum: [pwm0]
32162306a36Sopenharmony_ci
32262306a36Sopenharmony_ci          - if:
32362306a36Sopenharmony_ci              properties:
32462306a36Sopenharmony_ci                function:
32562306a36Sopenharmony_ci                  const: spi
32662306a36Sopenharmony_ci            then:
32762306a36Sopenharmony_ci              properties:
32862306a36Sopenharmony_ci                groups:
32962306a36Sopenharmony_ci                  enum: [spi]
33062306a36Sopenharmony_ci
33162306a36Sopenharmony_ci          - if:
33262306a36Sopenharmony_ci              properties:
33362306a36Sopenharmony_ci                function:
33462306a36Sopenharmony_ci                  const: spi cs1
33562306a36Sopenharmony_ci            then:
33662306a36Sopenharmony_ci              properties:
33762306a36Sopenharmony_ci                groups:
33862306a36Sopenharmony_ci                  enum: [spi cs1]
33962306a36Sopenharmony_ci
34062306a36Sopenharmony_ci          - if:
34162306a36Sopenharmony_ci              properties:
34262306a36Sopenharmony_ci                function:
34362306a36Sopenharmony_ci                  const: spis
34462306a36Sopenharmony_ci            then:
34562306a36Sopenharmony_ci              properties:
34662306a36Sopenharmony_ci                groups:
34762306a36Sopenharmony_ci                  enum: [spis]
34862306a36Sopenharmony_ci
34962306a36Sopenharmony_ci          - if:
35062306a36Sopenharmony_ci              properties:
35162306a36Sopenharmony_ci                function:
35262306a36Sopenharmony_ci                  const: sw_r
35362306a36Sopenharmony_ci            then:
35462306a36Sopenharmony_ci              properties:
35562306a36Sopenharmony_ci                groups:
35662306a36Sopenharmony_ci                  enum: [uart1]
35762306a36Sopenharmony_ci
35862306a36Sopenharmony_ci          - if:
35962306a36Sopenharmony_ci              properties:
36062306a36Sopenharmony_ci                function:
36162306a36Sopenharmony_ci                  const: uart0
36262306a36Sopenharmony_ci            then:
36362306a36Sopenharmony_ci              properties:
36462306a36Sopenharmony_ci                groups:
36562306a36Sopenharmony_ci                  enum: [uart0]
36662306a36Sopenharmony_ci
36762306a36Sopenharmony_ci          - if:
36862306a36Sopenharmony_ci              properties:
36962306a36Sopenharmony_ci                function:
37062306a36Sopenharmony_ci                  const: uart1
37162306a36Sopenharmony_ci            then:
37262306a36Sopenharmony_ci              properties:
37362306a36Sopenharmony_ci                groups:
37462306a36Sopenharmony_ci                  enum: [uart1]
37562306a36Sopenharmony_ci
37662306a36Sopenharmony_ci          - if:
37762306a36Sopenharmony_ci              properties:
37862306a36Sopenharmony_ci                function:
37962306a36Sopenharmony_ci                  const: uart2
38062306a36Sopenharmony_ci            then:
38162306a36Sopenharmony_ci              properties:
38262306a36Sopenharmony_ci                groups:
38362306a36Sopenharmony_ci                  enum: [uart2]
38462306a36Sopenharmony_ci
38562306a36Sopenharmony_ci          - if:
38662306a36Sopenharmony_ci              properties:
38762306a36Sopenharmony_ci                function:
38862306a36Sopenharmony_ci                  const: utif
38962306a36Sopenharmony_ci            then:
39062306a36Sopenharmony_ci              properties:
39162306a36Sopenharmony_ci                groups:
39262306a36Sopenharmony_ci                  enum: [p1led_an, p1led_kn, p2led_an, p2led_kn, p3led_an,
39362306a36Sopenharmony_ci                         p3led_kn, p4led_an, p4led_kn, pwm0, pwm1, sdmode, spis]
39462306a36Sopenharmony_ci
39562306a36Sopenharmony_ci          - if:
39662306a36Sopenharmony_ci              properties:
39762306a36Sopenharmony_ci                function:
39862306a36Sopenharmony_ci                  const: wdt
39962306a36Sopenharmony_ci            then:
40062306a36Sopenharmony_ci              properties:
40162306a36Sopenharmony_ci                groups:
40262306a36Sopenharmony_ci                  enum: [wdt]
40362306a36Sopenharmony_ci
40462306a36Sopenharmony_ci          - if:
40562306a36Sopenharmony_ci              properties:
40662306a36Sopenharmony_ci                function:
40762306a36Sopenharmony_ci                  const: wled_an
40862306a36Sopenharmony_ci            then:
40962306a36Sopenharmony_ci              properties:
41062306a36Sopenharmony_ci                groups:
41162306a36Sopenharmony_ci                  enum: [wled_an]
41262306a36Sopenharmony_ci
41362306a36Sopenharmony_ci          - if:
41462306a36Sopenharmony_ci              properties:
41562306a36Sopenharmony_ci                function:
41662306a36Sopenharmony_ci                  const: wled_kn
41762306a36Sopenharmony_ci            then:
41862306a36Sopenharmony_ci              properties:
41962306a36Sopenharmony_ci                groups:
42062306a36Sopenharmony_ci                  enum: [wled_kn]
42162306a36Sopenharmony_ci
42262306a36Sopenharmony_ci          - if:
42362306a36Sopenharmony_ci              properties:
42462306a36Sopenharmony_ci                function:
42562306a36Sopenharmony_ci                  const: "-"
42662306a36Sopenharmony_ci            then:
42762306a36Sopenharmony_ci              properties:
42862306a36Sopenharmony_ci                groups:
42962306a36Sopenharmony_ci                  enum: [i2c, spi cs1, uart0]
43062306a36Sopenharmony_ci
43162306a36Sopenharmony_ciallOf:
43262306a36Sopenharmony_ci  - $ref: pinctrl.yaml#
43362306a36Sopenharmony_ci
43462306a36Sopenharmony_cirequired:
43562306a36Sopenharmony_ci  - compatible
43662306a36Sopenharmony_ci
43762306a36Sopenharmony_ciadditionalProperties: false
43862306a36Sopenharmony_ci
43962306a36Sopenharmony_ciexamples:
44062306a36Sopenharmony_ci  - |
44162306a36Sopenharmony_ci    pinctrl {
44262306a36Sopenharmony_ci      compatible = "ralink,mt76x8-pinctrl";
44362306a36Sopenharmony_ci
44462306a36Sopenharmony_ci      i2c_pins: i2c0-pins {
44562306a36Sopenharmony_ci        pinmux {
44662306a36Sopenharmony_ci          groups = "i2c";
44762306a36Sopenharmony_ci          function = "i2c";
44862306a36Sopenharmony_ci        };
44962306a36Sopenharmony_ci      };
45062306a36Sopenharmony_ci    };
451