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/ralink,rt2880-pinctrl.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Ralink RT2880 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  Ralink RT2880 pin controller for RT2880 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,rt2880-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: [gpio, i2c, spi, uartlite, jtag, mdio, sdram, pci]
3962306a36Sopenharmony_ci
4062306a36Sopenharmony_ci          groups:
4162306a36Sopenharmony_ci            description:
4262306a36Sopenharmony_ci              An array of strings. Each string contains the name of a group.
4362306a36Sopenharmony_ci            maxItems: 1
4462306a36Sopenharmony_ci
4562306a36Sopenharmony_ci        required:
4662306a36Sopenharmony_ci          - groups
4762306a36Sopenharmony_ci          - function
4862306a36Sopenharmony_ci
4962306a36Sopenharmony_ci        allOf:
5062306a36Sopenharmony_ci          - if:
5162306a36Sopenharmony_ci              properties:
5262306a36Sopenharmony_ci                function:
5362306a36Sopenharmony_ci                  const: gpio
5462306a36Sopenharmony_ci            then:
5562306a36Sopenharmony_ci              properties:
5662306a36Sopenharmony_ci                groups:
5762306a36Sopenharmony_ci                  enum: [i2c, spi, uartlite, jtag, mdio, sdram, pci]
5862306a36Sopenharmony_ci
5962306a36Sopenharmony_ci          - if:
6062306a36Sopenharmony_ci              properties:
6162306a36Sopenharmony_ci                function:
6262306a36Sopenharmony_ci                  const: i2c
6362306a36Sopenharmony_ci            then:
6462306a36Sopenharmony_ci              properties:
6562306a36Sopenharmony_ci                groups:
6662306a36Sopenharmony_ci                  enum: [i2c]
6762306a36Sopenharmony_ci
6862306a36Sopenharmony_ci          - if:
6962306a36Sopenharmony_ci              properties:
7062306a36Sopenharmony_ci                function:
7162306a36Sopenharmony_ci                  const: spi
7262306a36Sopenharmony_ci            then:
7362306a36Sopenharmony_ci              properties:
7462306a36Sopenharmony_ci                groups:
7562306a36Sopenharmony_ci                  enum: [spi]
7662306a36Sopenharmony_ci
7762306a36Sopenharmony_ci          - if:
7862306a36Sopenharmony_ci              properties:
7962306a36Sopenharmony_ci                function:
8062306a36Sopenharmony_ci                  const: uartlite
8162306a36Sopenharmony_ci            then:
8262306a36Sopenharmony_ci              properties:
8362306a36Sopenharmony_ci                groups:
8462306a36Sopenharmony_ci                  enum: [uartlite]
8562306a36Sopenharmony_ci
8662306a36Sopenharmony_ci          - if:
8762306a36Sopenharmony_ci              properties:
8862306a36Sopenharmony_ci                function:
8962306a36Sopenharmony_ci                  const: jtag
9062306a36Sopenharmony_ci            then:
9162306a36Sopenharmony_ci              properties:
9262306a36Sopenharmony_ci                groups:
9362306a36Sopenharmony_ci                  enum: [jtag]
9462306a36Sopenharmony_ci
9562306a36Sopenharmony_ci          - if:
9662306a36Sopenharmony_ci              properties:
9762306a36Sopenharmony_ci                function:
9862306a36Sopenharmony_ci                  const: mdio
9962306a36Sopenharmony_ci            then:
10062306a36Sopenharmony_ci              properties:
10162306a36Sopenharmony_ci                groups:
10262306a36Sopenharmony_ci                  enum: [mdio]
10362306a36Sopenharmony_ci
10462306a36Sopenharmony_ci          - if:
10562306a36Sopenharmony_ci              properties:
10662306a36Sopenharmony_ci                function:
10762306a36Sopenharmony_ci                  const: sdram
10862306a36Sopenharmony_ci            then:
10962306a36Sopenharmony_ci              properties:
11062306a36Sopenharmony_ci                groups:
11162306a36Sopenharmony_ci                  enum: [sdram]
11262306a36Sopenharmony_ci
11362306a36Sopenharmony_ci          - if:
11462306a36Sopenharmony_ci              properties:
11562306a36Sopenharmony_ci                function:
11662306a36Sopenharmony_ci                  const: pci
11762306a36Sopenharmony_ci            then:
11862306a36Sopenharmony_ci              properties:
11962306a36Sopenharmony_ci                groups:
12062306a36Sopenharmony_ci                  enum: [pci]
12162306a36Sopenharmony_ci
12262306a36Sopenharmony_ciallOf:
12362306a36Sopenharmony_ci  - $ref: pinctrl.yaml#
12462306a36Sopenharmony_ci
12562306a36Sopenharmony_cirequired:
12662306a36Sopenharmony_ci  - compatible
12762306a36Sopenharmony_ci
12862306a36Sopenharmony_ciadditionalProperties: false
12962306a36Sopenharmony_ci
13062306a36Sopenharmony_ciexamples:
13162306a36Sopenharmony_ci  - |
13262306a36Sopenharmony_ci    pinctrl {
13362306a36Sopenharmony_ci      compatible = "ralink,rt2880-pinctrl";
13462306a36Sopenharmony_ci
13562306a36Sopenharmony_ci      i2c_pins: i2c0-pins {
13662306a36Sopenharmony_ci        pinmux {
13762306a36Sopenharmony_ci          groups = "i2c";
13862306a36Sopenharmony_ci          function = "i2c";
13962306a36Sopenharmony_ci        };
14062306a36Sopenharmony_ci      };
14162306a36Sopenharmony_ci    };
142