xref: /linux/sound/soc/mediatek/mt8192/mt8192-dai-i2s.c (revision 0ea5c948cb64bab5bc7a5516774eb8536f05aa0d)
1 // SPDX-License-Identifier: GPL-2.0
2 //
3 // MediaTek ALSA SoC Audio DAI I2S Control
4 //
5 // Copyright (c) 2020 MediaTek Inc.
6 // Author: Shane Chien <shane.chien@mediatek.com>
7 //
8 
9 #include <linux/bitops.h>
10 #include <linux/regmap.h>
11 #include <sound/pcm_params.h>
12 
13 #include "mt8192-afe-clk.h"
14 #include "mt8192-afe-common.h"
15 #include "mt8192-afe-gpio.h"
16 #include "mt8192-interconnection.h"
17 
18 enum {
19 	I2S_FMT_EIAJ = 0,
20 	I2S_FMT_I2S = 1,
21 };
22 
23 enum {
24 	I2S_WLEN_16_BIT = 0,
25 	I2S_WLEN_32_BIT = 1,
26 };
27 
28 enum {
29 	I2S_HD_NORMAL = 0,
30 	I2S_HD_LOW_JITTER = 1,
31 };
32 
33 enum {
34 	I2S1_SEL_O28_O29 = 0,
35 	I2S1_SEL_O03_O04 = 1,
36 };
37 
38 enum {
39 	I2S_IN_PAD_CONNSYS = 0,
40 	I2S_IN_PAD_IO_MUX = 1,
41 };
42 
43 struct mtk_afe_i2s_priv {
44 	int id;
45 	int rate; /* for determine which apll to use */
46 	int low_jitter_en;
47 
48 	int share_i2s_id;
49 
50 	int mclk_id;
51 	int mclk_rate;
52 	int mclk_apll;
53 };
54 
get_i2s_wlen(snd_pcm_format_t format)55 static unsigned int get_i2s_wlen(snd_pcm_format_t format)
56 {
57 	return snd_pcm_format_physical_width(format) <= 16 ?
58 	       I2S_WLEN_16_BIT : I2S_WLEN_32_BIT;
59 }
60 
61 #define MTK_AFE_I2S0_KCONTROL_NAME "I2S0_HD_Mux"
62 #define MTK_AFE_I2S1_KCONTROL_NAME "I2S1_HD_Mux"
63 #define MTK_AFE_I2S2_KCONTROL_NAME "I2S2_HD_Mux"
64 #define MTK_AFE_I2S3_KCONTROL_NAME "I2S3_HD_Mux"
65 #define MTK_AFE_I2S5_KCONTROL_NAME "I2S5_HD_Mux"
66 #define MTK_AFE_I2S6_KCONTROL_NAME "I2S6_HD_Mux"
67 #define MTK_AFE_I2S7_KCONTROL_NAME "I2S7_HD_Mux"
68 #define MTK_AFE_I2S8_KCONTROL_NAME "I2S8_HD_Mux"
69 #define MTK_AFE_I2S9_KCONTROL_NAME "I2S9_HD_Mux"
70 
71 #define I2S0_HD_EN_W_NAME "I2S0_HD_EN"
72 #define I2S1_HD_EN_W_NAME "I2S1_HD_EN"
73 #define I2S2_HD_EN_W_NAME "I2S2_HD_EN"
74 #define I2S3_HD_EN_W_NAME "I2S3_HD_EN"
75 #define I2S5_HD_EN_W_NAME "I2S5_HD_EN"
76 #define I2S6_HD_EN_W_NAME "I2S6_HD_EN"
77 #define I2S7_HD_EN_W_NAME "I2S7_HD_EN"
78 #define I2S8_HD_EN_W_NAME "I2S8_HD_EN"
79 #define I2S9_HD_EN_W_NAME "I2S9_HD_EN"
80 
81 #define I2S0_MCLK_EN_W_NAME "I2S0_MCLK_EN"
82 #define I2S1_MCLK_EN_W_NAME "I2S1_MCLK_EN"
83 #define I2S2_MCLK_EN_W_NAME "I2S2_MCLK_EN"
84 #define I2S3_MCLK_EN_W_NAME "I2S3_MCLK_EN"
85 #define I2S5_MCLK_EN_W_NAME "I2S5_MCLK_EN"
86 #define I2S6_MCLK_EN_W_NAME "I2S6_MCLK_EN"
87 #define I2S7_MCLK_EN_W_NAME "I2S7_MCLK_EN"
88 #define I2S8_MCLK_EN_W_NAME "I2S8_MCLK_EN"
89 #define I2S9_MCLK_EN_W_NAME "I2S9_MCLK_EN"
90 
get_i2s_id_by_name(struct mtk_base_afe * afe,const char * name)91 static int get_i2s_id_by_name(struct mtk_base_afe *afe,
92 			      const char *name)
93 {
94 	if (strncmp(name, "I2S0", 4) == 0)
95 		return MT8192_DAI_I2S_0;
96 	else if (strncmp(name, "I2S1", 4) == 0)
97 		return MT8192_DAI_I2S_1;
98 	else if (strncmp(name, "I2S2", 4) == 0)
99 		return MT8192_DAI_I2S_2;
100 	else if (strncmp(name, "I2S3", 4) == 0)
101 		return MT8192_DAI_I2S_3;
102 	else if (strncmp(name, "I2S5", 4) == 0)
103 		return MT8192_DAI_I2S_5;
104 	else if (strncmp(name, "I2S6", 4) == 0)
105 		return MT8192_DAI_I2S_6;
106 	else if (strncmp(name, "I2S7", 4) == 0)
107 		return MT8192_DAI_I2S_7;
108 	else if (strncmp(name, "I2S8", 4) == 0)
109 		return MT8192_DAI_I2S_8;
110 	else if (strncmp(name, "I2S9", 4) == 0)
111 		return MT8192_DAI_I2S_9;
112 	else
113 		return -EINVAL;
114 }
115 
get_i2s_priv_by_name(struct mtk_base_afe * afe,const char * name)116 static struct mtk_afe_i2s_priv *get_i2s_priv_by_name(struct mtk_base_afe *afe,
117 						     const char *name)
118 {
119 	struct mt8192_afe_private *afe_priv = afe->platform_priv;
120 	int dai_id = get_i2s_id_by_name(afe, name);
121 
122 	if (dai_id < 0)
123 		return NULL;
124 
125 	return afe_priv->dai_priv[dai_id];
126 }
127 
128 /* low jitter control */
129 static const char * const mt8192_i2s_hd_str[] = {
130 	"Normal", "Low_Jitter"
131 };
132 
133 static SOC_ENUM_SINGLE_EXT_DECL(mt8192_i2s_enum, mt8192_i2s_hd_str);
134 
mt8192_i2s_hd_get(struct snd_kcontrol * kcontrol,struct snd_ctl_elem_value * ucontrol)135 static int mt8192_i2s_hd_get(struct snd_kcontrol *kcontrol,
136 			     struct snd_ctl_elem_value *ucontrol)
137 {
138 	struct snd_soc_component *cmpnt = snd_soc_kcontrol_component(kcontrol);
139 	struct mtk_base_afe *afe = snd_soc_component_get_drvdata(cmpnt);
140 	struct mtk_afe_i2s_priv *i2s_priv;
141 
142 	i2s_priv = get_i2s_priv_by_name(afe, kcontrol->id.name);
143 
144 	if (!i2s_priv) {
145 		dev_warn(afe->dev, "%s(), i2s_priv == NULL", __func__);
146 		return -EINVAL;
147 	}
148 
149 	ucontrol->value.integer.value[0] = i2s_priv->low_jitter_en;
150 
151 	return 0;
152 }
153 
mt8192_i2s_hd_set(struct snd_kcontrol * kcontrol,struct snd_ctl_elem_value * ucontrol)154 static int mt8192_i2s_hd_set(struct snd_kcontrol *kcontrol,
155 			     struct snd_ctl_elem_value *ucontrol)
156 {
157 	struct snd_soc_component *cmpnt = snd_soc_kcontrol_component(kcontrol);
158 	struct mtk_base_afe *afe = snd_soc_component_get_drvdata(cmpnt);
159 	struct mtk_afe_i2s_priv *i2s_priv;
160 	struct soc_enum *e = (struct soc_enum *)kcontrol->private_value;
161 	int hd_en;
162 
163 	if (ucontrol->value.enumerated.item[0] >= e->items)
164 		return -EINVAL;
165 
166 	hd_en = ucontrol->value.integer.value[0];
167 
168 	dev_dbg(afe->dev, "%s(), kcontrol name %s, hd_en %d\n",
169 		__func__, kcontrol->id.name, hd_en);
170 
171 	i2s_priv = get_i2s_priv_by_name(afe, kcontrol->id.name);
172 
173 	if (!i2s_priv) {
174 		dev_warn(afe->dev, "%s(), i2s_priv == NULL", __func__);
175 		return -EINVAL;
176 	}
177 
178 	i2s_priv->low_jitter_en = hd_en;
179 
180 	return 0;
181 }
182 
183 static const struct snd_kcontrol_new mtk_dai_i2s_controls[] = {
184 	SOC_ENUM_EXT(MTK_AFE_I2S0_KCONTROL_NAME, mt8192_i2s_enum,
185 		     mt8192_i2s_hd_get, mt8192_i2s_hd_set),
186 	SOC_ENUM_EXT(MTK_AFE_I2S1_KCONTROL_NAME, mt8192_i2s_enum,
187 		     mt8192_i2s_hd_get, mt8192_i2s_hd_set),
188 	SOC_ENUM_EXT(MTK_AFE_I2S2_KCONTROL_NAME, mt8192_i2s_enum,
189 		     mt8192_i2s_hd_get, mt8192_i2s_hd_set),
190 	SOC_ENUM_EXT(MTK_AFE_I2S3_KCONTROL_NAME, mt8192_i2s_enum,
191 		     mt8192_i2s_hd_get, mt8192_i2s_hd_set),
192 	SOC_ENUM_EXT(MTK_AFE_I2S5_KCONTROL_NAME, mt8192_i2s_enum,
193 		     mt8192_i2s_hd_get, mt8192_i2s_hd_set),
194 	SOC_ENUM_EXT(MTK_AFE_I2S6_KCONTROL_NAME, mt8192_i2s_enum,
195 		     mt8192_i2s_hd_get, mt8192_i2s_hd_set),
196 	SOC_ENUM_EXT(MTK_AFE_I2S7_KCONTROL_NAME, mt8192_i2s_enum,
197 		     mt8192_i2s_hd_get, mt8192_i2s_hd_set),
198 	SOC_ENUM_EXT(MTK_AFE_I2S8_KCONTROL_NAME, mt8192_i2s_enum,
199 		     mt8192_i2s_hd_get, mt8192_i2s_hd_set),
200 	SOC_ENUM_EXT(MTK_AFE_I2S9_KCONTROL_NAME, mt8192_i2s_enum,
201 		     mt8192_i2s_hd_get, mt8192_i2s_hd_set),
202 };
203 
204 /* dai component */
205 /* i2s virtual mux to output widget */
206 static const char * const i2s_mux_map[] = {
207 	"Normal", "Dummy_Widget",
208 };
209 
210 static int i2s_mux_map_value[] = {
211 	0, 1,
212 };
213 
214 static SOC_VALUE_ENUM_SINGLE_AUTODISABLE_DECL(i2s_mux_map_enum,
215 					      SND_SOC_NOPM,
216 					      0,
217 					      1,
218 					      i2s_mux_map,
219 					      i2s_mux_map_value);
220 
221 static const struct snd_kcontrol_new i2s0_in_mux_control =
222 	SOC_DAPM_ENUM("I2S0 In Select", i2s_mux_map_enum);
223 
224 static const struct snd_kcontrol_new i2s8_in_mux_control =
225 	SOC_DAPM_ENUM("I2S8 In Select", i2s_mux_map_enum);
226 
227 static const struct snd_kcontrol_new i2s1_out_mux_control =
228 	SOC_DAPM_ENUM("I2S1 Out Select", i2s_mux_map_enum);
229 
230 static const struct snd_kcontrol_new i2s3_out_mux_control =
231 	SOC_DAPM_ENUM("I2S3 Out Select", i2s_mux_map_enum);
232 
233 static const struct snd_kcontrol_new i2s5_out_mux_control =
234 	SOC_DAPM_ENUM("I2S5 Out Select", i2s_mux_map_enum);
235 
236 static const struct snd_kcontrol_new i2s7_out_mux_control =
237 	SOC_DAPM_ENUM("I2S7 Out Select", i2s_mux_map_enum);
238 
239 static const struct snd_kcontrol_new i2s9_out_mux_control =
240 	SOC_DAPM_ENUM("I2S9 Out Select", i2s_mux_map_enum);
241 
242 /* Tinyconn Mux */
243 enum {
244 	TINYCONN_CH1_MUX_DL1 = 0x0,
245 	TINYCONN_CH2_MUX_DL1 = 0x1,
246 	TINYCONN_CH1_MUX_DL12 = 0x2,
247 	TINYCONN_CH2_MUX_DL12 = 0x3,
248 	TINYCONN_CH1_MUX_DL2 = 0x4,
249 	TINYCONN_CH2_MUX_DL2 = 0x5,
250 	TINYCONN_CH1_MUX_DL3 = 0x6,
251 	TINYCONN_CH2_MUX_DL3 = 0x7,
252 	TINYCONN_MUX_NONE = 0x1f,
253 };
254 
255 static const char * const tinyconn_mux_map[] = {
256 	"NONE",
257 	"DL1_CH1",
258 	"DL1_CH2",
259 	"DL12_CH1",
260 	"DL12_CH2",
261 	"DL2_CH1",
262 	"DL2_CH2",
263 	"DL3_CH1",
264 	"DL3_CH2",
265 };
266 
267 static int tinyconn_mux_map_value[] = {
268 	TINYCONN_MUX_NONE,
269 	TINYCONN_CH1_MUX_DL1,
270 	TINYCONN_CH2_MUX_DL1,
271 	TINYCONN_CH1_MUX_DL12,
272 	TINYCONN_CH2_MUX_DL12,
273 	TINYCONN_CH1_MUX_DL2,
274 	TINYCONN_CH2_MUX_DL2,
275 	TINYCONN_CH1_MUX_DL3,
276 	TINYCONN_CH2_MUX_DL3,
277 };
278 
279 static SOC_VALUE_ENUM_SINGLE_DECL(i2s1_tinyconn_ch1_mux_map_enum,
280 				  AFE_TINY_CONN5,
281 				  O_20_CFG_SFT,
282 				  O_20_CFG_MASK,
283 				  tinyconn_mux_map,
284 				  tinyconn_mux_map_value);
285 static const struct snd_kcontrol_new i2s1_tinyconn_ch1_mux_control =
286 	SOC_DAPM_ENUM("i2s1 ch1 tinyconn Select",
287 		      i2s1_tinyconn_ch1_mux_map_enum);
288 
289 static SOC_VALUE_ENUM_SINGLE_DECL(i2s1_tinyconn_ch2_mux_map_enum,
290 				  AFE_TINY_CONN5,
291 				  O_21_CFG_SFT,
292 				  O_21_CFG_MASK,
293 				  tinyconn_mux_map,
294 				  tinyconn_mux_map_value);
295 static const struct snd_kcontrol_new i2s1_tinyconn_ch2_mux_control =
296 	SOC_DAPM_ENUM("i2s1 ch2 tinyconn Select",
297 		      i2s1_tinyconn_ch2_mux_map_enum);
298 
299 static SOC_VALUE_ENUM_SINGLE_DECL(i2s3_tinyconn_ch1_mux_map_enum,
300 				  AFE_TINY_CONN5,
301 				  O_22_CFG_SFT,
302 				  O_22_CFG_MASK,
303 				  tinyconn_mux_map,
304 				  tinyconn_mux_map_value);
305 static const struct snd_kcontrol_new i2s3_tinyconn_ch1_mux_control =
306 	SOC_DAPM_ENUM("i2s3 ch1 tinyconn Select",
307 		      i2s3_tinyconn_ch1_mux_map_enum);
308 
309 static SOC_VALUE_ENUM_SINGLE_DECL(i2s3_tinyconn_ch2_mux_map_enum,
310 				  AFE_TINY_CONN5,
311 				  O_23_CFG_SFT,
312 				  O_23_CFG_MASK,
313 				  tinyconn_mux_map,
314 				  tinyconn_mux_map_value);
315 static const struct snd_kcontrol_new i2s3_tinyconn_ch2_mux_control =
316 	SOC_DAPM_ENUM("i2s3 ch2 tinyconn Select",
317 		      i2s3_tinyconn_ch2_mux_map_enum);
318 
319 /* i2s in lpbk */
320 static const char * const i2s_lpbk_mux_map[] = {
321 	"Normal", "Lpbk",
322 };
323 
324 static int i2s_lpbk_mux_map_value[] = {
325 	0, 1,
326 };
327 
328 static SOC_VALUE_ENUM_SINGLE_AUTODISABLE_DECL(i2s0_lpbk_mux_map_enum,
329 					      AFE_I2S_CON,
330 					      I2S_LOOPBACK_SFT,
331 					      1,
332 					      i2s_lpbk_mux_map,
333 					      i2s_lpbk_mux_map_value);
334 
335 static const struct snd_kcontrol_new i2s0_lpbk_mux_control =
336 	SOC_DAPM_ENUM("I2S Lpbk Select", i2s0_lpbk_mux_map_enum);
337 
338 static SOC_VALUE_ENUM_SINGLE_AUTODISABLE_DECL(i2s2_lpbk_mux_map_enum,
339 					      AFE_I2S_CON2,
340 					      I2S3_LOOPBACK_SFT,
341 					      1,
342 					      i2s_lpbk_mux_map,
343 					      i2s_lpbk_mux_map_value);
344 
345 static const struct snd_kcontrol_new i2s2_lpbk_mux_control =
346 	SOC_DAPM_ENUM("I2S Lpbk Select", i2s2_lpbk_mux_map_enum);
347 
348 /* interconnection */
349 static const struct snd_kcontrol_new mtk_i2s3_ch1_mix[] = {
350 	SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH1", AFE_CONN0, I_DL1_CH1, 1, 0),
351 	SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH1", AFE_CONN0, I_DL2_CH1, 1, 0),
352 	SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH1", AFE_CONN0, I_DL3_CH1, 1, 0),
353 	SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH1", AFE_CONN0, I_DL12_CH1, 1, 0),
354 	SOC_DAPM_SINGLE_AUTODISABLE("DL6_CH1", AFE_CONN0_1, I_DL6_CH1, 1, 0),
355 	SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH1", AFE_CONN0_1, I_DL4_CH1, 1, 0),
356 	SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH1", AFE_CONN0_1, I_DL5_CH1, 1, 0),
357 	SOC_DAPM_SINGLE_AUTODISABLE("DL8_CH1", AFE_CONN0_1, I_DL8_CH1, 1, 0),
358 	SOC_DAPM_SINGLE_AUTODISABLE("DL9_CH1", AFE_CONN0_1, I_DL9_CH1, 1, 0),
359 	SOC_DAPM_SINGLE_AUTODISABLE("GAIN1_OUT_CH1", AFE_CONN0,
360 				    I_GAIN1_OUT_CH1, 1, 0),
361 	SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1", AFE_CONN0,
362 				    I_ADDA_UL_CH1, 1, 0),
363 	SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2", AFE_CONN0,
364 				    I_ADDA_UL_CH2, 1, 0),
365 	SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH3", AFE_CONN0,
366 				    I_ADDA_UL_CH3, 1, 0),
367 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH1", AFE_CONN0,
368 				    I_PCM_1_CAP_CH1, 1, 0),
369 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_2_CAP_CH1", AFE_CONN0,
370 				    I_PCM_2_CAP_CH1, 1, 0),
371 };
372 
373 static const struct snd_kcontrol_new mtk_i2s3_ch2_mix[] = {
374 	SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH2", AFE_CONN1, I_DL1_CH2, 1, 0),
375 	SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH2", AFE_CONN1, I_DL2_CH2, 1, 0),
376 	SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH2", AFE_CONN1, I_DL3_CH2, 1, 0),
377 	SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH2", AFE_CONN1, I_DL12_CH2, 1, 0),
378 	SOC_DAPM_SINGLE_AUTODISABLE("DL6_CH2", AFE_CONN1_1, I_DL6_CH2, 1, 0),
379 	SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH2", AFE_CONN1_1, I_DL4_CH2, 1, 0),
380 	SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH2", AFE_CONN1_1, I_DL5_CH2, 1, 0),
381 	SOC_DAPM_SINGLE_AUTODISABLE("DL8_CH2", AFE_CONN1_1, I_DL8_CH2, 1, 0),
382 	SOC_DAPM_SINGLE_AUTODISABLE("DL9_CH2", AFE_CONN1_1, I_DL9_CH2, 1, 0),
383 	SOC_DAPM_SINGLE_AUTODISABLE("GAIN1_OUT_CH2", AFE_CONN1,
384 				    I_GAIN1_OUT_CH2, 1, 0),
385 	SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1", AFE_CONN1,
386 				    I_ADDA_UL_CH1, 1, 0),
387 	SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2", AFE_CONN1,
388 				    I_ADDA_UL_CH2, 1, 0),
389 	SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH3", AFE_CONN1,
390 				    I_ADDA_UL_CH3, 1, 0),
391 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH1", AFE_CONN1,
392 				    I_PCM_1_CAP_CH1, 1, 0),
393 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_2_CAP_CH1", AFE_CONN1,
394 				    I_PCM_2_CAP_CH1, 1, 0),
395 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH2", AFE_CONN1,
396 				    I_PCM_1_CAP_CH2, 1, 0),
397 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_2_CAP_CH2", AFE_CONN1,
398 				    I_PCM_2_CAP_CH2, 1, 0),
399 };
400 
401 static const struct snd_kcontrol_new mtk_i2s1_ch1_mix[] = {
402 	SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH1", AFE_CONN28, I_DL1_CH1, 1, 0),
403 	SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH1", AFE_CONN28, I_DL2_CH1, 1, 0),
404 	SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH1", AFE_CONN28, I_DL3_CH1, 1, 0),
405 	SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH1", AFE_CONN28, I_DL12_CH1, 1, 0),
406 	SOC_DAPM_SINGLE_AUTODISABLE("DL6_CH1", AFE_CONN28_1, I_DL6_CH1, 1, 0),
407 	SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH1", AFE_CONN28_1, I_DL4_CH1, 1, 0),
408 	SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH1", AFE_CONN28_1, I_DL5_CH1, 1, 0),
409 	SOC_DAPM_SINGLE_AUTODISABLE("DL8_CH1", AFE_CONN28_1, I_DL8_CH1, 1, 0),
410 	SOC_DAPM_SINGLE_AUTODISABLE("DL9_CH1", AFE_CONN28_1, I_DL9_CH1, 1, 0),
411 	SOC_DAPM_SINGLE_AUTODISABLE("GAIN1_OUT_CH1", AFE_CONN28,
412 				    I_GAIN1_OUT_CH1, 1, 0),
413 	SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1", AFE_CONN28,
414 				    I_ADDA_UL_CH1, 1, 0),
415 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH1", AFE_CONN28,
416 				    I_PCM_1_CAP_CH1, 1, 0),
417 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_2_CAP_CH1", AFE_CONN28,
418 				    I_PCM_2_CAP_CH1, 1, 0),
419 };
420 
421 static const struct snd_kcontrol_new mtk_i2s1_ch2_mix[] = {
422 	SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH2", AFE_CONN29, I_DL1_CH2, 1, 0),
423 	SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH2", AFE_CONN29, I_DL2_CH2, 1, 0),
424 	SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH2", AFE_CONN29, I_DL3_CH2, 1, 0),
425 	SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH2", AFE_CONN29, I_DL12_CH2, 1, 0),
426 	SOC_DAPM_SINGLE_AUTODISABLE("DL6_CH2", AFE_CONN29_1, I_DL6_CH2, 1, 0),
427 	SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH2", AFE_CONN29_1, I_DL4_CH2, 1, 0),
428 	SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH2", AFE_CONN29_1, I_DL5_CH2, 1, 0),
429 	SOC_DAPM_SINGLE_AUTODISABLE("DL8_CH2", AFE_CONN29_1, I_DL8_CH2, 1, 0),
430 	SOC_DAPM_SINGLE_AUTODISABLE("DL9_CH2", AFE_CONN29_1, I_DL9_CH2, 1, 0),
431 	SOC_DAPM_SINGLE_AUTODISABLE("GAIN1_OUT_CH2", AFE_CONN29,
432 				    I_GAIN1_OUT_CH2, 1, 0),
433 	SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2", AFE_CONN29,
434 				    I_ADDA_UL_CH2, 1, 0),
435 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH1", AFE_CONN29,
436 				    I_PCM_1_CAP_CH1, 1, 0),
437 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_2_CAP_CH1", AFE_CONN29,
438 				    I_PCM_2_CAP_CH1, 1, 0),
439 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH2", AFE_CONN29,
440 				    I_PCM_1_CAP_CH2, 1, 0),
441 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_2_CAP_CH2", AFE_CONN29,
442 				    I_PCM_2_CAP_CH2, 1, 0),
443 };
444 
445 static const struct snd_kcontrol_new mtk_i2s5_ch1_mix[] = {
446 	SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH1", AFE_CONN30, I_DL1_CH1, 1, 0),
447 	SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH1", AFE_CONN30, I_DL2_CH1, 1, 0),
448 	SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH1", AFE_CONN30, I_DL3_CH1, 1, 0),
449 	SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH1", AFE_CONN30, I_DL12_CH1, 1, 0),
450 	SOC_DAPM_SINGLE_AUTODISABLE("DL6_CH1", AFE_CONN30_1, I_DL6_CH1, 1, 0),
451 	SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH1", AFE_CONN30_1, I_DL4_CH1, 1, 0),
452 	SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH1", AFE_CONN30_1, I_DL5_CH1, 1, 0),
453 	SOC_DAPM_SINGLE_AUTODISABLE("DL8_CH1", AFE_CONN30_1, I_DL8_CH1, 1, 0),
454 	SOC_DAPM_SINGLE_AUTODISABLE("DL9_CH1", AFE_CONN30_1, I_DL9_CH1, 1, 0),
455 	SOC_DAPM_SINGLE_AUTODISABLE("GAIN1_OUT_CH1", AFE_CONN30,
456 				    I_GAIN1_OUT_CH1, 1, 0),
457 	SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1", AFE_CONN30,
458 				    I_ADDA_UL_CH1, 1, 0),
459 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH1", AFE_CONN30,
460 				    I_PCM_1_CAP_CH1, 1, 0),
461 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_2_CAP_CH1", AFE_CONN30,
462 				    I_PCM_2_CAP_CH1, 1, 0),
463 };
464 
465 static const struct snd_kcontrol_new mtk_i2s5_ch2_mix[] = {
466 	SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH2", AFE_CONN31, I_DL1_CH2, 1, 0),
467 	SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH2", AFE_CONN31, I_DL2_CH2, 1, 0),
468 	SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH2", AFE_CONN31, I_DL3_CH2, 1, 0),
469 	SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH2", AFE_CONN31, I_DL12_CH2, 1, 0),
470 	SOC_DAPM_SINGLE_AUTODISABLE("DL6_CH2", AFE_CONN31_1, I_DL6_CH2, 1, 0),
471 	SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH2", AFE_CONN31_1, I_DL4_CH2, 1, 0),
472 	SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH2", AFE_CONN31_1, I_DL5_CH2, 1, 0),
473 	SOC_DAPM_SINGLE_AUTODISABLE("DL8_CH2", AFE_CONN31_1, I_DL8_CH2, 1, 0),
474 	SOC_DAPM_SINGLE_AUTODISABLE("DL9_CH2", AFE_CONN31_1, I_DL9_CH2, 1, 0),
475 	SOC_DAPM_SINGLE_AUTODISABLE("GAIN1_OUT_CH2", AFE_CONN31,
476 				    I_GAIN1_OUT_CH2, 1, 0),
477 	SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2", AFE_CONN31,
478 				    I_ADDA_UL_CH2, 1, 0),
479 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH1", AFE_CONN31,
480 				    I_PCM_1_CAP_CH1, 1, 0),
481 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_2_CAP_CH1", AFE_CONN31,
482 				    I_PCM_2_CAP_CH1, 1, 0),
483 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH2", AFE_CONN31,
484 				    I_PCM_1_CAP_CH2, 1, 0),
485 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_2_CAP_CH2", AFE_CONN31,
486 				    I_PCM_2_CAP_CH2, 1, 0),
487 };
488 
489 static const struct snd_kcontrol_new mtk_i2s7_ch1_mix[] = {
490 	SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH1", AFE_CONN54, I_DL1_CH1, 1, 0),
491 	SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH1", AFE_CONN54, I_DL2_CH1, 1, 0),
492 	SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH1", AFE_CONN54, I_DL3_CH1, 1, 0),
493 	SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH1", AFE_CONN54, I_DL12_CH1, 1, 0),
494 	SOC_DAPM_SINGLE_AUTODISABLE("DL6_CH1", AFE_CONN54_1, I_DL6_CH1, 1, 0),
495 	SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH1", AFE_CONN54_1, I_DL4_CH1, 1, 0),
496 	SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH1", AFE_CONN54_1, I_DL5_CH1, 1, 0),
497 	SOC_DAPM_SINGLE_AUTODISABLE("DL9_CH1", AFE_CONN54_1, I_DL9_CH1, 1, 0),
498 	SOC_DAPM_SINGLE_AUTODISABLE("GAIN1_OUT_CH1", AFE_CONN54,
499 				    I_GAIN1_OUT_CH1, 1, 0),
500 	SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1", AFE_CONN54,
501 				    I_ADDA_UL_CH1, 1, 0),
502 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH1", AFE_CONN54,
503 				    I_PCM_1_CAP_CH1, 1, 0),
504 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_2_CAP_CH1", AFE_CONN54,
505 				    I_PCM_2_CAP_CH1, 1, 0),
506 };
507 
508 static const struct snd_kcontrol_new mtk_i2s7_ch2_mix[] = {
509 	SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH2", AFE_CONN55, I_DL1_CH2, 1, 0),
510 	SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH2", AFE_CONN55, I_DL2_CH2, 1, 0),
511 	SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH2", AFE_CONN55, I_DL3_CH2, 1, 0),
512 	SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH2", AFE_CONN55, I_DL12_CH2, 1, 0),
513 	SOC_DAPM_SINGLE_AUTODISABLE("DL6_CH2", AFE_CONN55_1, I_DL6_CH2, 1, 0),
514 	SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH2", AFE_CONN55_1, I_DL4_CH2, 1, 0),
515 	SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH2", AFE_CONN55_1, I_DL5_CH2, 1, 0),
516 	SOC_DAPM_SINGLE_AUTODISABLE("DL9_CH2", AFE_CONN55_1, I_DL9_CH2, 1, 0),
517 	SOC_DAPM_SINGLE_AUTODISABLE("GAIN1_OUT_CH2", AFE_CONN55,
518 				    I_GAIN1_OUT_CH2, 1, 0),
519 	SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2", AFE_CONN55,
520 				    I_ADDA_UL_CH2, 1, 0),
521 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH1", AFE_CONN55,
522 				    I_PCM_1_CAP_CH1, 1, 0),
523 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_2_CAP_CH1", AFE_CONN55,
524 				    I_PCM_2_CAP_CH1, 1, 0),
525 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH2", AFE_CONN55,
526 				    I_PCM_1_CAP_CH2, 1, 0),
527 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_2_CAP_CH2", AFE_CONN55,
528 				    I_PCM_2_CAP_CH2, 1, 0),
529 };
530 
531 static const struct snd_kcontrol_new mtk_i2s9_ch1_mix[] = {
532 	SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH1", AFE_CONN56, I_DL1_CH1, 1, 0),
533 	SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH1", AFE_CONN56, I_DL2_CH1, 1, 0),
534 	SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH1", AFE_CONN56, I_DL3_CH1, 1, 0),
535 	SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH1", AFE_CONN56, I_DL12_CH1, 1, 0),
536 	SOC_DAPM_SINGLE_AUTODISABLE("DL6_CH1", AFE_CONN56_1, I_DL6_CH1, 1, 0),
537 	SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH1", AFE_CONN56_1, I_DL4_CH1, 1, 0),
538 	SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH1", AFE_CONN56_1, I_DL5_CH1, 1, 0),
539 	SOC_DAPM_SINGLE_AUTODISABLE("DL8_CH1", AFE_CONN56_1, I_DL8_CH1, 1, 0),
540 	SOC_DAPM_SINGLE_AUTODISABLE("DL9_CH1", AFE_CONN56_1, I_DL9_CH1, 1, 0),
541 	SOC_DAPM_SINGLE_AUTODISABLE("GAIN1_OUT_CH1", AFE_CONN56,
542 				    I_GAIN1_OUT_CH1, 1, 0),
543 	SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1", AFE_CONN56,
544 				    I_ADDA_UL_CH1, 1, 0),
545 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH1", AFE_CONN56,
546 				    I_PCM_1_CAP_CH1, 1, 0),
547 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_2_CAP_CH1", AFE_CONN56,
548 				    I_PCM_2_CAP_CH1, 1, 0),
549 };
550 
551 static const struct snd_kcontrol_new mtk_i2s9_ch2_mix[] = {
552 	SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH2", AFE_CONN57, I_DL1_CH2, 1, 0),
553 	SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH2", AFE_CONN57, I_DL2_CH2, 1, 0),
554 	SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH2", AFE_CONN57, I_DL3_CH2, 1, 0),
555 	SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH2", AFE_CONN57, I_DL12_CH2, 1, 0),
556 	SOC_DAPM_SINGLE_AUTODISABLE("DL6_CH2", AFE_CONN57_1, I_DL6_CH2, 1, 0),
557 	SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH2", AFE_CONN57_1, I_DL4_CH2, 1, 0),
558 	SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH2", AFE_CONN57_1, I_DL5_CH2, 1, 0),
559 	SOC_DAPM_SINGLE_AUTODISABLE("DL8_CH2", AFE_CONN57_1, I_DL8_CH2, 1, 0),
560 	SOC_DAPM_SINGLE_AUTODISABLE("DL9_CH2", AFE_CONN57_1, I_DL9_CH2, 1, 0),
561 	SOC_DAPM_SINGLE_AUTODISABLE("GAIN1_OUT_CH2", AFE_CONN57,
562 				    I_GAIN1_OUT_CH2, 1, 0),
563 	SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2", AFE_CONN57,
564 				    I_ADDA_UL_CH2, 1, 0),
565 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH1", AFE_CONN57,
566 				    I_PCM_1_CAP_CH1, 1, 0),
567 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_2_CAP_CH1", AFE_CONN57,
568 				    I_PCM_2_CAP_CH1, 1, 0),
569 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH2", AFE_CONN57,
570 				    I_PCM_1_CAP_CH2, 1, 0),
571 	SOC_DAPM_SINGLE_AUTODISABLE("PCM_2_CAP_CH2", AFE_CONN57,
572 				    I_PCM_2_CAP_CH2, 1, 0),
573 };
574 
575 enum {
576 	SUPPLY_SEQ_APLL,
577 	SUPPLY_SEQ_I2S_MCLK_EN,
578 	SUPPLY_SEQ_I2S_HD_EN,
579 	SUPPLY_SEQ_I2S_EN,
580 };
581 
mtk_i2s_en_event(struct snd_soc_dapm_widget * w,struct snd_kcontrol * kcontrol,int event)582 static int mtk_i2s_en_event(struct snd_soc_dapm_widget *w,
583 			    struct snd_kcontrol *kcontrol,
584 			    int event)
585 {
586 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
587 	struct mtk_base_afe *afe = snd_soc_component_get_drvdata(cmpnt);
588 	struct mtk_afe_i2s_priv *i2s_priv;
589 
590 	i2s_priv = get_i2s_priv_by_name(afe, w->name);
591 
592 	if (!i2s_priv) {
593 		dev_warn(afe->dev, "%s(), i2s_priv == NULL", __func__);
594 		return -EINVAL;
595 	}
596 
597 	dev_dbg(cmpnt->dev, "%s(), name %s, event 0x%x\n",
598 		__func__, w->name, event);
599 
600 	switch (event) {
601 	case SND_SOC_DAPM_PRE_PMU:
602 		mt8192_afe_gpio_request(afe->dev, true, i2s_priv->id, 0);
603 		break;
604 	case SND_SOC_DAPM_POST_PMD:
605 		mt8192_afe_gpio_request(afe->dev, false, i2s_priv->id, 0);
606 		break;
607 	default:
608 		break;
609 	}
610 
611 	return 0;
612 }
613 
mtk_apll_event(struct snd_soc_dapm_widget * w,struct snd_kcontrol * kcontrol,int event)614 static int mtk_apll_event(struct snd_soc_dapm_widget *w,
615 			  struct snd_kcontrol *kcontrol,
616 			  int event)
617 {
618 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
619 	struct mtk_base_afe *afe = snd_soc_component_get_drvdata(cmpnt);
620 
621 	dev_dbg(cmpnt->dev, "%s(), name %s, event 0x%x\n",
622 		__func__, w->name, event);
623 
624 	switch (event) {
625 	case SND_SOC_DAPM_PRE_PMU:
626 		if (snd_soc_dapm_widget_name_cmp(w, APLL1_W_NAME) == 0)
627 			mt8192_apll1_enable(afe);
628 		else
629 			mt8192_apll2_enable(afe);
630 		break;
631 	case SND_SOC_DAPM_POST_PMD:
632 		if (snd_soc_dapm_widget_name_cmp(w, APLL1_W_NAME) == 0)
633 			mt8192_apll1_disable(afe);
634 		else
635 			mt8192_apll2_disable(afe);
636 		break;
637 	default:
638 		break;
639 	}
640 
641 	return 0;
642 }
643 
i2s_out_tinyconn_event(struct snd_soc_dapm_widget * w,struct snd_kcontrol * kcontrol,int event)644 static int i2s_out_tinyconn_event(struct snd_soc_dapm_widget *w,
645 				  struct snd_kcontrol *kcontrol,
646 				  int event)
647 {
648 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
649 	struct mtk_base_afe *afe = snd_soc_component_get_drvdata(cmpnt);
650 	unsigned int reg;
651 	unsigned int reg_shift;
652 	unsigned int reg_mask_shift;
653 
654 	dev_dbg(afe->dev, "%s(), event 0x%x\n", __func__, event);
655 
656 	if (strstr(w->name, "I2S1")) {
657 		reg = AFE_I2S_CON1;
658 		reg_shift = I2S2_32BIT_EN_SFT;
659 		reg_mask_shift = I2S2_32BIT_EN_MASK_SFT;
660 	} else if (strstr(w->name, "I2S3")) {
661 		reg = AFE_I2S_CON3;
662 		reg_shift = I2S4_32BIT_EN_SFT;
663 		reg_mask_shift = I2S4_32BIT_EN_MASK_SFT;
664 	} else if (strstr(w->name, "I2S5")) {
665 		reg = AFE_I2S_CON4;
666 		reg_shift = I2S5_32BIT_EN_SFT;
667 		reg_mask_shift = I2S5_32BIT_EN_MASK_SFT;
668 	} else if (strstr(w->name, "I2S7")) {
669 		reg = AFE_I2S_CON7;
670 		reg_shift = I2S7_32BIT_EN_SFT;
671 		reg_mask_shift = I2S7_32BIT_EN_MASK_SFT;
672 	} else if (strstr(w->name, "I2S9")) {
673 		reg = AFE_I2S_CON9;
674 		reg_shift = I2S9_32BIT_EN_SFT;
675 		reg_mask_shift = I2S9_32BIT_EN_MASK_SFT;
676 	} else {
677 		reg = AFE_I2S_CON1;
678 		reg_shift = I2S2_32BIT_EN_SFT;
679 		reg_mask_shift = I2S2_32BIT_EN_MASK_SFT;
680 		dev_warn(afe->dev, "%s(), error widget name %s, use i2s1\n",
681 			 __func__, w->name);
682 	}
683 
684 	switch (event) {
685 	case SND_SOC_DAPM_PRE_PMU:
686 		regmap_update_bits(afe->regmap, reg, reg_mask_shift,
687 				   0x1 << reg_shift);
688 		break;
689 	case SND_SOC_DAPM_PRE_PMD:
690 		regmap_update_bits(afe->regmap, reg, reg_mask_shift,
691 				   0x0 << reg_shift);
692 		break;
693 	default:
694 		break;
695 	}
696 
697 	return 0;
698 }
699 
mtk_mclk_en_event(struct snd_soc_dapm_widget * w,struct snd_kcontrol * kcontrol,int event)700 static int mtk_mclk_en_event(struct snd_soc_dapm_widget *w,
701 			     struct snd_kcontrol *kcontrol,
702 			     int event)
703 {
704 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
705 	struct mtk_base_afe *afe = snd_soc_component_get_drvdata(cmpnt);
706 	struct mtk_afe_i2s_priv *i2s_priv;
707 
708 	dev_dbg(cmpnt->dev, "%s(), name %s, event 0x%x\n",
709 		__func__, w->name, event);
710 
711 	i2s_priv = get_i2s_priv_by_name(afe, w->name);
712 	if (!i2s_priv) {
713 		dev_warn(afe->dev, "%s(), i2s_priv == NULL", __func__);
714 		return -EINVAL;
715 	}
716 
717 	switch (event) {
718 	case SND_SOC_DAPM_PRE_PMU:
719 		mt8192_mck_enable(afe, i2s_priv->mclk_id, i2s_priv->mclk_rate);
720 		break;
721 	case SND_SOC_DAPM_POST_PMD:
722 		i2s_priv->mclk_rate = 0;
723 		mt8192_mck_disable(afe, i2s_priv->mclk_id);
724 		break;
725 	default:
726 		break;
727 	}
728 
729 	return 0;
730 }
731 
732 static const struct snd_soc_dapm_widget mtk_dai_i2s_widgets[] = {
733 	SND_SOC_DAPM_INPUT("CONNSYS"),
734 
735 	SND_SOC_DAPM_MIXER("I2S1_CH1", SND_SOC_NOPM, 0, 0,
736 			   mtk_i2s1_ch1_mix,
737 			   ARRAY_SIZE(mtk_i2s1_ch1_mix)),
738 	SND_SOC_DAPM_MIXER("I2S1_CH2", SND_SOC_NOPM, 0, 0,
739 			   mtk_i2s1_ch2_mix,
740 			   ARRAY_SIZE(mtk_i2s1_ch2_mix)),
741 
742 	SND_SOC_DAPM_MIXER("I2S3_CH1", SND_SOC_NOPM, 0, 0,
743 			   mtk_i2s3_ch1_mix,
744 			   ARRAY_SIZE(mtk_i2s3_ch1_mix)),
745 	SND_SOC_DAPM_MIXER("I2S3_CH2", SND_SOC_NOPM, 0, 0,
746 			   mtk_i2s3_ch2_mix,
747 			   ARRAY_SIZE(mtk_i2s3_ch2_mix)),
748 
749 	SND_SOC_DAPM_MIXER("I2S5_CH1", SND_SOC_NOPM, 0, 0,
750 			   mtk_i2s5_ch1_mix,
751 			   ARRAY_SIZE(mtk_i2s5_ch1_mix)),
752 	SND_SOC_DAPM_MIXER("I2S5_CH2", SND_SOC_NOPM, 0, 0,
753 			   mtk_i2s5_ch2_mix,
754 			   ARRAY_SIZE(mtk_i2s5_ch2_mix)),
755 
756 	SND_SOC_DAPM_MIXER("I2S7_CH1", SND_SOC_NOPM, 0, 0,
757 			   mtk_i2s7_ch1_mix,
758 			   ARRAY_SIZE(mtk_i2s7_ch1_mix)),
759 	SND_SOC_DAPM_MIXER("I2S7_CH2", SND_SOC_NOPM, 0, 0,
760 			   mtk_i2s7_ch2_mix,
761 			   ARRAY_SIZE(mtk_i2s7_ch2_mix)),
762 
763 	SND_SOC_DAPM_MIXER("I2S9_CH1", SND_SOC_NOPM, 0, 0,
764 			   mtk_i2s9_ch1_mix,
765 			   ARRAY_SIZE(mtk_i2s9_ch1_mix)),
766 	SND_SOC_DAPM_MIXER("I2S9_CH2", SND_SOC_NOPM, 0, 0,
767 			   mtk_i2s9_ch2_mix,
768 			   ARRAY_SIZE(mtk_i2s9_ch2_mix)),
769 
770 	SND_SOC_DAPM_MUX_E("I2S1_TINYCONN_CH1_MUX", SND_SOC_NOPM, 0, 0,
771 			   &i2s1_tinyconn_ch1_mux_control,
772 			   i2s_out_tinyconn_event,
773 			   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_PRE_PMD),
774 	SND_SOC_DAPM_MUX_E("I2S1_TINYCONN_CH2_MUX", SND_SOC_NOPM, 0, 0,
775 			   &i2s1_tinyconn_ch2_mux_control,
776 			   i2s_out_tinyconn_event,
777 			   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_PRE_PMD),
778 	SND_SOC_DAPM_MUX_E("I2S3_TINYCONN_CH1_MUX", SND_SOC_NOPM, 0, 0,
779 			   &i2s3_tinyconn_ch1_mux_control,
780 			   i2s_out_tinyconn_event,
781 			   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_PRE_PMD),
782 	SND_SOC_DAPM_MUX_E("I2S3_TINYCONN_CH2_MUX", SND_SOC_NOPM, 0, 0,
783 			   &i2s3_tinyconn_ch2_mux_control,
784 			   i2s_out_tinyconn_event,
785 			   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_PRE_PMD),
786 
787 	/* i2s en*/
788 	SND_SOC_DAPM_SUPPLY_S("I2S0_EN", SUPPLY_SEQ_I2S_EN,
789 			      AFE_I2S_CON, I2S_EN_SFT, 0,
790 			      mtk_i2s_en_event,
791 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
792 	SND_SOC_DAPM_SUPPLY_S("I2S1_EN", SUPPLY_SEQ_I2S_EN,
793 			      AFE_I2S_CON1, I2S_EN_SFT, 0,
794 			      mtk_i2s_en_event,
795 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
796 	SND_SOC_DAPM_SUPPLY_S("I2S2_EN", SUPPLY_SEQ_I2S_EN,
797 			      AFE_I2S_CON2, I2S_EN_SFT, 0,
798 			      mtk_i2s_en_event,
799 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
800 	SND_SOC_DAPM_SUPPLY_S("I2S3_EN", SUPPLY_SEQ_I2S_EN,
801 			      AFE_I2S_CON3, I2S_EN_SFT, 0,
802 			      mtk_i2s_en_event,
803 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
804 	SND_SOC_DAPM_SUPPLY_S("I2S5_EN", SUPPLY_SEQ_I2S_EN,
805 			      AFE_I2S_CON4, I2S5_EN_SFT, 0,
806 			      mtk_i2s_en_event,
807 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
808 	SND_SOC_DAPM_SUPPLY_S("I2S6_EN", SUPPLY_SEQ_I2S_EN,
809 			      AFE_I2S_CON6, I2S6_EN_SFT, 0,
810 			      mtk_i2s_en_event,
811 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
812 	SND_SOC_DAPM_SUPPLY_S("I2S7_EN", SUPPLY_SEQ_I2S_EN,
813 			      AFE_I2S_CON7, I2S7_EN_SFT, 0,
814 			      mtk_i2s_en_event,
815 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
816 	SND_SOC_DAPM_SUPPLY_S("I2S8_EN", SUPPLY_SEQ_I2S_EN,
817 			      AFE_I2S_CON8, I2S8_EN_SFT, 0,
818 			      mtk_i2s_en_event,
819 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
820 	SND_SOC_DAPM_SUPPLY_S("I2S9_EN", SUPPLY_SEQ_I2S_EN,
821 			      AFE_I2S_CON9, I2S9_EN_SFT, 0,
822 			      mtk_i2s_en_event,
823 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
824 	/* i2s hd en */
825 	SND_SOC_DAPM_SUPPLY_S(I2S0_HD_EN_W_NAME, SUPPLY_SEQ_I2S_HD_EN,
826 			      AFE_I2S_CON, I2S1_HD_EN_SFT, 0, NULL, 0),
827 	SND_SOC_DAPM_SUPPLY_S(I2S1_HD_EN_W_NAME, SUPPLY_SEQ_I2S_HD_EN,
828 			      AFE_I2S_CON1, I2S2_HD_EN_SFT, 0, NULL, 0),
829 	SND_SOC_DAPM_SUPPLY_S(I2S2_HD_EN_W_NAME, SUPPLY_SEQ_I2S_HD_EN,
830 			      AFE_I2S_CON2, I2S3_HD_EN_SFT, 0, NULL, 0),
831 	SND_SOC_DAPM_SUPPLY_S(I2S3_HD_EN_W_NAME, SUPPLY_SEQ_I2S_HD_EN,
832 			      AFE_I2S_CON3, I2S4_HD_EN_SFT, 0, NULL, 0),
833 	SND_SOC_DAPM_SUPPLY_S(I2S5_HD_EN_W_NAME, SUPPLY_SEQ_I2S_HD_EN,
834 			      AFE_I2S_CON4, I2S5_HD_EN_SFT, 0, NULL, 0),
835 	SND_SOC_DAPM_SUPPLY_S(I2S6_HD_EN_W_NAME, SUPPLY_SEQ_I2S_HD_EN,
836 			      AFE_I2S_CON6, I2S6_HD_EN_SFT, 0, NULL, 0),
837 	SND_SOC_DAPM_SUPPLY_S(I2S7_HD_EN_W_NAME, SUPPLY_SEQ_I2S_HD_EN,
838 			      AFE_I2S_CON7, I2S7_HD_EN_SFT, 0, NULL, 0),
839 	SND_SOC_DAPM_SUPPLY_S(I2S8_HD_EN_W_NAME, SUPPLY_SEQ_I2S_HD_EN,
840 			      AFE_I2S_CON8, I2S8_HD_EN_SFT, 0, NULL, 0),
841 	SND_SOC_DAPM_SUPPLY_S(I2S9_HD_EN_W_NAME, SUPPLY_SEQ_I2S_HD_EN,
842 			      AFE_I2S_CON9, I2S9_HD_EN_SFT, 0, NULL, 0),
843 
844 	/* i2s mclk en */
845 	SND_SOC_DAPM_SUPPLY_S(I2S0_MCLK_EN_W_NAME, SUPPLY_SEQ_I2S_MCLK_EN,
846 			      SND_SOC_NOPM, 0, 0,
847 			      mtk_mclk_en_event,
848 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
849 	SND_SOC_DAPM_SUPPLY_S(I2S1_MCLK_EN_W_NAME, SUPPLY_SEQ_I2S_MCLK_EN,
850 			      SND_SOC_NOPM, 0, 0,
851 			      mtk_mclk_en_event,
852 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
853 	SND_SOC_DAPM_SUPPLY_S(I2S2_MCLK_EN_W_NAME, SUPPLY_SEQ_I2S_MCLK_EN,
854 			      SND_SOC_NOPM, 0, 0,
855 			      mtk_mclk_en_event,
856 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
857 	SND_SOC_DAPM_SUPPLY_S(I2S3_MCLK_EN_W_NAME, SUPPLY_SEQ_I2S_MCLK_EN,
858 			      SND_SOC_NOPM, 0, 0,
859 			      mtk_mclk_en_event,
860 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
861 	SND_SOC_DAPM_SUPPLY_S(I2S5_MCLK_EN_W_NAME, SUPPLY_SEQ_I2S_MCLK_EN,
862 			      SND_SOC_NOPM, 0, 0,
863 			      mtk_mclk_en_event,
864 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
865 	SND_SOC_DAPM_SUPPLY_S(I2S6_MCLK_EN_W_NAME, SUPPLY_SEQ_I2S_MCLK_EN,
866 			      SND_SOC_NOPM, 0, 0,
867 			      mtk_mclk_en_event,
868 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
869 	SND_SOC_DAPM_SUPPLY_S(I2S7_MCLK_EN_W_NAME, SUPPLY_SEQ_I2S_MCLK_EN,
870 			      SND_SOC_NOPM, 0, 0,
871 			      mtk_mclk_en_event,
872 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
873 	SND_SOC_DAPM_SUPPLY_S(I2S8_MCLK_EN_W_NAME, SUPPLY_SEQ_I2S_MCLK_EN,
874 			      SND_SOC_NOPM, 0, 0,
875 			      mtk_mclk_en_event,
876 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
877 	SND_SOC_DAPM_SUPPLY_S(I2S9_MCLK_EN_W_NAME, SUPPLY_SEQ_I2S_MCLK_EN,
878 			      SND_SOC_NOPM, 0, 0,
879 			      mtk_mclk_en_event,
880 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
881 
882 	/* apll */
883 	SND_SOC_DAPM_SUPPLY_S(APLL1_W_NAME, SUPPLY_SEQ_APLL,
884 			      SND_SOC_NOPM, 0, 0,
885 			      mtk_apll_event,
886 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
887 	SND_SOC_DAPM_SUPPLY_S(APLL2_W_NAME, SUPPLY_SEQ_APLL,
888 			      SND_SOC_NOPM, 0, 0,
889 			      mtk_apll_event,
890 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
891 
892 	/* allow i2s on without codec on */
893 	SND_SOC_DAPM_OUTPUT("I2S_DUMMY_OUT"),
894 	SND_SOC_DAPM_MUX("I2S1_Out_Mux",
895 			 SND_SOC_NOPM, 0, 0, &i2s1_out_mux_control),
896 	SND_SOC_DAPM_MUX("I2S3_Out_Mux",
897 			 SND_SOC_NOPM, 0, 0, &i2s3_out_mux_control),
898 	SND_SOC_DAPM_MUX("I2S5_Out_Mux",
899 			 SND_SOC_NOPM, 0, 0, &i2s5_out_mux_control),
900 	SND_SOC_DAPM_MUX("I2S7_Out_Mux",
901 			 SND_SOC_NOPM, 0, 0, &i2s7_out_mux_control),
902 	SND_SOC_DAPM_MUX("I2S9_Out_Mux",
903 			 SND_SOC_NOPM, 0, 0, &i2s9_out_mux_control),
904 
905 	SND_SOC_DAPM_INPUT("I2S_DUMMY_IN"),
906 	SND_SOC_DAPM_MUX("I2S0_In_Mux",
907 			 SND_SOC_NOPM, 0, 0, &i2s0_in_mux_control),
908 	SND_SOC_DAPM_MUX("I2S8_In_Mux",
909 			 SND_SOC_NOPM, 0, 0, &i2s8_in_mux_control),
910 
911 	/* i2s in lpbk */
912 	SND_SOC_DAPM_MUX("I2S0_Lpbk_Mux",
913 			 SND_SOC_NOPM, 0, 0, &i2s0_lpbk_mux_control),
914 	SND_SOC_DAPM_MUX("I2S2_Lpbk_Mux",
915 			 SND_SOC_NOPM, 0, 0, &i2s2_lpbk_mux_control),
916 };
917 
mtk_afe_i2s_share_connect(struct snd_soc_dapm_widget * source,struct snd_soc_dapm_widget * sink)918 static int mtk_afe_i2s_share_connect(struct snd_soc_dapm_widget *source,
919 				     struct snd_soc_dapm_widget *sink)
920 {
921 	struct snd_soc_dapm_widget *w = sink;
922 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
923 	struct mtk_base_afe *afe = snd_soc_component_get_drvdata(cmpnt);
924 	struct mtk_afe_i2s_priv *i2s_priv;
925 
926 	i2s_priv = get_i2s_priv_by_name(afe, sink->name);
927 	if (!i2s_priv) {
928 		dev_warn(afe->dev, "%s(), i2s_priv == NULL", __func__);
929 		return 0;
930 	}
931 
932 	if (i2s_priv->share_i2s_id < 0)
933 		return 0;
934 
935 	return i2s_priv->share_i2s_id == get_i2s_id_by_name(afe, source->name);
936 }
937 
mtk_afe_i2s_hd_connect(struct snd_soc_dapm_widget * source,struct snd_soc_dapm_widget * sink)938 static int mtk_afe_i2s_hd_connect(struct snd_soc_dapm_widget *source,
939 				  struct snd_soc_dapm_widget *sink)
940 {
941 	struct snd_soc_dapm_widget *w = sink;
942 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
943 	struct mtk_base_afe *afe = snd_soc_component_get_drvdata(cmpnt);
944 	struct mtk_afe_i2s_priv *i2s_priv;
945 
946 	i2s_priv = get_i2s_priv_by_name(afe, sink->name);
947 	if (!i2s_priv) {
948 		dev_warn(afe->dev, "%s(), i2s_priv == NULL", __func__);
949 		return 0;
950 	}
951 
952 	if (get_i2s_id_by_name(afe, sink->name) ==
953 	    get_i2s_id_by_name(afe, source->name))
954 		return i2s_priv->low_jitter_en;
955 
956 	/* check if share i2s need hd en */
957 	if (i2s_priv->share_i2s_id < 0)
958 		return 0;
959 
960 	if (i2s_priv->share_i2s_id == get_i2s_id_by_name(afe, source->name))
961 		return i2s_priv->low_jitter_en;
962 
963 	return 0;
964 }
965 
mtk_afe_i2s_apll_connect(struct snd_soc_dapm_widget * source,struct snd_soc_dapm_widget * sink)966 static int mtk_afe_i2s_apll_connect(struct snd_soc_dapm_widget *source,
967 				    struct snd_soc_dapm_widget *sink)
968 {
969 	struct snd_soc_dapm_widget *w = sink;
970 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
971 	struct mtk_base_afe *afe = snd_soc_component_get_drvdata(cmpnt);
972 	struct mtk_afe_i2s_priv *i2s_priv;
973 	int cur_apll;
974 	int i2s_need_apll;
975 
976 	i2s_priv = get_i2s_priv_by_name(afe, w->name);
977 	if (!i2s_priv) {
978 		dev_warn(afe->dev, "%s(), i2s_priv == NULL", __func__);
979 		return 0;
980 	}
981 
982 	/* which apll */
983 	cur_apll = mt8192_get_apll_by_name(afe, source->name);
984 
985 	/* choose APLL from i2s rate */
986 	i2s_need_apll = mt8192_get_apll_by_rate(afe, i2s_priv->rate);
987 
988 	if (i2s_need_apll == cur_apll)
989 		return 1;
990 
991 	return 0;
992 }
993 
mtk_afe_i2s_mclk_connect(struct snd_soc_dapm_widget * source,struct snd_soc_dapm_widget * sink)994 static int mtk_afe_i2s_mclk_connect(struct snd_soc_dapm_widget *source,
995 				    struct snd_soc_dapm_widget *sink)
996 {
997 	struct snd_soc_dapm_widget *w = sink;
998 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
999 	struct mtk_base_afe *afe = snd_soc_component_get_drvdata(cmpnt);
1000 	struct mtk_afe_i2s_priv *i2s_priv;
1001 
1002 	i2s_priv = get_i2s_priv_by_name(afe, sink->name);
1003 	if (!i2s_priv) {
1004 		dev_warn(afe->dev, "%s(), i2s_priv == NULL", __func__);
1005 		return 0;
1006 	}
1007 
1008 	if (get_i2s_id_by_name(afe, sink->name) ==
1009 	    get_i2s_id_by_name(afe, source->name))
1010 		return (i2s_priv->mclk_rate > 0) ? 1 : 0;
1011 
1012 	/* check if share i2s need mclk */
1013 	if (i2s_priv->share_i2s_id < 0)
1014 		return 0;
1015 
1016 	if (i2s_priv->share_i2s_id == get_i2s_id_by_name(afe, source->name))
1017 		return (i2s_priv->mclk_rate > 0) ? 1 : 0;
1018 
1019 	return 0;
1020 }
1021 
mtk_afe_mclk_apll_connect(struct snd_soc_dapm_widget * source,struct snd_soc_dapm_widget * sink)1022 static int mtk_afe_mclk_apll_connect(struct snd_soc_dapm_widget *source,
1023 				     struct snd_soc_dapm_widget *sink)
1024 {
1025 	struct snd_soc_dapm_widget *w = sink;
1026 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
1027 	struct mtk_base_afe *afe = snd_soc_component_get_drvdata(cmpnt);
1028 	struct mtk_afe_i2s_priv *i2s_priv;
1029 	int cur_apll;
1030 
1031 	i2s_priv = get_i2s_priv_by_name(afe, w->name);
1032 	if (!i2s_priv) {
1033 		dev_warn(afe->dev, "%s(), i2s_priv == NULL", __func__);
1034 		return 0;
1035 	}
1036 
1037 	/* which apll */
1038 	cur_apll = mt8192_get_apll_by_name(afe, source->name);
1039 
1040 	if (i2s_priv->mclk_apll == cur_apll)
1041 		return 1;
1042 
1043 	return 0;
1044 }
1045 
1046 static const struct snd_soc_dapm_route mtk_dai_i2s_routes[] = {
1047 	{"Connsys I2S", NULL, "CONNSYS"},
1048 
1049 	/* i2s0 */
1050 	{"I2S0", NULL, "I2S0_EN"},
1051 	{"I2S0", NULL, "I2S1_EN", mtk_afe_i2s_share_connect},
1052 	{"I2S0", NULL, "I2S2_EN", mtk_afe_i2s_share_connect},
1053 	{"I2S0", NULL, "I2S3_EN", mtk_afe_i2s_share_connect},
1054 	{"I2S0", NULL, "I2S5_EN", mtk_afe_i2s_share_connect},
1055 	{"I2S0", NULL, "I2S6_EN", mtk_afe_i2s_share_connect},
1056 	{"I2S0", NULL, "I2S7_EN", mtk_afe_i2s_share_connect},
1057 	{"I2S0", NULL, "I2S8_EN", mtk_afe_i2s_share_connect},
1058 	{"I2S0", NULL, "I2S9_EN", mtk_afe_i2s_share_connect},
1059 
1060 	{"I2S0", NULL, I2S0_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1061 	{"I2S0", NULL, I2S1_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1062 	{"I2S0", NULL, I2S2_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1063 	{"I2S0", NULL, I2S3_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1064 	{"I2S0", NULL, I2S5_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1065 	{"I2S0", NULL, I2S6_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1066 	{"I2S0", NULL, I2S7_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1067 	{"I2S0", NULL, I2S8_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1068 	{"I2S0", NULL, I2S9_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1069 	{I2S0_HD_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_i2s_apll_connect},
1070 	{I2S0_HD_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_i2s_apll_connect},
1071 
1072 	{"I2S0", NULL, I2S0_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1073 	{"I2S0", NULL, I2S1_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1074 	{"I2S0", NULL, I2S2_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1075 	{"I2S0", NULL, I2S3_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1076 	{"I2S0", NULL, I2S5_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1077 	{"I2S0", NULL, I2S6_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1078 	{"I2S0", NULL, I2S7_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1079 	{"I2S0", NULL, I2S8_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1080 	{"I2S0", NULL, I2S9_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1081 	{I2S0_MCLK_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_mclk_apll_connect},
1082 	{I2S0_MCLK_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_mclk_apll_connect},
1083 
1084 	/* i2s1 */
1085 	{"I2S1_CH1", "DL1_CH1", "DL1"},
1086 	{"I2S1_CH2", "DL1_CH2", "DL1"},
1087 	{"I2S1_TINYCONN_CH1_MUX", "DL1_CH1", "DL1"},
1088 	{"I2S1_TINYCONN_CH2_MUX", "DL1_CH2", "DL1"},
1089 
1090 	{"I2S1_CH1", "DL2_CH1", "DL2"},
1091 	{"I2S1_CH2", "DL2_CH2", "DL2"},
1092 	{"I2S1_TINYCONN_CH1_MUX", "DL2_CH1", "DL2"},
1093 	{"I2S1_TINYCONN_CH2_MUX", "DL2_CH2", "DL2"},
1094 
1095 	{"I2S1_CH1", "DL3_CH1", "DL3"},
1096 	{"I2S1_CH2", "DL3_CH2", "DL3"},
1097 	{"I2S1_TINYCONN_CH1_MUX", "DL3_CH1", "DL3"},
1098 	{"I2S1_TINYCONN_CH2_MUX", "DL3_CH2", "DL3"},
1099 
1100 	{"I2S1_CH1", "DL12_CH1", "DL12"},
1101 	{"I2S1_CH2", "DL12_CH2", "DL12"},
1102 	{"I2S1_TINYCONN_CH1_MUX", "DL12_CH1", "DL12"},
1103 	{"I2S1_TINYCONN_CH2_MUX", "DL12_CH2", "DL12"},
1104 
1105 	{"I2S1_CH1", "DL4_CH1", "DL4"},
1106 	{"I2S1_CH2", "DL4_CH2", "DL4"},
1107 
1108 	{"I2S1_CH1", "DL5_CH1", "DL5"},
1109 	{"I2S1_CH2", "DL5_CH2", "DL5"},
1110 
1111 	{"I2S1_CH1", "DL6_CH1", "DL6"},
1112 	{"I2S1_CH2", "DL6_CH2", "DL6"},
1113 
1114 	{"I2S1_CH1", "DL8_CH1", "DL8"},
1115 	{"I2S1_CH2", "DL8_CH2", "DL8"},
1116 
1117 	{"I2S1", NULL, "I2S1_CH1"},
1118 	{"I2S1", NULL, "I2S1_CH2"},
1119 	{"I2S1", NULL, "I2S3_TINYCONN_CH1_MUX"},
1120 	{"I2S1", NULL, "I2S3_TINYCONN_CH2_MUX"},
1121 
1122 	{"I2S1", NULL, "I2S0_EN", mtk_afe_i2s_share_connect},
1123 	{"I2S1", NULL, "I2S1_EN"},
1124 	{"I2S1", NULL, "I2S2_EN", mtk_afe_i2s_share_connect},
1125 	{"I2S1", NULL, "I2S3_EN", mtk_afe_i2s_share_connect},
1126 	{"I2S1", NULL, "I2S5_EN", mtk_afe_i2s_share_connect},
1127 	{"I2S1", NULL, "I2S6_EN", mtk_afe_i2s_share_connect},
1128 	{"I2S1", NULL, "I2S7_EN", mtk_afe_i2s_share_connect},
1129 	{"I2S1", NULL, "I2S8_EN", mtk_afe_i2s_share_connect},
1130 	{"I2S1", NULL, "I2S9_EN", mtk_afe_i2s_share_connect},
1131 
1132 	{"I2S1", NULL, I2S0_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1133 	{"I2S1", NULL, I2S1_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1134 	{"I2S1", NULL, I2S2_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1135 	{"I2S1", NULL, I2S3_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1136 	{"I2S1", NULL, I2S5_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1137 	{"I2S1", NULL, I2S6_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1138 	{"I2S1", NULL, I2S7_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1139 	{"I2S1", NULL, I2S8_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1140 	{"I2S1", NULL, I2S9_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1141 	{I2S1_HD_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_i2s_apll_connect},
1142 	{I2S1_HD_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_i2s_apll_connect},
1143 
1144 	{"I2S1", NULL, I2S0_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1145 	{"I2S1", NULL, I2S1_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1146 	{"I2S1", NULL, I2S2_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1147 	{"I2S1", NULL, I2S3_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1148 	{"I2S1", NULL, I2S5_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1149 	{"I2S1", NULL, I2S6_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1150 	{"I2S1", NULL, I2S7_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1151 	{"I2S1", NULL, I2S8_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1152 	{"I2S1", NULL, I2S9_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1153 	{I2S1_MCLK_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_mclk_apll_connect},
1154 	{I2S1_MCLK_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_mclk_apll_connect},
1155 
1156 	/* i2s2 */
1157 	{"I2S2", NULL, "I2S0_EN", mtk_afe_i2s_share_connect},
1158 	{"I2S2", NULL, "I2S1_EN", mtk_afe_i2s_share_connect},
1159 	{"I2S2", NULL, "I2S2_EN"},
1160 	{"I2S2", NULL, "I2S3_EN", mtk_afe_i2s_share_connect},
1161 	{"I2S2", NULL, "I2S5_EN", mtk_afe_i2s_share_connect},
1162 	{"I2S2", NULL, "I2S6_EN", mtk_afe_i2s_share_connect},
1163 	{"I2S2", NULL, "I2S7_EN", mtk_afe_i2s_share_connect},
1164 	{"I2S2", NULL, "I2S8_EN", mtk_afe_i2s_share_connect},
1165 	{"I2S2", NULL, "I2S9_EN", mtk_afe_i2s_share_connect},
1166 
1167 	{"I2S2", NULL, I2S0_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1168 	{"I2S2", NULL, I2S1_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1169 	{"I2S2", NULL, I2S2_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1170 	{"I2S2", NULL, I2S3_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1171 	{"I2S2", NULL, I2S5_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1172 	{"I2S2", NULL, I2S6_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1173 	{"I2S2", NULL, I2S7_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1174 	{"I2S2", NULL, I2S8_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1175 	{"I2S2", NULL, I2S9_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1176 	{I2S2_HD_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_i2s_apll_connect},
1177 	{I2S2_HD_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_i2s_apll_connect},
1178 
1179 	{"I2S2", NULL, I2S0_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1180 	{"I2S2", NULL, I2S1_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1181 	{"I2S2", NULL, I2S2_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1182 	{"I2S2", NULL, I2S3_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1183 	{"I2S2", NULL, I2S5_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1184 	{"I2S2", NULL, I2S6_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1185 	{"I2S2", NULL, I2S7_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1186 	{"I2S2", NULL, I2S8_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1187 	{"I2S2", NULL, I2S9_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1188 	{I2S2_MCLK_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_mclk_apll_connect},
1189 	{I2S2_MCLK_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_mclk_apll_connect},
1190 
1191 	/* i2s3 */
1192 	{"I2S3_CH1", "DL1_CH1", "DL1"},
1193 	{"I2S3_CH2", "DL1_CH2", "DL1"},
1194 	{"I2S3_TINYCONN_CH1_MUX", "DL1_CH1", "DL1"},
1195 	{"I2S3_TINYCONN_CH2_MUX", "DL1_CH2", "DL1"},
1196 
1197 	{"I2S3_CH1", "DL2_CH1", "DL2"},
1198 	{"I2S3_CH2", "DL2_CH2", "DL2"},
1199 	{"I2S3_TINYCONN_CH1_MUX", "DL2_CH1", "DL2"},
1200 	{"I2S3_TINYCONN_CH2_MUX", "DL2_CH2", "DL2"},
1201 
1202 	{"I2S3_CH1", "DL3_CH1", "DL3"},
1203 	{"I2S3_CH2", "DL3_CH2", "DL3"},
1204 	{"I2S3_TINYCONN_CH1_MUX", "DL3_CH1", "DL3"},
1205 	{"I2S3_TINYCONN_CH2_MUX", "DL3_CH2", "DL3"},
1206 
1207 	{"I2S3_CH1", "DL12_CH1", "DL12"},
1208 	{"I2S3_CH2", "DL12_CH2", "DL12"},
1209 	{"I2S3_TINYCONN_CH1_MUX", "DL12_CH1", "DL12"},
1210 	{"I2S3_TINYCONN_CH2_MUX", "DL12_CH2", "DL12"},
1211 
1212 	{"I2S3_CH1", "DL4_CH1", "DL4"},
1213 	{"I2S3_CH2", "DL4_CH2", "DL4"},
1214 
1215 	{"I2S3_CH1", "DL5_CH1", "DL5"},
1216 	{"I2S3_CH2", "DL5_CH2", "DL5"},
1217 
1218 	{"I2S3_CH1", "DL6_CH1", "DL6"},
1219 	{"I2S3_CH2", "DL6_CH2", "DL6"},
1220 
1221 	{"I2S3_CH1", "DL8_CH1", "DL8"},
1222 	{"I2S3_CH2", "DL8_CH2", "DL8"},
1223 
1224 	{"I2S3", NULL, "I2S3_CH1"},
1225 	{"I2S3", NULL, "I2S3_CH2"},
1226 	{"I2S3", NULL, "I2S3_TINYCONN_CH1_MUX"},
1227 	{"I2S3", NULL, "I2S3_TINYCONN_CH2_MUX"},
1228 
1229 	{"I2S3", NULL, "I2S0_EN", mtk_afe_i2s_share_connect},
1230 	{"I2S3", NULL, "I2S1_EN", mtk_afe_i2s_share_connect},
1231 	{"I2S3", NULL, "I2S2_EN", mtk_afe_i2s_share_connect},
1232 	{"I2S3", NULL, "I2S3_EN"},
1233 	{"I2S3", NULL, "I2S5_EN", mtk_afe_i2s_share_connect},
1234 	{"I2S3", NULL, "I2S6_EN", mtk_afe_i2s_share_connect},
1235 	{"I2S3", NULL, "I2S7_EN", mtk_afe_i2s_share_connect},
1236 	{"I2S3", NULL, "I2S8_EN", mtk_afe_i2s_share_connect},
1237 	{"I2S3", NULL, "I2S9_EN", mtk_afe_i2s_share_connect},
1238 
1239 	{"I2S3", NULL, I2S0_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1240 	{"I2S3", NULL, I2S1_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1241 	{"I2S3", NULL, I2S2_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1242 	{"I2S3", NULL, I2S3_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1243 	{"I2S3", NULL, I2S5_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1244 	{"I2S3", NULL, I2S6_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1245 	{"I2S3", NULL, I2S7_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1246 	{"I2S3", NULL, I2S8_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1247 	{"I2S3", NULL, I2S9_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1248 	{I2S3_HD_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_i2s_apll_connect},
1249 	{I2S3_HD_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_i2s_apll_connect},
1250 
1251 	{"I2S3", NULL, I2S0_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1252 	{"I2S3", NULL, I2S1_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1253 	{"I2S3", NULL, I2S2_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1254 	{"I2S3", NULL, I2S3_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1255 	{"I2S3", NULL, I2S5_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1256 	{"I2S3", NULL, I2S6_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1257 	{"I2S3", NULL, I2S7_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1258 	{"I2S3", NULL, I2S8_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1259 	{"I2S3", NULL, I2S9_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1260 	{I2S3_MCLK_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_mclk_apll_connect},
1261 	{I2S3_MCLK_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_mclk_apll_connect},
1262 
1263 	/* i2s5 */
1264 	{"I2S5_CH1", "DL1_CH1", "DL1"},
1265 	{"I2S5_CH2", "DL1_CH2", "DL1"},
1266 
1267 	{"I2S5_CH1", "DL2_CH1", "DL2"},
1268 	{"I2S5_CH2", "DL2_CH2", "DL2"},
1269 
1270 	{"I2S5_CH1", "DL3_CH1", "DL3"},
1271 	{"I2S5_CH2", "DL3_CH2", "DL3"},
1272 
1273 	{"I2S5_CH1", "DL12_CH1", "DL12"},
1274 	{"I2S5_CH2", "DL12_CH2", "DL12"},
1275 
1276 	{"I2S5_CH1", "DL4_CH1", "DL4"},
1277 	{"I2S5_CH2", "DL4_CH2", "DL4"},
1278 
1279 	{"I2S5_CH1", "DL5_CH1", "DL5"},
1280 	{"I2S5_CH2", "DL5_CH2", "DL5"},
1281 
1282 	{"I2S5_CH1", "DL6_CH1", "DL6"},
1283 	{"I2S5_CH2", "DL6_CH2", "DL6"},
1284 
1285 	{"I2S5_CH1", "DL8_CH1", "DL8"},
1286 	{"I2S5_CH2", "DL8_CH2", "DL8"},
1287 
1288 	{"I2S5", NULL, "I2S5_CH1"},
1289 	{"I2S5", NULL, "I2S5_CH2"},
1290 
1291 	{"I2S5", NULL, "I2S0_EN", mtk_afe_i2s_share_connect},
1292 	{"I2S5", NULL, "I2S1_EN", mtk_afe_i2s_share_connect},
1293 	{"I2S5", NULL, "I2S2_EN", mtk_afe_i2s_share_connect},
1294 	{"I2S5", NULL, "I2S3_EN", mtk_afe_i2s_share_connect},
1295 	{"I2S5", NULL, "I2S5_EN"},
1296 	{"I2S5", NULL, "I2S6_EN", mtk_afe_i2s_share_connect},
1297 	{"I2S5", NULL, "I2S7_EN", mtk_afe_i2s_share_connect},
1298 	{"I2S5", NULL, "I2S8_EN", mtk_afe_i2s_share_connect},
1299 	{"I2S5", NULL, "I2S9_EN", mtk_afe_i2s_share_connect},
1300 
1301 	{"I2S5", NULL, I2S0_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1302 	{"I2S5", NULL, I2S1_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1303 	{"I2S5", NULL, I2S2_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1304 	{"I2S5", NULL, I2S3_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1305 	{"I2S5", NULL, I2S5_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1306 	{"I2S5", NULL, I2S6_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1307 	{"I2S5", NULL, I2S7_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1308 	{"I2S5", NULL, I2S8_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1309 	{"I2S5", NULL, I2S9_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1310 	{I2S5_HD_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_i2s_apll_connect},
1311 	{I2S5_HD_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_i2s_apll_connect},
1312 
1313 	{"I2S5", NULL, I2S0_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1314 	{"I2S5", NULL, I2S1_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1315 	{"I2S5", NULL, I2S2_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1316 	{"I2S5", NULL, I2S3_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1317 	{"I2S5", NULL, I2S5_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1318 	{"I2S5", NULL, I2S6_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1319 	{"I2S5", NULL, I2S7_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1320 	{"I2S5", NULL, I2S8_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1321 	{"I2S5", NULL, I2S9_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1322 	{I2S5_MCLK_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_mclk_apll_connect},
1323 	{I2S5_MCLK_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_mclk_apll_connect},
1324 
1325 	/* i2s6 */
1326 	{"I2S6", NULL, "I2S0_EN", mtk_afe_i2s_share_connect},
1327 	{"I2S6", NULL, "I2S1_EN", mtk_afe_i2s_share_connect},
1328 	{"I2S6", NULL, "I2S2_EN", mtk_afe_i2s_share_connect},
1329 	{"I2S6", NULL, "I2S3_EN", mtk_afe_i2s_share_connect},
1330 	{"I2S6", NULL, "I2S5_EN", mtk_afe_i2s_share_connect},
1331 	{"I2S6", NULL, "I2S6_EN"},
1332 	{"I2S6", NULL, "I2S7_EN", mtk_afe_i2s_share_connect},
1333 	{"I2S6", NULL, "I2S8_EN", mtk_afe_i2s_share_connect},
1334 	{"I2S6", NULL, "I2S9_EN", mtk_afe_i2s_share_connect},
1335 
1336 	{"I2S6", NULL, I2S0_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1337 	{"I2S6", NULL, I2S1_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1338 	{"I2S6", NULL, I2S2_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1339 	{"I2S6", NULL, I2S3_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1340 	{"I2S6", NULL, I2S5_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1341 	{"I2S6", NULL, I2S6_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1342 	{"I2S6", NULL, I2S7_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1343 	{"I2S6", NULL, I2S8_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1344 	{"I2S6", NULL, I2S9_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1345 	{I2S6_HD_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_i2s_apll_connect},
1346 	{I2S6_HD_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_i2s_apll_connect},
1347 
1348 	{"I2S6", NULL, I2S0_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1349 	{"I2S6", NULL, I2S1_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1350 	{"I2S6", NULL, I2S2_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1351 	{"I2S6", NULL, I2S3_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1352 	{"I2S6", NULL, I2S5_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1353 	{"I2S6", NULL, I2S6_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1354 	{"I2S6", NULL, I2S7_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1355 	{"I2S6", NULL, I2S8_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1356 	{"I2S6", NULL, I2S9_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1357 	{I2S6_MCLK_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_mclk_apll_connect},
1358 	{I2S6_MCLK_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_mclk_apll_connect},
1359 
1360 	/* i2s7 */
1361 	{"I2S7", NULL, "I2S7_CH1"},
1362 	{"I2S7", NULL, "I2S7_CH2"},
1363 
1364 	{"I2S7", NULL, "I2S0_EN", mtk_afe_i2s_share_connect},
1365 	{"I2S7", NULL, "I2S1_EN", mtk_afe_i2s_share_connect},
1366 	{"I2S7", NULL, "I2S2_EN", mtk_afe_i2s_share_connect},
1367 	{"I2S7", NULL, "I2S3_EN", mtk_afe_i2s_share_connect},
1368 	{"I2S7", NULL, "I2S5_EN", mtk_afe_i2s_share_connect},
1369 	{"I2S7", NULL, "I2S6_EN", mtk_afe_i2s_share_connect},
1370 	{"I2S7", NULL, "I2S7_EN"},
1371 	{"I2S7", NULL, "I2S8_EN", mtk_afe_i2s_share_connect},
1372 	{"I2S7", NULL, "I2S9_EN", mtk_afe_i2s_share_connect},
1373 
1374 	{"I2S7", NULL, I2S0_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1375 	{"I2S7", NULL, I2S1_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1376 	{"I2S7", NULL, I2S2_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1377 	{"I2S7", NULL, I2S3_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1378 	{"I2S7", NULL, I2S5_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1379 	{"I2S7", NULL, I2S6_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1380 	{"I2S7", NULL, I2S7_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1381 	{"I2S7", NULL, I2S8_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1382 	{"I2S7", NULL, I2S9_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1383 	{I2S7_HD_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_i2s_apll_connect},
1384 	{I2S7_HD_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_i2s_apll_connect},
1385 
1386 	{"I2S7", NULL, I2S0_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1387 	{"I2S7", NULL, I2S1_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1388 	{"I2S7", NULL, I2S2_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1389 	{"I2S7", NULL, I2S3_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1390 	{"I2S7", NULL, I2S5_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1391 	{"I2S7", NULL, I2S6_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1392 	{"I2S7", NULL, I2S7_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1393 	{"I2S7", NULL, I2S8_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1394 	{"I2S7", NULL, I2S9_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1395 	{I2S7_MCLK_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_mclk_apll_connect},
1396 	{I2S7_MCLK_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_mclk_apll_connect},
1397 
1398 	/* i2s8 */
1399 	{"I2S8", NULL, "I2S0_EN", mtk_afe_i2s_share_connect},
1400 	{"I2S8", NULL, "I2S1_EN", mtk_afe_i2s_share_connect},
1401 	{"I2S8", NULL, "I2S2_EN", mtk_afe_i2s_share_connect},
1402 	{"I2S8", NULL, "I2S3_EN", mtk_afe_i2s_share_connect},
1403 	{"I2S8", NULL, "I2S5_EN", mtk_afe_i2s_share_connect},
1404 	{"I2S8", NULL, "I2S6_EN", mtk_afe_i2s_share_connect},
1405 	{"I2S8", NULL, "I2S7_EN", mtk_afe_i2s_share_connect},
1406 	{"I2S8", NULL, "I2S8_EN"},
1407 	{"I2S8", NULL, "I2S9_EN", mtk_afe_i2s_share_connect},
1408 
1409 	{"I2S8", NULL, I2S0_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1410 	{"I2S8", NULL, I2S1_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1411 	{"I2S8", NULL, I2S2_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1412 	{"I2S8", NULL, I2S3_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1413 	{"I2S8", NULL, I2S5_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1414 	{"I2S8", NULL, I2S6_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1415 	{"I2S8", NULL, I2S7_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1416 	{"I2S8", NULL, I2S8_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1417 	{"I2S8", NULL, I2S9_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1418 	{I2S8_HD_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_i2s_apll_connect},
1419 	{I2S8_HD_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_i2s_apll_connect},
1420 
1421 	{"I2S8", NULL, I2S0_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1422 	{"I2S8", NULL, I2S1_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1423 	{"I2S8", NULL, I2S2_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1424 	{"I2S8", NULL, I2S3_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1425 	{"I2S8", NULL, I2S5_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1426 	{"I2S8", NULL, I2S6_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1427 	{"I2S8", NULL, I2S7_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1428 	{"I2S8", NULL, I2S8_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1429 	{"I2S8", NULL, I2S9_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1430 	{I2S8_MCLK_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_mclk_apll_connect},
1431 	{I2S8_MCLK_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_mclk_apll_connect},
1432 
1433 	/* i2s9 */
1434 	{"I2S9_CH1", "DL1_CH1", "DL1"},
1435 	{"I2S9_CH2", "DL1_CH2", "DL1"},
1436 
1437 	{"I2S9_CH1", "DL2_CH1", "DL2"},
1438 	{"I2S9_CH2", "DL2_CH2", "DL2"},
1439 
1440 	{"I2S9_CH1", "DL3_CH1", "DL3"},
1441 	{"I2S9_CH2", "DL3_CH2", "DL3"},
1442 
1443 	{"I2S9_CH1", "DL12_CH1", "DL12"},
1444 	{"I2S9_CH2", "DL12_CH2", "DL12"},
1445 
1446 	{"I2S9_CH1", "DL4_CH1", "DL4"},
1447 	{"I2S9_CH2", "DL4_CH2", "DL4"},
1448 
1449 	{"I2S9_CH1", "DL5_CH1", "DL5"},
1450 	{"I2S9_CH2", "DL5_CH2", "DL5"},
1451 
1452 	{"I2S9_CH1", "DL6_CH1", "DL6"},
1453 	{"I2S9_CH2", "DL6_CH2", "DL6"},
1454 
1455 	{"I2S9_CH1", "DL8_CH1", "DL8"},
1456 	{"I2S9_CH2", "DL8_CH2", "DL8"},
1457 
1458 	{"I2S9_CH1", "DL9_CH1", "DL9"},
1459 	{"I2S9_CH2", "DL9_CH2", "DL9"},
1460 
1461 	{"I2S9", NULL, "I2S9_CH1"},
1462 	{"I2S9", NULL, "I2S9_CH2"},
1463 
1464 	{"I2S9", NULL, "I2S0_EN", mtk_afe_i2s_share_connect},
1465 	{"I2S9", NULL, "I2S1_EN", mtk_afe_i2s_share_connect},
1466 	{"I2S9", NULL, "I2S2_EN", mtk_afe_i2s_share_connect},
1467 	{"I2S9", NULL, "I2S3_EN", mtk_afe_i2s_share_connect},
1468 	{"I2S9", NULL, "I2S5_EN", mtk_afe_i2s_share_connect},
1469 	{"I2S9", NULL, "I2S6_EN", mtk_afe_i2s_share_connect},
1470 	{"I2S9", NULL, "I2S7_EN", mtk_afe_i2s_share_connect},
1471 	{"I2S9", NULL, "I2S8_EN", mtk_afe_i2s_share_connect},
1472 	{"I2S9", NULL, "I2S9_EN"},
1473 
1474 	{"I2S9", NULL, I2S0_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1475 	{"I2S9", NULL, I2S1_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1476 	{"I2S9", NULL, I2S2_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1477 	{"I2S9", NULL, I2S3_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1478 	{"I2S9", NULL, I2S5_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1479 	{"I2S9", NULL, I2S6_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1480 	{"I2S9", NULL, I2S7_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1481 	{"I2S9", NULL, I2S8_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1482 	{"I2S9", NULL, I2S9_HD_EN_W_NAME, mtk_afe_i2s_hd_connect},
1483 	{I2S9_HD_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_i2s_apll_connect},
1484 	{I2S9_HD_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_i2s_apll_connect},
1485 
1486 	{"I2S9", NULL, I2S0_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1487 	{"I2S9", NULL, I2S1_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1488 	{"I2S9", NULL, I2S2_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1489 	{"I2S9", NULL, I2S3_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1490 	{"I2S9", NULL, I2S5_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1491 	{"I2S9", NULL, I2S6_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1492 	{"I2S9", NULL, I2S7_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1493 	{"I2S9", NULL, I2S8_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1494 	{"I2S9", NULL, I2S9_MCLK_EN_W_NAME, mtk_afe_i2s_mclk_connect},
1495 	{I2S9_MCLK_EN_W_NAME, NULL, APLL1_W_NAME, mtk_afe_mclk_apll_connect},
1496 	{I2S9_MCLK_EN_W_NAME, NULL, APLL2_W_NAME, mtk_afe_mclk_apll_connect},
1497 
1498 	/* allow i2s on without codec on */
1499 	{"I2S0", NULL, "I2S0_In_Mux"},
1500 	{"I2S0_In_Mux", "Dummy_Widget", "I2S_DUMMY_IN"},
1501 
1502 	{"I2S8", NULL, "I2S8_In_Mux"},
1503 	{"I2S8_In_Mux", "Dummy_Widget", "I2S_DUMMY_IN"},
1504 
1505 	{"I2S1_Out_Mux", "Dummy_Widget", "I2S1"},
1506 	{"I2S_DUMMY_OUT", NULL, "I2S1_Out_Mux"},
1507 
1508 	{"I2S3_Out_Mux", "Dummy_Widget", "I2S3"},
1509 	{"I2S_DUMMY_OUT", NULL, "I2S3_Out_Mux"},
1510 
1511 	{"I2S5_Out_Mux", "Dummy_Widget", "I2S5"},
1512 	{"I2S_DUMMY_OUT", NULL, "I2S5_Out_Mux"},
1513 
1514 	{"I2S7_Out_Mux", "Dummy_Widget", "I2S7"},
1515 	{"I2S_DUMMY_OUT", NULL, "I2S7_Out_Mux"},
1516 
1517 	{"I2S9_Out_Mux", "Dummy_Widget", "I2S9"},
1518 	{"I2S_DUMMY_OUT", NULL, "I2S9_Out_Mux"},
1519 
1520 	/* i2s in lpbk */
1521 	{"I2S0_Lpbk_Mux", "Lpbk", "I2S3"},
1522 	{"I2S2_Lpbk_Mux", "Lpbk", "I2S1"},
1523 	{"I2S0", NULL, "I2S0_Lpbk_Mux"},
1524 	{"I2S2", NULL, "I2S2_Lpbk_Mux"},
1525 };
1526 
1527 /* dai ops */
mtk_dai_connsys_i2s_hw_params(struct snd_pcm_substream * substream,struct snd_pcm_hw_params * params,struct snd_soc_dai * dai)1528 static int mtk_dai_connsys_i2s_hw_params(struct snd_pcm_substream *substream,
1529 					 struct snd_pcm_hw_params *params,
1530 					 struct snd_soc_dai *dai)
1531 {
1532 	struct mtk_base_afe *afe = snd_soc_dai_get_drvdata(dai);
1533 	unsigned int rate = params_rate(params);
1534 	unsigned int rate_reg = mt8192_rate_transform(afe->dev,
1535 						      rate, dai->id);
1536 	unsigned int i2s_con = 0;
1537 
1538 	dev_dbg(afe->dev, "%s(), id %d, stream %d, rate %d\n",
1539 		__func__, dai->id, substream->stream, rate);
1540 
1541 	/* non-inverse, i2s mode, proxy mode, 16bits, from connsys */
1542 	i2s_con |= 0 << INV_PAD_CTRL_SFT;
1543 	i2s_con |= I2S_FMT_I2S << I2S_FMT_SFT;
1544 	i2s_con |= 1 << I2S_SRC_SFT;
1545 	i2s_con |= get_i2s_wlen(SNDRV_PCM_FORMAT_S16_LE) << I2S_WLEN_SFT;
1546 	i2s_con |= 0 << I2SIN_PAD_SEL_SFT;
1547 	regmap_write(afe->regmap, AFE_CONNSYS_I2S_CON, i2s_con);
1548 
1549 	/* use asrc */
1550 	regmap_update_bits(afe->regmap,
1551 			   AFE_CONNSYS_I2S_CON,
1552 			   I2S_BYPSRC_MASK_SFT,
1553 			   0x0 << I2S_BYPSRC_SFT);
1554 
1555 	/* proxy mode, set i2s for asrc */
1556 	regmap_update_bits(afe->regmap,
1557 			   AFE_CONNSYS_I2S_CON,
1558 			   I2S_MODE_MASK_SFT,
1559 			   rate_reg << I2S_MODE_SFT);
1560 
1561 	switch (rate) {
1562 	case 32000:
1563 		regmap_write(afe->regmap, AFE_ASRC_2CH_CON3, 0x140000);
1564 		break;
1565 	case 44100:
1566 		regmap_write(afe->regmap, AFE_ASRC_2CH_CON3, 0x001B9000);
1567 		break;
1568 	default:
1569 		regmap_write(afe->regmap, AFE_ASRC_2CH_CON3, 0x001E0000);
1570 		break;
1571 	}
1572 
1573 	/* Calibration setting */
1574 	regmap_write(afe->regmap, AFE_ASRC_2CH_CON4, 0x00140000);
1575 	regmap_write(afe->regmap, AFE_ASRC_2CH_CON9, 0x00036000);
1576 	regmap_write(afe->regmap, AFE_ASRC_2CH_CON10, 0x0002FC00);
1577 	regmap_write(afe->regmap, AFE_ASRC_2CH_CON6, 0x00007EF4);
1578 	regmap_write(afe->regmap, AFE_ASRC_2CH_CON5, 0x00FF5986);
1579 
1580 	/* 0:Stereo 1:Mono */
1581 	regmap_update_bits(afe->regmap,
1582 			   AFE_ASRC_2CH_CON2,
1583 			   CHSET_IS_MONO_MASK_SFT,
1584 			   0x0 << CHSET_IS_MONO_SFT);
1585 
1586 	return 0;
1587 }
1588 
mtk_dai_connsys_i2s_trigger(struct snd_pcm_substream * substream,int cmd,struct snd_soc_dai * dai)1589 static int mtk_dai_connsys_i2s_trigger(struct snd_pcm_substream *substream,
1590 				       int cmd, struct snd_soc_dai *dai)
1591 {
1592 	struct mtk_base_afe *afe = snd_soc_dai_get_drvdata(dai);
1593 	struct mt8192_afe_private *afe_priv = afe->platform_priv;
1594 
1595 	dev_dbg(afe->dev, "%s(), cmd %d, stream %d\n",
1596 		__func__, cmd, substream->stream);
1597 
1598 	switch (cmd) {
1599 	case SNDRV_PCM_TRIGGER_START:
1600 	case SNDRV_PCM_TRIGGER_RESUME:
1601 		/* i2s enable */
1602 		regmap_update_bits(afe->regmap,
1603 				   AFE_CONNSYS_I2S_CON,
1604 				   I2S_EN_MASK_SFT,
1605 				   0x1 << I2S_EN_SFT);
1606 
1607 		/* calibrator enable */
1608 		regmap_update_bits(afe->regmap,
1609 				   AFE_ASRC_2CH_CON5,
1610 				   CALI_EN_MASK_SFT,
1611 				   0x1 << CALI_EN_SFT);
1612 
1613 		/* asrc enable */
1614 		regmap_update_bits(afe->regmap,
1615 				   AFE_ASRC_2CH_CON0,
1616 				   CON0_CHSET_STR_CLR_MASK_SFT,
1617 				   0x1 << CON0_CHSET_STR_CLR_SFT);
1618 		regmap_update_bits(afe->regmap,
1619 				   AFE_ASRC_2CH_CON0,
1620 				   CON0_ASM_ON_MASK_SFT,
1621 				   0x1 << CON0_ASM_ON_SFT);
1622 
1623 		afe_priv->dai_on[dai->id] = true;
1624 		break;
1625 	case SNDRV_PCM_TRIGGER_STOP:
1626 	case SNDRV_PCM_TRIGGER_SUSPEND:
1627 		regmap_update_bits(afe->regmap,
1628 				   AFE_ASRC_2CH_CON0,
1629 				   CON0_ASM_ON_MASK_SFT,
1630 				   0 << CON0_ASM_ON_SFT);
1631 		regmap_update_bits(afe->regmap,
1632 				   AFE_ASRC_2CH_CON5,
1633 				   CALI_EN_MASK_SFT,
1634 				   0 << CALI_EN_SFT);
1635 
1636 		/* i2s disable */
1637 		regmap_update_bits(afe->regmap,
1638 				   AFE_CONNSYS_I2S_CON,
1639 				   I2S_EN_MASK_SFT,
1640 				   0x0 << I2S_EN_SFT);
1641 
1642 		/* bypass asrc */
1643 		regmap_update_bits(afe->regmap,
1644 				   AFE_CONNSYS_I2S_CON,
1645 				   I2S_BYPSRC_MASK_SFT,
1646 				   0x1 << I2S_BYPSRC_SFT);
1647 
1648 		afe_priv->dai_on[dai->id] = false;
1649 		break;
1650 	default:
1651 		return -EINVAL;
1652 	}
1653 	return 0;
1654 }
1655 
1656 static const struct snd_soc_dai_ops mtk_dai_connsys_i2s_ops = {
1657 	.hw_params = mtk_dai_connsys_i2s_hw_params,
1658 	.trigger = mtk_dai_connsys_i2s_trigger,
1659 };
1660 
1661 /* i2s */
mtk_dai_i2s_config(struct mtk_base_afe * afe,struct snd_pcm_hw_params * params,int i2s_id)1662 static int mtk_dai_i2s_config(struct mtk_base_afe *afe,
1663 			      struct snd_pcm_hw_params *params,
1664 			      int i2s_id)
1665 {
1666 	struct mt8192_afe_private *afe_priv = afe->platform_priv;
1667 	struct mtk_afe_i2s_priv *i2s_priv = afe_priv->dai_priv[i2s_id];
1668 
1669 	unsigned int rate = params_rate(params);
1670 	unsigned int rate_reg = mt8192_rate_transform(afe->dev,
1671 						      rate, i2s_id);
1672 	snd_pcm_format_t format = params_format(params);
1673 	unsigned int i2s_con = 0;
1674 	int ret = 0;
1675 
1676 	dev_dbg(afe->dev, "%s(), id %d, rate %d, format %d\n",
1677 		__func__, i2s_id, rate, format);
1678 
1679 	if (i2s_priv)
1680 		i2s_priv->rate = rate;
1681 	else
1682 		dev_warn(afe->dev, "%s(), i2s_priv == NULL", __func__);
1683 
1684 	switch (i2s_id) {
1685 	case MT8192_DAI_I2S_0:
1686 		i2s_con = I2S_IN_PAD_IO_MUX << I2SIN_PAD_SEL_SFT;
1687 		i2s_con |= rate_reg << I2S_OUT_MODE_SFT;
1688 		i2s_con |= I2S_FMT_I2S << I2S_FMT_SFT;
1689 		i2s_con |= get_i2s_wlen(format) << I2S_WLEN_SFT;
1690 		regmap_update_bits(afe->regmap, AFE_I2S_CON,
1691 				   0xffffeffe, i2s_con);
1692 		break;
1693 	case MT8192_DAI_I2S_1:
1694 		i2s_con = I2S1_SEL_O28_O29 << I2S2_SEL_O03_O04_SFT;
1695 		i2s_con |= rate_reg << I2S2_OUT_MODE_SFT;
1696 		i2s_con |= I2S_FMT_I2S << I2S2_FMT_SFT;
1697 		i2s_con |= get_i2s_wlen(format) << I2S2_WLEN_SFT;
1698 		regmap_update_bits(afe->regmap, AFE_I2S_CON1,
1699 				   0xffffeffe, i2s_con);
1700 		break;
1701 	case MT8192_DAI_I2S_2:
1702 		i2s_con = 8 << I2S3_UPDATE_WORD_SFT;
1703 		i2s_con |= rate_reg << I2S3_OUT_MODE_SFT;
1704 		i2s_con |= I2S_FMT_I2S << I2S3_FMT_SFT;
1705 		i2s_con |= get_i2s_wlen(format) << I2S3_WLEN_SFT;
1706 		regmap_update_bits(afe->regmap, AFE_I2S_CON2,
1707 				   0xffffeffe, i2s_con);
1708 		break;
1709 	case MT8192_DAI_I2S_3:
1710 		i2s_con = rate_reg << I2S4_OUT_MODE_SFT;
1711 		i2s_con |= I2S_FMT_I2S << I2S4_FMT_SFT;
1712 		i2s_con |= get_i2s_wlen(format) << I2S4_WLEN_SFT;
1713 		regmap_update_bits(afe->regmap, AFE_I2S_CON3,
1714 				   0xffffeffe, i2s_con);
1715 		break;
1716 	case MT8192_DAI_I2S_5:
1717 		i2s_con = rate_reg << I2S5_OUT_MODE_SFT;
1718 		i2s_con |= I2S_FMT_I2S << I2S5_FMT_SFT;
1719 		i2s_con |= get_i2s_wlen(format) << I2S5_WLEN_SFT;
1720 		regmap_update_bits(afe->regmap, AFE_I2S_CON4,
1721 				   0xffffeffe, i2s_con);
1722 		break;
1723 	case MT8192_DAI_I2S_6:
1724 		i2s_con = rate_reg << I2S6_OUT_MODE_SFT;
1725 		i2s_con |= I2S_FMT_I2S << I2S6_FMT_SFT;
1726 		i2s_con |= get_i2s_wlen(format) << I2S6_WLEN_SFT;
1727 		regmap_update_bits(afe->regmap, AFE_I2S_CON6,
1728 				   0xffffeffe, i2s_con);
1729 		break;
1730 	case MT8192_DAI_I2S_7:
1731 		i2s_con = rate_reg << I2S7_OUT_MODE_SFT;
1732 		i2s_con |= I2S_FMT_I2S << I2S7_FMT_SFT;
1733 		i2s_con |= get_i2s_wlen(format) << I2S7_WLEN_SFT;
1734 		regmap_update_bits(afe->regmap, AFE_I2S_CON7,
1735 				   0xffffeffe, i2s_con);
1736 		break;
1737 	case MT8192_DAI_I2S_8:
1738 		i2s_con = rate_reg << I2S8_OUT_MODE_SFT;
1739 		i2s_con |= I2S_FMT_I2S << I2S8_FMT_SFT;
1740 		i2s_con |= get_i2s_wlen(format) << I2S8_WLEN_SFT;
1741 		regmap_update_bits(afe->regmap, AFE_I2S_CON8,
1742 				   0xffffeffe, i2s_con);
1743 		break;
1744 	case MT8192_DAI_I2S_9:
1745 		i2s_con = rate_reg << I2S9_OUT_MODE_SFT;
1746 		i2s_con |= I2S_FMT_I2S << I2S9_FMT_SFT;
1747 		i2s_con |= get_i2s_wlen(format) << I2S9_WLEN_SFT;
1748 		regmap_update_bits(afe->regmap, AFE_I2S_CON9,
1749 				   0xffffeffe, i2s_con);
1750 		break;
1751 	default:
1752 		dev_warn(afe->dev, "%s(), id %d not support\n",
1753 			 __func__, i2s_id);
1754 		return -EINVAL;
1755 	}
1756 
1757 	/* set share i2s */
1758 	if (i2s_priv && i2s_priv->share_i2s_id >= 0)
1759 		ret = mtk_dai_i2s_config(afe, params, i2s_priv->share_i2s_id);
1760 
1761 	return ret;
1762 }
1763 
mtk_dai_i2s_hw_params(struct snd_pcm_substream * substream,struct snd_pcm_hw_params * params,struct snd_soc_dai * dai)1764 static int mtk_dai_i2s_hw_params(struct snd_pcm_substream *substream,
1765 				 struct snd_pcm_hw_params *params,
1766 				 struct snd_soc_dai *dai)
1767 {
1768 	struct mtk_base_afe *afe = snd_soc_dai_get_drvdata(dai);
1769 
1770 	return mtk_dai_i2s_config(afe, params, dai->id);
1771 }
1772 
mtk_dai_i2s_set_sysclk(struct snd_soc_dai * dai,int clk_id,unsigned int freq,int dir)1773 static int mtk_dai_i2s_set_sysclk(struct snd_soc_dai *dai,
1774 				  int clk_id, unsigned int freq, int dir)
1775 {
1776 	struct mtk_base_afe *afe = dev_get_drvdata(dai->dev);
1777 	struct mt8192_afe_private *afe_priv = afe->platform_priv;
1778 	struct mtk_afe_i2s_priv *i2s_priv = afe_priv->dai_priv[dai->id];
1779 	int apll;
1780 	int apll_rate;
1781 
1782 	if (!i2s_priv) {
1783 		dev_warn(afe->dev, "%s(), i2s_priv == NULL", __func__);
1784 		return -EINVAL;
1785 	}
1786 
1787 	if (dir != SND_SOC_CLOCK_OUT) {
1788 		dev_warn(afe->dev, "%s(), dir != SND_SOC_CLOCK_OUT", __func__);
1789 		return -EINVAL;
1790 	}
1791 
1792 	dev_dbg(afe->dev, "%s(), freq %d\n", __func__, freq);
1793 
1794 	apll = mt8192_get_apll_by_rate(afe, freq);
1795 	apll_rate = mt8192_get_apll_rate(afe, apll);
1796 
1797 	if (freq > apll_rate) {
1798 		dev_warn(afe->dev, "%s(), freq > apll rate", __func__);
1799 		return -EINVAL;
1800 	}
1801 
1802 	if (apll_rate % freq != 0) {
1803 		dev_warn(afe->dev, "%s(), APLL can't gen freq Hz", __func__);
1804 		return -EINVAL;
1805 	}
1806 
1807 	i2s_priv->mclk_rate = freq;
1808 	i2s_priv->mclk_apll = apll;
1809 
1810 	if (i2s_priv->share_i2s_id > 0) {
1811 		struct mtk_afe_i2s_priv *share_i2s_priv;
1812 
1813 		share_i2s_priv = afe_priv->dai_priv[i2s_priv->share_i2s_id];
1814 		if (!share_i2s_priv) {
1815 			dev_warn(afe->dev, "%s(), share_i2s_priv = NULL",
1816 				 __func__);
1817 			return -EINVAL;
1818 		}
1819 
1820 		share_i2s_priv->mclk_rate = i2s_priv->mclk_rate;
1821 		share_i2s_priv->mclk_apll = i2s_priv->mclk_apll;
1822 	}
1823 
1824 	return 0;
1825 }
1826 
1827 static const struct snd_soc_dai_ops mtk_dai_i2s_ops = {
1828 	.hw_params = mtk_dai_i2s_hw_params,
1829 	.set_sysclk = mtk_dai_i2s_set_sysclk,
1830 };
1831 
1832 /* dai driver */
1833 #define MTK_CONNSYS_I2S_RATES (SNDRV_PCM_RATE_44100 | SNDRV_PCM_RATE_48000)
1834 
1835 #define MTK_I2S_RATES (SNDRV_PCM_RATE_8000_48000 |\
1836 		       SNDRV_PCM_RATE_88200 |\
1837 		       SNDRV_PCM_RATE_96000 |\
1838 		       SNDRV_PCM_RATE_176400 |\
1839 		       SNDRV_PCM_RATE_192000)
1840 
1841 #define MTK_I2S_FORMATS (SNDRV_PCM_FMTBIT_S16_LE |\
1842 			 SNDRV_PCM_FMTBIT_S24_LE |\
1843 			 SNDRV_PCM_FMTBIT_S32_LE)
1844 
1845 static struct snd_soc_dai_driver mtk_dai_i2s_driver[] = {
1846 	{
1847 		.name = "CONNSYS_I2S",
1848 		.id = MT8192_DAI_CONNSYS_I2S,
1849 		.capture = {
1850 			.stream_name = "Connsys I2S",
1851 			.channels_min = 1,
1852 			.channels_max = 2,
1853 			.rates = MTK_CONNSYS_I2S_RATES,
1854 			.formats = MTK_I2S_FORMATS,
1855 		},
1856 		.ops = &mtk_dai_connsys_i2s_ops,
1857 	},
1858 	{
1859 		.name = "I2S0",
1860 		.id = MT8192_DAI_I2S_0,
1861 		.capture = {
1862 			.stream_name = "I2S0",
1863 			.channels_min = 1,
1864 			.channels_max = 2,
1865 			.rates = MTK_I2S_RATES,
1866 			.formats = MTK_I2S_FORMATS,
1867 		},
1868 		.ops = &mtk_dai_i2s_ops,
1869 	},
1870 	{
1871 		.name = "I2S1",
1872 		.id = MT8192_DAI_I2S_1,
1873 		.playback = {
1874 			.stream_name = "I2S1",
1875 			.channels_min = 1,
1876 			.channels_max = 2,
1877 			.rates = MTK_I2S_RATES,
1878 			.formats = MTK_I2S_FORMATS,
1879 		},
1880 		.ops = &mtk_dai_i2s_ops,
1881 	},
1882 	{
1883 		.name = "I2S2",
1884 		.id = MT8192_DAI_I2S_2,
1885 		.capture = {
1886 			.stream_name = "I2S2",
1887 			.channels_min = 1,
1888 			.channels_max = 2,
1889 			.rates = MTK_I2S_RATES,
1890 			.formats = MTK_I2S_FORMATS,
1891 		},
1892 		.ops = &mtk_dai_i2s_ops,
1893 	},
1894 	{
1895 		.name = "I2S3",
1896 		.id = MT8192_DAI_I2S_3,
1897 		.playback = {
1898 			.stream_name = "I2S3",
1899 			.channels_min = 1,
1900 			.channels_max = 2,
1901 			.rates = MTK_I2S_RATES,
1902 			.formats = MTK_I2S_FORMATS,
1903 		},
1904 		.ops = &mtk_dai_i2s_ops,
1905 	},
1906 	{
1907 		.name = "I2S5",
1908 		.id = MT8192_DAI_I2S_5,
1909 		.playback = {
1910 			.stream_name = "I2S5",
1911 			.channels_min = 1,
1912 			.channels_max = 2,
1913 			.rates = MTK_I2S_RATES,
1914 			.formats = MTK_I2S_FORMATS,
1915 		},
1916 		.ops = &mtk_dai_i2s_ops,
1917 	},
1918 	{
1919 		.name = "I2S6",
1920 		.id = MT8192_DAI_I2S_6,
1921 		.capture = {
1922 			.stream_name = "I2S6",
1923 			.channels_min = 1,
1924 			.channels_max = 2,
1925 			.rates = MTK_I2S_RATES,
1926 			.formats = MTK_I2S_FORMATS,
1927 		},
1928 		.ops = &mtk_dai_i2s_ops,
1929 	},
1930 	{
1931 		.name = "I2S7",
1932 		.id = MT8192_DAI_I2S_7,
1933 		.playback = {
1934 			.stream_name = "I2S7",
1935 			.channels_min = 1,
1936 			.channels_max = 2,
1937 			.rates = MTK_I2S_RATES,
1938 			.formats = MTK_I2S_FORMATS,
1939 		},
1940 		.ops = &mtk_dai_i2s_ops,
1941 	},
1942 	{
1943 		.name = "I2S8",
1944 		.id = MT8192_DAI_I2S_8,
1945 		.capture = {
1946 			.stream_name = "I2S8",
1947 			.channels_min = 1,
1948 			.channels_max = 2,
1949 			.rates = MTK_I2S_RATES,
1950 			.formats = MTK_I2S_FORMATS,
1951 		},
1952 		.ops = &mtk_dai_i2s_ops,
1953 	},
1954 	{
1955 		.name = "I2S9",
1956 		.id = MT8192_DAI_I2S_9,
1957 		.playback = {
1958 			.stream_name = "I2S9",
1959 			.channels_min = 1,
1960 			.channels_max = 2,
1961 			.rates = MTK_I2S_RATES,
1962 			.formats = MTK_I2S_FORMATS,
1963 		},
1964 		.ops = &mtk_dai_i2s_ops,
1965 	}
1966 };
1967 
1968 /* this enum is merely for mtk_afe_i2s_priv declare */
1969 enum {
1970 	DAI_I2S0 = 0,
1971 	DAI_I2S1,
1972 	DAI_I2S2,
1973 	DAI_I2S3,
1974 	DAI_I2S5,
1975 	DAI_I2S6,
1976 	DAI_I2S7,
1977 	DAI_I2S8,
1978 	DAI_I2S9,
1979 	DAI_I2S_NUM,
1980 };
1981 
1982 static const struct mtk_afe_i2s_priv mt8192_i2s_priv[DAI_I2S_NUM] = {
1983 	[DAI_I2S0] = {
1984 		.id = MT8192_DAI_I2S_0,
1985 		.mclk_id = MT8192_I2S0_MCK,
1986 		.share_i2s_id = -1,
1987 	},
1988 	[DAI_I2S1] = {
1989 		.id = MT8192_DAI_I2S_1,
1990 		.mclk_id = MT8192_I2S1_MCK,
1991 		.share_i2s_id = -1,
1992 	},
1993 	[DAI_I2S2] = {
1994 		.id = MT8192_DAI_I2S_2,
1995 		.mclk_id = MT8192_I2S2_MCK,
1996 		.share_i2s_id = -1,
1997 	},
1998 	[DAI_I2S3] = {
1999 		.id = MT8192_DAI_I2S_3,
2000 		.mclk_id = MT8192_I2S3_MCK,
2001 		.share_i2s_id = -1,
2002 	},
2003 	[DAI_I2S5] = {
2004 		.id = MT8192_DAI_I2S_5,
2005 		.mclk_id = MT8192_I2S5_MCK,
2006 		.share_i2s_id = -1,
2007 	},
2008 	[DAI_I2S6] = {
2009 		.id = MT8192_DAI_I2S_6,
2010 		.mclk_id = MT8192_I2S6_MCK,
2011 		.share_i2s_id = -1,
2012 	},
2013 	[DAI_I2S7] = {
2014 		.id = MT8192_DAI_I2S_7,
2015 		.mclk_id = MT8192_I2S7_MCK,
2016 		.share_i2s_id = -1,
2017 	},
2018 	[DAI_I2S8] = {
2019 		.id = MT8192_DAI_I2S_8,
2020 		.mclk_id = MT8192_I2S8_MCK,
2021 		.share_i2s_id = -1,
2022 	},
2023 	[DAI_I2S9] = {
2024 		.id = MT8192_DAI_I2S_9,
2025 		.mclk_id = MT8192_I2S9_MCK,
2026 		.share_i2s_id = -1,
2027 	},
2028 };
2029 
2030 /**
2031  * mt8192_dai_i2s_set_share() - Set up I2S ports to share a single clock.
2032  * @afe: Pointer to &struct mtk_base_afe
2033  * @main_i2s_name: The name of the I2S port that will provide the clock
2034  * @secondary_i2s_name: The name of the I2S port that will use this clock
2035  */
mt8192_dai_i2s_set_share(struct mtk_base_afe * afe,const char * main_i2s_name,const char * secondary_i2s_name)2036 int mt8192_dai_i2s_set_share(struct mtk_base_afe *afe, const char *main_i2s_name,
2037 			     const char *secondary_i2s_name)
2038 {
2039 	struct mtk_afe_i2s_priv *secondary_i2s_priv;
2040 	int main_i2s_id;
2041 
2042 	secondary_i2s_priv = get_i2s_priv_by_name(afe, secondary_i2s_name);
2043 	if (!secondary_i2s_priv)
2044 		return -EINVAL;
2045 
2046 	main_i2s_id = get_i2s_id_by_name(afe, main_i2s_name);
2047 	if (main_i2s_id < 0)
2048 		return main_i2s_id;
2049 
2050 	secondary_i2s_priv->share_i2s_id = main_i2s_id;
2051 
2052 	return 0;
2053 }
2054 EXPORT_SYMBOL_GPL(mt8192_dai_i2s_set_share);
2055 
mt8192_dai_i2s_set_priv(struct mtk_base_afe * afe)2056 static int mt8192_dai_i2s_set_priv(struct mtk_base_afe *afe)
2057 {
2058 	int i;
2059 	int ret;
2060 
2061 	for (i = 0; i < DAI_I2S_NUM; i++) {
2062 		ret = mt8192_dai_set_priv(afe, mt8192_i2s_priv[i].id,
2063 					  sizeof(struct mtk_afe_i2s_priv),
2064 					  &mt8192_i2s_priv[i]);
2065 		if (ret)
2066 			return ret;
2067 	}
2068 
2069 	return 0;
2070 }
2071 
mt8192_dai_i2s_register(struct mtk_base_afe * afe)2072 int mt8192_dai_i2s_register(struct mtk_base_afe *afe)
2073 {
2074 	struct mtk_base_afe_dai *dai;
2075 	int ret;
2076 
2077 	dev_dbg(afe->dev, "%s()\n", __func__);
2078 
2079 	dai = devm_kzalloc(afe->dev, sizeof(*dai), GFP_KERNEL);
2080 	if (!dai)
2081 		return -ENOMEM;
2082 
2083 	list_add(&dai->list, &afe->sub_dais);
2084 
2085 	dai->dai_drivers = mtk_dai_i2s_driver;
2086 	dai->num_dai_drivers = ARRAY_SIZE(mtk_dai_i2s_driver);
2087 
2088 	dai->controls = mtk_dai_i2s_controls;
2089 	dai->num_controls = ARRAY_SIZE(mtk_dai_i2s_controls);
2090 	dai->dapm_widgets = mtk_dai_i2s_widgets;
2091 	dai->num_dapm_widgets = ARRAY_SIZE(mtk_dai_i2s_widgets);
2092 	dai->dapm_routes = mtk_dai_i2s_routes;
2093 	dai->num_dapm_routes = ARRAY_SIZE(mtk_dai_i2s_routes);
2094 
2095 	/* set all dai i2s private data */
2096 	ret = mt8192_dai_i2s_set_priv(afe);
2097 	if (ret)
2098 		return ret;
2099 
2100 	return 0;
2101 }
2102