GNU Linux-libre 6.9.1-gnu
[releases.git] / sound / soc / generic / audio-graph-card2-custom-sample.dtsi
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * audio-graph-card2-custom-sample.dtsi
4  *
5  * Copyright (C) 2020 Renesas Electronics Corp.
6  * Copyright (C) 2020 Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
7  *
8  * This sample indicates how to use audio-graph-card2 and its
9  * custom driver. "audio-graph-card2-custom-sample" is the custome driver
10  * which is using audio-graph-card2.
11  *
12  * You can easily use this sample by adding below line on your DT file,
13  * and add new CONFIG to your .config.
14  *
15  *      #include "../../../../../sound/soc/generic/audio-graph-card2-custom-sample.dtsi"
16  *
17  *      CONFIG_SND_AUDIO_GRAPH_CARD2
18  *      CONFIG_SND_AUDIO_GRAPH_CARD2_CUSTOM_SAMPLE
19  *      CONFIG_SND_TEST_COMPONENT
20  *
21  *
22  * You can indicate more detail each device behavior as debug if you modify
23  * "compatible" on each test-component. see below
24  *
25  *      test_cpu {
26  *      -       compatible = "test-cpu";
27  *      +       compatible = "test-cpu-verbose";
28  *              ...
29  *      };
30  *
31  *      test_codec {
32  *      -       compatible = "test-codec";
33  *      +       compatible = "test-codec-verbose";
34  *              ...
35  *      };
36  *
37  *
38  * Below sample doesn't use "format" property,
39  * because test-component driver (test-cpu/test-codec) is supporting
40  * snd_soc_dai_ops :: .auto_selectable_formats.
41  * see
42  *      snd_soc_runtime_get_dai_fmt()
43  *      linux/sound/soc/generic/test-component.c :: test_dai_formats
44  */
45 / {
46         /*
47          * @ : used at links
48          *
49          * [Normal]
50          *      cpu0 <-@-----------------> codec0
51          *
52          * [Semi-Multi]
53          *
54          * CPU:Codec = 1:N
55          *
56          *                      +-+
57          *      cpu7 <-@------->| |-> codec12
58          *                      | |-> codec13
59          *                      +-+
60          *
61          * [Multi-CPU/Codec-0]
62          *              +-+             +-+
63          *      cpu1 <--| |<-@--------->| |-> codec1
64          *      cpu2 <--| |             | |-> codec2
65          *              +-+             +-+
66          *
67          * [Multi-CPU/Codec-1]
68          *
69          *              +-+             +-+
70          *              | |<-@--------->| |
71          *              | |             | |
72          *      cpu8 <--| |<----------->| |-> codec14
73          *      cpu9 <--| |<---+------->| |-> codec15
74          *              +-+     \------>| |-> codec16
75          *                              +-+
76          *
77          * [Multi-CPU/Codec-2]
78          *
79          *              +-+             +-+
80          *              | |<-@--------->| |
81          *              | |             | |
82          *      cpu10 <-| |<----------->| |-> codec17
83          *      cpu11 <-| |<-----+----->| |-> codec18
84          *      cpu12 <-| |<----/       +-+
85          *              +-+
86          *
87          * [DPCM]
88          *
89          *      CPU3/CPU4 are converting rate to 44100
90          *
91          *      FE              BE
92          *                ****
93          *      cpu3 <-@--*  *--@-> codec3
94          *      cpu4 <-@--*  *  (44.1kHz)
95          *                ****
96          *
97          * [DPCM-Multi]
98          *
99          * --NOTE--
100          * Multi-FE is not supported by ASoC.
101          *
102          *      FE              BE
103          *                ****      +-+
104          *      cpu5 <-@--*  *--@-> | | -> codec4
105          *      cpu6 <-@--*  *      | | -> codec5
106          *                ****      +-+
107          *
108          * [Codec2Codec]
109          *                         +-@-> codec6
110          *                         |
111          *                         +---> codec7
112          *
113          * [Codec2Codec-Multi]
114          *
115          * --NOTE--
116          * Multi connect N:M is not supported by ASoC.
117          *
118          *                              +-+
119          *                         +-@->| |-> codec8
120          *                         |    | |-> codec9
121          *                         |    +-+
122          *                         |    +-+
123          *                         +--->| |-> codec10
124          *                              | |-> codec11
125          *                              +-+
126          */
127         audio-graph-card2-custom-sample {
128                 /*
129                  * You can use audio-graph-card2 directly by using
130                  *
131                  * compatible = "audio-graph-card2";
132                  */
133                 compatible = "audio-graph-card2-custom-sample";
134
135                         /* for [DPCM]              */
136                         /* BE                   FE */
137                 routing = "TC DAI3 Playback",   "DAI3 Playback",
138                           "TC DAI3 Playback",   "DAI4 Playback",
139                           "DAI3 Capture",       "TC DAI3 Capture",
140                           "DAI4 Capture",       "TC DAI3 Capture",
141                         /* for [DPCM-Multi]        */
142                         /* BE                   FE */
143                           "TC DAI4 Playback",   "DAI5 Playback",
144                           "TC DAI5 Playback",   "DAI5 Playback",
145                           "TC DAI4 Playback",   "DAI6 Playback",
146                           "TC DAI5 Playback",   "DAI6 Playback",
147                           "DAI5 Capture",       "TC DAI4 Capture",
148                           "DAI5 Capture",       "TC DAI5 Capture",
149                           "DAI6 Capture",       "TC DAI4 Capture",
150                           "DAI6 Capture",       "TC DAI5 Capture",
151                         /* for [Codec2Codec] */
152                           "TC OUT",             "TC DAI7 Playback",
153                           "TC DAI6 Capture",    "TC IN",
154                         /* for [Codec2Codec-Multi] */
155                           "TC OUT",             "TC DAI10 Playback",
156                           "TC DAI8 Capture",    "TC IN",
157                           "TC OUT",             "TC DAI11 Playback",
158                           "TC DAI9 Capture",    "TC IN";
159
160                 links = <
161                         /*
162                          * [Normal]: cpu side only
163                          * cpu0/codec0
164                          */
165                          &cpu0
166
167                         /*
168                          * [Semi-Multi]
169                          * cpu7/codec12/codec13
170                          */
171                         &sm0
172
173                         /*
174                          * [Multi-CPU/Codec-0]: cpu side only
175                          * cpu1/cpu2/codec1/codec2
176                          */
177                          &mcpu0
178
179                         /*
180                          * [Multi-CPU/Codec-1]: cpu side only
181                          * cpu8/cpu9/codec14/codec15/codec16
182                          *
183                          * Because it will reach to the maximum of sound minor number,
184                          * disable it so far.
185                          * If you want to try it, please disable some other one instead.
186                          */
187                         //&mcpu1
188
189                         /*
190                          * [Multi-CPU/Codec-2]: cpu side only
191                          * cpu10/cpu11/cpu12/codec17/codec18
192                          *
193                          * Because it will reach to the maximum of sound minor number,
194                          * disable it so far.
195                          * If you want to try it, please disable some other one instead.
196                          */
197                         //&mcpu2
198
199                         /*
200                          * [DPCM]: both FE / BE
201                          * cpu3/cpu4/codec3
202                          */
203                          &fe00 &fe01 &be0
204
205                         /*
206                          * [DPCM-Multi]: both FE / BE
207                          * cpu5/cpu6/codec4/codec5
208                          */
209                          &fe10 &fe11 &be1
210
211                         /*
212                          * [Codec2Codec]: cpu side only
213                          * codec6/codec7
214                          */
215                          &c2c
216
217                         /*
218                          * [Codec2Codec-Multi]: cpu side only
219                          * codec8/codec9/codec10/codec11
220                          */
221                          &c2c_m
222                 >;
223
224                 multi {
225                         #address-cells = <1>;
226                         #size-cells = <0>;
227
228                         /*
229                          * [Multi-CPU-0]
230                          *
231                          *              +---+           +---+
232                          *      cpu1 <--|A X|<-@------->|x a|-> codec1
233                          *      cpu2 <--|B  |           |  b|-> codec2
234                          *              +---+           +---+
235                          */
236                         ports@0 {
237                                 reg = <0>;
238                                 #address-cells = <1>;
239                                 #size-cells = <0>;
240                         mcpu0:  port@0 { reg = <0>; mcpu00_ep: endpoint { remote-endpoint = <&mcodec00_ep>; };};/* (X) to pair */
241                                 port@1 { reg = <1>; mcpu01_ep: endpoint { remote-endpoint = <&cpu1_ep>;     };};/* (A) Multi Element */
242                                 port@2 { reg = <2>; mcpu02_ep: endpoint { remote-endpoint = <&cpu2_ep>;     };};/* (B) Multi Element */
243                         };
244
245                         /*
246                          * [Multi-Codec-0]
247                          *
248                          *              +---+           +---+
249                          *      cpu1 <--|A X|<-@------->|x a|-> codec1
250                          *      cpu2 <--|B  |           |  b|-> codec2
251                          *              +---+           +---+
252                          */
253                         ports@1 {
254                                 reg = <1>;
255                                 #address-cells = <1>;
256                                 #size-cells = <0>;
257                                 port@0 { reg = <0>; mcodec00_ep: endpoint { remote-endpoint = <&mcpu00_ep>; };};/* (x) to pair */
258                                 port@1 { reg = <1>; mcodec01_ep: endpoint { remote-endpoint = <&codec1_ep>; };};/* (a) Multi Element */
259                                 port@2 { reg = <2>; mcodec02_ep: endpoint { remote-endpoint = <&codec2_ep>; };};/* (b) Multi Element */
260                         };
261
262                         /*
263                          * [DPCM-Multi]::BE
264                          *
265                          *      FE                      BE
266                          *                ****          +---+
267                          *      cpu5 <-@--*  *-----@--->|x a|-> codec4
268                          *      cpu6 <-@--*  *          |  b|-> codec5
269                          *                ****          +---+
270                          */
271                         ports@2 {
272                                 reg = <2>;
273                                 #address-cells = <1>;
274                                 #size-cells = <0>;
275                                 port@0 { reg = <0>; mbe_ep:  endpoint { remote-endpoint = <&be10_ep>;   };};/* (x) to pair */
276                                 port@1 { reg = <1>; mbe1_ep: endpoint { remote-endpoint = <&codec4_ep>; };};/* (a) Multi Element */
277                                 port@2 { reg = <2>; mbe2_ep: endpoint { remote-endpoint = <&codec5_ep>; };};/* (b) Multi Element */
278                         };
279
280                         /*
281                          * [Codec2Codec-Multi]::CPU
282                          *
283                          *              +---+
284                          *         +-@->|X A|-> codec8
285                          *         |    |  B|-> codec9
286                          *         |    +---+
287                          *         |    +---+
288                          *         +--->|x a|-> codec10
289                          *              |  b|-> codec11
290                          *              +---+
291                          */
292                         ports@3 {
293                                 reg = <3>;
294                                 #address-cells = <1>;
295                                 #size-cells = <0>;
296                                 port@0 { reg = <0>; mc2c0_ep:  endpoint { remote-endpoint = <&c2cmf_ep>;  };};/* (X) to pair */
297                                 port@1 { reg = <1>; mc2c00_ep: endpoint { remote-endpoint = <&codec8_ep>; };};/* (A) Multi Element */
298                                 port@2 { reg = <2>; mc2c01_ep: endpoint { remote-endpoint = <&codec9_ep>; };};/* (B) Multi Element */
299                         };
300
301                         /*
302                          * [Codec2Codec-Multi]::Codec
303                          *
304                          *              +---+
305                          *         +-@->|X A|-> codec8
306                          *         |    |  B|-> codec9
307                          *         |    +---+
308                          *         |    +---+
309                          *         +--->|x a|-> codec10
310                          *              |  b|-> codec11
311                          *              +---+
312                          */
313                         ports@4 {
314                                 reg = <4>;
315                                 #address-cells = <1>;
316                                 #size-cells = <0>;
317                                 port@0 { reg = <0>; mc2c1_ep:  endpoint { remote-endpoint = <&c2cmb_ep>;   };};/* (x) to pair */
318                                 port@1 { reg = <1>; mc2c10_ep: endpoint { remote-endpoint = <&codec10_ep>; };};/* (a) Multi Element */
319                                 port@2 { reg = <2>; mc2c11_ep: endpoint { remote-endpoint = <&codec11_ep>; };};/* (b) Multi Element */
320                         };
321
322                         /*
323                          * [Semi-Multi]
324                          *
325                          *                      +---+
326                          *      cpu7 <-@------->|X A|-> codec12
327                          *                      |  B|-> codec13
328                          *                      +---+
329                          */
330                         ports@5 {
331                                 reg = <5>;
332                                 #address-cells = <1>;
333                                 #size-cells = <0>;
334                                 port@0 { reg = <0>; smcodec0_ep: endpoint { remote-endpoint = <&cpu7_ep>;    };};/* (X) to pair */
335                                 port@1 { reg = <1>; smcodec1_ep: endpoint { remote-endpoint = <&codec12_ep>; };};/* (A) Multi Element */
336                                 port@2 { reg = <2>; smcodec2_ep: endpoint { remote-endpoint = <&codec13_ep>; };};/* (B) Multi Element */
337                         };
338
339                         /*
340                          * [Multi-CPU-1]
341                          *
342                          *              +---+           +---+
343                          *              |  X|<-@------->|x  |
344                          *              |   |           |   |
345                          *      cpu8 <--|A 1|<--------->|3 a|-> codec14
346                          *      cpu9 <--|B 2|<---+----->|4 b|-> codec15
347                          *              +---+     \---->|5 c|-> codec16
348                          *                              +---+
349                          */
350                         ports@6 {
351                                 reg = <6>;
352                                 #address-cells = <1>;
353                                 #size-cells = <0>;
354                         mcpu1:  port@0 { reg = <0>; mcpu10_ep: endpoint { remote-endpoint = <&mcodec10_ep>; };};    /* (X) to pair */
355                                 port@1 {
356                                         #address-cells = <1>;
357                                         #size-cells = <0>;
358                                         reg = <1>;
359                                         mcpu11_ep:   endpoint@0 { reg = <0>; remote-endpoint = <&cpu8_ep>;       }; /* (A) Multi Element */
360                                         mcpu11_ep_0: endpoint@1 { reg = <1>; remote-endpoint = <&mcodec11_ep_0>; }; /* (1) connected Codec */
361                                 };
362                                 port@2 {
363                                         #address-cells = <1>;
364                                         #size-cells = <0>;
365                                         reg = <2>;
366                                         mcpu12_ep:   endpoint@0 { reg = <0>; remote-endpoint = <&cpu9_ep>;       }; /* (B) Multi Element */
367                                         mcpu12_ep_0: endpoint@1 { reg = <1>; remote-endpoint = <&mcodec12_ep_0>; }; /* (2) connected Codec */
368                                         mcpu12_ep_1: endpoint@2 { reg = <2>; remote-endpoint = <&mcodec13_ep_0>; }; /* (2) connected Codec */
369                                 };
370                         };
371
372                         /*
373                          * [Multi-Codec-1]
374                          *
375                          *              +---+           +---+
376                          *              |  X|<-@------->|x  |
377                          *              |   |           |   |
378                          *      cpu8 <--|A 1|<--------->|3 a|-> codec14
379                          *      cpu9 <--|B 2|<---+----->|4 b|-> codec15
380                          *              +---+     \---->|5 c|-> codec16
381                          *                              +---+
382                          */
383                         ports@7 {
384                                 reg = <7>;
385                                 #address-cells = <1>;
386                                 #size-cells = <0>;
387                                 port@0 { reg = <0>; mcodec10_ep: endpoint { remote-endpoint = <&mcpu10_ep>;  };};   /* (x) to pair */
388                                 port@1 {
389                                         #address-cells = <1>;
390                                         #size-cells = <0>;
391                                         reg = <1>;
392                                         mcodec11_ep:   endpoint@0 { reg = <0>; remote-endpoint = <&codec14_ep>;  }; /* (a) Multi Element */
393                                         mcodec11_ep_0: endpoint@1 { reg = <1>; remote-endpoint = <&mcpu11_ep_0>; }; /* (3) connected CPU */
394                                 };
395                                 port@2 {
396                                         #address-cells = <1>;
397                                         #size-cells = <0>;
398                                         reg = <2>;
399                                         mcodec12_ep:   endpoint@0 { reg = <0>; remote-endpoint = <&codec15_ep>;  }; /* (b) Multi Element */
400                                         mcodec12_ep_0: endpoint@1 { reg = <1>; remote-endpoint = <&mcpu12_ep_0>; }; /* (4) connected CPU */
401                                 };
402                                 port@3 {
403                                         #address-cells = <1>;
404                                         #size-cells = <0>;
405                                         reg = <3>;
406                                         mcodec13_ep:   endpoint@0 { reg = <0>; remote-endpoint = <&codec16_ep>;  }; /* (c) Multi Element */
407                                         mcodec13_ep_0: endpoint@1 { reg = <1>; remote-endpoint = <&mcpu12_ep_1>; }; /* (5) connected CPU */
408                                 };
409                         };
410
411                         /*
412                          * [Multi-CPU-2]
413                          *
414                          *              +---+           +---+
415                          *              |  X|<-@------->|x  |
416                          *              |   |           |   |
417                          *      cpu10 <-|A 1|<--------->|4 a|-> codec17
418                          *      cpu11 <-|B 2|<-----+--->|5 b|-> codec18
419                          *      cpu12 <-|C 3|<----/     +---+
420                          *              +---+
421                          */
422                         ports@8 {
423                                 reg = <8>;
424                                 #address-cells = <1>;
425                                 #size-cells = <0>;
426                         mcpu2:  port@0 { reg = <0>; mcpu20_ep: endpoint { remote-endpoint = <&mcodec20_ep>; };};    /* (X) to pair */
427                                 port@1 {
428                                         #address-cells = <1>;
429                                         #size-cells = <0>;
430                                         reg = <1>;
431                                         mcpu21_ep:   endpoint@0 { reg = <0>; remote-endpoint = <&cpu10_ep>;      }; /* (A) Multi Element */
432                                         mcpu21_ep_0: endpoint@1 { reg = <1>; remote-endpoint = <&mcodec21_ep_0>; }; /* (1) connected Codec */
433                                 };
434                                 port@2 {
435                                         #address-cells = <1>;
436                                         #size-cells = <0>;
437                                         reg = <2>;
438                                         mcpu22_ep:   endpoint@0 { reg = <0>; remote-endpoint = <&cpu11_ep>;      }; /* (B) Multi Element */
439                                         mcpu22_ep_0: endpoint@1 { reg = <1>; remote-endpoint = <&mcodec22_ep_0>; }; /* (2) connected Codec */
440                                 };
441                                 port@3 {
442                                         #address-cells = <1>;
443                                         #size-cells = <0>;
444                                         reg = <3>;
445                                         mcpu23_ep:   endpoint@0 { reg = <0>; remote-endpoint = <&cpu12_ep>;      }; /* (C) Multi Element */
446                                         mcpu23_ep_0: endpoint@1 { reg = <1>; remote-endpoint = <&mcodec22_ep_1>; }; /* (3) connected Codec */
447                                 };
448                         };
449
450                         /*
451                          * [Multi-Codec-2]
452                          *
453                          *              +---+           +---+
454                          *              |  X|<-@------->|x  |
455                          *              |   |           |   |
456                          *      cpu10 <-|A 1|<--------->|4 a|-> codec17
457                          *      cpu11 <-|B 2|<-----+--->|5 b|-> codec18
458                          *      cpu12 <-|C 3|<----/     +---+
459                          *              +---+
460                          */
461                         ports@9 {
462                                 reg = <9>;
463                                 #address-cells = <1>;
464                                 #size-cells = <0>;
465                                 port@0 { reg = <0>; mcodec20_ep: endpoint { remote-endpoint = <&mcpu20_ep>;  };};   /* (x) to pair */
466                                 port@1 {
467                                         #address-cells = <1>;
468                                         #size-cells = <0>;
469                                         reg = <1>;
470                                         mcodec21_ep:   endpoint@0 { reg = <0>; remote-endpoint = <&codec17_ep>;  }; /* (a) Multi Element */
471                                         mcodec21_ep_0: endpoint@1 { reg = <1>; remote-endpoint = <&mcpu21_ep_0>; }; /* (4) connected CPU */
472                                 };
473                                 port@2 {
474                                         #address-cells = <1>;
475                                         #size-cells = <0>;
476                                         reg = <2>;
477                                         mcodec22_ep:   endpoint@0 { reg = <0>; remote-endpoint = <&codec18_ep>;  }; /* (b) Multi Element */
478                                         mcodec22_ep_0: endpoint@1 { reg = <1>; remote-endpoint = <&mcpu22_ep_0>; }; /* (5) connected CPU */
479                                         mcodec22_ep_1: endpoint@2 { reg = <2>; remote-endpoint = <&mcpu23_ep_0>; }; /* (5) connected CPU */
480                                 };
481                         };
482                 };
483
484                 dpcm {
485                         #address-cells = <1>;
486                         #size-cells = <0>;
487
488                         ports@0 {
489                                 reg = <0>;
490
491                                 #address-cells = <1>;
492                                 #size-cells = <0>;
493                                 /*
494                                  * [DPCM]::FE
495                                  *
496                                  *      FE                              BE
497                                  *                      ****
498                                  *      cpu3 <-@(fe00)--*  *--(be0)@--> codec3
499                                  *      cpu4 <-@(fe01)--*  *            (44.1kHz)
500                                  *                      ****
501                                  */
502                         fe00:   port@0 { reg = <0>; fe00_ep: endpoint { remote-endpoint = <&cpu3_ep>; }; };
503                         fe01:   port@1 { reg = <1>; fe01_ep: endpoint { remote-endpoint = <&cpu4_ep>; }; };
504
505                                 /*
506                                  * [DPCM-Multi]::FE
507                                  *
508                                  *              FE                      BE
509                                  *                      ****            +-+
510                                  *      cpu5 <-@(fe10)--*  *---(be1)@-->| |-> codec4
511                                  *      cpu6 <-@(fe11)--*  *            | |-> codec5
512                                  *                      ****            +-+
513                                  */
514                         fe10:   port@2 { reg = <2>; fe10_ep: endpoint { remote-endpoint = <&cpu5_ep>; }; };
515                         fe11:   port@3 { reg = <3>; fe11_ep: endpoint { remote-endpoint = <&cpu6_ep>; }; };
516                         };
517
518                         ports@1 {
519                                 reg = <1>;
520
521                                 #address-cells = <1>;
522                                 #size-cells = <0>;
523                                 /*
524                                  * [DPCM]::BE
525                                  *
526                                  *      FE                              BE
527                                  *                      ****
528                                  *      cpu3 <-@(fe00)--*  *--(be0)@--> codec3
529                                  *      cpu4 <-@(fe01)--*  *            (44.1kHz)
530                                  *                      ****
531                                  */
532                         be0:    port@0 { reg = <0>; be00_ep: endpoint { remote-endpoint = <&codec3_ep>; }; };
533
534                                 /*
535                                  * [DPCM-Multi]::BE
536                                  *
537                                  *              FE                      BE
538                                  *                      ****            +-+
539                                  *      cpu5 <-@(fe10)--*  *---(be1)@-->| |-> codec4
540                                  *      cpu6 <-@(fe11)--*  *            | |-> codec5
541                                  *                      ****            +-+
542                                  */
543                         be1:    port@1 { reg = <1>; be10_ep: endpoint { remote-endpoint = <&mbe_ep>; }; };
544                         };
545                 };
546
547                 codec2codec {
548                         #address-cells = <1>;
549                         #size-cells = <0>;
550                         /*
551                          * [Codec2Codec]
552                          *
553                          *      +-@(c2c)-> codec6
554                          *      |
555                          *      +--------> codec7
556                          */
557                         ports@0 {
558                                 reg = <0>;
559
560                                 #address-cells = <1>;
561                                 #size-cells = <0>;
562
563                                 /* use default settings */
564                         c2c:    port@0 { reg = <0>; c2cf_ep: endpoint { remote-endpoint = <&codec6_ep>; }; };
565                                 port@1 { reg = <1>; c2cb_ep: endpoint { remote-endpoint = <&codec7_ep>; }; };
566                         };
567
568                         /*
569                          * [Codec2Codec-Multi]
570                          *
571                          *                      +-+
572                          *         +-@(c2c_m)-->| |-> codec8
573                          *         |            | |-> codec9
574                          *         |            +-+
575                          *         |            +-+
576                          *         +----------->| |-> codec10
577                          *                      | |-> codec11
578                          *                      +-+
579                          */
580                         ports@1 {
581                                 reg = <1>;
582
583                                 #address-cells = <1>;
584                                 #size-cells = <0>;
585
586                                 /* use original settings */
587                                 rate = <48000>;
588                         c2c_m:  port@0 { reg = <0>; c2cmf_ep: endpoint { remote-endpoint = <&mc2c0_ep>; }; };
589                                 port@1 { reg = <1>; c2cmb_ep: endpoint { remote-endpoint = <&mc2c1_ep>; }; };
590                         };
591                 };
592         };
593
594         test_cpu {
595                 /*
596                  * update compatible to indicate more detail behaviour
597                  * if you want. see test-compatible for more detail.
598                  *
599                  * ex)
600                  *      - compatible = "test-cpu";
601                  *      + compatible = "test-cpu-verbose";
602                  */
603                 compatible = "test-cpu";
604                 ports {
605                         #address-cells = <1>;
606                         #size-cells = <0>;
607
608                         bitclock-master;
609                         frame-master;
610                         /* [Normal] */
611                         cpu0: port@0 { reg = <0>; cpu0_ep: endpoint { remote-endpoint = <&codec0_ep>; }; };
612
613                         /* [Multi-CPU-0] */
614                               port@1 { reg = <1>; cpu1_ep: endpoint { remote-endpoint = <&mcpu01_ep>; }; };
615                               port@2 { reg = <2>; cpu2_ep: endpoint { remote-endpoint = <&mcpu02_ep>; }; };
616
617                         /* [DPCM]::FE */
618                               port@3 { reg = <3>; cpu3_ep: endpoint { remote-endpoint = <&fe00_ep>; }; };
619                               port@4 { reg = <4>; cpu4_ep: endpoint { remote-endpoint = <&fe01_ep>; }; };
620
621                         /* [DPCM-Multi]::FE */
622                               port@5 { reg = <5>; cpu5_ep: endpoint { remote-endpoint = <&fe10_ep>; }; };
623                               port@6 { reg = <6>; cpu6_ep: endpoint { remote-endpoint = <&fe11_ep>; }; };
624
625                         /* [Semi-Multi] */
626                         sm0:  port@7 { reg = <7>; cpu7_ep: endpoint { remote-endpoint = <&smcodec0_ep>; }; };
627
628                         /* [Multi-CPU-1] */
629                               port@8 { reg = <8>; cpu8_ep: endpoint { remote-endpoint = <&mcpu11_ep>;   }; };
630                               port@9 { reg = <9>; cpu9_ep: endpoint { remote-endpoint = <&mcpu12_ep>;   }; };
631                         /* [Multi-CPU-2] */
632                               port@a { reg = <10>; cpu10_ep: endpoint { remote-endpoint = <&mcpu21_ep>; }; };
633                               port@b { reg = <11>; cpu11_ep: endpoint { remote-endpoint = <&mcpu22_ep>; }; };
634                               port@c { reg = <12>; cpu12_ep: endpoint { remote-endpoint = <&mcpu23_ep>; }; };
635                 };
636         };
637
638         test_codec {
639                 /*
640                  * update compatible to indicate more detail behaviour
641                  * if you want. see test-compatible for more detail.
642                  *
643                  * ex)
644                  *      - compatible = "test-codec";
645                  *      + compatible = "test-codec-verbose";
646                  */
647                 compatible = "test-codec";
648                 ports {
649                         #address-cells = <1>;
650                         #size-cells = <0>;
651
652                         /*
653                          * prefix can be added to *component*,
654                          * see audio-graph-card2::routing
655                          */
656                         prefix = "TC";
657
658                         /* [Normal] */
659                         port@0  { reg = <0>; codec0_ep:  endpoint { remote-endpoint = <&cpu0_ep>; }; };
660
661                         /* [Multi-Codec-0] */
662                         port@1  { reg = <1>; codec1_ep:  endpoint { remote-endpoint = <&mcodec01_ep>; }; };
663                         port@2  { reg = <2>; codec2_ep:  endpoint { remote-endpoint = <&mcodec02_ep>; }; };
664
665                         /* [DPCM]::BE */
666                         port@3  {
667                                 convert-rate = <44100>;
668                                 reg = <3>; codec3_ep:  endpoint { remote-endpoint = <&be00_ep>; };
669                         };
670
671                         /* [DPCM-Multi]::BE */
672                         port@4  { reg = <4>; codec4_ep:  endpoint { remote-endpoint = <&mbe1_ep>; }; };
673                         port@5  { reg = <5>; codec5_ep:  endpoint { remote-endpoint = <&mbe2_ep>; }; };
674
675                         /* [Codec2Codec] */
676                         port@6  { bitclock-master;
677                                   frame-master;
678                                   reg = <6>; codec6_ep:  endpoint { remote-endpoint = <&c2cf_ep>; }; };
679                         port@7  { reg = <7>; codec7_ep:  endpoint { remote-endpoint = <&c2cb_ep>; }; };
680
681                         /* [Codec2Codec-Multi] */
682                         port@8  { bitclock-master;
683                                   frame-master;
684                                   reg = <8>;  codec8_ep:  endpoint { remote-endpoint = <&mc2c00_ep>; }; };
685                         port@9  { reg = <9>;  codec9_ep:  endpoint { remote-endpoint = <&mc2c01_ep>; }; };
686                         port@a  { reg = <10>; codec10_ep: endpoint { remote-endpoint = <&mc2c10_ep>; }; };
687                         port@b  { reg = <11>; codec11_ep: endpoint { remote-endpoint = <&mc2c11_ep>; }; };
688
689                         /* [Semi-Multi] */
690                         port@c { reg = <12>; codec12_ep: endpoint { remote-endpoint = <&smcodec1_ep>; }; };
691                         port@d { reg = <13>; codec13_ep: endpoint { remote-endpoint = <&smcodec2_ep>; }; };
692
693                         /* [Multi-Codec-1] */
694                         port@e  { reg = <14>; codec14_ep: endpoint { remote-endpoint = <&mcodec11_ep>; }; };
695                         port@f  { reg = <15>; codec15_ep: endpoint { remote-endpoint = <&mcodec12_ep>; }; };
696                         port@10 { reg = <16>; codec16_ep: endpoint { remote-endpoint = <&mcodec13_ep>; }; };
697                         /* [Multi-Codec-2] */
698                         port@11 { reg = <17>; codec17_ep: endpoint { remote-endpoint = <&mcodec21_ep>; }; };
699                         port@12 { reg = <18>; codec18_ep: endpoint { remote-endpoint = <&mcodec22_ep>; }; };
700                 };
701         };
702 };