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/sound/nvidia,tegra210-i2s.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Tegra210 I2S Controller
862306a36Sopenharmony_ci
962306a36Sopenharmony_cidescription: |
1062306a36Sopenharmony_ci  The Inter-IC Sound (I2S) controller implements full-duplex,
1162306a36Sopenharmony_ci  bi-directional and single direction point-to-point serial
1262306a36Sopenharmony_ci  interfaces. It can interface with I2S compatible devices.
1362306a36Sopenharmony_ci  I2S controller can operate both in master and slave mode.
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_cimaintainers:
1662306a36Sopenharmony_ci  - Jon Hunter <jonathanh@nvidia.com>
1762306a36Sopenharmony_ci  - Sameer Pujar <spujar@nvidia.com>
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_ciallOf:
2062306a36Sopenharmony_ci  - $ref: dai-common.yaml#
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_ciproperties:
2362306a36Sopenharmony_ci  $nodename:
2462306a36Sopenharmony_ci    pattern: "^i2s@[0-9a-f]*$"
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_ci  compatible:
2762306a36Sopenharmony_ci    oneOf:
2862306a36Sopenharmony_ci      - const: nvidia,tegra210-i2s
2962306a36Sopenharmony_ci      - items:
3062306a36Sopenharmony_ci          - enum:
3162306a36Sopenharmony_ci              - nvidia,tegra234-i2s
3262306a36Sopenharmony_ci              - nvidia,tegra194-i2s
3362306a36Sopenharmony_ci              - nvidia,tegra186-i2s
3462306a36Sopenharmony_ci          - const: nvidia,tegra210-i2s
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ci  reg:
3762306a36Sopenharmony_ci    maxItems: 1
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_ci  clocks:
4062306a36Sopenharmony_ci    minItems: 1
4162306a36Sopenharmony_ci    items:
4262306a36Sopenharmony_ci      - description: I2S bit clock
4362306a36Sopenharmony_ci      - description:
4462306a36Sopenharmony_ci          Sync input clock, which can act as clock source to other I/O
4562306a36Sopenharmony_ci          modules in AHUB. The Tegra I2S driver sets this clock rate as
4662306a36Sopenharmony_ci          per bit clock rate. I/O module which wants to use this clock
4762306a36Sopenharmony_ci          as source, can mention this clock as parent in the DT bindings.
4862306a36Sopenharmony_ci          This is an optional clock entry, since it is only required when
4962306a36Sopenharmony_ci          some other I/O wants to reference from a particular I2Sx
5062306a36Sopenharmony_ci          instance.
5162306a36Sopenharmony_ci
5262306a36Sopenharmony_ci  clock-names:
5362306a36Sopenharmony_ci    minItems: 1
5462306a36Sopenharmony_ci    items:
5562306a36Sopenharmony_ci      - const: i2s
5662306a36Sopenharmony_ci      - const: sync_input
5762306a36Sopenharmony_ci
5862306a36Sopenharmony_ci  assigned-clocks:
5962306a36Sopenharmony_ci    minItems: 1
6062306a36Sopenharmony_ci    maxItems: 2
6162306a36Sopenharmony_ci
6262306a36Sopenharmony_ci  assigned-clock-parents:
6362306a36Sopenharmony_ci    minItems: 1
6462306a36Sopenharmony_ci    maxItems: 2
6562306a36Sopenharmony_ci
6662306a36Sopenharmony_ci  assigned-clock-rates:
6762306a36Sopenharmony_ci    minItems: 1
6862306a36Sopenharmony_ci    maxItems: 2
6962306a36Sopenharmony_ci
7062306a36Sopenharmony_ci  sound-name-prefix:
7162306a36Sopenharmony_ci    pattern: "^I2S[1-9]$"
7262306a36Sopenharmony_ci
7362306a36Sopenharmony_ci  ports:
7462306a36Sopenharmony_ci    $ref: /schemas/graph.yaml#/properties/ports
7562306a36Sopenharmony_ci    properties:
7662306a36Sopenharmony_ci      port@0:
7762306a36Sopenharmony_ci        $ref: audio-graph-port.yaml#
7862306a36Sopenharmony_ci        unevaluatedProperties: false
7962306a36Sopenharmony_ci        description: |
8062306a36Sopenharmony_ci          I2S ACIF (Audio Client Interface) port connected to the
8162306a36Sopenharmony_ci          corresponding AHUB (Audio Hub) ACIF port.
8262306a36Sopenharmony_ci
8362306a36Sopenharmony_ci      port@1:
8462306a36Sopenharmony_ci        $ref: audio-graph-port.yaml#
8562306a36Sopenharmony_ci        unevaluatedProperties: false
8662306a36Sopenharmony_ci        description: |
8762306a36Sopenharmony_ci          I2S DAP (Digital Audio Port) interface which can be connected
8862306a36Sopenharmony_ci          to external audio codec for playback or capture.
8962306a36Sopenharmony_ci
9062306a36Sopenharmony_cirequired:
9162306a36Sopenharmony_ci  - compatible
9262306a36Sopenharmony_ci  - reg
9362306a36Sopenharmony_ci  - clocks
9462306a36Sopenharmony_ci  - clock-names
9562306a36Sopenharmony_ci  - assigned-clocks
9662306a36Sopenharmony_ci  - assigned-clock-parents
9762306a36Sopenharmony_ci
9862306a36Sopenharmony_ciadditionalProperties: false
9962306a36Sopenharmony_ci
10062306a36Sopenharmony_ciexamples:
10162306a36Sopenharmony_ci  - |
10262306a36Sopenharmony_ci    #include<dt-bindings/clock/tegra210-car.h>
10362306a36Sopenharmony_ci
10462306a36Sopenharmony_ci    i2s@702d1000 {
10562306a36Sopenharmony_ci        compatible = "nvidia,tegra210-i2s";
10662306a36Sopenharmony_ci        reg = <0x702d1000 0x100>;
10762306a36Sopenharmony_ci        clocks = <&tegra_car TEGRA210_CLK_I2S0>;
10862306a36Sopenharmony_ci        clock-names = "i2s";
10962306a36Sopenharmony_ci        assigned-clocks = <&tegra_car TEGRA210_CLK_I2S0>;
11062306a36Sopenharmony_ci        assigned-clock-parents = <&tegra_car TEGRA210_CLK_PLL_A_OUT0>;
11162306a36Sopenharmony_ci        assigned-clock-rates = <1536000>;
11262306a36Sopenharmony_ci        sound-name-prefix = "I2S1";
11362306a36Sopenharmony_ci    };
11462306a36Sopenharmony_ci
11562306a36Sopenharmony_ci...
116