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