arm64: dts: renesas: Add ulcb{-kf} Audio Graph Card2 MIX + TDM Split dtsi
authorKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Fri, 13 Jan 2023 02:04:22 +0000 (02:04 +0000)
committerGeert Uytterhoeven <geert+renesas@glider.be>
Thu, 26 Jan 2023 15:03:04 +0000 (16:03 +0100)
ALSA SoC has many types of Generic Audio Card drivers (Simple Audio
Card, Audio Graph Card, Audio Graph Card2), and Renesas/Kuninori
Morimoto wants to test these.

The Generic Audio Card driver had been requested on ALSA SoC.
It supports many types of device connection methods, and historically,
the requested connection support range of the generic driver has been
upgraded.

Upgrading the connection support range itself could not be implemented
in the generic driver, because we need to keep compatibility with old
DTBs. This is one of the reasons why we have many types of Generic Audio
Card driver.

The ULCB/KF combo is a good board stack to test these.
Kuninori has been testing these Generic Audio Card drivers by using his
local patches to switching drivers.  But from an information sharing
point of view, it is a good idea to upstream these, because the DT
configuration is complex.  Hence this can be a good sample for the user.

Hence add an "Audio Graph Card2 + MIXer + TDM Split" DT setting file
for ULCB/KF.  Because of the limited number of subdevices, the HDMI
output is ignored.
This setting can be enabled by updating ulcb.dtsi / ulcb-kf.dtsi.

From a normal user point of view who doesn't need to test the driver,
everything should stay as-is, and nothing changes.

Note that because this needs "switching driver", and not "adding extra
feature", this does not use a Device Tree overlay.

Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Reviewed-by: Geert Uytterhoeven <geert+renesas@glider.be>
Link: https://lore.kernel.org/r/877cxri40q.wl-kuninori.morimoto.gx@renesas.com
Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be>
arch/arm64/boot/dts/renesas/ulcb-audio-graph-card2-mix+split.dtsi [new file with mode: 0644]
arch/arm64/boot/dts/renesas/ulcb-kf-audio-graph-card2-mix+split.dtsi [new file with mode: 0644]
arch/arm64/boot/dts/renesas/ulcb-kf.dtsi
arch/arm64/boot/dts/renesas/ulcb.dtsi

