# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) %YAML 1.2 --- $id: http://devicetree.org/schemas/sound/renesas,rsnd.yaml# $schema: http://devicetree.org/meta-schemas/core.yaml# title: Renesas R-Car Sound Driver maintainers: - Kuninori Morimoto properties: compatible: oneOf: # for Gen1 SoC - items: - enum: - renesas,rcar_sound-r8a7778 # R-Car M1A - renesas,rcar_sound-r8a7779 # R-Car H1 - const: renesas,rcar_sound-gen1 # for Gen2 SoC - items: - enum: - renesas,rcar_sound-r8a7742 # RZ/G1H - renesas,rcar_sound-r8a7743 # RZ/G1M - renesas,rcar_sound-r8a7744 # RZ/G1N - renesas,rcar_sound-r8a7745 # RZ/G1E - renesas,rcar_sound-r8a77470 # RZ/G1C - renesas,rcar_sound-r8a7790 # R-Car H2 - renesas,rcar_sound-r8a7791 # R-Car M2-W - renesas,rcar_sound-r8a7793 # R-Car M2-N - renesas,rcar_sound-r8a7794 # R-Car E2 - const: renesas,rcar_sound-gen2 # for Gen3 SoC - items: - enum: - renesas,rcar_sound-r8a774a1 # RZ/G2M - renesas,rcar_sound-r8a774b1 # RZ/G2N - renesas,rcar_sound-r8a774c0 # RZ/G2E - renesas,rcar_sound-r8a774e1 # RZ/G2H - renesas,rcar_sound-r8a7795 # R-Car H3 - renesas,rcar_sound-r8a7796 # R-Car M3-W - renesas,rcar_sound-r8a77961 # R-Car M3-W+ - renesas,rcar_sound-r8a77965 # R-Car M3-N - renesas,rcar_sound-r8a77990 # R-Car E3 - renesas,rcar_sound-r8a77995 # R-Car D3 - const: renesas,rcar_sound-gen3 # for Gen4 SoC - items: - enum: - renesas,rcar_sound-r8a779g0 # R-Car V4H - renesas,rcar_sound-r8a779h0 # R-Car V4M - const: renesas,rcar_sound-gen4 # for Generic - enum: - renesas,rcar_sound-gen1 - renesas,rcar_sound-gen2 - renesas,rcar_sound-gen3 - renesas,rcar_sound-gen4 reg: minItems: 1 maxItems: 5 reg-names: minItems: 1 maxItems: 5 "#sound-dai-cells": description: | it must be 0 if your system is using single DAI it must be 1 if your system is using multi DAIs This is used on simple-audio-card enum: [0, 1] "#clock-cells": description: | it must be 0 if your system has audio_clkout it must be 1 if your system has audio_clkout0/1/2/3 enum: [0, 1] "#address-cells": const: 1 "#size-cells": const: 0 clock-frequency: description: for audio_clkout0/1/2/3 clkout-lr-asynchronous: description: audio_clkoutn is asynchronizes with lr-clock. $ref: /schemas/types.yaml#/definitions/flag power-domains: true resets: minItems: 1 maxItems: 11 reset-names: minItems: 1 maxItems: 11 clocks: description: References to SSI/SRC/MIX/CTU/DVC/AUDIO_CLK clocks. minItems: 1 maxItems: 31 clock-names: description: List of necessary clock names. # details are defined below post-init-providers: description: At least if rsnd is using DPCM connection on Audio-Graph-Card2, fw_devlink might doesn't have enough information to break the cycle. rsnd driver will not be probed in such case. Same problem might occur with Multi-CPU/Codec or Codec2Codec. # ports is below port: $ref: audio-graph-port.yaml#/definitions/port-base unevaluatedProperties: false patternProperties: "^endpoint(@[0-9a-f]+)?": $ref: audio-graph-port.yaml#/definitions/endpoint-base properties: playback: $ref: /schemas/types.yaml#/definitions/phandle-array capture: $ref: /schemas/types.yaml#/definitions/phandle-array unevaluatedProperties: false rcar_sound,dvc: description: DVC subnode. type: object patternProperties: "^dvc-[0-1]$": type: object additionalProperties: false properties: dmas: maxItems: 1 dma-names: const: tx required: - dmas - dma-names additionalProperties: false rcar_sound,mix: description: MIX subnode. type: object patternProperties: "^mix-[0-1]$": type: object additionalProperties: false additionalProperties: false rcar_sound,ctu: description: CTU subnode. type: object patternProperties: "^ctu-[0-7]$": type: object additionalProperties: false additionalProperties: false rcar_sound,src: description: SRC subnode. type: object patternProperties: "^src-[0-9]$": type: object additionalProperties: false properties: interrupts: maxItems: 1 dmas: maxItems: 2 dma-names: allOf: - items: enum: - tx - rx additionalProperties: false rcar_sound,ssiu: description: SSIU subnode. type: object patternProperties: "^ssiu-[0-9]+$": type: object additionalProperties: false properties: dmas: maxItems: 2 dma-names: allOf: - items: enum: - tx - rx required: - dmas - dma-names additionalProperties: false rcar_sound,ssi: description: SSI subnode. type: object patternProperties: "^ssi-[0-9]$": type: object additionalProperties: false properties: interrupts: maxItems: 1 dmas: minItems: 2 maxItems: 4 dma-names: allOf: - items: enum: - tx - rx - txu # if no ssiu node - rxu # if no ssiu node shared-pin: description: shared clock pin $ref: /schemas/types.yaml#/definitions/flag pio-transfer: description: PIO transfer mode $ref: /schemas/types.yaml#/definitions/flag no-busif: description: BUSIF is not used when [mem -> SSI] via DMA case $ref: /schemas/types.yaml#/definitions/flag required: - interrupts additionalProperties: false patternProperties: # For DAI base 'rcar_sound,dai(@[0-9a-f]+)?$': description: DAI subnode. type: object patternProperties: "^dai([0-9]+)?$": type: object additionalProperties: false properties: playback: $ref: /schemas/types.yaml#/definitions/phandle-array capture: $ref: /schemas/types.yaml#/definitions/phandle-array anyOf: - required: - playback - required: - capture additionalProperties: false 'ports(@[0-9a-f]+)?$': $ref: audio-graph-port.yaml#/definitions/port-base unevaluatedProperties: false patternProperties: '^port(@[0-9a-f]+)?$': $ref: "#/properties/port" required: - compatible - reg - reg-names - clocks - clock-names allOf: - $ref: dai-common.yaml# # -------------------- # reg/reg-names # -------------------- # for Gen1 - if: properties: compatible: contains: const: renesas,rcar_sound-gen1 then: properties: reg: maxItems: 3 reg-names: items: enum: - sru - ssi - adg # for Gen2/Gen3 - if: properties: compatible: contains: enum: - renesas,rcar_sound-gen2 - renesas,rcar_sound-gen3 then: properties: reg: minItems: 5 reg-names: items: enum: - scu - adg - ssiu - ssi - audmapp # for Gen4 - if: properties: compatible: contains: const: renesas,rcar_sound-gen4 then: properties: reg: maxItems: 4 reg-names: items: enum: - adg - ssiu - ssi - sdmc # -------------------- # clock-names # -------------------- - if: properties: compatible: contains: const: renesas,rcar_sound-gen4 then: properties: clock-names: maxItems: 3 items: enum: - ssi.0 - ssiu.0 - clkin else: properties: clock-names: minItems: 1 maxItems: 31 items: oneOf: - const: ssi-all - pattern: '^ssi\.[0-9]$' - pattern: '^src\.[0-9]$' - pattern: '^mix\.[0-1]$' - pattern: '^ctu\.[0-1]$' - pattern: '^dvc\.[0-1]$' - pattern: '^clk_(a|b|c|i)$' unevaluatedProperties: false examples: - | #include #include #include rcar_sound: sound@ec500000 { #sound-dai-cells = <1>; compatible = "renesas,rcar_sound-r8a7790", "renesas,rcar_sound-gen2"; reg = <0xec500000 0x1000>, /* SCU */ <0xec5a0000 0x100>, /* ADG */ <0xec540000 0x1000>, /* SSIU */ <0xec541000 0x280>, /* SSI */ <0xec740000 0x200>; /* Audio DMAC peri peri*/ reg-names = "scu", "adg", "ssiu", "ssi", "audmapp"; clocks = <&cpg CPG_MOD 1005>, /* SSI-ALL */ <&cpg CPG_MOD 1006>, <&cpg CPG_MOD 1007>, /* SSI9, SSI8 */ <&cpg CPG_MOD 1008>, <&cpg CPG_MOD 1009>, /* SSI7, SSI6 */ <&cpg CPG_MOD 1010>, <&cpg CPG_MOD 1011>, /* SSI5, SSI4 */ <&cpg CPG_MOD 1012>, <&cpg CPG_MOD 1013>, /* SSI3, SSI2 */ <&cpg CPG_MOD 1014>, <&cpg CPG_MOD 1015>, /* SSI1, SSI0 */ <&cpg CPG_MOD 1022>, <&cpg CPG_MOD 1023>, /* SRC9, SRC8 */ <&cpg CPG_MOD 1024>, <&cpg CPG_MOD 1025>, /* SRC7, SRC6 */ <&cpg CPG_MOD 1026>, <&cpg CPG_MOD 1027>, /* SRC5, SRC4 */ <&cpg CPG_MOD 1028>, <&cpg CPG_MOD 1029>, /* SRC3, SRC2 */ <&cpg CPG_MOD 1030>, <&cpg CPG_MOD 1031>, /* SRC1, SRC0 */ <&cpg CPG_MOD 1020>, <&cpg CPG_MOD 1021>, /* MIX1, MIX0 */ <&cpg CPG_MOD 1020>, <&cpg CPG_MOD 1021>, /* CTU1, CTU0 */ <&cpg CPG_MOD 1019>, <&cpg CPG_MOD 1018>, /* DVC0, DVC1 */ <&audio_clk_a>, <&audio_clk_b>, /* CLKA, CLKB */ <&audio_clk_c>, <&audio_clk_i>; /* CLKC, CLKI */ clock-names = "ssi-all", "ssi.9", "ssi.8", "ssi.7", "ssi.6", "ssi.5", "ssi.4", "ssi.3", "ssi.2", "ssi.1", "ssi.0", "src.9", "src.8", "src.7", "src.6", "src.5", "src.4", "src.3", "src.2", "src.1", "src.0", "mix.1", "mix.0", "ctu.1", "ctu.0", "dvc.0", "dvc.1", "clk_a", "clk_b", "clk_c", "clk_i"; power-domains = <&sysc R8A7790_PD_ALWAYS_ON>; resets = <&cpg 1005>, <&cpg 1006>, <&cpg 1007>, <&cpg 1008>, <&cpg 1009>, <&cpg 1010>, <&cpg 1011>, <&cpg 1012>, <&cpg 1013>, <&cpg 1014>, <&cpg 1015>; reset-names = "ssi-all", "ssi.9", "ssi.8", "ssi.7", "ssi.6", "ssi.5", "ssi.4", "ssi.3", "ssi.2", "ssi.1", "ssi.0"; rcar_sound,dvc { dvc0: dvc-0 { dmas = <&audma0 0xbc>; dma-names = "tx"; }; dvc1: dvc-1 { dmas = <&audma0 0xbe>; dma-names = "tx"; }; }; rcar_sound,mix { mix0: mix-0 { }; mix1: mix-1 { }; }; rcar_sound,ctu { ctu00: ctu-0 { }; ctu01: ctu-1 { }; ctu02: ctu-2 { }; ctu03: ctu-3 { }; ctu10: ctu-4 { }; ctu11: ctu-5 { }; ctu12: ctu-6 { }; ctu13: ctu-7 { }; }; rcar_sound,src { src0: src-0 { status = "disabled"; }; src1: src-1 { interrupts = ; dmas = <&audma0 0x87>, <&audma1 0x9c>; dma-names = "rx", "tx"; }; /* skip after src-2 */ }; rcar_sound,ssiu { ssiu00: ssiu-0 { dmas = <&audma0 0x15>, <&audma1 0x16>; dma-names = "rx", "tx"; }; ssiu01: ssiu-1 { dmas = <&audma0 0x35>, <&audma1 0x36>; dma-names = "rx", "tx"; }; /* skip after ssiu-2 */ }; rcar_sound,ssi { ssi0: ssi-0 { interrupts = ; dmas = <&audma0 0x01>, <&audma1 0x02>; dma-names = "rx", "tx"; }; ssi1: ssi-1 { interrupts = ; dmas = <&audma0 0x03>, <&audma1 0x04>; dma-names = "rx", "tx"; }; /* skip other ssi-2 */ }; /* DAI base */ rcar_sound,dai { dai0 { playback = <&ssi5>, <&src5>; capture = <&ssi6>; }; dai1 { playback = <&ssi3>; }; dai2 { capture = <&ssi4>; }; dai3 { playback = <&ssi7>; }; dai4 { capture = <&ssi8>; }; }; /* assume audio-graph */ port { rsnd_endpoint: endpoint { remote-endpoint = <&codec_endpoint>; dai-format = "left_j"; bitclock-master = <&rsnd_endpoint0>; frame-master = <&rsnd_endpoint0>; playback = <&ssi0>, <&src0>, <&dvc0>; capture = <&ssi1>, <&src1>, <&dvc1>; }; }; }; /* assume audio-graph */ codec { port { codec_endpoint: endpoint { remote-endpoint = <&rsnd_endpoint>; }; }; };