162306a36Sopenharmony_ci# SPDX-License-Identifier: (GPL-2.0+ OR BSD-2-Clause)
262306a36Sopenharmony_ci%YAML 1.2
362306a36Sopenharmony_ci---
462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/sound/allwinner,sun4i-a10-i2s.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Allwinner A10 I2S 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  "#sound-dai-cells":
1562306a36Sopenharmony_ci    const: 0
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_ci  compatible:
1862306a36Sopenharmony_ci    oneOf:
1962306a36Sopenharmony_ci      - const: allwinner,sun4i-a10-i2s
2062306a36Sopenharmony_ci      - const: allwinner,sun6i-a31-i2s
2162306a36Sopenharmony_ci      - const: allwinner,sun8i-a83t-i2s
2262306a36Sopenharmony_ci      - const: allwinner,sun8i-h3-i2s
2362306a36Sopenharmony_ci      - items:
2462306a36Sopenharmony_ci          - const: allwinner,sun8i-r40-i2s
2562306a36Sopenharmony_ci          - const: allwinner,sun8i-h3-i2s
2662306a36Sopenharmony_ci      - items:
2762306a36Sopenharmony_ci          - const: allwinner,sun8i-v3-i2s
2862306a36Sopenharmony_ci          - const: allwinner,sun8i-h3-i2s
2962306a36Sopenharmony_ci      - const: allwinner,sun50i-a64-codec-i2s
3062306a36Sopenharmony_ci      - items:
3162306a36Sopenharmony_ci          - const: allwinner,sun50i-a64-i2s
3262306a36Sopenharmony_ci          - const: allwinner,sun8i-h3-i2s
3362306a36Sopenharmony_ci      - const: allwinner,sun50i-h6-i2s
3462306a36Sopenharmony_ci      - const: allwinner,sun50i-r329-i2s
3562306a36Sopenharmony_ci      - items:
3662306a36Sopenharmony_ci          - const: allwinner,sun20i-d1-i2s
3762306a36Sopenharmony_ci          - const: allwinner,sun50i-r329-i2s
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_ci  reg:
4062306a36Sopenharmony_ci    maxItems: 1
4162306a36Sopenharmony_ci
4262306a36Sopenharmony_ci  interrupts:
4362306a36Sopenharmony_ci    maxItems: 1
4462306a36Sopenharmony_ci
4562306a36Sopenharmony_ci  clocks:
4662306a36Sopenharmony_ci    items:
4762306a36Sopenharmony_ci      - description: Bus Clock
4862306a36Sopenharmony_ci      - description: Module Clock
4962306a36Sopenharmony_ci
5062306a36Sopenharmony_ci  clock-names:
5162306a36Sopenharmony_ci    items:
5262306a36Sopenharmony_ci      - const: apb
5362306a36Sopenharmony_ci      - const: mod
5462306a36Sopenharmony_ci
5562306a36Sopenharmony_ci  # Even though it only applies to subschemas under the conditionals,
5662306a36Sopenharmony_ci  # not listing them here will trigger a warning because of the
5762306a36Sopenharmony_ci  # additionalsProperties set to false.
5862306a36Sopenharmony_ci  dmas: true
5962306a36Sopenharmony_ci  dma-names: true
6062306a36Sopenharmony_ci  resets:
6162306a36Sopenharmony_ci    maxItems: 1
6262306a36Sopenharmony_ci
6362306a36Sopenharmony_ciallOf:
6462306a36Sopenharmony_ci  - $ref: dai-common.yaml#
6562306a36Sopenharmony_ci  - if:
6662306a36Sopenharmony_ci      properties:
6762306a36Sopenharmony_ci        compatible:
6862306a36Sopenharmony_ci          contains:
6962306a36Sopenharmony_ci            enum:
7062306a36Sopenharmony_ci              - allwinner,sun6i-a31-i2s
7162306a36Sopenharmony_ci              - allwinner,sun8i-a83t-i2s
7262306a36Sopenharmony_ci              - allwinner,sun8i-h3-i2s
7362306a36Sopenharmony_ci              - allwinner,sun50i-a64-codec-i2s
7462306a36Sopenharmony_ci              - allwinner,sun50i-h6-i2s
7562306a36Sopenharmony_ci              - allwinner,sun50i-r329-i2s
7662306a36Sopenharmony_ci
7762306a36Sopenharmony_ci    then:
7862306a36Sopenharmony_ci      required:
7962306a36Sopenharmony_ci        - resets
8062306a36Sopenharmony_ci
8162306a36Sopenharmony_ci  - if:
8262306a36Sopenharmony_ci      properties:
8362306a36Sopenharmony_ci        compatible:
8462306a36Sopenharmony_ci          contains:
8562306a36Sopenharmony_ci            enum:
8662306a36Sopenharmony_ci              - allwinner,sun8i-a83t-i2s
8762306a36Sopenharmony_ci              - allwinner,sun8i-h3-i2s
8862306a36Sopenharmony_ci
8962306a36Sopenharmony_ci    then:
9062306a36Sopenharmony_ci      properties:
9162306a36Sopenharmony_ci        dmas:
9262306a36Sopenharmony_ci          minItems: 1
9362306a36Sopenharmony_ci          items:
9462306a36Sopenharmony_ci            - description: RX DMA Channel
9562306a36Sopenharmony_ci            - description: TX DMA Channel
9662306a36Sopenharmony_ci          description:
9762306a36Sopenharmony_ci            Some controllers cannot receive but can only transmit
9862306a36Sopenharmony_ci            data. In such a case, the RX DMA channel is to be omitted.
9962306a36Sopenharmony_ci
10062306a36Sopenharmony_ci        dma-names:
10162306a36Sopenharmony_ci          oneOf:
10262306a36Sopenharmony_ci            - items:
10362306a36Sopenharmony_ci                - const: rx
10462306a36Sopenharmony_ci                - const: tx
10562306a36Sopenharmony_ci            - const: tx
10662306a36Sopenharmony_ci          description:
10762306a36Sopenharmony_ci            Some controllers cannot receive but can only transmit
10862306a36Sopenharmony_ci            data. In such a case, the RX name is to be omitted.
10962306a36Sopenharmony_ci
11062306a36Sopenharmony_ci    else:
11162306a36Sopenharmony_ci      properties:
11262306a36Sopenharmony_ci        dmas:
11362306a36Sopenharmony_ci          items:
11462306a36Sopenharmony_ci            - description: RX DMA Channel
11562306a36Sopenharmony_ci            - description: TX DMA Channel
11662306a36Sopenharmony_ci
11762306a36Sopenharmony_ci        dma-names:
11862306a36Sopenharmony_ci          items:
11962306a36Sopenharmony_ci            - const: rx
12062306a36Sopenharmony_ci            - const: tx
12162306a36Sopenharmony_ci
12262306a36Sopenharmony_cirequired:
12362306a36Sopenharmony_ci  - "#sound-dai-cells"
12462306a36Sopenharmony_ci  - compatible
12562306a36Sopenharmony_ci  - reg
12662306a36Sopenharmony_ci  - interrupts
12762306a36Sopenharmony_ci  - clocks
12862306a36Sopenharmony_ci  - clock-names
12962306a36Sopenharmony_ci  - dmas
13062306a36Sopenharmony_ci  - dma-names
13162306a36Sopenharmony_ci
13262306a36Sopenharmony_ciunevaluatedProperties: false
13362306a36Sopenharmony_ci
13462306a36Sopenharmony_ciexamples:
13562306a36Sopenharmony_ci  - |
13662306a36Sopenharmony_ci    i2s0: i2s@1c22400 {
13762306a36Sopenharmony_ci        #sound-dai-cells = <0>;
13862306a36Sopenharmony_ci        compatible = "allwinner,sun4i-a10-i2s";
13962306a36Sopenharmony_ci        reg = <0x01c22400 0x400>;
14062306a36Sopenharmony_ci        interrupts = <0 16 4>;
14162306a36Sopenharmony_ci        clocks = <&apb0_gates 3>, <&i2s0_clk>;
14262306a36Sopenharmony_ci        clock-names = "apb", "mod";
14362306a36Sopenharmony_ci        dmas = <&dma 0 3>, <&dma 0 3>;
14462306a36Sopenharmony_ci        dma-names = "rx", "tx";
14562306a36Sopenharmony_ci    };
14662306a36Sopenharmony_ci
14762306a36Sopenharmony_ci...
148