diff --git a/arch/arm64/boot/dts/renesas/ulcb-audio-graph-card2-mix+split.dtsi b/arch/arm64/boot/dts/renesas/ulcb-audio-graph-card2-mix+split.dtsi
new file mode 100644 (file)
index 0000000..75b024e
--- /dev/null
@@ -0,0 +1,111 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * Device Tree for ULCB + Audio Graph Card2 (MIX + TDM Split)
+ *
+ * Copyright (C) 2022 Renesas Electronics Corp.
+ */
+
+/*
+ * Note:
+ * The HDMI output is ignored due to the limited number of subdevices
+ *
+ *     (A) CPU0 (2ch) <----> (2ch) (X) ak4613  (MIX-0)
+ *     (B) CPU1 (2ch)  --/                     (MIX-1)
+ *
+ *     (A) aplay   -D plughw:0,0 xxx.wav
+ *     (B) aplay   -D plughw:0,1 xxx.wav
+ *
+ *     (A) arecord -D plughw:0,0 xxx.wav
+ */
+/ {
+       sound_card: sound {
+               compatible = "audio-graph-card2";
+               label = "rcar-sound";
+
+               routing = "ak4613 Playback", "DAI0 Playback",
+                         "ak4613 Playback", "DAI1 Playback",
+                         "DAI0 Capture",    "ak4613 Capture";
+
+               /delete-property/ dais;
+               links = <&fe_a          /* (A) CPU0   */
+                        &fe_b          /* (B) CPU1   */
+                        &be_x          /* (X) ak4613 */
+               >;
+
+               dpcm {
+                       #address-cells = <1>;
+                       #size-cells = <0>;
+
+                       ports@0 {
+                               #address-cells = <1>;
+                               #size-cells = <0>;
+                               reg = <0>;
+                               /*
+                                * FE
+                                * (A) CPU0 (MIX-0)
+                                * (B) CPU1 (MIX-1)
+                                */
+                               fe_a: port@0 { reg = <0>; fe_a_ep: endpoint { remote-endpoint = <&rsnd_a_ep>; }; };
+                               fe_b: port@1 { reg = <1>; fe_b_ep: endpoint { remote-endpoint = <&rsnd_b_ep>; }; };
+                       };
+
+                       ports@1 {
+                               #address-cells = <1>;
+                               #size-cells = <0>;
+                               reg = <1>;
+                               /*
+                                * BE
+                                * (X) ak4613
+                                */
+                               be_x: port@0 { reg = <0>; be_x_ep: endpoint { remote-endpoint = <&ak4613_x_ep>; }; };
+                       };
+               };
+       };
+};
+
+&ak4613 {
+       port {
+               /*
+                * (X) ak4613
+                */
+               prefix = "ak4613";
+               convert-rate = <48000>;
+
+               ak4613_x_ep: endpoint {
+                       remote-endpoint = <&be_x_ep>;
+               };
+       };
+};
+
+&rcar_sound {
+       ports {
+               #address-cells = <1>;
+               #size-cells = <0>;
+
+               /*
+                * (A) CPU0
+                */
+               port@0 {
+                       reg = <0>;
+                       rsnd_a_ep: endpoint {
+                               remote-endpoint = <&fe_a_ep>;
+                               bitclock-master;
+                               frame-master;
+                               playback = <&src1 &ctu02 &mix0 &dvc0 &ssi0>;
+                               capture  = <&ssi1 &src0 &dvc1>;
+                       };
+               };
+               /*
+                * (B) CPU1
+                */
+               port@1 {
+                       reg = <1>;
+                       rsnd_b_ep: endpoint {
+                               remote-endpoint = <&fe_b_ep>;
+                               bitclock-master;
+                               frame-master;
+                               playback = <&src2 &ctu03 &mix0 &dvc0 &ssi0>;
+                       };
+               };
+       };
+};
diff --git a/arch/arm64/boot/dts/renesas/ulcb-kf-audio-graph-card2-mix+split.dtsi b/arch/arm64/boot/dts/renesas/ulcb-kf-audio-graph-card2-mix+split.dtsi
new file mode 100644 (file)
index 0000000..da64412
--- /dev/null
@@ -0,0 +1,178 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * Device Tree for ULCB + Kingfisher + Audio Graph Card2 (MIX + TDM Split)
+ *
+ * Copyright (C) 2022 Renesas Electronics Corp.
+ */
+
+/*
+ * Note:
+ * The HDMI output is ignored due to the limited number of subdevices
+ *
+ *     (A) CPU0 (2ch) <----> (2ch) (X) ak4613     (MIX-0)
+ *     (B) CPU1 (2ch)  --/                        (MIX-1)
+ *     (C) CPU3 (2ch)  ----> (8ch) (Y) PCM3168A-p (TDM-0 : 0,1ch)
+ *     (D) CPU2 (2ch)  --/                        (TDM-1 : 2,3ch)
+ *     (E) CPU4 (2ch)  --/                        (TDM-2 : 4,5ch)
+ *     (F) CPU5 (2ch)  --/                        (TDM-3 : 6,7ch)
+ *     (G) CPU6 (6ch) <----  (6ch) (Z) PCM3168A-c
+ *
+ *     (A) aplay   -D plughw:0,0 xxx.wav (MIX-0)
+ *     (B) aplay   -D plughw:0,1 xxx.wav (MIX-1)
+ *     (C) aplay   -D plughw:0,2 xxx.wav (TDM-0)
+ *     (D) aplay   -D plughw:0,3 xxx.wav (TDM-1)
+ *     (E) aplay   -D plughw:0,4 xxx.wav (TDM-2)
+ *     (F) aplay   -D plughw:0,5 xxx.wav (TDM-3)
+ *
+ *     (A) arecord -D plughw:0,0 xxx.wav
+ *     (G) arecord -D plughw:0,6 xxx.wav
+ */
+&sound_card {
+       routing = "ak4613 Playback",   "DAI0 Playback",
+                 "ak4613 Playback",   "DAI1 Playback",
+                 "DAI0 Capture",      "ak4613 Capture",
+                 "pcm3168a Playback", "DAI2 Playback",
+                 "pcm3168a Playback", "DAI3 Playback",
+                 "pcm3168a Playback", "DAI4 Playback",
+                 "pcm3168a Playback", "DAI5 Playback",
+                 "DAI6 Capture",      "pcm3168a Capture";
+
+       /delete-property/ dais;
+       links = <&fe_a          /* (A) CPU0       */
+                &fe_b          /* (B) CPU1       */
+                &fe_c          /* (C) CPU2       */
+                &fe_d          /* (D) CPU3       */
+                &fe_e          /* (E) CPU4       */
+                &fe_f          /* (F) CPU5       */
+                &rsnd_g        /* (G) CPU6       */
+                &be_x          /* (X) ak4613     */
+                &be_y          /* (Y) PCM3168A-p */
+       >;
+
+       dpcm {
+               ports@0 {
+               /*
+                * FE
+                *
+                * (A)/(B) are defined on ulcb
+                * (C) CPU2
+                * (D) CPU3
+                * (E) CPU4
+                * (F) CPU5
+                */
+               fe_c:   port@2 { reg = <2>; fe_c_ep: endpoint { remote-endpoint = <&rsnd_c_ep>; }; };
+               fe_d:   port@3 { reg = <3>; fe_d_ep: endpoint { remote-endpoint = <&rsnd_d_ep>; }; };
+               fe_e:   port@4 { reg = <4>; fe_e_ep: endpoint { remote-endpoint = <&rsnd_e_ep>; }; };
+               fe_f:   port@5 { reg = <5>; fe_f_ep: endpoint { remote-endpoint = <&rsnd_f_ep>; }; };
+               };
+
+               ports@1 {
+               /*
+                * BE
+                *
+                * (X) is defined on ulcb
+                * (Y) PCM3168A-p
+                */
+               be_y:   port@1 { reg = <1>; be_y_ep: endpoint { remote-endpoint = <&pcm3168a_y_ep>; }; };
+               };
+       };
+};
+
+&pcm3168a {
+       ports {
+               #address-cells = <1>;
+               #size-cells = <0>;
+
+               mclk-fs = <512>;
+               prefix = "pcm3168a";
+
+               /*
+                * (Y) PCM3168A-p
+                */
+               port@0 {
+                       reg = <0>;
+                       convert-channels = <8>; /* to 8ch TDM */
+                       pcm3168a_y_ep: endpoint {
+                               remote-endpoint = <&be_y_ep>;
+                               clocks = <&clksndsel>;
+                       };
+               };
+               /*
+                * (Z) PCM3168A-c
+                */
+               port@1 {
+                       reg = <1>;
+                       pcm3168a_z_ep: endpoint {
+                               remote-endpoint = <&rsnd_g_ep>;
+                               clocks = <&clksndsel>;
+                       };
+               };
+       };
+};
+
+&rcar_sound {
+       ports {
+               /* (A)/(B) are defined in ulcb.dtsi */
+
+               /*
+                * (C) CPU2
+                */
+               port@2 {
+                       reg = <2>;
+                       rsnd_c_ep: endpoint {
+                               remote-endpoint = <&fe_c_ep>;
+                               bitclock-master;
+                               frame-master;
+                               playback = <&ssiu30 &ssi3>;
+                       };
+               };
+               /*
+                * (D) CPU3
+                */
+               port@3 {
+                       reg = <3>;
+                       rsnd_d_ep: endpoint {
+                               remote-endpoint = <&fe_d_ep>;
+                               bitclock-master;
+                               frame-master;
+                               playback = <&ssiu31 &ssi3>;
+                       };
+               };
+               /*
+                * (E) CPU4
+                */
+               port@4 {
+                       reg = <4>;
+                       rsnd_e_ep: endpoint {
+                               remote-endpoint = <&fe_e_ep>;
+                               bitclock-master;
+                               frame-master;
+                               playback = <&ssiu32 &ssi3>;
+                       };
+               };
+               /*
+                * (F) CPU5
+                */
+               port@5 {
+                       reg = <5>;
+                       rsnd_f_ep: endpoint {
+                               remote-endpoint = <&fe_f_ep>;
+                               bitclock-master;
+                               frame-master;
+                               playback = <&ssiu33 &ssi3>;
+                       };
+               };
+               /*
+                * (G) CPU6
+                */
+               rsnd_g: port@6 {
+                       reg = <6>;
+                       rsnd_g_ep: endpoint {
+                               remote-endpoint = <&pcm3168a_z_ep>;
+                               bitclock-master;
+                               frame-master;
+                               capture = <&ssi4>;
+                       };
+               };
+       };
+};
index 4b5887952da6acfa1385384ca92f4967899499e2..9b50f9881d2576c36a4e959f4ea8e24657508d25 100644 (file)
  *
  * #include "ulcb-kf-simple-audio-card.dtsi"
  * #include "ulcb-kf-audio-graph-card.dtsi"
+ * #include "ulcb-kf-audio-graph-card2-mix+split.dtsi"
  */
 #include "ulcb-kf-audio-graph-card2.dtsi"
index 95d9086b92fef71d9281303c6cf6315e1a6eb207..bb93ba4ff946522f2cb740b5f911dd75f8d90132 100644 (file)
  *
  * #include "ulcb-simple-audio-card.dtsi"
  * #include "ulcb-audio-graph-card.dtsi"
+ * #include "ulcb-audio-graph-card2-mix+split.dtsi"
  */
 #include "ulcb-audio-graph-card2.dtsi"