xref: /linux/sound/soc/codecs/mt6351.c (revision 0ea5c948cb64bab5bc7a5516774eb8536f05aa0d)
1 // SPDX-License-Identifier: GPL-2.0
2 //
3 // mt6351.c  --  mt6351 ALSA SoC audio codec driver
4 //
5 // Copyright (c) 2018 MediaTek Inc.
6 // Author: KaiChieh Chuang <kaichieh.chuang@mediatek.com>
7 
8 #include <linux/dma-mapping.h>
9 #include <linux/platform_device.h>
10 #include <linux/slab.h>
11 #include <linux/mod_devicetable.h>
12 #include <linux/module.h>
13 #include <linux/delay.h>
14 
15 #include <sound/core.h>
16 #include <sound/pcm.h>
17 #include <sound/soc.h>
18 #include <sound/tlv.h>
19 
20 #include "mt6351.h"
21 
22 /* MT6351_TOP_CLKSQ */
23 #define RG_CLKSQ_EN_AUD_BIT (0)
24 
25 /* MT6351_TOP_CKPDN_CON0 */
26 #define RG_AUDNCP_CK_PDN_BIT (12)
27 #define RG_AUDIF_CK_PDN_BIT (13)
28 #define RG_AUD_CK_PDN_BIT (14)
29 #define RG_ZCD13M_CK_PDN_BIT (15)
30 
31 /* MT6351_AUDDEC_ANA_CON0 */
32 #define RG_AUDDACLPWRUP_VAUDP32_BIT (0)
33 #define RG_AUDDACRPWRUP_VAUDP32_BIT (1)
34 #define RG_AUD_DAC_PWR_UP_VA32_BIT (2)
35 #define RG_AUD_DAC_PWL_UP_VA32_BIT (3)
36 
37 #define RG_AUDHSPWRUP_VAUDP32_BIT (4)
38 
39 #define RG_AUDHPLPWRUP_VAUDP32_BIT (5)
40 #define RG_AUDHPRPWRUP_VAUDP32_BIT (6)
41 
42 #define RG_AUDHSMUXINPUTSEL_VAUDP32_SFT (7)
43 #define RG_AUDHSMUXINPUTSEL_VAUDP32_MASK (0x3)
44 
45 #define RG_AUDHPLMUXINPUTSEL_VAUDP32_SFT (9)
46 #define RG_AUDHPLMUXINPUTSEL_VAUDP32_MASK (0x3)
47 
48 #define RG_AUDHPRMUXINPUTSEL_VAUDP32_SFT (11)
49 #define RG_AUDHPRMUXINPUTSEL_VAUDP32_MASK (0x3)
50 
51 #define RG_AUDHSSCDISABLE_VAUDP32 (13)
52 #define RG_AUDHPLSCDISABLE_VAUDP32_BIT (14)
53 #define RG_AUDHPRSCDISABLE_VAUDP32_BIT (15)
54 
55 /* MT6351_AUDDEC_ANA_CON1 */
56 #define RG_HSOUTPUTSTBENH_VAUDP32_BIT (8)
57 
58 /* MT6351_AUDDEC_ANA_CON3 */
59 #define RG_AUDLOLPWRUP_VAUDP32_BIT (2)
60 
61 #define RG_AUDLOLMUXINPUTSEL_VAUDP32_SFT (3)
62 #define RG_AUDLOLMUXINPUTSEL_VAUDP32_MASK (0x3)
63 
64 #define RG_AUDLOLSCDISABLE_VAUDP32_BIT (5)
65 #define RG_LOOUTPUTSTBENH_VAUDP32_BIT (9)
66 
67 /* MT6351_AUDDEC_ANA_CON6 */
68 #define RG_ABIDEC_RSVD0_VAUDP32_HPL_BIT (8)
69 #define RG_ABIDEC_RSVD0_VAUDP32_HPR_BIT (9)
70 #define RG_ABIDEC_RSVD0_VAUDP32_HS_BIT (10)
71 #define RG_ABIDEC_RSVD0_VAUDP32_LOL_BIT (11)
72 
73 /* MT6351_AUDDEC_ANA_CON9 */
74 #define RG_AUDIBIASPWRDN_VAUDP32_BIT (8)
75 #define RG_RSTB_DECODER_VA32_BIT (9)
76 #define RG_AUDGLB_PWRDN_VA32_BIT (12)
77 
78 #define RG_LCLDO_DEC_EN_VA32_BIT (13)
79 #define RG_LCLDO_DEC_REMOTE_SENSE_VA18_BIT (15)
80 /* MT6351_AUDDEC_ANA_CON10 */
81 #define RG_NVREG_EN_VAUDP32_BIT (8)
82 
83 #define RG_AUDGLB_LP2_VOW_EN_VA32 10
84 
85 /* MT6351_AFE_UL_DL_CON0 */
86 #define RG_AFE_ON_BIT (0)
87 
88 /* MT6351_AFE_DL_SRC2_CON0_L */
89 #define RG_DL_2_SRC_ON_TMP_CTL_PRE_BIT (0)
90 
91 /* MT6351_AFE_UL_SRC_CON0_L */
92 #define UL_SRC_ON_TMP_CTL (0)
93 
94 /* MT6351_AFE_TOP_CON0 */
95 #define RG_DL_SINE_ON_SFT (0)
96 #define RG_DL_SINE_ON_MASK (0x1)
97 
98 #define RG_UL_SINE_ON_SFT (1)
99 #define RG_UL_SINE_ON_MASK (0x1)
100 
101 /* MT6351_AUDIO_TOP_CON0 */
102 #define AUD_TOP_PDN_RESERVED_BIT 0
103 #define AUD_TOP_PWR_CLK_DIS_CTL_BIT 2
104 #define AUD_TOP_PDN_ADC_CTL_BIT 5
105 #define AUD_TOP_PDN_DAC_CTL_BIT 6
106 #define AUD_TOP_PDN_AFE_CTL_BIT 7
107 
108 /* MT6351_AFE_SGEN_CFG0 */
109 #define SGEN_C_MUTE_SW_CTL_BIT 6
110 #define SGEN_C_DAC_EN_CTL_BIT 7
111 
112 /* MT6351_AFE_NCP_CFG0 */
113 #define RG_NCP_ON_BIT 0
114 
115 /* MT6351_LDO_VUSB33_CON0 */
116 #define RG_VUSB33_EN 1
117 #define RG_VUSB33_ON_CTRL 3
118 
119 /* MT6351_LDO_VA18_CON0 */
120 #define RG_VA18_EN 1
121 #define RG_VA18_ON_CTRL 3
122 
123 /* MT6351_AUDENC_ANA_CON0 */
124 #define RG_AUDPREAMPLON 0
125 #define RG_AUDPREAMPLDCCEN 1
126 #define RG_AUDPREAMPLDCPRECHARGE 2
127 
128 #define RG_AUDPREAMPLINPUTSEL_SFT (4)
129 #define RG_AUDPREAMPLINPUTSEL_MASK (0x3)
130 
131 #define RG_AUDADCLPWRUP 12
132 
133 #define RG_AUDADCLINPUTSEL_SFT (13)
134 #define RG_AUDADCLINPUTSEL_MASK (0x3)
135 
136 /* MT6351_AUDENC_ANA_CON1 */
137 #define RG_AUDPREAMPRON 0
138 #define RG_AUDPREAMPRDCCEN 1
139 #define RG_AUDPREAMPRDCPRECHARGE 2
140 
141 #define RG_AUDPREAMPRINPUTSEL_SFT (4)
142 #define RG_AUDPREAMPRINPUTSEL_MASK (0x3)
143 
144 #define RG_AUDADCRPWRUP 12
145 
146 #define RG_AUDADCRINPUTSEL_SFT (13)
147 #define RG_AUDADCRINPUTSEL_MASK (0x3)
148 
149 /* MT6351_AUDENC_ANA_CON3 */
150 #define RG_AUDADCCLKRSTB 6
151 
152 /* MT6351_AUDENC_ANA_CON9 */
153 #define RG_AUDPWDBMICBIAS0 0
154 #define RG_AUDMICBIAS0VREF 4
155 #define RG_AUDMICBIAS0LOWPEN 7
156 
157 #define RG_AUDPWDBMICBIAS2 8
158 #define RG_AUDMICBIAS2VREF 12
159 #define RG_AUDMICBIAS2LOWPEN 15
160 
161 /* MT6351_AUDENC_ANA_CON10 */
162 #define RG_AUDPWDBMICBIAS1 0
163 #define RG_AUDMICBIAS1DCSW1NEN 2
164 #define RG_AUDMICBIAS1VREF 4
165 #define RG_AUDMICBIAS1LOWPEN 7
166 
167 enum {
168 	AUDIO_ANALOG_VOLUME_HSOUTL,
169 	AUDIO_ANALOG_VOLUME_HSOUTR,
170 	AUDIO_ANALOG_VOLUME_HPOUTL,
171 	AUDIO_ANALOG_VOLUME_HPOUTR,
172 	AUDIO_ANALOG_VOLUME_LINEOUTL,
173 	AUDIO_ANALOG_VOLUME_LINEOUTR,
174 	AUDIO_ANALOG_VOLUME_MICAMP1,
175 	AUDIO_ANALOG_VOLUME_MICAMP2,
176 	AUDIO_ANALOG_VOLUME_TYPE_MAX
177 };
178 
179 /* Supply subseq */
180 enum {
181 	SUPPLY_SUBSEQ_SETTING,
182 	SUPPLY_SUBSEQ_ENABLE,
183 	SUPPLY_SUBSEQ_MICBIAS,
184 };
185 
186 #define REG_STRIDE 2
187 
188 struct mt6351_priv {
189 	struct device *dev;
190 	struct regmap *regmap;
191 
192 	unsigned int dl_rate;
193 	unsigned int ul_rate;
194 
195 	int ana_gain[AUDIO_ANALOG_VOLUME_TYPE_MAX];
196 
197 	int hp_en_counter;
198 };
199 
set_hp_gain_zero(struct snd_soc_component * cmpnt)200 static void set_hp_gain_zero(struct snd_soc_component *cmpnt)
201 {
202 	regmap_update_bits(cmpnt->regmap, MT6351_ZCD_CON2,
203 			   0x1f << 7, 0x8 << 7);
204 	regmap_update_bits(cmpnt->regmap, MT6351_ZCD_CON2,
205 			   0x1f << 0, 0x8 << 0);
206 }
207 
get_cap_reg_val(struct snd_soc_component * cmpnt,unsigned int rate)208 static unsigned int get_cap_reg_val(struct snd_soc_component *cmpnt,
209 				    unsigned int rate)
210 {
211 	switch (rate) {
212 	case 8000:
213 		return 0;
214 	case 16000:
215 		return 1;
216 	case 32000:
217 		return 2;
218 	case 48000:
219 		return 3;
220 	case 96000:
221 		return 4;
222 	case 192000:
223 		return 5;
224 	default:
225 		dev_warn(cmpnt->dev, "%s(), error rate %d, return 3",
226 			 __func__, rate);
227 		return 3;
228 	}
229 }
230 
get_play_reg_val(struct snd_soc_component * cmpnt,unsigned int rate)231 static unsigned int get_play_reg_val(struct snd_soc_component *cmpnt,
232 				     unsigned int rate)
233 {
234 	switch (rate) {
235 	case 8000:
236 		return 0;
237 	case 11025:
238 		return 1;
239 	case 12000:
240 		return 2;
241 	case 16000:
242 		return 3;
243 	case 22050:
244 		return 4;
245 	case 24000:
246 		return 5;
247 	case 32000:
248 		return 6;
249 	case 44100:
250 		return 7;
251 	case 48000:
252 	case 96000:
253 	case 192000:
254 		return 8;
255 	default:
256 		dev_warn(cmpnt->dev, "%s(), error rate %d, return 8",
257 			 __func__, rate);
258 		return 8;
259 	}
260 }
261 
mt6351_codec_dai_hw_params(struct snd_pcm_substream * substream,struct snd_pcm_hw_params * params,struct snd_soc_dai * dai)262 static int mt6351_codec_dai_hw_params(struct snd_pcm_substream *substream,
263 				      struct snd_pcm_hw_params *params,
264 				      struct snd_soc_dai *dai)
265 {
266 	struct snd_soc_component *cmpnt = dai->component;
267 	struct mt6351_priv *priv = snd_soc_component_get_drvdata(cmpnt);
268 	unsigned int rate = params_rate(params);
269 
270 	dev_dbg(priv->dev, "%s(), substream->stream %d, rate %d\n",
271 		__func__, substream->stream, rate);
272 
273 	if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK)
274 		priv->dl_rate = rate;
275 	else if (substream->stream == SNDRV_PCM_STREAM_CAPTURE)
276 		priv->ul_rate = rate;
277 
278 	return 0;
279 }
280 
281 static const struct snd_soc_dai_ops mt6351_codec_dai_ops = {
282 	.hw_params = mt6351_codec_dai_hw_params,
283 };
284 
285 #define MT6351_FORMATS (SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_U16_LE |\
286 			SNDRV_PCM_FMTBIT_S24_LE | SNDRV_PCM_FMTBIT_U24_LE |\
287 			SNDRV_PCM_FMTBIT_S32_LE | SNDRV_PCM_FMTBIT_U32_LE)
288 
289 static struct snd_soc_dai_driver mt6351_dai_driver[] = {
290 	{
291 		.name = "mt6351-snd-codec-aif1",
292 		.playback = {
293 			.stream_name = "AIF1 Playback",
294 			.channels_min = 1,
295 			.channels_max = 2,
296 			.rates = SNDRV_PCM_RATE_8000_48000 |
297 				 SNDRV_PCM_RATE_96000 |
298 				 SNDRV_PCM_RATE_192000,
299 			.formats = MT6351_FORMATS,
300 		},
301 		.capture = {
302 			.stream_name = "AIF1 Capture",
303 			.channels_min = 1,
304 			.channels_max = 2,
305 			.rates = SNDRV_PCM_RATE_8000 |
306 				 SNDRV_PCM_RATE_16000 |
307 				 SNDRV_PCM_RATE_32000 |
308 				 SNDRV_PCM_RATE_48000 |
309 				 SNDRV_PCM_RATE_96000 |
310 				 SNDRV_PCM_RATE_192000,
311 			.formats = MT6351_FORMATS,
312 		},
313 		.ops = &mt6351_codec_dai_ops,
314 	},
315 };
316 
317 enum {
318 	HP_GAIN_SET_ZERO,
319 	HP_GAIN_RESTORE,
320 };
321 
hp_gain_ramp_set(struct snd_soc_component * cmpnt,int hp_gain_ctl)322 static void hp_gain_ramp_set(struct snd_soc_component *cmpnt, int hp_gain_ctl)
323 {
324 	struct mt6351_priv *priv = snd_soc_component_get_drvdata(cmpnt);
325 	int idx, old_idx, offset, reg_idx;
326 
327 	if (hp_gain_ctl == HP_GAIN_SET_ZERO) {
328 		idx = 8;	/* 0dB */
329 		old_idx = priv->ana_gain[AUDIO_ANALOG_VOLUME_HPOUTL];
330 	} else {
331 		idx = priv->ana_gain[AUDIO_ANALOG_VOLUME_HPOUTL];
332 		old_idx = 8;	/* 0dB */
333 	}
334 	dev_dbg(priv->dev, "%s(), idx %d, old_idx %d\n",
335 		__func__, idx, old_idx);
336 
337 	if (idx > old_idx)
338 		offset = idx - old_idx;
339 	else
340 		offset = old_idx - idx;
341 
342 	reg_idx = old_idx;
343 
344 	while (offset > 0) {
345 		reg_idx = idx > old_idx ? reg_idx + 1 : reg_idx - 1;
346 
347 		/* check valid range, and set value */
348 		if ((reg_idx >= 0 && reg_idx <= 0x12) || reg_idx == 0x1f) {
349 			regmap_update_bits(cmpnt->regmap,
350 					   MT6351_ZCD_CON2,
351 					   0xf9f,
352 					   (reg_idx << 7) | reg_idx);
353 			usleep_range(100, 120);
354 		}
355 		offset--;
356 	}
357 }
358 
hp_zcd_enable(struct snd_soc_component * cmpnt)359 static void hp_zcd_enable(struct snd_soc_component *cmpnt)
360 {
361 	/* Enable ZCD, for minimize pop noise */
362 	/* when adjust gain during HP buffer on */
363 	regmap_update_bits(cmpnt->regmap, MT6351_ZCD_CON0, 0x7 << 8, 0x1 << 8);
364 	regmap_update_bits(cmpnt->regmap, MT6351_ZCD_CON0, 0x1 << 7, 0x0 << 7);
365 
366 	/* timeout, 1=5ms, 0=30ms */
367 	regmap_update_bits(cmpnt->regmap, MT6351_ZCD_CON0, 0x1 << 6, 0x1 << 6);
368 
369 	regmap_update_bits(cmpnt->regmap, MT6351_ZCD_CON0, 0x3 << 4, 0x0 << 4);
370 	regmap_update_bits(cmpnt->regmap, MT6351_ZCD_CON0, 0x7 << 1, 0x5 << 1);
371 	regmap_update_bits(cmpnt->regmap, MT6351_ZCD_CON0, 0x1 << 0, 0x1 << 0);
372 }
373 
hp_zcd_disable(struct snd_soc_component * cmpnt)374 static void hp_zcd_disable(struct snd_soc_component *cmpnt)
375 {
376 	regmap_write(cmpnt->regmap, MT6351_ZCD_CON0, 0x0000);
377 }
378 
379 static const DECLARE_TLV_DB_SCALE(playback_tlv, -1000, 100, 0);
380 static const DECLARE_TLV_DB_SCALE(pga_tlv, 0, 600, 0);
381 
382 static const struct snd_kcontrol_new mt6351_snd_controls[] = {
383 	/* dl pga gain */
384 	SOC_DOUBLE_TLV("Headphone Volume",
385 		       MT6351_ZCD_CON2, 0, 7, 0x12, 1,
386 		       playback_tlv),
387 	SOC_DOUBLE_TLV("Lineout Volume",
388 		       MT6351_ZCD_CON1, 0, 7, 0x12, 1,
389 		       playback_tlv),
390 	SOC_SINGLE_TLV("Handset Volume",
391 		       MT6351_ZCD_CON3, 0, 0x12, 1,
392 		       playback_tlv),
393        /* ul pga gain */
394 	SOC_DOUBLE_R_TLV("PGA Volume",
395 			 MT6351_AUDENC_ANA_CON0, MT6351_AUDENC_ANA_CON1,
396 			 8, 4, 0,
397 			 pga_tlv),
398 };
399 
400 /* MUX */
401 
402 /* LOL MUX */
403 static const char *const lo_in_mux_map[] = {
404 	"Open", "Mute", "Playback", "Test Mode",
405 };
406 
407 static int lo_in_mux_map_value[] = {
408 	0x0, 0x1, 0x2, 0x3,
409 };
410 
411 static SOC_VALUE_ENUM_SINGLE_DECL(lo_in_mux_map_enum,
412 				  MT6351_AUDDEC_ANA_CON3,
413 				  RG_AUDLOLMUXINPUTSEL_VAUDP32_SFT,
414 				  RG_AUDLOLMUXINPUTSEL_VAUDP32_MASK,
415 				  lo_in_mux_map,
416 				  lo_in_mux_map_value);
417 
418 static const struct snd_kcontrol_new lo_in_mux_control =
419 	SOC_DAPM_ENUM("In Select", lo_in_mux_map_enum);
420 
421 /*HP MUX */
422 static const char *const hp_in_mux_map[] = {
423 	"Open", "LoudSPK Playback", "Audio Playback", "Test Mode",
424 };
425 
426 static int hp_in_mux_map_value[] = {
427 	0x0, 0x1, 0x2, 0x3,
428 };
429 
430 static SOC_VALUE_ENUM_SINGLE_DECL(hpl_in_mux_map_enum,
431 				  MT6351_AUDDEC_ANA_CON0,
432 				  RG_AUDHPLMUXINPUTSEL_VAUDP32_SFT,
433 				  RG_AUDHPLMUXINPUTSEL_VAUDP32_MASK,
434 				  hp_in_mux_map,
435 				  hp_in_mux_map_value);
436 
437 static const struct snd_kcontrol_new hpl_in_mux_control =
438 	SOC_DAPM_ENUM("HPL Select", hpl_in_mux_map_enum);
439 
440 static SOC_VALUE_ENUM_SINGLE_DECL(hpr_in_mux_map_enum,
441 				  MT6351_AUDDEC_ANA_CON0,
442 				  RG_AUDHPRMUXINPUTSEL_VAUDP32_SFT,
443 				  RG_AUDHPRMUXINPUTSEL_VAUDP32_MASK,
444 				  hp_in_mux_map,
445 				  hp_in_mux_map_value);
446 
447 static const struct snd_kcontrol_new hpr_in_mux_control =
448 	SOC_DAPM_ENUM("HPR Select", hpr_in_mux_map_enum);
449 
450 /* RCV MUX */
451 static const char *const rcv_in_mux_map[] = {
452 	"Open", "Mute", "Voice Playback", "Test Mode",
453 };
454 
455 static int rcv_in_mux_map_value[] = {
456 	0x0, 0x1, 0x2, 0x3,
457 };
458 
459 static SOC_VALUE_ENUM_SINGLE_DECL(rcv_in_mux_map_enum,
460 				  MT6351_AUDDEC_ANA_CON0,
461 				  RG_AUDHSMUXINPUTSEL_VAUDP32_SFT,
462 				  RG_AUDHSMUXINPUTSEL_VAUDP32_MASK,
463 				  rcv_in_mux_map,
464 				  rcv_in_mux_map_value);
465 
466 static const struct snd_kcontrol_new rcv_in_mux_control =
467 	SOC_DAPM_ENUM("RCV Select", rcv_in_mux_map_enum);
468 
469 /* DAC In MUX */
470 static const char *const dac_in_mux_map[] = {
471 	"Normal Path", "Sgen",
472 };
473 
474 static int dac_in_mux_map_value[] = {
475 	0x0, 0x1,
476 };
477 
478 static SOC_VALUE_ENUM_SINGLE_DECL(dac_in_mux_map_enum,
479 				  MT6351_AFE_TOP_CON0,
480 				  RG_DL_SINE_ON_SFT,
481 				  RG_DL_SINE_ON_MASK,
482 				  dac_in_mux_map,
483 				  dac_in_mux_map_value);
484 
485 static const struct snd_kcontrol_new dac_in_mux_control =
486 	SOC_DAPM_ENUM("DAC Select", dac_in_mux_map_enum);
487 
488 /* AIF Out MUX */
489 static SOC_VALUE_ENUM_SINGLE_DECL(aif_out_mux_map_enum,
490 				  MT6351_AFE_TOP_CON0,
491 				  RG_UL_SINE_ON_SFT,
492 				  RG_UL_SINE_ON_MASK,
493 				  dac_in_mux_map,
494 				  dac_in_mux_map_value);
495 
496 static const struct snd_kcontrol_new aif_out_mux_control =
497 	SOC_DAPM_ENUM("AIF Out Select", aif_out_mux_map_enum);
498 
499 /* ADC L MUX */
500 static const char *const adc_left_mux_map[] = {
501 	"Idle", "AIN0", "Left Preamplifier", "Idle_1",
502 };
503 
504 static int adc_left_mux_map_value[] = {
505 	0x0, 0x1, 0x2, 0x3,
506 };
507 
508 static SOC_VALUE_ENUM_SINGLE_DECL(adc_left_mux_map_enum,
509 				  MT6351_AUDENC_ANA_CON0,
510 				  RG_AUDADCLINPUTSEL_SFT,
511 				  RG_AUDADCLINPUTSEL_MASK,
512 				  adc_left_mux_map,
513 				  adc_left_mux_map_value);
514 
515 static const struct snd_kcontrol_new adc_left_mux_control =
516 	SOC_DAPM_ENUM("ADC L Select", adc_left_mux_map_enum);
517 
518 /* ADC R MUX */
519 static const char *const adc_right_mux_map[] = {
520 	"Idle", "AIN0", "Right Preamplifier", "Idle_1",
521 };
522 
523 static int adc_right_mux_map_value[] = {
524 	0x0, 0x1, 0x2, 0x3,
525 };
526 
527 static SOC_VALUE_ENUM_SINGLE_DECL(adc_right_mux_map_enum,
528 				  MT6351_AUDENC_ANA_CON1,
529 				  RG_AUDADCRINPUTSEL_SFT,
530 				  RG_AUDADCRINPUTSEL_MASK,
531 				  adc_right_mux_map,
532 				  adc_right_mux_map_value);
533 
534 static const struct snd_kcontrol_new adc_right_mux_control =
535 	SOC_DAPM_ENUM("ADC R Select", adc_right_mux_map_enum);
536 
537 /* PGA L MUX */
538 static const char *const pga_left_mux_map[] = {
539 	"None", "AIN0", "AIN1", "AIN2",
540 };
541 
542 static int pga_left_mux_map_value[] = {
543 	0x0, 0x1, 0x2, 0x3,
544 };
545 
546 static SOC_VALUE_ENUM_SINGLE_DECL(pga_left_mux_map_enum,
547 				  MT6351_AUDENC_ANA_CON0,
548 				  RG_AUDPREAMPLINPUTSEL_SFT,
549 				  RG_AUDPREAMPLINPUTSEL_MASK,
550 				  pga_left_mux_map,
551 				  pga_left_mux_map_value);
552 
553 static const struct snd_kcontrol_new pga_left_mux_control =
554 	SOC_DAPM_ENUM("PGA L Select", pga_left_mux_map_enum);
555 
556 /* PGA R MUX */
557 static const char *const pga_right_mux_map[] = {
558 	"None", "AIN0", "AIN3", "AIN2",
559 };
560 
561 static int pga_right_mux_map_value[] = {
562 	0x0, 0x1, 0x2, 0x3,
563 };
564 
565 static SOC_VALUE_ENUM_SINGLE_DECL(pga_right_mux_map_enum,
566 				  MT6351_AUDENC_ANA_CON1,
567 				  RG_AUDPREAMPRINPUTSEL_SFT,
568 				  RG_AUDPREAMPRINPUTSEL_MASK,
569 				  pga_right_mux_map,
570 				  pga_right_mux_map_value);
571 
572 static const struct snd_kcontrol_new pga_right_mux_control =
573 	SOC_DAPM_ENUM("PGA R Select", pga_right_mux_map_enum);
574 
mt_reg_set_clr_event(struct snd_soc_dapm_widget * w,struct snd_kcontrol * kcontrol,int event)575 static int mt_reg_set_clr_event(struct snd_soc_dapm_widget *w,
576 				struct snd_kcontrol *kcontrol,
577 				int event)
578 {
579 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
580 
581 	switch (event) {
582 	case SND_SOC_DAPM_POST_PMU:
583 		if (w->on_val) {
584 			/* SET REG */
585 			regmap_update_bits(cmpnt->regmap,
586 					   w->reg + REG_STRIDE,
587 					   0x1 << w->shift,
588 					   0x1 << w->shift);
589 		} else {
590 			/* CLR REG */
591 			regmap_update_bits(cmpnt->regmap,
592 					   w->reg + REG_STRIDE * 2,
593 					   0x1 << w->shift,
594 					   0x1 << w->shift);
595 		}
596 		break;
597 	case SND_SOC_DAPM_PRE_PMD:
598 		if (w->off_val) {
599 			/* SET REG */
600 			regmap_update_bits(cmpnt->regmap,
601 					   w->reg + REG_STRIDE,
602 					   0x1 << w->shift,
603 					   0x1 << w->shift);
604 		} else {
605 			/* CLR REG */
606 			regmap_update_bits(cmpnt->regmap,
607 					   w->reg + REG_STRIDE * 2,
608 					   0x1 << w->shift,
609 					   0x1 << w->shift);
610 		}
611 		break;
612 	default:
613 		break;
614 	}
615 
616 	return 0;
617 }
618 
mt_ncp_event(struct snd_soc_dapm_widget * w,struct snd_kcontrol * kcontrol,int event)619 static int mt_ncp_event(struct snd_soc_dapm_widget *w,
620 			struct snd_kcontrol *kcontrol,
621 			int event)
622 {
623 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
624 
625 	switch (event) {
626 	case SND_SOC_DAPM_PRE_PMU:
627 		regmap_update_bits(cmpnt->regmap, MT6351_AFE_NCP_CFG1,
628 				   0xffff, 0x1515);
629 		/* NCP: ck1 and ck2 clock frequecy adjust configure */
630 		regmap_update_bits(cmpnt->regmap, MT6351_AFE_NCP_CFG0,
631 				   0xfffe, 0x8C00);
632 		break;
633 	case SND_SOC_DAPM_POST_PMU:
634 		usleep_range(250, 270);
635 		break;
636 	default:
637 		break;
638 	}
639 
640 	return 0;
641 }
642 
mt_sgen_event(struct snd_soc_dapm_widget * w,struct snd_kcontrol * kcontrol,int event)643 static int mt_sgen_event(struct snd_soc_dapm_widget *w,
644 			 struct snd_kcontrol *kcontrol,
645 			 int event)
646 {
647 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
648 
649 	switch (event) {
650 	case SND_SOC_DAPM_PRE_PMU:
651 		regmap_update_bits(cmpnt->regmap, MT6351_AFE_SGEN_CFG0,
652 				   0xffef, 0x0008);
653 		regmap_update_bits(cmpnt->regmap, MT6351_AFE_SGEN_CFG1,
654 				   0xffff, 0x0101);
655 		break;
656 	default:
657 		break;
658 	}
659 
660 	return 0;
661 }
662 
mt_aif_in_event(struct snd_soc_dapm_widget * w,struct snd_kcontrol * kcontrol,int event)663 static int mt_aif_in_event(struct snd_soc_dapm_widget *w,
664 			   struct snd_kcontrol *kcontrol,
665 			   int event)
666 {
667 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
668 	struct mt6351_priv *priv = snd_soc_component_get_drvdata(cmpnt);
669 
670 	dev_dbg(priv->dev, "%s(), event 0x%x, rate %d\n",
671 		__func__, event, priv->dl_rate);
672 
673 	switch (event) {
674 	case SND_SOC_DAPM_PRE_PMU:
675 		/* sdm audio fifo clock power on */
676 		regmap_update_bits(cmpnt->regmap, MT6351_AFUNC_AUD_CON2,
677 				   0xffff, 0x0006);
678 		/* scrambler clock on enable */
679 		regmap_update_bits(cmpnt->regmap, MT6351_AFUNC_AUD_CON0,
680 				   0xffff, 0xC3A1);
681 		/* sdm power on */
682 		regmap_update_bits(cmpnt->regmap, MT6351_AFUNC_AUD_CON2,
683 				   0xffff, 0x0003);
684 		/* sdm fifo enable */
685 		regmap_update_bits(cmpnt->regmap, MT6351_AFUNC_AUD_CON2,
686 				   0xffff, 0x000B);
687 		/* set attenuation gain */
688 		regmap_update_bits(cmpnt->regmap, MT6351_AFE_DL_SDM_CON1,
689 				   0xffff, 0x001E);
690 
691 		regmap_write(cmpnt->regmap, MT6351_AFE_PMIC_NEWIF_CFG0,
692 			     (get_play_reg_val(cmpnt, priv->dl_rate) << 12) |
693 			     0x330);
694 		regmap_write(cmpnt->regmap, MT6351_AFE_DL_SRC2_CON0_H,
695 			     (get_play_reg_val(cmpnt, priv->dl_rate) << 12) |
696 			     0x300);
697 
698 		regmap_update_bits(cmpnt->regmap, MT6351_AFE_PMIC_NEWIF_CFG2,
699 				   0x8000, 0x8000);
700 		break;
701 	default:
702 		break;
703 	}
704 
705 	return 0;
706 }
707 
mt_hp_event(struct snd_soc_dapm_widget * w,struct snd_kcontrol * kcontrol,int event)708 static int mt_hp_event(struct snd_soc_dapm_widget *w,
709 		       struct snd_kcontrol *kcontrol,
710 		       int event)
711 {
712 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
713 	struct mt6351_priv *priv = snd_soc_component_get_drvdata(cmpnt);
714 	int reg;
715 
716 	dev_dbg(priv->dev, "%s(), event 0x%x, hp_en_counter %d\n",
717 		__func__, event, priv->hp_en_counter);
718 
719 	switch (event) {
720 	case SND_SOC_DAPM_PRE_PMU:
721 		priv->hp_en_counter++;
722 		if (priv->hp_en_counter > 1)
723 			break;	/* already enabled, do nothing */
724 		else if (priv->hp_en_counter <= 0)
725 			dev_err(priv->dev, "%s(), hp_en_counter %d <= 0\n",
726 				__func__,
727 				priv->hp_en_counter);
728 
729 		hp_zcd_disable(cmpnt);
730 
731 		/* from yoyo HQA script */
732 		regmap_update_bits(cmpnt->regmap, MT6351_AUDDEC_ANA_CON6,
733 				   0x0700, 0x0700);
734 
735 		/* save target gain to restore after hardware open complete */
736 		regmap_read(cmpnt->regmap, MT6351_ZCD_CON2, &reg);
737 		priv->ana_gain[AUDIO_ANALOG_VOLUME_HPOUTL] = reg & 0x1f;
738 		priv->ana_gain[AUDIO_ANALOG_VOLUME_HPOUTR] = (reg >> 7) & 0x1f;
739 
740 		/* Set HPR/HPL gain as minimum (~ -40dB) */
741 		regmap_update_bits(cmpnt->regmap,
742 				   MT6351_ZCD_CON2, 0xffff, 0x0F9F);
743 		/* Set HS gain as minimum (~ -40dB) */
744 		regmap_update_bits(cmpnt->regmap,
745 				   MT6351_ZCD_CON3, 0xffff, 0x001F);
746 		/* De_OSC of HP */
747 		regmap_update_bits(cmpnt->regmap, MT6351_AUDDEC_ANA_CON2,
748 				   0x0001, 0x0001);
749 		/* enable output STBENH */
750 		regmap_update_bits(cmpnt->regmap, MT6351_AUDDEC_ANA_CON1,
751 				   0xffff, 0x2000);
752 		/* De_OSC of voice, enable output STBENH */
753 		regmap_update_bits(cmpnt->regmap, MT6351_AUDDEC_ANA_CON1,
754 				   0xffff, 0x2100);
755 		/* Enable voice driver */
756 		regmap_update_bits(cmpnt->regmap, MT6351_AUDDEC_ANA_CON0,
757 				   0x0010, 0xE090);
758 		/* Enable pre-charge buffer  */
759 		regmap_update_bits(cmpnt->regmap, MT6351_AUDDEC_ANA_CON1,
760 				   0xffff, 0x2140);
761 
762 		usleep_range(50, 60);
763 
764 		/* Apply digital DC compensation value to DAC */
765 		set_hp_gain_zero(cmpnt);
766 
767 		/* Enable HPR/HPL */
768 		regmap_update_bits(cmpnt->regmap, MT6351_AUDDEC_ANA_CON1,
769 				   0xffff, 0x2100);
770 		/* Disable pre-charge buffer */
771 		regmap_update_bits(cmpnt->regmap, MT6351_AUDDEC_ANA_CON1,
772 				   0xffff, 0x2000);
773 		/* Disable De_OSC of voice */
774 		regmap_update_bits(cmpnt->regmap, MT6351_AUDDEC_ANA_CON0,
775 				   0x0010, 0xF4EF);
776 		/* Disable voice buffer */
777 
778 		/* from yoyo HQ */
779 		regmap_update_bits(cmpnt->regmap, MT6351_AUDDEC_ANA_CON6,
780 				   0x0700, 0x0300);
781 
782 		/* Enable ZCD, for minimize pop noise */
783 		/* when adjust gain during HP buffer on */
784 		hp_zcd_enable(cmpnt);
785 
786 		/* apply volume setting */
787 		hp_gain_ramp_set(cmpnt, HP_GAIN_RESTORE);
788 
789 		break;
790 	case SND_SOC_DAPM_PRE_PMD:
791 		priv->hp_en_counter--;
792 		if (priv->hp_en_counter > 0)
793 			break;	/* still being used, don't close */
794 		else if (priv->hp_en_counter < 0)
795 			dev_err(priv->dev, "%s(), hp_en_counter %d <= 0\n",
796 				__func__,
797 				priv->hp_en_counter);
798 
799 		/* Disable AUD_ZCD */
800 		hp_zcd_disable(cmpnt);
801 
802 		/* Set HPR/HPL gain as -1dB, step by step */
803 		hp_gain_ramp_set(cmpnt, HP_GAIN_SET_ZERO);
804 
805 		set_hp_gain_zero(cmpnt);
806 		break;
807 	case SND_SOC_DAPM_POST_PMD:
808 		if (priv->hp_en_counter > 0)
809 			break;	/* still being used, don't close */
810 		else if (priv->hp_en_counter < 0)
811 			dev_err(priv->dev, "%s(), hp_en_counter %d <= 0\n",
812 				__func__,
813 				priv->hp_en_counter);
814 
815 		/* reset*/
816 		regmap_update_bits(cmpnt->regmap,
817 				   MT6351_AUDDEC_ANA_CON6,
818 				   0x0700,
819 				   0x0000);
820 		/* De_OSC of HP */
821 		regmap_update_bits(cmpnt->regmap,
822 				   MT6351_AUDDEC_ANA_CON2,
823 				   0x0001,
824 				   0x0000);
825 
826 		/* apply volume setting */
827 		hp_gain_ramp_set(cmpnt, HP_GAIN_RESTORE);
828 		break;
829 	default:
830 		break;
831 	}
832 
833 	return 0;
834 }
835 
mt_aif_out_event(struct snd_soc_dapm_widget * w,struct snd_kcontrol * kcontrol,int event)836 static int mt_aif_out_event(struct snd_soc_dapm_widget *w,
837 			    struct snd_kcontrol *kcontrol,
838 			    int event)
839 {
840 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
841 	struct mt6351_priv *priv = snd_soc_component_get_drvdata(cmpnt);
842 
843 	dev_dbg(priv->dev, "%s(), event 0x%x, rate %d\n",
844 		__func__, event, priv->ul_rate);
845 
846 	switch (event) {
847 	case SND_SOC_DAPM_PRE_PMU:
848 		/* dcclk_div=11'b00100000011, dcclk_ref_ck_sel=2'b00 */
849 		regmap_update_bits(cmpnt->regmap, MT6351_AFE_DCCLK_CFG0,
850 				   0xffff, 0x2062);
851 		/* dcclk_pdn=1'b0 */
852 		regmap_update_bits(cmpnt->regmap, MT6351_AFE_DCCLK_CFG0,
853 				   0xffff, 0x2060);
854 		/* dcclk_gen_on=1'b1 */
855 		regmap_update_bits(cmpnt->regmap, MT6351_AFE_DCCLK_CFG0,
856 				   0xffff, 0x2061);
857 
858 		/* UL sample rate and mode configure */
859 		regmap_update_bits(cmpnt->regmap, MT6351_AFE_UL_SRC_CON0_H,
860 				   0x000E,
861 				   get_cap_reg_val(cmpnt, priv->ul_rate) << 1);
862 
863 		/* fixed 260k path for 8/16/32/48 */
864 		if (priv->ul_rate <= 48000) {
865 			/* anc ul path src on */
866 			regmap_update_bits(cmpnt->regmap,
867 					   MT6351_AFE_HPANC_CFG0,
868 					   0x1 << 1,
869 					   0x1 << 1);
870 			/* ANC clk pdn release */
871 			regmap_update_bits(cmpnt->regmap,
872 					   MT6351_AFE_HPANC_CFG0,
873 					   0x1 << 0,
874 					   0x0 << 0);
875 		}
876 		break;
877 	case SND_SOC_DAPM_PRE_PMD:
878 		/* fixed 260k path for 8/16/32/48 */
879 		if (priv->ul_rate <= 48000) {
880 			/* anc ul path src on */
881 			regmap_update_bits(cmpnt->regmap,
882 					   MT6351_AFE_HPANC_CFG0,
883 					   0x1 << 1,
884 					   0x0 << 1);
885 			/* ANC clk pdn release */
886 			regmap_update_bits(cmpnt->regmap,
887 					   MT6351_AFE_HPANC_CFG0,
888 					   0x1 << 0,
889 					   0x1 << 0);
890 		}
891 		break;
892 	default:
893 		break;
894 	}
895 
896 	return 0;
897 }
898 
mt_adc_clkgen_event(struct snd_soc_dapm_widget * w,struct snd_kcontrol * kcontrol,int event)899 static int mt_adc_clkgen_event(struct snd_soc_dapm_widget *w,
900 			       struct snd_kcontrol *kcontrol,
901 			       int event)
902 {
903 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
904 
905 	switch (event) {
906 	case SND_SOC_DAPM_PRE_PMU:
907 		/* Audio ADC clock gen. mode: 00_divided by 2 (Normal) */
908 		regmap_update_bits(cmpnt->regmap, MT6351_AUDENC_ANA_CON3,
909 				   0x3 << 4, 0x0);
910 		break;
911 	case SND_SOC_DAPM_POST_PMU:
912 		/* ADC CLK from: 00_13MHz from CLKSQ (Default) */
913 		regmap_update_bits(cmpnt->regmap, MT6351_AUDENC_ANA_CON3,
914 				   0x3 << 2, 0x0);
915 		break;
916 	default:
917 		break;
918 	}
919 	return 0;
920 }
921 
mt_pga_left_event(struct snd_soc_dapm_widget * w,struct snd_kcontrol * kcontrol,int event)922 static int mt_pga_left_event(struct snd_soc_dapm_widget *w,
923 			     struct snd_kcontrol *kcontrol,
924 			     int event)
925 {
926 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
927 
928 	switch (event) {
929 	case SND_SOC_DAPM_PRE_PMU:
930 		/* Audio L PGA precharge on */
931 		regmap_update_bits(cmpnt->regmap, MT6351_AUDENC_ANA_CON0,
932 				   0x3 << RG_AUDPREAMPLDCPRECHARGE,
933 				   0x1 << RG_AUDPREAMPLDCPRECHARGE);
934 		/* Audio L PGA mode: 1_DCC */
935 		regmap_update_bits(cmpnt->regmap, MT6351_AUDENC_ANA_CON0,
936 				   0x3 << RG_AUDPREAMPLDCCEN,
937 				   0x1 << RG_AUDPREAMPLDCCEN);
938 		break;
939 	case SND_SOC_DAPM_POST_PMU:
940 		usleep_range(100, 120);
941 		/* Audio L PGA precharge off */
942 		regmap_update_bits(cmpnt->regmap, MT6351_AUDENC_ANA_CON0,
943 				   0x3 << RG_AUDPREAMPLDCPRECHARGE,
944 				   0x0 << RG_AUDPREAMPLDCPRECHARGE);
945 		break;
946 	default:
947 		break;
948 	}
949 	return 0;
950 }
951 
mt_pga_right_event(struct snd_soc_dapm_widget * w,struct snd_kcontrol * kcontrol,int event)952 static int mt_pga_right_event(struct snd_soc_dapm_widget *w,
953 			      struct snd_kcontrol *kcontrol,
954 			      int event)
955 {
956 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
957 
958 	switch (event) {
959 	case SND_SOC_DAPM_PRE_PMU:
960 		/* Audio R PGA precharge on */
961 		regmap_update_bits(cmpnt->regmap, MT6351_AUDENC_ANA_CON1,
962 				   0x3 << RG_AUDPREAMPRDCPRECHARGE,
963 				   0x1 << RG_AUDPREAMPRDCPRECHARGE);
964 		/* Audio R PGA mode: 1_DCC */
965 		regmap_update_bits(cmpnt->regmap, MT6351_AUDENC_ANA_CON1,
966 				   0x3 << RG_AUDPREAMPRDCCEN,
967 				   0x1 << RG_AUDPREAMPRDCCEN);
968 		break;
969 	case SND_SOC_DAPM_POST_PMU:
970 		usleep_range(100, 120);
971 		/* Audio R PGA precharge off */
972 		regmap_update_bits(cmpnt->regmap, MT6351_AUDENC_ANA_CON1,
973 				   0x3 << RG_AUDPREAMPRDCPRECHARGE,
974 				   0x0 << RG_AUDPREAMPRDCPRECHARGE);
975 		break;
976 	default:
977 		break;
978 	}
979 	return 0;
980 }
981 
mt_mic_bias_0_event(struct snd_soc_dapm_widget * w,struct snd_kcontrol * kcontrol,int event)982 static int mt_mic_bias_0_event(struct snd_soc_dapm_widget *w,
983 			       struct snd_kcontrol *kcontrol,
984 			       int event)
985 {
986 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
987 
988 	switch (event) {
989 	case SND_SOC_DAPM_PRE_PMU:
990 		/* MIC Bias 0 LowPower: 0_Normal */
991 		regmap_update_bits(cmpnt->regmap, MT6351_AUDENC_ANA_CON9,
992 				   0x3 << RG_AUDMICBIAS0LOWPEN, 0x0);
993 		/* MISBIAS0 = 1P9V */
994 		regmap_update_bits(cmpnt->regmap, MT6351_AUDENC_ANA_CON9,
995 				   0x7 << RG_AUDMICBIAS0VREF,
996 				   0x2 << RG_AUDMICBIAS0VREF);
997 		break;
998 	case SND_SOC_DAPM_POST_PMD:
999 		/* MISBIAS0 = 1P97 */
1000 		regmap_update_bits(cmpnt->regmap, MT6351_AUDENC_ANA_CON9,
1001 				   0x7 << RG_AUDMICBIAS0VREF,
1002 				   0x0 << RG_AUDMICBIAS0VREF);
1003 		break;
1004 	default:
1005 		break;
1006 	}
1007 	return 0;
1008 }
1009 
mt_mic_bias_1_event(struct snd_soc_dapm_widget * w,struct snd_kcontrol * kcontrol,int event)1010 static int mt_mic_bias_1_event(struct snd_soc_dapm_widget *w,
1011 			       struct snd_kcontrol *kcontrol,
1012 			       int event)
1013 {
1014 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
1015 
1016 	switch (event) {
1017 	case SND_SOC_DAPM_PRE_PMU:
1018 		/* MIC Bias 1 LowPower: 0_Normal */
1019 		regmap_update_bits(cmpnt->regmap, MT6351_AUDENC_ANA_CON10,
1020 				   0x3 << RG_AUDMICBIAS1LOWPEN, 0x0);
1021 		/* MISBIAS1 = 2P7V */
1022 		regmap_update_bits(cmpnt->regmap, MT6351_AUDENC_ANA_CON10,
1023 				   0x7 << RG_AUDMICBIAS1VREF,
1024 				   0x7 << RG_AUDMICBIAS1VREF);
1025 		break;
1026 	case SND_SOC_DAPM_POST_PMD:
1027 		/* MISBIAS1 = 1P7V */
1028 		regmap_update_bits(cmpnt->regmap, MT6351_AUDENC_ANA_CON10,
1029 				   0x7 << RG_AUDMICBIAS1VREF,
1030 				   0x0 << RG_AUDMICBIAS1VREF);
1031 		break;
1032 	default:
1033 		break;
1034 	}
1035 	return 0;
1036 }
1037 
mt_mic_bias_2_event(struct snd_soc_dapm_widget * w,struct snd_kcontrol * kcontrol,int event)1038 static int mt_mic_bias_2_event(struct snd_soc_dapm_widget *w,
1039 			       struct snd_kcontrol *kcontrol,
1040 			       int event)
1041 {
1042 	struct snd_soc_component *cmpnt = snd_soc_dapm_to_component(w->dapm);
1043 
1044 	switch (event) {
1045 	case SND_SOC_DAPM_PRE_PMU:
1046 		/* MIC Bias 2 LowPower: 0_Normal */
1047 		regmap_update_bits(cmpnt->regmap, MT6351_AUDENC_ANA_CON9,
1048 				   0x3 << RG_AUDMICBIAS2LOWPEN, 0x0);
1049 		/* MISBIAS2 = 1P9V */
1050 		regmap_update_bits(cmpnt->regmap, MT6351_AUDENC_ANA_CON9,
1051 				   0x7 << RG_AUDMICBIAS2VREF,
1052 				   0x2 << RG_AUDMICBIAS2VREF);
1053 		break;
1054 	case SND_SOC_DAPM_POST_PMD:
1055 		/* MISBIAS2 = 1P97 */
1056 		regmap_update_bits(cmpnt->regmap, MT6351_AUDENC_ANA_CON9,
1057 				   0x7 << RG_AUDMICBIAS2VREF,
1058 				   0x0 << RG_AUDMICBIAS2VREF);
1059 		break;
1060 	default:
1061 		break;
1062 	}
1063 	return 0;
1064 }
1065 
1066 /* DAPM Widgets */
1067 static const struct snd_soc_dapm_widget mt6351_dapm_widgets[] = {
1068 	/* Digital Clock */
1069 	SND_SOC_DAPM_SUPPLY("AUDIO_TOP_AFE_CTL", MT6351_AUDIO_TOP_CON0,
1070 			    AUD_TOP_PDN_AFE_CTL_BIT, 1, NULL, 0),
1071 	SND_SOC_DAPM_SUPPLY("AUDIO_TOP_DAC_CTL", MT6351_AUDIO_TOP_CON0,
1072 			    AUD_TOP_PDN_DAC_CTL_BIT, 1, NULL, 0),
1073 	SND_SOC_DAPM_SUPPLY("AUDIO_TOP_ADC_CTL", MT6351_AUDIO_TOP_CON0,
1074 			    AUD_TOP_PDN_ADC_CTL_BIT, 1, NULL, 0),
1075 	SND_SOC_DAPM_SUPPLY("AUDIO_TOP_PWR_CLK", MT6351_AUDIO_TOP_CON0,
1076 			    AUD_TOP_PWR_CLK_DIS_CTL_BIT, 1, NULL, 0),
1077 	SND_SOC_DAPM_SUPPLY("AUDIO_TOP_PDN_RESERVED", MT6351_AUDIO_TOP_CON0,
1078 			    AUD_TOP_PDN_RESERVED_BIT, 1, NULL, 0),
1079 
1080 	SND_SOC_DAPM_SUPPLY("NCP", MT6351_AFE_NCP_CFG0,
1081 			    RG_NCP_ON_BIT, 0,
1082 			    mt_ncp_event,
1083 			    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1084 
1085 	SND_SOC_DAPM_SUPPLY("DL Digital Clock", SND_SOC_NOPM,
1086 			    0, 0, NULL, 0),
1087 
1088 	/* Global Supply*/
1089 	SND_SOC_DAPM_SUPPLY("AUDGLB", MT6351_AUDDEC_ANA_CON9,
1090 			    RG_AUDGLB_PWRDN_VA32_BIT, 1, NULL, 0),
1091 	SND_SOC_DAPM_SUPPLY("CLKSQ Audio", MT6351_TOP_CLKSQ,
1092 			    RG_CLKSQ_EN_AUD_BIT, 0,
1093 			    mt_reg_set_clr_event,
1094 			    SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_PRE_PMD),
1095 	SND_SOC_DAPM_SUPPLY("ZCD13M_CK", MT6351_TOP_CKPDN_CON0,
1096 			    RG_ZCD13M_CK_PDN_BIT, 1,
1097 			    mt_reg_set_clr_event,
1098 			    SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_PRE_PMD),
1099 	SND_SOC_DAPM_SUPPLY("AUD_CK", MT6351_TOP_CKPDN_CON0,
1100 			    RG_AUD_CK_PDN_BIT, 1,
1101 			    mt_reg_set_clr_event,
1102 			    SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_PRE_PMD),
1103 	SND_SOC_DAPM_SUPPLY("AUDIF_CK", MT6351_TOP_CKPDN_CON0,
1104 			    RG_AUDIF_CK_PDN_BIT, 1,
1105 			    mt_reg_set_clr_event,
1106 			    SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_PRE_PMD),
1107 	SND_SOC_DAPM_SUPPLY("AUDNCP_CK", MT6351_TOP_CKPDN_CON0,
1108 			    RG_AUDNCP_CK_PDN_BIT, 1,
1109 			    mt_reg_set_clr_event,
1110 			    SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_PRE_PMD),
1111 
1112 	SND_SOC_DAPM_SUPPLY("AFE_ON", MT6351_AFE_UL_DL_CON0, RG_AFE_ON_BIT, 0,
1113 			    NULL, 0),
1114 
1115 	/* AIF Rx*/
1116 	SND_SOC_DAPM_AIF_IN_E("AIF_RX", "AIF1 Playback", 0,
1117 			      MT6351_AFE_DL_SRC2_CON0_L,
1118 			      RG_DL_2_SRC_ON_TMP_CTL_PRE_BIT, 0,
1119 			      mt_aif_in_event, SND_SOC_DAPM_PRE_PMU),
1120 
1121 	/* DL Supply */
1122 	SND_SOC_DAPM_SUPPLY("DL Power Supply", SND_SOC_NOPM,
1123 			    0, 0, NULL, 0),
1124 	SND_SOC_DAPM_SUPPLY("NV Regulator", MT6351_AUDDEC_ANA_CON10,
1125 			    RG_NVREG_EN_VAUDP32_BIT, 0, NULL, 0),
1126 	SND_SOC_DAPM_SUPPLY("AUD_CLK", MT6351_AUDDEC_ANA_CON9,
1127 			    RG_RSTB_DECODER_VA32_BIT, 0, NULL, 0),
1128 	SND_SOC_DAPM_SUPPLY("IBIST", MT6351_AUDDEC_ANA_CON9,
1129 			    RG_AUDIBIASPWRDN_VAUDP32_BIT, 1, NULL, 0),
1130 	SND_SOC_DAPM_SUPPLY("LDO", MT6351_AUDDEC_ANA_CON9,
1131 			    RG_LCLDO_DEC_EN_VA32_BIT, 0, NULL, 0),
1132 	SND_SOC_DAPM_SUPPLY("LDO_REMOTE_SENSE", MT6351_AUDDEC_ANA_CON9,
1133 			    RG_LCLDO_DEC_REMOTE_SENSE_VA18_BIT, 0, NULL, 0),
1134 
1135 	/* DAC */
1136 	SND_SOC_DAPM_MUX("DAC In Mux", SND_SOC_NOPM, 0, 0, &dac_in_mux_control),
1137 
1138 	SND_SOC_DAPM_DAC("DACL", NULL, MT6351_AUDDEC_ANA_CON0,
1139 			 RG_AUDDACLPWRUP_VAUDP32_BIT, 0),
1140 	SND_SOC_DAPM_SUPPLY("DACL_BIASGEN", MT6351_AUDDEC_ANA_CON0,
1141 			    RG_AUD_DAC_PWL_UP_VA32_BIT, 0, NULL, 0),
1142 
1143 	SND_SOC_DAPM_DAC("DACR", NULL, MT6351_AUDDEC_ANA_CON0,
1144 			 RG_AUDDACRPWRUP_VAUDP32_BIT, 0),
1145 	SND_SOC_DAPM_SUPPLY("DACR_BIASGEN", MT6351_AUDDEC_ANA_CON0,
1146 			    RG_AUD_DAC_PWR_UP_VA32_BIT, 0, NULL, 0),
1147 	/* LOL */
1148 	SND_SOC_DAPM_MUX("LOL Mux", SND_SOC_NOPM, 0, 0, &lo_in_mux_control),
1149 
1150 	SND_SOC_DAPM_SUPPLY("LO Stability Enh", MT6351_AUDDEC_ANA_CON3,
1151 			    RG_LOOUTPUTSTBENH_VAUDP32_BIT, 0, NULL, 0),
1152 	SND_SOC_DAPM_SUPPLY("LOL Bias Gen", MT6351_AUDDEC_ANA_CON6,
1153 			    RG_ABIDEC_RSVD0_VAUDP32_LOL_BIT, 0, NULL, 0),
1154 
1155 	SND_SOC_DAPM_OUT_DRV("LOL Buffer", MT6351_AUDDEC_ANA_CON3,
1156 			     RG_AUDLOLPWRUP_VAUDP32_BIT, 0, NULL, 0),
1157 
1158 	/* Headphone */
1159 	SND_SOC_DAPM_MUX("HPL Mux", SND_SOC_NOPM, 0, 0, &hpl_in_mux_control),
1160 	SND_SOC_DAPM_MUX("HPR Mux", SND_SOC_NOPM, 0, 0, &hpr_in_mux_control),
1161 
1162 	SND_SOC_DAPM_OUT_DRV_E("HPL Power", MT6351_AUDDEC_ANA_CON0,
1163 			       RG_AUDHPLPWRUP_VAUDP32_BIT, 0, NULL, 0,
1164 			       mt_hp_event,
1165 			       SND_SOC_DAPM_PRE_PMU |
1166 			       SND_SOC_DAPM_PRE_PMD |
1167 			       SND_SOC_DAPM_POST_PMD),
1168 	SND_SOC_DAPM_OUT_DRV_E("HPR Power", MT6351_AUDDEC_ANA_CON0,
1169 			       RG_AUDHPRPWRUP_VAUDP32_BIT, 0, NULL, 0,
1170 			       mt_hp_event,
1171 			       SND_SOC_DAPM_PRE_PMU |
1172 			       SND_SOC_DAPM_PRE_PMD |
1173 			       SND_SOC_DAPM_POST_PMD),
1174 
1175 	/* Receiver */
1176 	SND_SOC_DAPM_MUX("RCV Mux", SND_SOC_NOPM, 0, 0, &rcv_in_mux_control),
1177 
1178 	SND_SOC_DAPM_SUPPLY("RCV Stability Enh", MT6351_AUDDEC_ANA_CON1,
1179 			    RG_HSOUTPUTSTBENH_VAUDP32_BIT, 0, NULL, 0),
1180 	SND_SOC_DAPM_SUPPLY("RCV Bias Gen", MT6351_AUDDEC_ANA_CON6,
1181 			    RG_ABIDEC_RSVD0_VAUDP32_HS_BIT, 0, NULL, 0),
1182 
1183 	SND_SOC_DAPM_OUT_DRV("RCV Buffer", MT6351_AUDDEC_ANA_CON0,
1184 			     RG_AUDHSPWRUP_VAUDP32_BIT, 0, NULL, 0),
1185 
1186 	/* Outputs */
1187 	SND_SOC_DAPM_OUTPUT("Receiver"),
1188 	SND_SOC_DAPM_OUTPUT("Headphone L"),
1189 	SND_SOC_DAPM_OUTPUT("Headphone R"),
1190 	SND_SOC_DAPM_OUTPUT("LINEOUT L"),
1191 
1192 	/* SGEN */
1193 	SND_SOC_DAPM_SUPPLY("SGEN DL Enable", MT6351_AFE_SGEN_CFG0,
1194 			    SGEN_C_DAC_EN_CTL_BIT, 0, NULL, 0),
1195 	SND_SOC_DAPM_SUPPLY("SGEN MUTE", MT6351_AFE_SGEN_CFG0,
1196 			    SGEN_C_MUTE_SW_CTL_BIT, 1,
1197 			    mt_sgen_event, SND_SOC_DAPM_PRE_PMU),
1198 	SND_SOC_DAPM_SUPPLY("SGEN DL SRC", MT6351_AFE_DL_SRC2_CON0_L,
1199 			    RG_DL_2_SRC_ON_TMP_CTL_PRE_BIT, 0, NULL, 0),
1200 
1201 	SND_SOC_DAPM_INPUT("SGEN DL"),
1202 
1203 	/* Uplinks */
1204 	SND_SOC_DAPM_AIF_OUT_E("AIF1TX", "AIF1 Capture", 0,
1205 			       MT6351_AFE_UL_SRC_CON0_L,
1206 			       UL_SRC_ON_TMP_CTL, 0,
1207 			       mt_aif_out_event,
1208 			       SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_PRE_PMD),
1209 
1210 	SND_SOC_DAPM_SUPPLY_S("VUSB33_LDO", SUPPLY_SUBSEQ_ENABLE,
1211 			      MT6351_LDO_VUSB33_CON0, RG_VUSB33_EN, 0,
1212 			      NULL, 0),
1213 	SND_SOC_DAPM_SUPPLY_S("VUSB33_LDO_CTRL", SUPPLY_SUBSEQ_SETTING,
1214 			      MT6351_LDO_VUSB33_CON0, RG_VUSB33_ON_CTRL, 1,
1215 			      NULL, 0),
1216 
1217 	SND_SOC_DAPM_SUPPLY_S("VA18_LDO", SUPPLY_SUBSEQ_ENABLE,
1218 			      MT6351_LDO_VA18_CON0, RG_VA18_EN, 0, NULL, 0),
1219 	SND_SOC_DAPM_SUPPLY_S("VA18_LDO_CTRL", SUPPLY_SUBSEQ_SETTING,
1220 			      MT6351_LDO_VA18_CON0, RG_VA18_ON_CTRL, 1,
1221 			      NULL, 0),
1222 
1223 	SND_SOC_DAPM_SUPPLY_S("ADC CLKGEN", SUPPLY_SUBSEQ_ENABLE,
1224 			      MT6351_AUDENC_ANA_CON3, RG_AUDADCCLKRSTB, 0,
1225 			      mt_adc_clkgen_event,
1226 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1227 
1228 	/* Uplinks MUX */
1229 	SND_SOC_DAPM_MUX("AIF Out Mux", SND_SOC_NOPM, 0, 0,
1230 			 &aif_out_mux_control),
1231 
1232 	SND_SOC_DAPM_MUX("ADC L Mux", SND_SOC_NOPM, 0, 0,
1233 			 &adc_left_mux_control),
1234 	SND_SOC_DAPM_MUX("ADC R Mux", SND_SOC_NOPM, 0, 0,
1235 			 &adc_right_mux_control),
1236 
1237 	SND_SOC_DAPM_ADC("ADC L", NULL,
1238 			 MT6351_AUDENC_ANA_CON0, RG_AUDADCLPWRUP, 0),
1239 	SND_SOC_DAPM_ADC("ADC R", NULL,
1240 			 MT6351_AUDENC_ANA_CON1, RG_AUDADCRPWRUP, 0),
1241 
1242 	SND_SOC_DAPM_MUX("PGA L Mux", SND_SOC_NOPM, 0, 0,
1243 			 &pga_left_mux_control),
1244 	SND_SOC_DAPM_MUX("PGA R Mux", SND_SOC_NOPM, 0, 0,
1245 			 &pga_right_mux_control),
1246 
1247 	SND_SOC_DAPM_PGA_E("PGA L", MT6351_AUDENC_ANA_CON0, RG_AUDPREAMPLON, 0,
1248 			   NULL, 0,
1249 			   mt_pga_left_event,
1250 			   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1251 	SND_SOC_DAPM_PGA_E("PGA R", MT6351_AUDENC_ANA_CON1, RG_AUDPREAMPRON, 0,
1252 			   NULL, 0,
1253 			   mt_pga_right_event,
1254 			   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1255 
1256 	/* main mic mic bias */
1257 	SND_SOC_DAPM_SUPPLY_S("Mic Bias 0", SUPPLY_SUBSEQ_MICBIAS,
1258 			      MT6351_AUDENC_ANA_CON9, RG_AUDPWDBMICBIAS0, 0,
1259 			      mt_mic_bias_0_event,
1260 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
1261 	/* ref mic mic bias */
1262 	SND_SOC_DAPM_SUPPLY_S("Mic Bias 2", SUPPLY_SUBSEQ_MICBIAS,
1263 			      MT6351_AUDENC_ANA_CON9, RG_AUDPWDBMICBIAS2, 0,
1264 			      mt_mic_bias_2_event,
1265 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
1266 	/* headset mic1/2 mic bias */
1267 	SND_SOC_DAPM_SUPPLY_S("Mic Bias 1", SUPPLY_SUBSEQ_MICBIAS,
1268 			      MT6351_AUDENC_ANA_CON10, RG_AUDPWDBMICBIAS1, 0,
1269 			      mt_mic_bias_1_event,
1270 			      SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
1271 	SND_SOC_DAPM_SUPPLY_S("Mic Bias 1 DCC pull high", SUPPLY_SUBSEQ_MICBIAS,
1272 			      MT6351_AUDENC_ANA_CON10,
1273 			      RG_AUDMICBIAS1DCSW1NEN, 0,
1274 			      NULL, 0),
1275 
1276 	/* UL input */
1277 	SND_SOC_DAPM_INPUT("AIN0"),
1278 	SND_SOC_DAPM_INPUT("AIN1"),
1279 	SND_SOC_DAPM_INPUT("AIN2"),
1280 	SND_SOC_DAPM_INPUT("AIN3"),
1281 };
1282 
1283 static const struct snd_soc_dapm_route mt6351_dapm_routes[] = {
1284 	/* Capture */
1285 	{"AIF1TX", NULL, "AIF Out Mux"},
1286 	{"AIF1TX", NULL, "VUSB33_LDO"},
1287 	{"VUSB33_LDO", NULL, "VUSB33_LDO_CTRL"},
1288 	{"AIF1TX", NULL, "VA18_LDO"},
1289 	{"VA18_LDO", NULL, "VA18_LDO_CTRL"},
1290 
1291 	{"AIF1TX", NULL, "AUDGLB"},
1292 	{"AIF1TX", NULL, "CLKSQ Audio"},
1293 
1294 	{"AIF1TX", NULL, "AFE_ON"},
1295 
1296 	{"AIF1TX", NULL, "AUDIO_TOP_AFE_CTL"},
1297 	{"AIF1TX", NULL, "AUDIO_TOP_ADC_CTL"},
1298 	{"AIF1TX", NULL, "AUDIO_TOP_PWR_CLK"},
1299 	{"AIF1TX", NULL, "AUDIO_TOP_PDN_RESERVED"},
1300 
1301 	{"AIF Out Mux", "Normal Path", "ADC L"},
1302 	{"AIF Out Mux", "Normal Path", "ADC R"},
1303 
1304 	{"ADC L", NULL, "ADC L Mux"},
1305 	{"ADC L", NULL, "AUD_CK"},
1306 	{"ADC L", NULL, "AUDIF_CK"},
1307 	{"ADC L", NULL, "ADC CLKGEN"},
1308 	{"ADC R", NULL, "ADC R Mux"},
1309 	{"ADC R", NULL, "AUD_CK"},
1310 	{"ADC R", NULL, "AUDIF_CK"},
1311 	{"ADC R", NULL, "ADC CLKGEN"},
1312 
1313 	{"ADC L Mux", "AIN0", "AIN0"},
1314 	{"ADC L Mux", "Left Preamplifier", "PGA L"},
1315 
1316 	{"ADC R Mux", "AIN0", "AIN0"},
1317 	{"ADC R Mux", "Right Preamplifier", "PGA R"},
1318 
1319 	{"PGA L", NULL, "PGA L Mux"},
1320 	{"PGA R", NULL, "PGA R Mux"},
1321 
1322 	{"PGA L Mux", "AIN0", "AIN0"},
1323 	{"PGA L Mux", "AIN1", "AIN1"},
1324 	{"PGA L Mux", "AIN2", "AIN2"},
1325 
1326 	{"PGA R Mux", "AIN0", "AIN0"},
1327 	{"PGA R Mux", "AIN3", "AIN3"},
1328 	{"PGA R Mux", "AIN2", "AIN2"},
1329 
1330 	{"AIN0", NULL, "Mic Bias 0"},
1331 	{"AIN2", NULL, "Mic Bias 2"},
1332 
1333 	{"AIN1", NULL, "Mic Bias 1"},
1334 	{"AIN1", NULL, "Mic Bias 1 DCC pull high"},
1335 
1336 	/* DL Supply */
1337 	{"DL Power Supply", NULL, "AUDGLB"},
1338 	{"DL Power Supply", NULL, "CLKSQ Audio"},
1339 	{"DL Power Supply", NULL, "ZCD13M_CK"},
1340 	{"DL Power Supply", NULL, "AUD_CK"},
1341 	{"DL Power Supply", NULL, "AUDIF_CK"},
1342 	{"DL Power Supply", NULL, "AUDNCP_CK"},
1343 
1344 	{"DL Power Supply", NULL, "NV Regulator"},
1345 	{"DL Power Supply", NULL, "AUD_CLK"},
1346 	{"DL Power Supply", NULL, "IBIST"},
1347 	{"DL Power Supply", NULL, "LDO"},
1348 	{"LDO", NULL, "LDO_REMOTE_SENSE"},
1349 
1350 	/* DL Digital Supply */
1351 	{"DL Digital Clock", NULL, "AUDIO_TOP_AFE_CTL"},
1352 	{"DL Digital Clock", NULL, "AUDIO_TOP_DAC_CTL"},
1353 	{"DL Digital Clock", NULL, "AUDIO_TOP_PWR_CLK"},
1354 	{"DL Digital Clock", NULL, "AUDIO_TOP_PDN_RESERVED"},
1355 	{"DL Digital Clock", NULL, "NCP"},
1356 	{"DL Digital Clock", NULL, "AFE_ON"},
1357 
1358 	{"AIF_RX", NULL, "DL Digital Clock"},
1359 
1360 	/* DL Path */
1361 	{"DAC In Mux", "Normal Path", "AIF_RX"},
1362 
1363 	{"DAC In Mux", "Sgen", "SGEN DL"},
1364 	{"SGEN DL", NULL, "SGEN DL SRC"},
1365 	{"SGEN DL", NULL, "SGEN MUTE"},
1366 	{"SGEN DL", NULL, "SGEN DL Enable"},
1367 	{"SGEN DL", NULL, "DL Digital Clock"},
1368 
1369 	{"DACL", NULL, "DAC In Mux"},
1370 	{"DACL", NULL, "DL Power Supply"},
1371 	{"DACL", NULL, "DACL_BIASGEN"},
1372 
1373 	{"DACR", NULL, "DAC In Mux"},
1374 	{"DACR", NULL, "DL Power Supply"},
1375 	{"DACR", NULL, "DACR_BIASGEN"},
1376 
1377 	{"LOL Mux", "Playback", "DACL"},
1378 
1379 	{"LOL Buffer", NULL, "LOL Mux"},
1380 	{"LOL Buffer", NULL, "LO Stability Enh"},
1381 	{"LOL Buffer", NULL, "LOL Bias Gen"},
1382 
1383 	{"LINEOUT L", NULL, "LOL Buffer"},
1384 
1385 	/* Headphone Path */
1386 	{"HPL Mux", "Audio Playback", "DACL"},
1387 	{"HPR Mux", "Audio Playback", "DACR"},
1388 
1389 	{"HPL Mux", "LoudSPK Playback", "DACL"},
1390 	{"HPR Mux", "LoudSPK Playback", "DACR"},
1391 
1392 	{"HPL Power", NULL, "HPL Mux"},
1393 	{"HPR Power", NULL, "HPR Mux"},
1394 
1395 	{"Headphone L", NULL, "HPL Power"},
1396 	{"Headphone R", NULL, "HPR Power"},
1397 
1398 	/* Receiver Path */
1399 	{"RCV Mux", "Voice Playback", "DACL"},
1400 
1401 	{"RCV Buffer", NULL, "RCV Mux"},
1402 	{"RCV Buffer", NULL, "RCV Stability Enh"},
1403 	{"RCV Buffer", NULL, "RCV Bias Gen"},
1404 
1405 	{"Receiver", NULL, "RCV Buffer"},
1406 };
1407 
mt6351_codec_init_reg(struct snd_soc_component * cmpnt)1408 static int mt6351_codec_init_reg(struct snd_soc_component *cmpnt)
1409 {
1410 	/* Disable CLKSQ 26MHz */
1411 	regmap_update_bits(cmpnt->regmap, MT6351_TOP_CLKSQ, 0x0001, 0x0);
1412 	/* disable AUDGLB */
1413 	regmap_update_bits(cmpnt->regmap, MT6351_AUDDEC_ANA_CON9,
1414 			   0x1000, 0x1000);
1415 	/* Turn off AUDNCP_CLKDIV engine clock,Turn off AUD 26M */
1416 	regmap_update_bits(cmpnt->regmap, MT6351_TOP_CKPDN_CON0_SET,
1417 			   0x3800, 0x3800);
1418 	/* Disable HeadphoneL/HeadphoneR/voice short circuit protection */
1419 	regmap_update_bits(cmpnt->regmap, MT6351_AUDDEC_ANA_CON0,
1420 			   0xe000, 0xe000);
1421 	/* [5] = 1, disable LO buffer left short circuit protection */
1422 	regmap_update_bits(cmpnt->regmap, MT6351_AUDDEC_ANA_CON3,
1423 			   0x20, 0x20);
1424 	/* Reverse the PMIC clock*/
1425 	regmap_update_bits(cmpnt->regmap, MT6351_AFE_PMIC_NEWIF_CFG2,
1426 			   0x8000, 0x8000);
1427 	return 0;
1428 }
1429 
mt6351_codec_probe(struct snd_soc_component * cmpnt)1430 static int mt6351_codec_probe(struct snd_soc_component *cmpnt)
1431 {
1432 	struct mt6351_priv *priv = snd_soc_component_get_drvdata(cmpnt);
1433 
1434 	snd_soc_component_init_regmap(cmpnt, priv->regmap);
1435 
1436 	mt6351_codec_init_reg(cmpnt);
1437 	return 0;
1438 }
1439 
1440 static const struct snd_soc_component_driver mt6351_soc_component_driver = {
1441 	.probe = mt6351_codec_probe,
1442 	.controls = mt6351_snd_controls,
1443 	.num_controls = ARRAY_SIZE(mt6351_snd_controls),
1444 	.dapm_widgets = mt6351_dapm_widgets,
1445 	.num_dapm_widgets = ARRAY_SIZE(mt6351_dapm_widgets),
1446 	.dapm_routes = mt6351_dapm_routes,
1447 	.num_dapm_routes = ARRAY_SIZE(mt6351_dapm_routes),
1448 	.endianness = 1,
1449 };
1450 
mt6351_codec_driver_probe(struct platform_device * pdev)1451 static int mt6351_codec_driver_probe(struct platform_device *pdev)
1452 {
1453 	struct mt6351_priv *priv;
1454 
1455 	priv = devm_kzalloc(&pdev->dev,
1456 			    sizeof(struct mt6351_priv),
1457 			    GFP_KERNEL);
1458 	if (!priv)
1459 		return -ENOMEM;
1460 
1461 	dev_set_drvdata(&pdev->dev, priv);
1462 
1463 	priv->dev = &pdev->dev;
1464 
1465 	priv->regmap = dev_get_regmap(pdev->dev.parent, NULL);
1466 	if (!priv->regmap)
1467 		return -ENODEV;
1468 
1469 	dev_dbg(priv->dev, "%s(), dev name %s\n",
1470 		__func__, dev_name(&pdev->dev));
1471 
1472 	return devm_snd_soc_register_component(&pdev->dev,
1473 					       &mt6351_soc_component_driver,
1474 					       mt6351_dai_driver,
1475 					       ARRAY_SIZE(mt6351_dai_driver));
1476 }
1477 
1478 static const struct of_device_id mt6351_of_match[] = {
1479 	{.compatible = "mediatek,mt6351-sound",},
1480 	{}
1481 };
1482 
1483 static struct platform_driver mt6351_codec_driver = {
1484 	.driver = {
1485 		.name = "mt6351-sound",
1486 		.of_match_table = mt6351_of_match,
1487 	},
1488 	.probe = mt6351_codec_driver_probe,
1489 };
1490 
1491 module_platform_driver(mt6351_codec_driver)
1492 
1493 /* Module information */
1494 MODULE_DESCRIPTION("MT6351 ALSA SoC codec driver");
1495 MODULE_AUTHOR("KaiChieh Chuang <kaichieh.chuang@mediatek.com>");
1496 MODULE_LICENSE("GPL v2");
1497