ASoC: audio-graph-card2-custom-sample.dtsi: add Codec2Codec sample (Single)
authorKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Tue, 12 Oct 2021 04:56:31 +0000 (13:56 +0900)
committerMark Brown <broonie@kernel.org>
Fri, 15 Oct 2021 15:10:48 +0000 (16:10 +0100)
This patch adds Codec2Codec-Single sample to audio-graph-card2-custom-sample.dtsi.
Because it can use very basic connection only for now,
it can use only

- 2channels
- S32_LE format

Test-Component driver has "IN" and "OUT" widget. Thus the route is

+--+
|  | <-- Codec6 <-- IN
|  | --> Codec7 --> OUT
+--+

One note here is that it will start works when it boot.
In other words we can't stop it so far.
We need to update driver for it in the future.

...
asoc-audio-graph-card2-custom-sample: test_codec.7 <-> test_codec.6 mapping ok
test-component test_codec: test_dai_startup() : test_codec.6
test-component test_codec: test_dai_startup() : test_codec.7
...

Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Link: https://lore.kernel.org/r/87o87ulu2o.wl-kuninori.morimoto.gx@renesas.com
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/generic/audio-graph-card2-custom-sample.dtsi

index 4bc96e0..f416dea 100644 (file)
         *      cpu5 <-@--*  *--@-> | | -> codec4
         *      cpu6 <-@--*  *      | | -> codec5
         *                ****      +-+
+        *
+        * [Codec2Codec]
+        *                         +-@-> codec6
+        *                         |
+        *                         +---> codec7
         */
        audio-graph-card2-custom-sample {
                /*
                          "DAI5 Capture",       "TC DAI4 Capture",
                          "DAI5 Capture",       "TC DAI5 Capture",
                          "DAI6 Capture",       "TC DAI4 Capture",
-                         "DAI6 Capture",       "TC DAI5 Capture";
+                         "DAI6 Capture",       "TC DAI5 Capture",
+                       /* for [Codec2Codec] */
+                         "TC OUT",             "TC DAI7 Playback",
+                         "TC DAI6 Capture",    "TC IN";
 
                links = <&cpu0                  /* normal: cpu side only */
                         &mcpu0                 /* multi:  cpu side only */
                         &fe00 &fe01 &be0       /* dpcm:   both FE / BE  */
                         &fe10 &fe11 &be1       /* dpcm-m: both FE / BE  */
+                        &c2c                   /* c2c:    cpu side only */
                >;
 
                multi {
                        be1:    port@1 { be10_ep: endpoint { remote-endpoint = <&mbe_ep>; }; };
                        };
                };
+
+               codec2codec {
+                       ports@0 {
+                               rate = <48000>;
+                       c2c:    port@0 { c2cf_ep: endpoint { remote-endpoint = <&codec6_ep>; }; };
+                               port@1 { c2cb_ep: endpoint { remote-endpoint = <&codec7_ep>; }; };
+                       };
+               };
        };
 
        test_cpu {
                        port@3  { codec3_ep:  endpoint { remote-endpoint = <&be00_ep>; }; };
                        port@4  { codec4_ep:  endpoint { remote-endpoint = <&mbe1_ep>; }; };
                        port@5  { codec5_ep:  endpoint { remote-endpoint = <&mbe2_ep>; }; };
+                       port@6  { bitclock-master;
+                                 frame-master;
+                                 codec6_ep:  endpoint { remote-endpoint = <&c2cf_ep>; }; };
+                       port@7  { codec7_ep:  endpoint { remote-endpoint = <&c2cb_ep>; }; };
                };
        };
 };