xref: /linux/sound/soc/generic/audio-graph-card2-custom-sample.dtsi (revision eb01fe7abbe2d0b38824d2a93fdb4cc3eaf2ccc1)
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};
703