blob: 4c866135e40fcce0b843bb53ad5fc58678a6c3f7 [file] [log] [blame]
Bard Liao997b0522013-06-11 13:10:16 +08001/*
2 * rt5640.c -- RT5640 ALSA SoC audio codec driver
3 *
4 * Copyright 2011 Realtek Semiconductor Corp.
5 * Author: Johnny Hsu <johnnyhsu@realtek.com>
6 * Copyright (c) 2013, NVIDIA CORPORATION. All rights reserved.
7 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License version 2 as
10 * published by the Free Software Foundation.
11 */
12
13#include <linux/module.h>
14#include <linux/moduleparam.h>
15#include <linux/init.h>
16#include <linux/delay.h>
17#include <linux/pm.h>
18#include <linux/gpio.h>
19#include <linux/i2c.h>
20#include <linux/regmap.h>
Stephen Warrendcad9f02013-06-12 11:34:30 -060021#include <linux/of_gpio.h>
Bard Liao997b0522013-06-11 13:10:16 +080022#include <linux/platform_device.h>
23#include <linux/spi/spi.h>
Liam Girdwood02b80772013-09-13 17:57:36 +010024#include <linux/acpi.h>
Bard Liao997b0522013-06-11 13:10:16 +080025#include <sound/core.h>
26#include <sound/pcm.h>
27#include <sound/pcm_params.h>
28#include <sound/soc.h>
29#include <sound/soc-dapm.h>
30#include <sound/initval.h>
31#include <sound/tlv.h>
32
33#include "rt5640.h"
34
35#define RT5640_DEVICE_ID 0x6231
36
37#define RT5640_PR_RANGE_BASE (0xff + 1)
38#define RT5640_PR_SPACING 0x100
39
40#define RT5640_PR_BASE (RT5640_PR_RANGE_BASE + (0 * RT5640_PR_SPACING))
41
42static const struct regmap_range_cfg rt5640_ranges[] = {
43 { .name = "PR", .range_min = RT5640_PR_BASE,
44 .range_max = RT5640_PR_BASE + 0xb4,
45 .selector_reg = RT5640_PRIV_INDEX,
46 .selector_mask = 0xff,
47 .selector_shift = 0x0,
48 .window_start = RT5640_PRIV_DATA,
49 .window_len = 0x1, },
50};
51
52static struct reg_default init_list[] = {
53 {RT5640_PR_BASE + 0x3d, 0x3600},
Bard Liao997b0522013-06-11 13:10:16 +080054 {RT5640_PR_BASE + 0x12, 0x0aa8},
55 {RT5640_PR_BASE + 0x14, 0x0aaa},
56 {RT5640_PR_BASE + 0x20, 0x6110},
57 {RT5640_PR_BASE + 0x21, 0xe0e0},
58 {RT5640_PR_BASE + 0x23, 0x1804},
59};
60#define RT5640_INIT_REG_LEN ARRAY_SIZE(init_list)
61
Oder Chiou2f2a7142014-03-28 20:28:25 +080062static const struct reg_default rt5640_reg[] = {
Bard Liao997b0522013-06-11 13:10:16 +080063 { 0x00, 0x000e },
64 { 0x01, 0xc8c8 },
65 { 0x02, 0xc8c8 },
66 { 0x03, 0xc8c8 },
67 { 0x04, 0x8000 },
68 { 0x0d, 0x0000 },
69 { 0x0e, 0x0000 },
70 { 0x0f, 0x0808 },
71 { 0x19, 0xafaf },
72 { 0x1a, 0xafaf },
73 { 0x1b, 0x0000 },
74 { 0x1c, 0x2f2f },
75 { 0x1d, 0x2f2f },
76 { 0x1e, 0x0000 },
77 { 0x27, 0x7060 },
78 { 0x28, 0x7070 },
79 { 0x29, 0x8080 },
80 { 0x2a, 0x5454 },
81 { 0x2b, 0x5454 },
82 { 0x2c, 0xaa00 },
83 { 0x2d, 0x0000 },
84 { 0x2e, 0xa000 },
85 { 0x2f, 0x0000 },
86 { 0x3b, 0x0000 },
87 { 0x3c, 0x007f },
88 { 0x3d, 0x0000 },
89 { 0x3e, 0x007f },
90 { 0x45, 0xe000 },
91 { 0x46, 0x003e },
92 { 0x47, 0x003e },
93 { 0x48, 0xf800 },
94 { 0x49, 0x3800 },
95 { 0x4a, 0x0004 },
96 { 0x4c, 0xfc00 },
97 { 0x4d, 0x0000 },
98 { 0x4f, 0x01ff },
99 { 0x50, 0x0000 },
100 { 0x51, 0x0000 },
101 { 0x52, 0x01ff },
102 { 0x53, 0xf000 },
103 { 0x61, 0x0000 },
104 { 0x62, 0x0000 },
105 { 0x63, 0x00c0 },
106 { 0x64, 0x0000 },
107 { 0x65, 0x0000 },
108 { 0x66, 0x0000 },
109 { 0x6a, 0x0000 },
110 { 0x6c, 0x0000 },
111 { 0x70, 0x8000 },
112 { 0x71, 0x8000 },
113 { 0x72, 0x8000 },
114 { 0x73, 0x1114 },
115 { 0x74, 0x0c00 },
116 { 0x75, 0x1d00 },
117 { 0x80, 0x0000 },
118 { 0x81, 0x0000 },
119 { 0x82, 0x0000 },
120 { 0x83, 0x0000 },
121 { 0x84, 0x0000 },
122 { 0x85, 0x0008 },
123 { 0x89, 0x0000 },
124 { 0x8a, 0x0000 },
125 { 0x8b, 0x0600 },
126 { 0x8c, 0x0228 },
127 { 0x8d, 0xa000 },
128 { 0x8e, 0x0004 },
129 { 0x8f, 0x1100 },
130 { 0x90, 0x0646 },
131 { 0x91, 0x0c00 },
132 { 0x92, 0x0000 },
133 { 0x93, 0x3000 },
134 { 0xb0, 0x2080 },
135 { 0xb1, 0x0000 },
136 { 0xb4, 0x2206 },
137 { 0xb5, 0x1f00 },
138 { 0xb6, 0x0000 },
139 { 0xb8, 0x034b },
140 { 0xb9, 0x0066 },
141 { 0xba, 0x000b },
142 { 0xbb, 0x0000 },
143 { 0xbc, 0x0000 },
144 { 0xbd, 0x0000 },
145 { 0xbe, 0x0000 },
146 { 0xbf, 0x0000 },
147 { 0xc0, 0x0400 },
148 { 0xc2, 0x0000 },
149 { 0xc4, 0x0000 },
150 { 0xc5, 0x0000 },
151 { 0xc6, 0x2000 },
152 { 0xc8, 0x0000 },
153 { 0xc9, 0x0000 },
154 { 0xca, 0x0000 },
155 { 0xcb, 0x0000 },
156 { 0xcc, 0x0000 },
157 { 0xcf, 0x0013 },
158 { 0xd0, 0x0680 },
159 { 0xd1, 0x1c17 },
160 { 0xd2, 0x8c00 },
161 { 0xd3, 0xaa20 },
162 { 0xd6, 0x0400 },
163 { 0xd9, 0x0809 },
164 { 0xfe, 0x10ec },
165 { 0xff, 0x6231 },
166};
167
168static int rt5640_reset(struct snd_soc_codec *codec)
169{
170 return snd_soc_write(codec, RT5640_RESET, 0);
171}
172
173static bool rt5640_volatile_register(struct device *dev, unsigned int reg)
174{
175 int i;
176
177 for (i = 0; i < ARRAY_SIZE(rt5640_ranges); i++)
178 if ((reg >= rt5640_ranges[i].window_start &&
179 reg <= rt5640_ranges[i].window_start +
180 rt5640_ranges[i].window_len) ||
181 (reg >= rt5640_ranges[i].range_min &&
182 reg <= rt5640_ranges[i].range_max))
183 return true;
184
185 switch (reg) {
186 case RT5640_RESET:
187 case RT5640_ASRC_5:
188 case RT5640_EQ_CTRL1:
189 case RT5640_DRC_AGC_1:
190 case RT5640_ANC_CTRL1:
191 case RT5640_IRQ_CTRL2:
192 case RT5640_INT_IRQ_ST:
193 case RT5640_DSP_CTRL2:
194 case RT5640_DSP_CTRL3:
195 case RT5640_PRIV_INDEX:
196 case RT5640_PRIV_DATA:
197 case RT5640_PGM_REG_ARR1:
198 case RT5640_PGM_REG_ARR3:
199 case RT5640_VENDOR_ID:
200 case RT5640_VENDOR_ID1:
201 case RT5640_VENDOR_ID2:
202 return true;
203 default:
204 return false;
205 }
206}
207
208static bool rt5640_readable_register(struct device *dev, unsigned int reg)
209{
210 int i;
211
212 for (i = 0; i < ARRAY_SIZE(rt5640_ranges); i++)
213 if ((reg >= rt5640_ranges[i].window_start &&
214 reg <= rt5640_ranges[i].window_start +
215 rt5640_ranges[i].window_len) ||
216 (reg >= rt5640_ranges[i].range_min &&
217 reg <= rt5640_ranges[i].range_max))
218 return true;
219
220 switch (reg) {
221 case RT5640_RESET:
222 case RT5640_SPK_VOL:
223 case RT5640_HP_VOL:
224 case RT5640_OUTPUT:
225 case RT5640_MONO_OUT:
226 case RT5640_IN1_IN2:
227 case RT5640_IN3_IN4:
228 case RT5640_INL_INR_VOL:
229 case RT5640_DAC1_DIG_VOL:
230 case RT5640_DAC2_DIG_VOL:
231 case RT5640_DAC2_CTRL:
232 case RT5640_ADC_DIG_VOL:
233 case RT5640_ADC_DATA:
234 case RT5640_ADC_BST_VOL:
235 case RT5640_STO_ADC_MIXER:
236 case RT5640_MONO_ADC_MIXER:
237 case RT5640_AD_DA_MIXER:
238 case RT5640_STO_DAC_MIXER:
239 case RT5640_MONO_DAC_MIXER:
240 case RT5640_DIG_MIXER:
241 case RT5640_DSP_PATH1:
242 case RT5640_DSP_PATH2:
243 case RT5640_DIG_INF_DATA:
244 case RT5640_REC_L1_MIXER:
245 case RT5640_REC_L2_MIXER:
246 case RT5640_REC_R1_MIXER:
247 case RT5640_REC_R2_MIXER:
248 case RT5640_HPO_MIXER:
249 case RT5640_SPK_L_MIXER:
250 case RT5640_SPK_R_MIXER:
251 case RT5640_SPO_L_MIXER:
252 case RT5640_SPO_R_MIXER:
253 case RT5640_SPO_CLSD_RATIO:
254 case RT5640_MONO_MIXER:
255 case RT5640_OUT_L1_MIXER:
256 case RT5640_OUT_L2_MIXER:
257 case RT5640_OUT_L3_MIXER:
258 case RT5640_OUT_R1_MIXER:
259 case RT5640_OUT_R2_MIXER:
260 case RT5640_OUT_R3_MIXER:
261 case RT5640_LOUT_MIXER:
262 case RT5640_PWR_DIG1:
263 case RT5640_PWR_DIG2:
264 case RT5640_PWR_ANLG1:
265 case RT5640_PWR_ANLG2:
266 case RT5640_PWR_MIXER:
267 case RT5640_PWR_VOL:
268 case RT5640_PRIV_INDEX:
269 case RT5640_PRIV_DATA:
270 case RT5640_I2S1_SDP:
271 case RT5640_I2S2_SDP:
272 case RT5640_ADDA_CLK1:
273 case RT5640_ADDA_CLK2:
274 case RT5640_DMIC:
275 case RT5640_GLB_CLK:
276 case RT5640_PLL_CTRL1:
277 case RT5640_PLL_CTRL2:
278 case RT5640_ASRC_1:
279 case RT5640_ASRC_2:
280 case RT5640_ASRC_3:
281 case RT5640_ASRC_4:
282 case RT5640_ASRC_5:
283 case RT5640_HP_OVCD:
284 case RT5640_CLS_D_OVCD:
285 case RT5640_CLS_D_OUT:
286 case RT5640_DEPOP_M1:
287 case RT5640_DEPOP_M2:
288 case RT5640_DEPOP_M3:
289 case RT5640_CHARGE_PUMP:
290 case RT5640_PV_DET_SPK_G:
291 case RT5640_MICBIAS:
292 case RT5640_EQ_CTRL1:
293 case RT5640_EQ_CTRL2:
294 case RT5640_WIND_FILTER:
295 case RT5640_DRC_AGC_1:
296 case RT5640_DRC_AGC_2:
297 case RT5640_DRC_AGC_3:
298 case RT5640_SVOL_ZC:
299 case RT5640_ANC_CTRL1:
300 case RT5640_ANC_CTRL2:
301 case RT5640_ANC_CTRL3:
302 case RT5640_JD_CTRL:
303 case RT5640_ANC_JD:
304 case RT5640_IRQ_CTRL1:
305 case RT5640_IRQ_CTRL2:
306 case RT5640_INT_IRQ_ST:
307 case RT5640_GPIO_CTRL1:
308 case RT5640_GPIO_CTRL2:
309 case RT5640_GPIO_CTRL3:
310 case RT5640_DSP_CTRL1:
311 case RT5640_DSP_CTRL2:
312 case RT5640_DSP_CTRL3:
313 case RT5640_DSP_CTRL4:
314 case RT5640_PGM_REG_ARR1:
315 case RT5640_PGM_REG_ARR2:
316 case RT5640_PGM_REG_ARR3:
317 case RT5640_PGM_REG_ARR4:
318 case RT5640_PGM_REG_ARR5:
319 case RT5640_SCB_FUNC:
320 case RT5640_SCB_CTRL:
321 case RT5640_BASE_BACK:
322 case RT5640_MP3_PLUS1:
323 case RT5640_MP3_PLUS2:
324 case RT5640_3D_HP:
325 case RT5640_ADJ_HPF:
326 case RT5640_HP_CALIB_AMP_DET:
327 case RT5640_HP_CALIB2:
328 case RT5640_SV_ZCD1:
329 case RT5640_SV_ZCD2:
330 case RT5640_DUMMY1:
331 case RT5640_DUMMY2:
332 case RT5640_DUMMY3:
333 case RT5640_VENDOR_ID:
334 case RT5640_VENDOR_ID1:
335 case RT5640_VENDOR_ID2:
336 return true;
337 default:
338 return false;
339 }
340}
341
342static const DECLARE_TLV_DB_SCALE(out_vol_tlv, -4650, 150, 0);
343static const DECLARE_TLV_DB_SCALE(dac_vol_tlv, -65625, 375, 0);
344static const DECLARE_TLV_DB_SCALE(in_vol_tlv, -3450, 150, 0);
345static const DECLARE_TLV_DB_SCALE(adc_vol_tlv, -17625, 375, 0);
346static const DECLARE_TLV_DB_SCALE(adc_bst_tlv, 0, 1200, 0);
347
348/* {0, +20, +24, +30, +35, +40, +44, +50, +52} dB */
349static unsigned int bst_tlv[] = {
350 TLV_DB_RANGE_HEAD(7),
351 0, 0, TLV_DB_SCALE_ITEM(0, 0, 0),
352 1, 1, TLV_DB_SCALE_ITEM(2000, 0, 0),
353 2, 2, TLV_DB_SCALE_ITEM(2400, 0, 0),
354 3, 5, TLV_DB_SCALE_ITEM(3000, 500, 0),
355 6, 6, TLV_DB_SCALE_ITEM(4400, 0, 0),
356 7, 7, TLV_DB_SCALE_ITEM(5000, 0, 0),
357 8, 8, TLV_DB_SCALE_ITEM(5200, 0, 0),
358};
359
360/* Interface data select */
361static const char * const rt5640_data_select[] = {
362 "Normal", "left copy to right", "right copy to left", "Swap"};
363
Takashi Iwai4c03cb62014-02-18 09:43:21 +0100364static SOC_ENUM_SINGLE_DECL(rt5640_if1_dac_enum, RT5640_DIG_INF_DATA,
365 RT5640_IF1_DAC_SEL_SFT, rt5640_data_select);
Bard Liao997b0522013-06-11 13:10:16 +0800366
Takashi Iwai4c03cb62014-02-18 09:43:21 +0100367static SOC_ENUM_SINGLE_DECL(rt5640_if1_adc_enum, RT5640_DIG_INF_DATA,
368 RT5640_IF1_ADC_SEL_SFT, rt5640_data_select);
Bard Liao997b0522013-06-11 13:10:16 +0800369
Takashi Iwai4c03cb62014-02-18 09:43:21 +0100370static SOC_ENUM_SINGLE_DECL(rt5640_if2_dac_enum, RT5640_DIG_INF_DATA,
371 RT5640_IF2_DAC_SEL_SFT, rt5640_data_select);
Bard Liao997b0522013-06-11 13:10:16 +0800372
Takashi Iwai4c03cb62014-02-18 09:43:21 +0100373static SOC_ENUM_SINGLE_DECL(rt5640_if2_adc_enum, RT5640_DIG_INF_DATA,
374 RT5640_IF2_ADC_SEL_SFT, rt5640_data_select);
Bard Liao997b0522013-06-11 13:10:16 +0800375
376/* Class D speaker gain ratio */
377static const char * const rt5640_clsd_spk_ratio[] = {"1.66x", "1.83x", "1.94x",
378 "2x", "2.11x", "2.22x", "2.33x", "2.44x", "2.55x", "2.66x", "2.77x"};
379
Takashi Iwai4c03cb62014-02-18 09:43:21 +0100380static SOC_ENUM_SINGLE_DECL(rt5640_clsd_spk_ratio_enum, RT5640_CLS_D_OUT,
381 RT5640_CLSD_RATIO_SFT, rt5640_clsd_spk_ratio);
Bard Liao997b0522013-06-11 13:10:16 +0800382
383static const struct snd_kcontrol_new rt5640_snd_controls[] = {
384 /* Speaker Output Volume */
Bard Liao997b0522013-06-11 13:10:16 +0800385 SOC_DOUBLE("Speaker Channel Switch", RT5640_SPK_VOL,
386 RT5640_VOL_L_SFT, RT5640_VOL_R_SFT, 1, 1),
387 SOC_DOUBLE_TLV("Speaker Playback Volume", RT5640_SPK_VOL,
388 RT5640_L_VOL_SFT, RT5640_R_VOL_SFT, 39, 1, out_vol_tlv),
389 /* Headphone Output Volume */
Bard Liao997b0522013-06-11 13:10:16 +0800390 SOC_DOUBLE("HP Channel Switch", RT5640_HP_VOL,
391 RT5640_VOL_L_SFT, RT5640_VOL_R_SFT, 1, 1),
392 SOC_DOUBLE_TLV("HP Playback Volume", RT5640_HP_VOL,
393 RT5640_L_VOL_SFT, RT5640_R_VOL_SFT, 39, 1, out_vol_tlv),
394 /* OUTPUT Control */
395 SOC_DOUBLE("OUT Playback Switch", RT5640_OUTPUT,
396 RT5640_L_MUTE_SFT, RT5640_R_MUTE_SFT, 1, 1),
397 SOC_DOUBLE("OUT Channel Switch", RT5640_OUTPUT,
398 RT5640_VOL_L_SFT, RT5640_VOL_R_SFT, 1, 1),
399 SOC_DOUBLE_TLV("OUT Playback Volume", RT5640_OUTPUT,
400 RT5640_L_VOL_SFT, RT5640_R_VOL_SFT, 39, 1, out_vol_tlv),
401 /* MONO Output Control */
402 SOC_SINGLE("Mono Playback Switch", RT5640_MONO_OUT,
403 RT5640_L_MUTE_SFT, 1, 1),
404 /* DAC Digital Volume */
405 SOC_DOUBLE("DAC2 Playback Switch", RT5640_DAC2_CTRL,
406 RT5640_M_DAC_L2_VOL_SFT, RT5640_M_DAC_R2_VOL_SFT, 1, 1),
407 SOC_DOUBLE_TLV("DAC1 Playback Volume", RT5640_DAC1_DIG_VOL,
408 RT5640_L_VOL_SFT, RT5640_R_VOL_SFT,
409 175, 0, dac_vol_tlv),
410 SOC_DOUBLE_TLV("Mono DAC Playback Volume", RT5640_DAC2_DIG_VOL,
411 RT5640_L_VOL_SFT, RT5640_R_VOL_SFT,
412 175, 0, dac_vol_tlv),
413 /* IN1/IN2 Control */
414 SOC_SINGLE_TLV("IN1 Boost", RT5640_IN1_IN2,
415 RT5640_BST_SFT1, 8, 0, bst_tlv),
416 SOC_SINGLE_TLV("IN2 Boost", RT5640_IN3_IN4,
417 RT5640_BST_SFT2, 8, 0, bst_tlv),
418 /* INL/INR Volume Control */
419 SOC_DOUBLE_TLV("IN Capture Volume", RT5640_INL_INR_VOL,
420 RT5640_INL_VOL_SFT, RT5640_INR_VOL_SFT,
421 31, 1, in_vol_tlv),
422 /* ADC Digital Volume Control */
423 SOC_DOUBLE("ADC Capture Switch", RT5640_ADC_DIG_VOL,
424 RT5640_L_MUTE_SFT, RT5640_R_MUTE_SFT, 1, 1),
425 SOC_DOUBLE_TLV("ADC Capture Volume", RT5640_ADC_DIG_VOL,
426 RT5640_L_VOL_SFT, RT5640_R_VOL_SFT,
427 127, 0, adc_vol_tlv),
428 SOC_DOUBLE_TLV("Mono ADC Capture Volume", RT5640_ADC_DATA,
429 RT5640_L_VOL_SFT, RT5640_R_VOL_SFT,
430 127, 0, adc_vol_tlv),
431 /* ADC Boost Volume Control */
432 SOC_DOUBLE_TLV("ADC Boost Gain", RT5640_ADC_BST_VOL,
433 RT5640_ADC_L_BST_SFT, RT5640_ADC_R_BST_SFT,
434 3, 0, adc_bst_tlv),
435 /* Class D speaker gain ratio */
436 SOC_ENUM("Class D SPK Ratio Control", rt5640_clsd_spk_ratio_enum),
437
438 SOC_ENUM("ADC IF1 Data Switch", rt5640_if1_adc_enum),
439 SOC_ENUM("DAC IF1 Data Switch", rt5640_if1_dac_enum),
440 SOC_ENUM("ADC IF2 Data Switch", rt5640_if2_adc_enum),
441 SOC_ENUM("DAC IF2 Data Switch", rt5640_if2_dac_enum),
442};
443
444/**
445 * set_dmic_clk - Set parameter of dmic.
446 *
447 * @w: DAPM widget.
448 * @kcontrol: The kcontrol of this widget.
449 * @event: Event id.
450 *
451 * Choose dmic clock between 1MHz and 3MHz.
452 * It is better for clock to approximate 3MHz.
453 */
454static int set_dmic_clk(struct snd_soc_dapm_widget *w,
455 struct snd_kcontrol *kcontrol, int event)
456{
457 struct snd_soc_codec *codec = w->codec;
458 struct rt5640_priv *rt5640 = snd_soc_codec_get_drvdata(codec);
459 int div[] = {2, 3, 4, 6, 8, 12};
460 int idx = -EINVAL, i;
461 int rate, red, bound, temp;
462
463 rate = rt5640->sysclk;
464 red = 3000000 * 12;
465 for (i = 0; i < ARRAY_SIZE(div); i++) {
466 bound = div[i] * 3000000;
467 if (rate > bound)
468 continue;
469 temp = bound - rate;
470 if (temp < red) {
471 red = temp;
472 idx = i;
473 }
474 }
475 if (idx < 0)
476 dev_err(codec->dev, "Failed to set DMIC clock\n");
477 else
478 snd_soc_update_bits(codec, RT5640_DMIC, RT5640_DMIC_CLK_MASK,
479 idx << RT5640_DMIC_CLK_SFT);
480 return idx;
481}
482
Oder Chiou218a3f92014-03-28 20:28:26 +0800483static int is_sys_clk_from_pll(struct snd_soc_dapm_widget *source,
Bard Liao997b0522013-06-11 13:10:16 +0800484 struct snd_soc_dapm_widget *sink)
485{
486 unsigned int val;
487
488 val = snd_soc_read(source->codec, RT5640_GLB_CLK);
489 val &= RT5640_SCLK_SRC_MASK;
Oder Chiouacf04e62014-03-28 20:28:27 +0800490 if (val == RT5640_SCLK_SRC_PLL1)
Bard Liao997b0522013-06-11 13:10:16 +0800491 return 1;
492 else
493 return 0;
494}
495
496/* Digital Mixer */
497static const struct snd_kcontrol_new rt5640_sto_adc_l_mix[] = {
498 SOC_DAPM_SINGLE("ADC1 Switch", RT5640_STO_ADC_MIXER,
499 RT5640_M_ADC_L1_SFT, 1, 1),
500 SOC_DAPM_SINGLE("ADC2 Switch", RT5640_STO_ADC_MIXER,
501 RT5640_M_ADC_L2_SFT, 1, 1),
502};
503
504static const struct snd_kcontrol_new rt5640_sto_adc_r_mix[] = {
505 SOC_DAPM_SINGLE("ADC1 Switch", RT5640_STO_ADC_MIXER,
506 RT5640_M_ADC_R1_SFT, 1, 1),
507 SOC_DAPM_SINGLE("ADC2 Switch", RT5640_STO_ADC_MIXER,
508 RT5640_M_ADC_R2_SFT, 1, 1),
509};
510
511static const struct snd_kcontrol_new rt5640_mono_adc_l_mix[] = {
512 SOC_DAPM_SINGLE("ADC1 Switch", RT5640_MONO_ADC_MIXER,
513 RT5640_M_MONO_ADC_L1_SFT, 1, 1),
514 SOC_DAPM_SINGLE("ADC2 Switch", RT5640_MONO_ADC_MIXER,
515 RT5640_M_MONO_ADC_L2_SFT, 1, 1),
516};
517
518static const struct snd_kcontrol_new rt5640_mono_adc_r_mix[] = {
519 SOC_DAPM_SINGLE("ADC1 Switch", RT5640_MONO_ADC_MIXER,
520 RT5640_M_MONO_ADC_R1_SFT, 1, 1),
521 SOC_DAPM_SINGLE("ADC2 Switch", RT5640_MONO_ADC_MIXER,
522 RT5640_M_MONO_ADC_R2_SFT, 1, 1),
523};
524
525static const struct snd_kcontrol_new rt5640_dac_l_mix[] = {
526 SOC_DAPM_SINGLE("Stereo ADC Switch", RT5640_AD_DA_MIXER,
527 RT5640_M_ADCMIX_L_SFT, 1, 1),
528 SOC_DAPM_SINGLE("INF1 Switch", RT5640_AD_DA_MIXER,
529 RT5640_M_IF1_DAC_L_SFT, 1, 1),
530};
531
532static const struct snd_kcontrol_new rt5640_dac_r_mix[] = {
533 SOC_DAPM_SINGLE("Stereo ADC Switch", RT5640_AD_DA_MIXER,
534 RT5640_M_ADCMIX_R_SFT, 1, 1),
535 SOC_DAPM_SINGLE("INF1 Switch", RT5640_AD_DA_MIXER,
536 RT5640_M_IF1_DAC_R_SFT, 1, 1),
537};
538
539static const struct snd_kcontrol_new rt5640_sto_dac_l_mix[] = {
540 SOC_DAPM_SINGLE("DAC L1 Switch", RT5640_STO_DAC_MIXER,
541 RT5640_M_DAC_L1_SFT, 1, 1),
542 SOC_DAPM_SINGLE("DAC L2 Switch", RT5640_STO_DAC_MIXER,
543 RT5640_M_DAC_L2_SFT, 1, 1),
544 SOC_DAPM_SINGLE("ANC Switch", RT5640_STO_DAC_MIXER,
545 RT5640_M_ANC_DAC_L_SFT, 1, 1),
546};
547
548static const struct snd_kcontrol_new rt5640_sto_dac_r_mix[] = {
549 SOC_DAPM_SINGLE("DAC R1 Switch", RT5640_STO_DAC_MIXER,
550 RT5640_M_DAC_R1_SFT, 1, 1),
551 SOC_DAPM_SINGLE("DAC R2 Switch", RT5640_STO_DAC_MIXER,
552 RT5640_M_DAC_R2_SFT, 1, 1),
553 SOC_DAPM_SINGLE("ANC Switch", RT5640_STO_DAC_MIXER,
554 RT5640_M_ANC_DAC_R_SFT, 1, 1),
555};
556
557static const struct snd_kcontrol_new rt5640_mono_dac_l_mix[] = {
558 SOC_DAPM_SINGLE("DAC L1 Switch", RT5640_MONO_DAC_MIXER,
559 RT5640_M_DAC_L1_MONO_L_SFT, 1, 1),
560 SOC_DAPM_SINGLE("DAC L2 Switch", RT5640_MONO_DAC_MIXER,
561 RT5640_M_DAC_L2_MONO_L_SFT, 1, 1),
562 SOC_DAPM_SINGLE("DAC R2 Switch", RT5640_MONO_DAC_MIXER,
563 RT5640_M_DAC_R2_MONO_L_SFT, 1, 1),
564};
565
566static const struct snd_kcontrol_new rt5640_mono_dac_r_mix[] = {
567 SOC_DAPM_SINGLE("DAC R1 Switch", RT5640_MONO_DAC_MIXER,
568 RT5640_M_DAC_R1_MONO_R_SFT, 1, 1),
569 SOC_DAPM_SINGLE("DAC R2 Switch", RT5640_MONO_DAC_MIXER,
570 RT5640_M_DAC_R2_MONO_R_SFT, 1, 1),
571 SOC_DAPM_SINGLE("DAC L2 Switch", RT5640_MONO_DAC_MIXER,
572 RT5640_M_DAC_L2_MONO_R_SFT, 1, 1),
573};
574
575static const struct snd_kcontrol_new rt5640_dig_l_mix[] = {
576 SOC_DAPM_SINGLE("DAC L1 Switch", RT5640_DIG_MIXER,
577 RT5640_M_STO_L_DAC_L_SFT, 1, 1),
578 SOC_DAPM_SINGLE("DAC L2 Switch", RT5640_DIG_MIXER,
579 RT5640_M_DAC_L2_DAC_L_SFT, 1, 1),
580};
581
582static const struct snd_kcontrol_new rt5640_dig_r_mix[] = {
583 SOC_DAPM_SINGLE("DAC R1 Switch", RT5640_DIG_MIXER,
584 RT5640_M_STO_R_DAC_R_SFT, 1, 1),
585 SOC_DAPM_SINGLE("DAC R2 Switch", RT5640_DIG_MIXER,
586 RT5640_M_DAC_R2_DAC_R_SFT, 1, 1),
587};
588
589/* Analog Input Mixer */
590static const struct snd_kcontrol_new rt5640_rec_l_mix[] = {
591 SOC_DAPM_SINGLE("HPOL Switch", RT5640_REC_L2_MIXER,
592 RT5640_M_HP_L_RM_L_SFT, 1, 1),
593 SOC_DAPM_SINGLE("INL Switch", RT5640_REC_L2_MIXER,
594 RT5640_M_IN_L_RM_L_SFT, 1, 1),
595 SOC_DAPM_SINGLE("BST2 Switch", RT5640_REC_L2_MIXER,
596 RT5640_M_BST4_RM_L_SFT, 1, 1),
597 SOC_DAPM_SINGLE("BST1 Switch", RT5640_REC_L2_MIXER,
598 RT5640_M_BST1_RM_L_SFT, 1, 1),
599 SOC_DAPM_SINGLE("OUT MIXL Switch", RT5640_REC_L2_MIXER,
600 RT5640_M_OM_L_RM_L_SFT, 1, 1),
601};
602
603static const struct snd_kcontrol_new rt5640_rec_r_mix[] = {
604 SOC_DAPM_SINGLE("HPOR Switch", RT5640_REC_R2_MIXER,
605 RT5640_M_HP_R_RM_R_SFT, 1, 1),
606 SOC_DAPM_SINGLE("INR Switch", RT5640_REC_R2_MIXER,
607 RT5640_M_IN_R_RM_R_SFT, 1, 1),
608 SOC_DAPM_SINGLE("BST2 Switch", RT5640_REC_R2_MIXER,
609 RT5640_M_BST4_RM_R_SFT, 1, 1),
610 SOC_DAPM_SINGLE("BST1 Switch", RT5640_REC_R2_MIXER,
611 RT5640_M_BST1_RM_R_SFT, 1, 1),
612 SOC_DAPM_SINGLE("OUT MIXR Switch", RT5640_REC_R2_MIXER,
613 RT5640_M_OM_R_RM_R_SFT, 1, 1),
614};
615
616/* Analog Output Mixer */
617static const struct snd_kcontrol_new rt5640_spk_l_mix[] = {
618 SOC_DAPM_SINGLE("REC MIXL Switch", RT5640_SPK_L_MIXER,
619 RT5640_M_RM_L_SM_L_SFT, 1, 1),
620 SOC_DAPM_SINGLE("INL Switch", RT5640_SPK_L_MIXER,
621 RT5640_M_IN_L_SM_L_SFT, 1, 1),
622 SOC_DAPM_SINGLE("DAC L1 Switch", RT5640_SPK_L_MIXER,
623 RT5640_M_DAC_L1_SM_L_SFT, 1, 1),
624 SOC_DAPM_SINGLE("DAC L2 Switch", RT5640_SPK_L_MIXER,
625 RT5640_M_DAC_L2_SM_L_SFT, 1, 1),
626 SOC_DAPM_SINGLE("OUT MIXL Switch", RT5640_SPK_L_MIXER,
627 RT5640_M_OM_L_SM_L_SFT, 1, 1),
628};
629
630static const struct snd_kcontrol_new rt5640_spk_r_mix[] = {
631 SOC_DAPM_SINGLE("REC MIXR Switch", RT5640_SPK_R_MIXER,
632 RT5640_M_RM_R_SM_R_SFT, 1, 1),
633 SOC_DAPM_SINGLE("INR Switch", RT5640_SPK_R_MIXER,
634 RT5640_M_IN_R_SM_R_SFT, 1, 1),
635 SOC_DAPM_SINGLE("DAC R1 Switch", RT5640_SPK_R_MIXER,
636 RT5640_M_DAC_R1_SM_R_SFT, 1, 1),
637 SOC_DAPM_SINGLE("DAC R2 Switch", RT5640_SPK_R_MIXER,
638 RT5640_M_DAC_R2_SM_R_SFT, 1, 1),
639 SOC_DAPM_SINGLE("OUT MIXR Switch", RT5640_SPK_R_MIXER,
640 RT5640_M_OM_R_SM_R_SFT, 1, 1),
641};
642
643static const struct snd_kcontrol_new rt5640_out_l_mix[] = {
644 SOC_DAPM_SINGLE("SPK MIXL Switch", RT5640_OUT_L3_MIXER,
645 RT5640_M_SM_L_OM_L_SFT, 1, 1),
646 SOC_DAPM_SINGLE("BST1 Switch", RT5640_OUT_L3_MIXER,
647 RT5640_M_BST1_OM_L_SFT, 1, 1),
648 SOC_DAPM_SINGLE("INL Switch", RT5640_OUT_L3_MIXER,
649 RT5640_M_IN_L_OM_L_SFT, 1, 1),
650 SOC_DAPM_SINGLE("REC MIXL Switch", RT5640_OUT_L3_MIXER,
651 RT5640_M_RM_L_OM_L_SFT, 1, 1),
652 SOC_DAPM_SINGLE("DAC R2 Switch", RT5640_OUT_L3_MIXER,
653 RT5640_M_DAC_R2_OM_L_SFT, 1, 1),
654 SOC_DAPM_SINGLE("DAC L2 Switch", RT5640_OUT_L3_MIXER,
655 RT5640_M_DAC_L2_OM_L_SFT, 1, 1),
656 SOC_DAPM_SINGLE("DAC L1 Switch", RT5640_OUT_L3_MIXER,
657 RT5640_M_DAC_L1_OM_L_SFT, 1, 1),
658};
659
660static const struct snd_kcontrol_new rt5640_out_r_mix[] = {
661 SOC_DAPM_SINGLE("SPK MIXR Switch", RT5640_OUT_R3_MIXER,
662 RT5640_M_SM_L_OM_R_SFT, 1, 1),
663 SOC_DAPM_SINGLE("BST2 Switch", RT5640_OUT_R3_MIXER,
664 RT5640_M_BST4_OM_R_SFT, 1, 1),
665 SOC_DAPM_SINGLE("BST1 Switch", RT5640_OUT_R3_MIXER,
666 RT5640_M_BST1_OM_R_SFT, 1, 1),
667 SOC_DAPM_SINGLE("INR Switch", RT5640_OUT_R3_MIXER,
668 RT5640_M_IN_R_OM_R_SFT, 1, 1),
669 SOC_DAPM_SINGLE("REC MIXR Switch", RT5640_OUT_R3_MIXER,
670 RT5640_M_RM_R_OM_R_SFT, 1, 1),
671 SOC_DAPM_SINGLE("DAC L2 Switch", RT5640_OUT_R3_MIXER,
672 RT5640_M_DAC_L2_OM_R_SFT, 1, 1),
673 SOC_DAPM_SINGLE("DAC R2 Switch", RT5640_OUT_R3_MIXER,
674 RT5640_M_DAC_R2_OM_R_SFT, 1, 1),
675 SOC_DAPM_SINGLE("DAC R1 Switch", RT5640_OUT_R3_MIXER,
676 RT5640_M_DAC_R1_OM_R_SFT, 1, 1),
677};
678
679static const struct snd_kcontrol_new rt5640_spo_l_mix[] = {
680 SOC_DAPM_SINGLE("DAC R1 Switch", RT5640_SPO_L_MIXER,
681 RT5640_M_DAC_R1_SPM_L_SFT, 1, 1),
682 SOC_DAPM_SINGLE("DAC L1 Switch", RT5640_SPO_L_MIXER,
683 RT5640_M_DAC_L1_SPM_L_SFT, 1, 1),
684 SOC_DAPM_SINGLE("SPKVOL R Switch", RT5640_SPO_L_MIXER,
685 RT5640_M_SV_R_SPM_L_SFT, 1, 1),
686 SOC_DAPM_SINGLE("SPKVOL L Switch", RT5640_SPO_L_MIXER,
687 RT5640_M_SV_L_SPM_L_SFT, 1, 1),
688 SOC_DAPM_SINGLE("BST1 Switch", RT5640_SPO_L_MIXER,
689 RT5640_M_BST1_SPM_L_SFT, 1, 1),
690};
691
692static const struct snd_kcontrol_new rt5640_spo_r_mix[] = {
693 SOC_DAPM_SINGLE("DAC R1 Switch", RT5640_SPO_R_MIXER,
694 RT5640_M_DAC_R1_SPM_R_SFT, 1, 1),
695 SOC_DAPM_SINGLE("SPKVOL R Switch", RT5640_SPO_R_MIXER,
696 RT5640_M_SV_R_SPM_R_SFT, 1, 1),
697 SOC_DAPM_SINGLE("BST1 Switch", RT5640_SPO_R_MIXER,
698 RT5640_M_BST1_SPM_R_SFT, 1, 1),
699};
700
701static const struct snd_kcontrol_new rt5640_hpo_mix[] = {
702 SOC_DAPM_SINGLE("HPO MIX DAC2 Switch", RT5640_HPO_MIXER,
703 RT5640_M_DAC2_HM_SFT, 1, 1),
704 SOC_DAPM_SINGLE("HPO MIX DAC1 Switch", RT5640_HPO_MIXER,
705 RT5640_M_DAC1_HM_SFT, 1, 1),
706 SOC_DAPM_SINGLE("HPO MIX HPVOL Switch", RT5640_HPO_MIXER,
707 RT5640_M_HPVOL_HM_SFT, 1, 1),
708};
709
710static const struct snd_kcontrol_new rt5640_lout_mix[] = {
711 SOC_DAPM_SINGLE("DAC L1 Switch", RT5640_LOUT_MIXER,
712 RT5640_M_DAC_L1_LM_SFT, 1, 1),
713 SOC_DAPM_SINGLE("DAC R1 Switch", RT5640_LOUT_MIXER,
714 RT5640_M_DAC_R1_LM_SFT, 1, 1),
715 SOC_DAPM_SINGLE("OUTVOL L Switch", RT5640_LOUT_MIXER,
716 RT5640_M_OV_L_LM_SFT, 1, 1),
717 SOC_DAPM_SINGLE("OUTVOL R Switch", RT5640_LOUT_MIXER,
718 RT5640_M_OV_R_LM_SFT, 1, 1),
719};
720
721static const struct snd_kcontrol_new rt5640_mono_mix[] = {
722 SOC_DAPM_SINGLE("DAC R2 Switch", RT5640_MONO_MIXER,
723 RT5640_M_DAC_R2_MM_SFT, 1, 1),
724 SOC_DAPM_SINGLE("DAC L2 Switch", RT5640_MONO_MIXER,
725 RT5640_M_DAC_L2_MM_SFT, 1, 1),
726 SOC_DAPM_SINGLE("OUTVOL R Switch", RT5640_MONO_MIXER,
727 RT5640_M_OV_R_MM_SFT, 1, 1),
728 SOC_DAPM_SINGLE("OUTVOL L Switch", RT5640_MONO_MIXER,
729 RT5640_M_OV_L_MM_SFT, 1, 1),
730 SOC_DAPM_SINGLE("BST1 Switch", RT5640_MONO_MIXER,
731 RT5640_M_BST1_MM_SFT, 1, 1),
732};
733
Bard Liao246693b2013-08-23 10:29:26 +0800734static const struct snd_kcontrol_new spk_l_enable_control =
735 SOC_DAPM_SINGLE_AUTODISABLE("Switch", RT5640_SPK_VOL,
736 RT5640_L_MUTE_SFT, 1, 1);
737
738static const struct snd_kcontrol_new spk_r_enable_control =
739 SOC_DAPM_SINGLE_AUTODISABLE("Switch", RT5640_SPK_VOL,
740 RT5640_R_MUTE_SFT, 1, 1);
741
742static const struct snd_kcontrol_new hp_l_enable_control =
743 SOC_DAPM_SINGLE_AUTODISABLE("Switch", RT5640_HP_VOL,
744 RT5640_L_MUTE_SFT, 1, 1);
745
746static const struct snd_kcontrol_new hp_r_enable_control =
747 SOC_DAPM_SINGLE_AUTODISABLE("Switch", RT5640_HP_VOL,
748 RT5640_R_MUTE_SFT, 1, 1);
749
Bard Liao997b0522013-06-11 13:10:16 +0800750/* Stereo ADC source */
751static const char * const rt5640_stereo_adc1_src[] = {
752 "DIG MIX", "ADC"
753};
754
Takashi Iwai4c03cb62014-02-18 09:43:21 +0100755static SOC_ENUM_SINGLE_DECL(rt5640_stereo_adc1_enum, RT5640_STO_ADC_MIXER,
756 RT5640_ADC_1_SRC_SFT, rt5640_stereo_adc1_src);
Bard Liao997b0522013-06-11 13:10:16 +0800757
758static const struct snd_kcontrol_new rt5640_sto_adc_1_mux =
759 SOC_DAPM_ENUM("Stereo ADC1 Mux", rt5640_stereo_adc1_enum);
760
761static const char * const rt5640_stereo_adc2_src[] = {
762 "DMIC1", "DMIC2", "DIG MIX"
763};
764
Takashi Iwai4c03cb62014-02-18 09:43:21 +0100765static SOC_ENUM_SINGLE_DECL(rt5640_stereo_adc2_enum, RT5640_STO_ADC_MIXER,
766 RT5640_ADC_2_SRC_SFT, rt5640_stereo_adc2_src);
Bard Liao997b0522013-06-11 13:10:16 +0800767
768static const struct snd_kcontrol_new rt5640_sto_adc_2_mux =
769 SOC_DAPM_ENUM("Stereo ADC2 Mux", rt5640_stereo_adc2_enum);
770
771/* Mono ADC source */
772static const char * const rt5640_mono_adc_l1_src[] = {
773 "Mono DAC MIXL", "ADCL"
774};
775
Takashi Iwai4c03cb62014-02-18 09:43:21 +0100776static SOC_ENUM_SINGLE_DECL(rt5640_mono_adc_l1_enum, RT5640_MONO_ADC_MIXER,
777 RT5640_MONO_ADC_L1_SRC_SFT, rt5640_mono_adc_l1_src);
Bard Liao997b0522013-06-11 13:10:16 +0800778
779static const struct snd_kcontrol_new rt5640_mono_adc_l1_mux =
780 SOC_DAPM_ENUM("Mono ADC1 left source", rt5640_mono_adc_l1_enum);
781
782static const char * const rt5640_mono_adc_l2_src[] = {
783 "DMIC L1", "DMIC L2", "Mono DAC MIXL"
784};
785
Takashi Iwai4c03cb62014-02-18 09:43:21 +0100786static SOC_ENUM_SINGLE_DECL(rt5640_mono_adc_l2_enum, RT5640_MONO_ADC_MIXER,
787 RT5640_MONO_ADC_L2_SRC_SFT, rt5640_mono_adc_l2_src);
Bard Liao997b0522013-06-11 13:10:16 +0800788
789static const struct snd_kcontrol_new rt5640_mono_adc_l2_mux =
790 SOC_DAPM_ENUM("Mono ADC2 left source", rt5640_mono_adc_l2_enum);
791
792static const char * const rt5640_mono_adc_r1_src[] = {
793 "Mono DAC MIXR", "ADCR"
794};
795
Takashi Iwai4c03cb62014-02-18 09:43:21 +0100796static SOC_ENUM_SINGLE_DECL(rt5640_mono_adc_r1_enum, RT5640_MONO_ADC_MIXER,
797 RT5640_MONO_ADC_R1_SRC_SFT, rt5640_mono_adc_r1_src);
Bard Liao997b0522013-06-11 13:10:16 +0800798
799static const struct snd_kcontrol_new rt5640_mono_adc_r1_mux =
800 SOC_DAPM_ENUM("Mono ADC1 right source", rt5640_mono_adc_r1_enum);
801
802static const char * const rt5640_mono_adc_r2_src[] = {
803 "DMIC R1", "DMIC R2", "Mono DAC MIXR"
804};
805
Takashi Iwai4c03cb62014-02-18 09:43:21 +0100806static SOC_ENUM_SINGLE_DECL(rt5640_mono_adc_r2_enum, RT5640_MONO_ADC_MIXER,
807 RT5640_MONO_ADC_R2_SRC_SFT, rt5640_mono_adc_r2_src);
Bard Liao997b0522013-06-11 13:10:16 +0800808
809static const struct snd_kcontrol_new rt5640_mono_adc_r2_mux =
810 SOC_DAPM_ENUM("Mono ADC2 right source", rt5640_mono_adc_r2_enum);
811
812/* DAC2 channel source */
813static const char * const rt5640_dac_l2_src[] = {
814 "IF2", "Base L/R"
815};
816
817static int rt5640_dac_l2_values[] = {
818 0,
819 3,
820};
821
Takashi Iwai4c03cb62014-02-18 09:43:21 +0100822static SOC_VALUE_ENUM_SINGLE_DECL(rt5640_dac_l2_enum,
823 RT5640_DSP_PATH2, RT5640_DAC_L2_SEL_SFT,
824 0x3, rt5640_dac_l2_src, rt5640_dac_l2_values);
Bard Liao997b0522013-06-11 13:10:16 +0800825
826static const struct snd_kcontrol_new rt5640_dac_l2_mux =
827 SOC_DAPM_VALUE_ENUM("DAC2 left channel source", rt5640_dac_l2_enum);
828
829static const char * const rt5640_dac_r2_src[] = {
830 "IF2",
831};
832
833static int rt5640_dac_r2_values[] = {
834 0,
835};
836
Takashi Iwai4c03cb62014-02-18 09:43:21 +0100837static SOC_VALUE_ENUM_SINGLE_DECL(rt5640_dac_r2_enum,
838 RT5640_DSP_PATH2, RT5640_DAC_R2_SEL_SFT,
839 0x3, rt5640_dac_r2_src, rt5640_dac_r2_values);
Bard Liao997b0522013-06-11 13:10:16 +0800840
841static const struct snd_kcontrol_new rt5640_dac_r2_mux =
842 SOC_DAPM_ENUM("DAC2 right channel source", rt5640_dac_r2_enum);
843
844/* digital interface and iis interface map */
845static const char * const rt5640_dai_iis_map[] = {
846 "1:1|2:2", "1:2|2:1", "1:1|2:1", "1:2|2:2"
847};
848
849static int rt5640_dai_iis_map_values[] = {
850 0,
851 5,
852 6,
853 7,
854};
855
Takashi Iwai4c03cb62014-02-18 09:43:21 +0100856static SOC_VALUE_ENUM_SINGLE_DECL(rt5640_dai_iis_map_enum,
857 RT5640_I2S1_SDP, RT5640_I2S_IF_SFT,
858 0x7, rt5640_dai_iis_map,
859 rt5640_dai_iis_map_values);
Bard Liao997b0522013-06-11 13:10:16 +0800860
861static const struct snd_kcontrol_new rt5640_dai_mux =
862 SOC_DAPM_VALUE_ENUM("DAI select", rt5640_dai_iis_map_enum);
863
864/* SDI select */
865static const char * const rt5640_sdi_sel[] = {
866 "IF1", "IF2"
867};
868
Takashi Iwai4c03cb62014-02-18 09:43:21 +0100869static SOC_ENUM_SINGLE_DECL(rt5640_sdi_sel_enum, RT5640_I2S2_SDP,
870 RT5640_I2S2_SDI_SFT, rt5640_sdi_sel);
Bard Liao997b0522013-06-11 13:10:16 +0800871
872static const struct snd_kcontrol_new rt5640_sdi_mux =
873 SOC_DAPM_ENUM("SDI select", rt5640_sdi_sel_enum);
874
Sachin Kamat89d05132013-09-13 15:22:18 +0530875static void hp_amp_power_on(struct snd_soc_codec *codec)
Bard Liao246693b2013-08-23 10:29:26 +0800876{
877 struct rt5640_priv *rt5640 = snd_soc_codec_get_drvdata(codec);
878
879 /* depop parameters */
880 regmap_update_bits(rt5640->regmap, RT5640_PR_BASE +
881 RT5640_CHPUMP_INT_REG1, 0x0700, 0x0200);
882 regmap_update_bits(rt5640->regmap, RT5640_DEPOP_M2,
883 RT5640_DEPOP_MASK, RT5640_DEPOP_MAN);
884 regmap_update_bits(rt5640->regmap, RT5640_DEPOP_M1,
885 RT5640_HP_CP_MASK | RT5640_HP_SG_MASK | RT5640_HP_CB_MASK,
886 RT5640_HP_CP_PU | RT5640_HP_SG_DIS | RT5640_HP_CB_PU);
887 regmap_write(rt5640->regmap, RT5640_PR_BASE + RT5640_HP_DCC_INT1,
888 0x9f00);
889 /* headphone amp power on */
890 regmap_update_bits(rt5640->regmap, RT5640_PWR_ANLG1,
891 RT5640_PWR_FV1 | RT5640_PWR_FV2, 0);
892 regmap_update_bits(rt5640->regmap, RT5640_PWR_ANLG1,
893 RT5640_PWR_HA,
894 RT5640_PWR_HA);
895 usleep_range(10000, 15000);
896 regmap_update_bits(rt5640->regmap, RT5640_PWR_ANLG1,
897 RT5640_PWR_FV1 | RT5640_PWR_FV2 ,
898 RT5640_PWR_FV1 | RT5640_PWR_FV2);
899}
900
901static void rt5640_pmu_depop(struct snd_soc_codec *codec)
902{
903 struct rt5640_priv *rt5640 = snd_soc_codec_get_drvdata(codec);
904
905 regmap_update_bits(rt5640->regmap, RT5640_DEPOP_M2,
906 RT5640_DEPOP_MASK | RT5640_DIG_DP_MASK,
907 RT5640_DEPOP_AUTO | RT5640_DIG_DP_EN);
908 regmap_update_bits(rt5640->regmap, RT5640_CHARGE_PUMP,
909 RT5640_PM_HP_MASK, RT5640_PM_HP_HV);
910
911 regmap_update_bits(rt5640->regmap, RT5640_DEPOP_M3,
912 RT5640_CP_FQ1_MASK | RT5640_CP_FQ2_MASK | RT5640_CP_FQ3_MASK,
913 (RT5640_CP_FQ_192_KHZ << RT5640_CP_FQ1_SFT) |
914 (RT5640_CP_FQ_12_KHZ << RT5640_CP_FQ2_SFT) |
915 (RT5640_CP_FQ_192_KHZ << RT5640_CP_FQ3_SFT));
916
917 regmap_write(rt5640->regmap, RT5640_PR_BASE +
918 RT5640_MAMP_INT_REG2, 0x1c00);
919 regmap_update_bits(rt5640->regmap, RT5640_DEPOP_M1,
920 RT5640_HP_CP_MASK | RT5640_HP_SG_MASK,
921 RT5640_HP_CP_PD | RT5640_HP_SG_EN);
922 regmap_update_bits(rt5640->regmap, RT5640_PR_BASE +
923 RT5640_CHPUMP_INT_REG1, 0x0700, 0x0400);
924}
925
926static int rt5640_hp_event(struct snd_soc_dapm_widget *w,
927 struct snd_kcontrol *kcontrol, int event)
928{
929 struct snd_soc_codec *codec = w->codec;
930 struct rt5640_priv *rt5640 = snd_soc_codec_get_drvdata(codec);
931
932 switch (event) {
933 case SND_SOC_DAPM_POST_PMU:
934 rt5640_pmu_depop(codec);
935 rt5640->hp_mute = 0;
936 break;
937
938 case SND_SOC_DAPM_PRE_PMD:
939 rt5640->hp_mute = 1;
940 usleep_range(70000, 75000);
941 break;
942
943 default:
944 return 0;
945 }
946
947 return 0;
948}
949
950static int rt5640_hp_power_event(struct snd_soc_dapm_widget *w,
951 struct snd_kcontrol *kcontrol, int event)
952{
953 struct snd_soc_codec *codec = w->codec;
954
955 switch (event) {
956 case SND_SOC_DAPM_POST_PMU:
957 hp_amp_power_on(codec);
958 break;
959 default:
960 return 0;
961 }
962
963 return 0;
964}
965
966static int rt5640_hp_post_event(struct snd_soc_dapm_widget *w,
967 struct snd_kcontrol *kcontrol, int event)
968{
969 struct snd_soc_codec *codec = w->codec;
970 struct rt5640_priv *rt5640 = snd_soc_codec_get_drvdata(codec);
971
972 switch (event) {
973 case SND_SOC_DAPM_POST_PMU:
974 if (!rt5640->hp_mute)
975 usleep_range(80000, 85000);
976
977 break;
978
979 default:
980 return 0;
981 }
982
983 return 0;
984}
985
Bard Liao997b0522013-06-11 13:10:16 +0800986static const struct snd_soc_dapm_widget rt5640_dapm_widgets[] = {
987 SND_SOC_DAPM_SUPPLY("PLL1", RT5640_PWR_ANLG2,
988 RT5640_PWR_PLL_BIT, 0, NULL, 0),
989 /* Input Side */
990 /* micbias */
991 SND_SOC_DAPM_SUPPLY("LDO2", RT5640_PWR_ANLG1,
992 RT5640_PWR_LDO2_BIT, 0, NULL, 0),
993 SND_SOC_DAPM_SUPPLY("MICBIAS1", RT5640_PWR_ANLG2,
Stephen Warren9be94ae2013-06-12 15:34:23 -0600994 RT5640_PWR_MB1_BIT, 0, NULL, 0),
Bard Liao997b0522013-06-11 13:10:16 +0800995 /* Input Lines */
996 SND_SOC_DAPM_INPUT("DMIC1"),
997 SND_SOC_DAPM_INPUT("DMIC2"),
998 SND_SOC_DAPM_INPUT("IN1P"),
999 SND_SOC_DAPM_INPUT("IN1N"),
1000 SND_SOC_DAPM_INPUT("IN2P"),
1001 SND_SOC_DAPM_INPUT("IN2N"),
1002 SND_SOC_DAPM_PGA("DMIC L1", SND_SOC_NOPM, 0, 0, NULL, 0),
1003 SND_SOC_DAPM_PGA("DMIC R1", SND_SOC_NOPM, 0, 0, NULL, 0),
1004 SND_SOC_DAPM_PGA("DMIC L2", SND_SOC_NOPM, 0, 0, NULL, 0),
1005 SND_SOC_DAPM_PGA("DMIC R2", SND_SOC_NOPM, 0, 0, NULL, 0),
1006
1007 SND_SOC_DAPM_SUPPLY("DMIC CLK", SND_SOC_NOPM, 0, 0,
1008 set_dmic_clk, SND_SOC_DAPM_PRE_PMU),
Oder Chiou71d97a792014-03-28 10:46:18 +08001009 SND_SOC_DAPM_SUPPLY("DMIC1 Power", RT5640_DMIC, RT5640_DMIC_1_EN_SFT, 0,
1010 NULL, 0),
1011 SND_SOC_DAPM_SUPPLY("DMIC2 Power", RT5640_DMIC, RT5640_DMIC_2_EN_SFT, 0,
1012 NULL, 0),
Bard Liao997b0522013-06-11 13:10:16 +08001013 /* Boost */
1014 SND_SOC_DAPM_PGA("BST1", RT5640_PWR_ANLG2,
1015 RT5640_PWR_BST1_BIT, 0, NULL, 0),
1016 SND_SOC_DAPM_PGA("BST2", RT5640_PWR_ANLG2,
1017 RT5640_PWR_BST4_BIT, 0, NULL, 0),
1018 /* Input Volume */
1019 SND_SOC_DAPM_PGA("INL VOL", RT5640_PWR_VOL,
1020 RT5640_PWR_IN_L_BIT, 0, NULL, 0),
1021 SND_SOC_DAPM_PGA("INR VOL", RT5640_PWR_VOL,
1022 RT5640_PWR_IN_R_BIT, 0, NULL, 0),
Bard Liao997b0522013-06-11 13:10:16 +08001023 /* REC Mixer */
1024 SND_SOC_DAPM_MIXER("RECMIXL", RT5640_PWR_MIXER, RT5640_PWR_RM_L_BIT, 0,
1025 rt5640_rec_l_mix, ARRAY_SIZE(rt5640_rec_l_mix)),
1026 SND_SOC_DAPM_MIXER("RECMIXR", RT5640_PWR_MIXER, RT5640_PWR_RM_R_BIT, 0,
1027 rt5640_rec_r_mix, ARRAY_SIZE(rt5640_rec_r_mix)),
1028 /* ADCs */
1029 SND_SOC_DAPM_ADC("ADC L", NULL, RT5640_PWR_DIG1,
1030 RT5640_PWR_ADC_L_BIT, 0),
1031 SND_SOC_DAPM_ADC("ADC R", NULL, RT5640_PWR_DIG1,
1032 RT5640_PWR_ADC_R_BIT, 0),
1033 /* ADC Mux */
1034 SND_SOC_DAPM_MUX("Stereo ADC L2 Mux", SND_SOC_NOPM, 0, 0,
1035 &rt5640_sto_adc_2_mux),
1036 SND_SOC_DAPM_MUX("Stereo ADC R2 Mux", SND_SOC_NOPM, 0, 0,
1037 &rt5640_sto_adc_2_mux),
1038 SND_SOC_DAPM_MUX("Stereo ADC L1 Mux", SND_SOC_NOPM, 0, 0,
1039 &rt5640_sto_adc_1_mux),
1040 SND_SOC_DAPM_MUX("Stereo ADC R1 Mux", SND_SOC_NOPM, 0, 0,
1041 &rt5640_sto_adc_1_mux),
1042 SND_SOC_DAPM_MUX("Mono ADC L2 Mux", SND_SOC_NOPM, 0, 0,
1043 &rt5640_mono_adc_l2_mux),
1044 SND_SOC_DAPM_MUX("Mono ADC L1 Mux", SND_SOC_NOPM, 0, 0,
1045 &rt5640_mono_adc_l1_mux),
1046 SND_SOC_DAPM_MUX("Mono ADC R1 Mux", SND_SOC_NOPM, 0, 0,
1047 &rt5640_mono_adc_r1_mux),
1048 SND_SOC_DAPM_MUX("Mono ADC R2 Mux", SND_SOC_NOPM, 0, 0,
1049 &rt5640_mono_adc_r2_mux),
1050 /* ADC Mixer */
1051 SND_SOC_DAPM_SUPPLY("Stereo Filter", RT5640_PWR_DIG2,
1052 RT5640_PWR_ADC_SF_BIT, 0, NULL, 0),
1053 SND_SOC_DAPM_MIXER("Stereo ADC MIXL", SND_SOC_NOPM, 0, 0,
1054 rt5640_sto_adc_l_mix, ARRAY_SIZE(rt5640_sto_adc_l_mix)),
1055 SND_SOC_DAPM_MIXER("Stereo ADC MIXR", SND_SOC_NOPM, 0, 0,
1056 rt5640_sto_adc_r_mix, ARRAY_SIZE(rt5640_sto_adc_r_mix)),
1057 SND_SOC_DAPM_SUPPLY("Mono Left Filter", RT5640_PWR_DIG2,
1058 RT5640_PWR_ADC_MF_L_BIT, 0, NULL, 0),
1059 SND_SOC_DAPM_MIXER("Mono ADC MIXL", SND_SOC_NOPM, 0, 0,
1060 rt5640_mono_adc_l_mix, ARRAY_SIZE(rt5640_mono_adc_l_mix)),
1061 SND_SOC_DAPM_SUPPLY("Mono Right Filter", RT5640_PWR_DIG2,
1062 RT5640_PWR_ADC_MF_R_BIT, 0, NULL, 0),
1063 SND_SOC_DAPM_MIXER("Mono ADC MIXR", SND_SOC_NOPM, 0, 0,
1064 rt5640_mono_adc_r_mix, ARRAY_SIZE(rt5640_mono_adc_r_mix)),
1065
1066 /* Digital Interface */
1067 SND_SOC_DAPM_SUPPLY("I2S1", RT5640_PWR_DIG1,
1068 RT5640_PWR_I2S1_BIT, 0, NULL, 0),
1069 SND_SOC_DAPM_PGA("IF1 DAC", SND_SOC_NOPM, 0, 0, NULL, 0),
1070 SND_SOC_DAPM_PGA("IF1 DAC L", SND_SOC_NOPM, 0, 0, NULL, 0),
1071 SND_SOC_DAPM_PGA("IF1 DAC R", SND_SOC_NOPM, 0, 0, NULL, 0),
1072 SND_SOC_DAPM_PGA("IF1 ADC", SND_SOC_NOPM, 0, 0, NULL, 0),
1073 SND_SOC_DAPM_PGA("IF1 ADC L", SND_SOC_NOPM, 0, 0, NULL, 0),
1074 SND_SOC_DAPM_PGA("IF1 ADC R", SND_SOC_NOPM, 0, 0, NULL, 0),
1075 SND_SOC_DAPM_SUPPLY("I2S2", RT5640_PWR_DIG1,
1076 RT5640_PWR_I2S2_BIT, 0, NULL, 0),
1077 SND_SOC_DAPM_PGA("IF2 DAC", SND_SOC_NOPM, 0, 0, NULL, 0),
1078 SND_SOC_DAPM_PGA("IF2 DAC L", SND_SOC_NOPM, 0, 0, NULL, 0),
1079 SND_SOC_DAPM_PGA("IF2 DAC R", SND_SOC_NOPM, 0, 0, NULL, 0),
1080 SND_SOC_DAPM_PGA("IF2 ADC", SND_SOC_NOPM, 0, 0, NULL, 0),
1081 SND_SOC_DAPM_PGA("IF2 ADC L", SND_SOC_NOPM, 0, 0, NULL, 0),
1082 SND_SOC_DAPM_PGA("IF2 ADC R", SND_SOC_NOPM, 0, 0, NULL, 0),
1083 /* Digital Interface Select */
1084 SND_SOC_DAPM_MUX("DAI1 RX Mux", SND_SOC_NOPM, 0, 0, &rt5640_dai_mux),
1085 SND_SOC_DAPM_MUX("DAI1 TX Mux", SND_SOC_NOPM, 0, 0, &rt5640_dai_mux),
1086 SND_SOC_DAPM_MUX("DAI1 IF1 Mux", SND_SOC_NOPM, 0, 0, &rt5640_dai_mux),
1087 SND_SOC_DAPM_MUX("DAI1 IF2 Mux", SND_SOC_NOPM, 0, 0, &rt5640_dai_mux),
1088 SND_SOC_DAPM_MUX("SDI1 TX Mux", SND_SOC_NOPM, 0, 0, &rt5640_sdi_mux),
1089 SND_SOC_DAPM_MUX("DAI2 RX Mux", SND_SOC_NOPM, 0, 0, &rt5640_dai_mux),
1090 SND_SOC_DAPM_MUX("DAI2 TX Mux", SND_SOC_NOPM, 0, 0, &rt5640_dai_mux),
1091 SND_SOC_DAPM_MUX("DAI2 IF1 Mux", SND_SOC_NOPM, 0, 0, &rt5640_dai_mux),
1092 SND_SOC_DAPM_MUX("DAI2 IF2 Mux", SND_SOC_NOPM, 0, 0, &rt5640_dai_mux),
1093 SND_SOC_DAPM_MUX("SDI2 TX Mux", SND_SOC_NOPM, 0, 0, &rt5640_sdi_mux),
1094 /* Audio Interface */
1095 SND_SOC_DAPM_AIF_IN("AIF1RX", "AIF1 Playback", 0, SND_SOC_NOPM, 0, 0),
1096 SND_SOC_DAPM_AIF_OUT("AIF1TX", "AIF1 Capture", 0, SND_SOC_NOPM, 0, 0),
1097 SND_SOC_DAPM_AIF_IN("AIF2RX", "AIF2 Playback", 0, SND_SOC_NOPM, 0, 0),
1098 SND_SOC_DAPM_AIF_OUT("AIF2TX", "AIF2 Capture", 0, SND_SOC_NOPM, 0, 0),
1099 /* Audio DSP */
1100 SND_SOC_DAPM_PGA("Audio DSP", SND_SOC_NOPM, 0, 0, NULL, 0),
1101 /* ANC */
1102 SND_SOC_DAPM_PGA("ANC", SND_SOC_NOPM, 0, 0, NULL, 0),
1103 /* Output Side */
1104 /* DAC mixer before sound effect */
1105 SND_SOC_DAPM_MIXER("DAC MIXL", SND_SOC_NOPM, 0, 0,
1106 rt5640_dac_l_mix, ARRAY_SIZE(rt5640_dac_l_mix)),
1107 SND_SOC_DAPM_MIXER("DAC MIXR", SND_SOC_NOPM, 0, 0,
1108 rt5640_dac_r_mix, ARRAY_SIZE(rt5640_dac_r_mix)),
1109 /* DAC2 channel Mux */
1110 SND_SOC_DAPM_MUX("DAC L2 Mux", SND_SOC_NOPM, 0, 0,
1111 &rt5640_dac_l2_mux),
1112 SND_SOC_DAPM_MUX("DAC R2 Mux", SND_SOC_NOPM, 0, 0,
1113 &rt5640_dac_r2_mux),
1114 /* DAC Mixer */
1115 SND_SOC_DAPM_MIXER("Stereo DAC MIXL", SND_SOC_NOPM, 0, 0,
1116 rt5640_sto_dac_l_mix, ARRAY_SIZE(rt5640_sto_dac_l_mix)),
1117 SND_SOC_DAPM_MIXER("Stereo DAC MIXR", SND_SOC_NOPM, 0, 0,
1118 rt5640_sto_dac_r_mix, ARRAY_SIZE(rt5640_sto_dac_r_mix)),
1119 SND_SOC_DAPM_MIXER("Mono DAC MIXL", SND_SOC_NOPM, 0, 0,
1120 rt5640_mono_dac_l_mix, ARRAY_SIZE(rt5640_mono_dac_l_mix)),
1121 SND_SOC_DAPM_MIXER("Mono DAC MIXR", SND_SOC_NOPM, 0, 0,
1122 rt5640_mono_dac_r_mix, ARRAY_SIZE(rt5640_mono_dac_r_mix)),
1123 SND_SOC_DAPM_MIXER("DIG MIXL", SND_SOC_NOPM, 0, 0,
1124 rt5640_dig_l_mix, ARRAY_SIZE(rt5640_dig_l_mix)),
1125 SND_SOC_DAPM_MIXER("DIG MIXR", SND_SOC_NOPM, 0, 0,
1126 rt5640_dig_r_mix, ARRAY_SIZE(rt5640_dig_r_mix)),
1127 /* DACs */
1128 SND_SOC_DAPM_DAC("DAC L1", NULL, RT5640_PWR_DIG1,
1129 RT5640_PWR_DAC_L1_BIT, 0),
1130 SND_SOC_DAPM_DAC("DAC L2", NULL, RT5640_PWR_DIG1,
1131 RT5640_PWR_DAC_L2_BIT, 0),
1132 SND_SOC_DAPM_DAC("DAC R1", NULL, RT5640_PWR_DIG1,
1133 RT5640_PWR_DAC_R1_BIT, 0),
1134 SND_SOC_DAPM_DAC("DAC R2", NULL, RT5640_PWR_DIG1,
1135 RT5640_PWR_DAC_R2_BIT, 0),
1136 /* SPK/OUT Mixer */
1137 SND_SOC_DAPM_MIXER("SPK MIXL", RT5640_PWR_MIXER, RT5640_PWR_SM_L_BIT,
1138 0, rt5640_spk_l_mix, ARRAY_SIZE(rt5640_spk_l_mix)),
1139 SND_SOC_DAPM_MIXER("SPK MIXR", RT5640_PWR_MIXER, RT5640_PWR_SM_R_BIT,
1140 0, rt5640_spk_r_mix, ARRAY_SIZE(rt5640_spk_r_mix)),
1141 SND_SOC_DAPM_MIXER("OUT MIXL", RT5640_PWR_MIXER, RT5640_PWR_OM_L_BIT,
1142 0, rt5640_out_l_mix, ARRAY_SIZE(rt5640_out_l_mix)),
1143 SND_SOC_DAPM_MIXER("OUT MIXR", RT5640_PWR_MIXER, RT5640_PWR_OM_R_BIT,
1144 0, rt5640_out_r_mix, ARRAY_SIZE(rt5640_out_r_mix)),
1145 /* Ouput Volume */
1146 SND_SOC_DAPM_PGA("SPKVOL L", RT5640_PWR_VOL,
1147 RT5640_PWR_SV_L_BIT, 0, NULL, 0),
1148 SND_SOC_DAPM_PGA("SPKVOL R", RT5640_PWR_VOL,
1149 RT5640_PWR_SV_R_BIT, 0, NULL, 0),
1150 SND_SOC_DAPM_PGA("OUTVOL L", RT5640_PWR_VOL,
1151 RT5640_PWR_OV_L_BIT, 0, NULL, 0),
1152 SND_SOC_DAPM_PGA("OUTVOL R", RT5640_PWR_VOL,
1153 RT5640_PWR_OV_R_BIT, 0, NULL, 0),
1154 SND_SOC_DAPM_PGA("HPOVOL L", RT5640_PWR_VOL,
1155 RT5640_PWR_HV_L_BIT, 0, NULL, 0),
1156 SND_SOC_DAPM_PGA("HPOVOL R", RT5640_PWR_VOL,
1157 RT5640_PWR_HV_R_BIT, 0, NULL, 0),
1158 /* SPO/HPO/LOUT/Mono Mixer */
1159 SND_SOC_DAPM_MIXER("SPOL MIX", SND_SOC_NOPM, 0,
1160 0, rt5640_spo_l_mix, ARRAY_SIZE(rt5640_spo_l_mix)),
1161 SND_SOC_DAPM_MIXER("SPOR MIX", SND_SOC_NOPM, 0,
1162 0, rt5640_spo_r_mix, ARRAY_SIZE(rt5640_spo_r_mix)),
1163 SND_SOC_DAPM_MIXER("HPO MIX L", SND_SOC_NOPM, 0, 0,
1164 rt5640_hpo_mix, ARRAY_SIZE(rt5640_hpo_mix)),
1165 SND_SOC_DAPM_MIXER("HPO MIX R", SND_SOC_NOPM, 0, 0,
1166 rt5640_hpo_mix, ARRAY_SIZE(rt5640_hpo_mix)),
1167 SND_SOC_DAPM_MIXER("LOUT MIX", RT5640_PWR_ANLG1, RT5640_PWR_LM_BIT, 0,
1168 rt5640_lout_mix, ARRAY_SIZE(rt5640_lout_mix)),
1169 SND_SOC_DAPM_MIXER("Mono MIX", RT5640_PWR_ANLG1, RT5640_PWR_MM_BIT, 0,
1170 rt5640_mono_mix, ARRAY_SIZE(rt5640_mono_mix)),
1171 SND_SOC_DAPM_SUPPLY("Improve MONO Amp Drv", RT5640_PWR_ANLG1,
1172 RT5640_PWR_MA_BIT, 0, NULL, 0),
Bard Liao246693b2013-08-23 10:29:26 +08001173 SND_SOC_DAPM_SUPPLY_S("Improve HP Amp Drv", 1, SND_SOC_NOPM,
1174 0, 0, rt5640_hp_power_event, SND_SOC_DAPM_POST_PMU),
1175 SND_SOC_DAPM_PGA_S("HP Amp", 1, SND_SOC_NOPM, 0, 0,
1176 rt5640_hp_event,
1177 SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMU),
1178 SND_SOC_DAPM_SUPPLY("HP L Amp", RT5640_PWR_ANLG1,
Bard Liao997b0522013-06-11 13:10:16 +08001179 RT5640_PWR_HP_L_BIT, 0, NULL, 0),
Bard Liao246693b2013-08-23 10:29:26 +08001180 SND_SOC_DAPM_SUPPLY("HP R Amp", RT5640_PWR_ANLG1,
Bard Liao997b0522013-06-11 13:10:16 +08001181 RT5640_PWR_HP_R_BIT, 0, NULL, 0),
1182 SND_SOC_DAPM_SUPPLY("Improve SPK Amp Drv", RT5640_PWR_DIG1,
Bard Liao246693b2013-08-23 10:29:26 +08001183 RT5640_PWR_CLS_D_BIT, 0, NULL, 0),
1184
1185 /* Output Switch */
1186 SND_SOC_DAPM_SWITCH("Speaker L Playback", SND_SOC_NOPM, 0, 0,
1187 &spk_l_enable_control),
1188 SND_SOC_DAPM_SWITCH("Speaker R Playback", SND_SOC_NOPM, 0, 0,
1189 &spk_r_enable_control),
1190 SND_SOC_DAPM_SWITCH("HP L Playback", SND_SOC_NOPM, 0, 0,
1191 &hp_l_enable_control),
1192 SND_SOC_DAPM_SWITCH("HP R Playback", SND_SOC_NOPM, 0, 0,
1193 &hp_r_enable_control),
1194 SND_SOC_DAPM_POST("HP Post", rt5640_hp_post_event),
Bard Liao997b0522013-06-11 13:10:16 +08001195 /* Output Lines */
1196 SND_SOC_DAPM_OUTPUT("SPOLP"),
1197 SND_SOC_DAPM_OUTPUT("SPOLN"),
1198 SND_SOC_DAPM_OUTPUT("SPORP"),
1199 SND_SOC_DAPM_OUTPUT("SPORN"),
1200 SND_SOC_DAPM_OUTPUT("HPOL"),
1201 SND_SOC_DAPM_OUTPUT("HPOR"),
1202 SND_SOC_DAPM_OUTPUT("LOUTL"),
1203 SND_SOC_DAPM_OUTPUT("LOUTR"),
1204 SND_SOC_DAPM_OUTPUT("MONOP"),
1205 SND_SOC_DAPM_OUTPUT("MONON"),
1206};
1207
1208static const struct snd_soc_dapm_route rt5640_dapm_routes[] = {
1209 {"IN1P", NULL, "LDO2"},
1210 {"IN2P", NULL, "LDO2"},
1211
1212 {"DMIC L1", NULL, "DMIC1"},
1213 {"DMIC R1", NULL, "DMIC1"},
1214 {"DMIC L2", NULL, "DMIC2"},
1215 {"DMIC R2", NULL, "DMIC2"},
1216
1217 {"BST1", NULL, "IN1P"},
1218 {"BST1", NULL, "IN1N"},
1219 {"BST2", NULL, "IN2P"},
1220 {"BST2", NULL, "IN2N"},
1221
1222 {"INL VOL", NULL, "IN2P"},
1223 {"INR VOL", NULL, "IN2N"},
1224
1225 {"RECMIXL", "HPOL Switch", "HPOL"},
1226 {"RECMIXL", "INL Switch", "INL VOL"},
1227 {"RECMIXL", "BST2 Switch", "BST2"},
1228 {"RECMIXL", "BST1 Switch", "BST1"},
1229 {"RECMIXL", "OUT MIXL Switch", "OUT MIXL"},
1230
1231 {"RECMIXR", "HPOR Switch", "HPOR"},
1232 {"RECMIXR", "INR Switch", "INR VOL"},
1233 {"RECMIXR", "BST2 Switch", "BST2"},
1234 {"RECMIXR", "BST1 Switch", "BST1"},
1235 {"RECMIXR", "OUT MIXR Switch", "OUT MIXR"},
1236
1237 {"ADC L", NULL, "RECMIXL"},
1238 {"ADC R", NULL, "RECMIXR"},
1239
1240 {"DMIC L1", NULL, "DMIC CLK"},
1241 {"DMIC L1", NULL, "DMIC1 Power"},
1242 {"DMIC R1", NULL, "DMIC CLK"},
1243 {"DMIC R1", NULL, "DMIC1 Power"},
1244 {"DMIC L2", NULL, "DMIC CLK"},
1245 {"DMIC L2", NULL, "DMIC2 Power"},
1246 {"DMIC R2", NULL, "DMIC CLK"},
1247 {"DMIC R2", NULL, "DMIC2 Power"},
1248
1249 {"Stereo ADC L2 Mux", "DMIC1", "DMIC L1"},
1250 {"Stereo ADC L2 Mux", "DMIC2", "DMIC L2"},
1251 {"Stereo ADC L2 Mux", "DIG MIX", "DIG MIXL"},
1252 {"Stereo ADC L1 Mux", "ADC", "ADC L"},
1253 {"Stereo ADC L1 Mux", "DIG MIX", "DIG MIXL"},
1254
1255 {"Stereo ADC R1 Mux", "ADC", "ADC R"},
1256 {"Stereo ADC R1 Mux", "DIG MIX", "DIG MIXR"},
1257 {"Stereo ADC R2 Mux", "DMIC1", "DMIC R1"},
1258 {"Stereo ADC R2 Mux", "DMIC2", "DMIC R2"},
1259 {"Stereo ADC R2 Mux", "DIG MIX", "DIG MIXR"},
1260
1261 {"Mono ADC L2 Mux", "DMIC L1", "DMIC L1"},
1262 {"Mono ADC L2 Mux", "DMIC L2", "DMIC L2"},
1263 {"Mono ADC L2 Mux", "Mono DAC MIXL", "Mono DAC MIXL"},
1264 {"Mono ADC L1 Mux", "Mono DAC MIXL", "Mono DAC MIXL"},
1265 {"Mono ADC L1 Mux", "ADCL", "ADC L"},
1266
1267 {"Mono ADC R1 Mux", "Mono DAC MIXR", "Mono DAC MIXR"},
1268 {"Mono ADC R1 Mux", "ADCR", "ADC R"},
1269 {"Mono ADC R2 Mux", "DMIC R1", "DMIC R1"},
1270 {"Mono ADC R2 Mux", "DMIC R2", "DMIC R2"},
1271 {"Mono ADC R2 Mux", "Mono DAC MIXR", "Mono DAC MIXR"},
1272
1273 {"Stereo ADC MIXL", "ADC1 Switch", "Stereo ADC L1 Mux"},
1274 {"Stereo ADC MIXL", "ADC2 Switch", "Stereo ADC L2 Mux"},
1275 {"Stereo ADC MIXL", NULL, "Stereo Filter"},
Oder Chiou218a3f92014-03-28 20:28:26 +08001276 {"Stereo Filter", NULL, "PLL1", is_sys_clk_from_pll},
Bard Liao997b0522013-06-11 13:10:16 +08001277
1278 {"Stereo ADC MIXR", "ADC1 Switch", "Stereo ADC R1 Mux"},
1279 {"Stereo ADC MIXR", "ADC2 Switch", "Stereo ADC R2 Mux"},
1280 {"Stereo ADC MIXR", NULL, "Stereo Filter"},
Oder Chiou218a3f92014-03-28 20:28:26 +08001281 {"Stereo Filter", NULL, "PLL1", is_sys_clk_from_pll},
Bard Liao997b0522013-06-11 13:10:16 +08001282
1283 {"Mono ADC MIXL", "ADC1 Switch", "Mono ADC L1 Mux"},
1284 {"Mono ADC MIXL", "ADC2 Switch", "Mono ADC L2 Mux"},
1285 {"Mono ADC MIXL", NULL, "Mono Left Filter"},
Oder Chiou218a3f92014-03-28 20:28:26 +08001286 {"Mono Left Filter", NULL, "PLL1", is_sys_clk_from_pll},
Bard Liao997b0522013-06-11 13:10:16 +08001287
1288 {"Mono ADC MIXR", "ADC1 Switch", "Mono ADC R1 Mux"},
1289 {"Mono ADC MIXR", "ADC2 Switch", "Mono ADC R2 Mux"},
1290 {"Mono ADC MIXR", NULL, "Mono Right Filter"},
Oder Chiou218a3f92014-03-28 20:28:26 +08001291 {"Mono Right Filter", NULL, "PLL1", is_sys_clk_from_pll},
Bard Liao997b0522013-06-11 13:10:16 +08001292
1293 {"IF2 ADC L", NULL, "Mono ADC MIXL"},
1294 {"IF2 ADC R", NULL, "Mono ADC MIXR"},
1295 {"IF1 ADC L", NULL, "Stereo ADC MIXL"},
1296 {"IF1 ADC R", NULL, "Stereo ADC MIXR"},
1297
1298 {"IF1 ADC", NULL, "I2S1"},
1299 {"IF1 ADC", NULL, "IF1 ADC L"},
1300 {"IF1 ADC", NULL, "IF1 ADC R"},
1301 {"IF2 ADC", NULL, "I2S2"},
1302 {"IF2 ADC", NULL, "IF2 ADC L"},
1303 {"IF2 ADC", NULL, "IF2 ADC R"},
1304
1305 {"DAI1 TX Mux", "1:1|2:2", "IF1 ADC"},
1306 {"DAI1 TX Mux", "1:2|2:1", "IF2 ADC"},
1307 {"DAI1 IF1 Mux", "1:1|2:1", "IF1 ADC"},
1308 {"DAI1 IF2 Mux", "1:1|2:1", "IF2 ADC"},
1309 {"SDI1 TX Mux", "IF1", "DAI1 IF1 Mux"},
1310 {"SDI1 TX Mux", "IF2", "DAI1 IF2 Mux"},
1311
1312 {"DAI2 TX Mux", "1:2|2:1", "IF1 ADC"},
1313 {"DAI2 TX Mux", "1:1|2:2", "IF2 ADC"},
1314 {"DAI2 IF1 Mux", "1:2|2:2", "IF1 ADC"},
1315 {"DAI2 IF2 Mux", "1:2|2:2", "IF2 ADC"},
1316 {"SDI2 TX Mux", "IF1", "DAI2 IF1 Mux"},
1317 {"SDI2 TX Mux", "IF2", "DAI2 IF2 Mux"},
1318
1319 {"AIF1TX", NULL, "DAI1 TX Mux"},
1320 {"AIF1TX", NULL, "SDI1 TX Mux"},
1321 {"AIF2TX", NULL, "DAI2 TX Mux"},
1322 {"AIF2TX", NULL, "SDI2 TX Mux"},
1323
1324 {"DAI1 RX Mux", "1:1|2:2", "AIF1RX"},
1325 {"DAI1 RX Mux", "1:1|2:1", "AIF1RX"},
1326 {"DAI1 RX Mux", "1:2|2:1", "AIF2RX"},
1327 {"DAI1 RX Mux", "1:2|2:2", "AIF2RX"},
1328
1329 {"DAI2 RX Mux", "1:2|2:1", "AIF1RX"},
1330 {"DAI2 RX Mux", "1:1|2:1", "AIF1RX"},
1331 {"DAI2 RX Mux", "1:1|2:2", "AIF2RX"},
1332 {"DAI2 RX Mux", "1:2|2:2", "AIF2RX"},
1333
1334 {"IF1 DAC", NULL, "I2S1"},
1335 {"IF1 DAC", NULL, "DAI1 RX Mux"},
1336 {"IF2 DAC", NULL, "I2S2"},
1337 {"IF2 DAC", NULL, "DAI2 RX Mux"},
1338
1339 {"IF1 DAC L", NULL, "IF1 DAC"},
1340 {"IF1 DAC R", NULL, "IF1 DAC"},
1341 {"IF2 DAC L", NULL, "IF2 DAC"},
1342 {"IF2 DAC R", NULL, "IF2 DAC"},
1343
1344 {"DAC MIXL", "Stereo ADC Switch", "Stereo ADC MIXL"},
1345 {"DAC MIXL", "INF1 Switch", "IF1 DAC L"},
1346 {"DAC MIXR", "Stereo ADC Switch", "Stereo ADC MIXR"},
1347 {"DAC MIXR", "INF1 Switch", "IF1 DAC R"},
1348
1349 {"ANC", NULL, "Stereo ADC MIXL"},
1350 {"ANC", NULL, "Stereo ADC MIXR"},
1351
1352 {"Audio DSP", NULL, "DAC MIXL"},
1353 {"Audio DSP", NULL, "DAC MIXR"},
1354
1355 {"DAC L2 Mux", "IF2", "IF2 DAC L"},
1356 {"DAC L2 Mux", "Base L/R", "Audio DSP"},
1357
1358 {"DAC R2 Mux", "IF2", "IF2 DAC R"},
1359
1360 {"Stereo DAC MIXL", "DAC L1 Switch", "DAC MIXL"},
1361 {"Stereo DAC MIXL", "DAC L2 Switch", "DAC L2 Mux"},
1362 {"Stereo DAC MIXL", "ANC Switch", "ANC"},
1363 {"Stereo DAC MIXR", "DAC R1 Switch", "DAC MIXR"},
1364 {"Stereo DAC MIXR", "DAC R2 Switch", "DAC R2 Mux"},
1365 {"Stereo DAC MIXR", "ANC Switch", "ANC"},
1366
1367 {"Mono DAC MIXL", "DAC L1 Switch", "DAC MIXL"},
1368 {"Mono DAC MIXL", "DAC L2 Switch", "DAC L2 Mux"},
1369 {"Mono DAC MIXL", "DAC R2 Switch", "DAC R2 Mux"},
1370 {"Mono DAC MIXR", "DAC R1 Switch", "DAC MIXR"},
1371 {"Mono DAC MIXR", "DAC R2 Switch", "DAC R2 Mux"},
1372 {"Mono DAC MIXR", "DAC L2 Switch", "DAC L2 Mux"},
1373
1374 {"DIG MIXL", "DAC L1 Switch", "DAC MIXL"},
1375 {"DIG MIXL", "DAC L2 Switch", "DAC L2 Mux"},
1376 {"DIG MIXR", "DAC R1 Switch", "DAC MIXR"},
1377 {"DIG MIXR", "DAC R2 Switch", "DAC R2 Mux"},
1378
1379 {"DAC L1", NULL, "Stereo DAC MIXL"},
Oder Chiou218a3f92014-03-28 20:28:26 +08001380 {"DAC L1", NULL, "PLL1", is_sys_clk_from_pll},
Bard Liao997b0522013-06-11 13:10:16 +08001381 {"DAC R1", NULL, "Stereo DAC MIXR"},
Oder Chiou218a3f92014-03-28 20:28:26 +08001382 {"DAC R1", NULL, "PLL1", is_sys_clk_from_pll},
Bard Liao997b0522013-06-11 13:10:16 +08001383 {"DAC L2", NULL, "Mono DAC MIXL"},
Oder Chiou218a3f92014-03-28 20:28:26 +08001384 {"DAC L2", NULL, "PLL1", is_sys_clk_from_pll},
Bard Liao997b0522013-06-11 13:10:16 +08001385 {"DAC R2", NULL, "Mono DAC MIXR"},
Oder Chiou218a3f92014-03-28 20:28:26 +08001386 {"DAC R2", NULL, "PLL1", is_sys_clk_from_pll},
Bard Liao997b0522013-06-11 13:10:16 +08001387
1388 {"SPK MIXL", "REC MIXL Switch", "RECMIXL"},
1389 {"SPK MIXL", "INL Switch", "INL VOL"},
1390 {"SPK MIXL", "DAC L1 Switch", "DAC L1"},
1391 {"SPK MIXL", "DAC L2 Switch", "DAC L2"},
1392 {"SPK MIXL", "OUT MIXL Switch", "OUT MIXL"},
1393 {"SPK MIXR", "REC MIXR Switch", "RECMIXR"},
1394 {"SPK MIXR", "INR Switch", "INR VOL"},
1395 {"SPK MIXR", "DAC R1 Switch", "DAC R1"},
1396 {"SPK MIXR", "DAC R2 Switch", "DAC R2"},
1397 {"SPK MIXR", "OUT MIXR Switch", "OUT MIXR"},
1398
1399 {"OUT MIXL", "SPK MIXL Switch", "SPK MIXL"},
1400 {"OUT MIXL", "BST1 Switch", "BST1"},
1401 {"OUT MIXL", "INL Switch", "INL VOL"},
1402 {"OUT MIXL", "REC MIXL Switch", "RECMIXL"},
1403 {"OUT MIXL", "DAC R2 Switch", "DAC R2"},
1404 {"OUT MIXL", "DAC L2 Switch", "DAC L2"},
1405 {"OUT MIXL", "DAC L1 Switch", "DAC L1"},
1406
1407 {"OUT MIXR", "SPK MIXR Switch", "SPK MIXR"},
1408 {"OUT MIXR", "BST2 Switch", "BST2"},
1409 {"OUT MIXR", "BST1 Switch", "BST1"},
1410 {"OUT MIXR", "INR Switch", "INR VOL"},
1411 {"OUT MIXR", "REC MIXR Switch", "RECMIXR"},
1412 {"OUT MIXR", "DAC L2 Switch", "DAC L2"},
1413 {"OUT MIXR", "DAC R2 Switch", "DAC R2"},
1414 {"OUT MIXR", "DAC R1 Switch", "DAC R1"},
1415
1416 {"SPKVOL L", NULL, "SPK MIXL"},
1417 {"SPKVOL R", NULL, "SPK MIXR"},
1418 {"HPOVOL L", NULL, "OUT MIXL"},
1419 {"HPOVOL R", NULL, "OUT MIXR"},
1420 {"OUTVOL L", NULL, "OUT MIXL"},
1421 {"OUTVOL R", NULL, "OUT MIXR"},
1422
1423 {"SPOL MIX", "DAC R1 Switch", "DAC R1"},
1424 {"SPOL MIX", "DAC L1 Switch", "DAC L1"},
1425 {"SPOL MIX", "SPKVOL R Switch", "SPKVOL R"},
1426 {"SPOL MIX", "SPKVOL L Switch", "SPKVOL L"},
1427 {"SPOL MIX", "BST1 Switch", "BST1"},
1428 {"SPOR MIX", "DAC R1 Switch", "DAC R1"},
1429 {"SPOR MIX", "SPKVOL R Switch", "SPKVOL R"},
1430 {"SPOR MIX", "BST1 Switch", "BST1"},
1431
1432 {"HPO MIX L", "HPO MIX DAC2 Switch", "DAC L2"},
1433 {"HPO MIX L", "HPO MIX DAC1 Switch", "DAC L1"},
1434 {"HPO MIX L", "HPO MIX HPVOL Switch", "HPOVOL L"},
Bard Liao246693b2013-08-23 10:29:26 +08001435 {"HPO MIX L", NULL, "HP L Amp"},
Bard Liao997b0522013-06-11 13:10:16 +08001436 {"HPO MIX R", "HPO MIX DAC2 Switch", "DAC R2"},
1437 {"HPO MIX R", "HPO MIX DAC1 Switch", "DAC R1"},
1438 {"HPO MIX R", "HPO MIX HPVOL Switch", "HPOVOL R"},
Bard Liao246693b2013-08-23 10:29:26 +08001439 {"HPO MIX R", NULL, "HP R Amp"},
Bard Liao997b0522013-06-11 13:10:16 +08001440
1441 {"LOUT MIX", "DAC L1 Switch", "DAC L1"},
1442 {"LOUT MIX", "DAC R1 Switch", "DAC R1"},
1443 {"LOUT MIX", "OUTVOL L Switch", "OUTVOL L"},
1444 {"LOUT MIX", "OUTVOL R Switch", "OUTVOL R"},
1445
1446 {"Mono MIX", "DAC R2 Switch", "DAC R2"},
1447 {"Mono MIX", "DAC L2 Switch", "DAC L2"},
1448 {"Mono MIX", "OUTVOL R Switch", "OUTVOL R"},
1449 {"Mono MIX", "OUTVOL L Switch", "OUTVOL L"},
1450 {"Mono MIX", "BST1 Switch", "BST1"},
1451
Bard Liao246693b2013-08-23 10:29:26 +08001452 {"HP Amp", NULL, "HPO MIX L"},
1453 {"HP Amp", NULL, "HPO MIX R"},
Bard Liao997b0522013-06-11 13:10:16 +08001454
Bard Liao246693b2013-08-23 10:29:26 +08001455 {"Speaker L Playback", "Switch", "SPOL MIX"},
1456 {"Speaker R Playback", "Switch", "SPOR MIX"},
1457 {"SPOLP", NULL, "Speaker L Playback"},
1458 {"SPOLN", NULL, "Speaker L Playback"},
1459 {"SPORP", NULL, "Speaker R Playback"},
1460 {"SPORN", NULL, "Speaker R Playback"},
Bard Liao997b0522013-06-11 13:10:16 +08001461
1462 {"SPOLP", NULL, "Improve SPK Amp Drv"},
1463 {"SPOLN", NULL, "Improve SPK Amp Drv"},
1464 {"SPORP", NULL, "Improve SPK Amp Drv"},
1465 {"SPORN", NULL, "Improve SPK Amp Drv"},
1466
1467 {"HPOL", NULL, "Improve HP Amp Drv"},
1468 {"HPOR", NULL, "Improve HP Amp Drv"},
1469
Bard Liao246693b2013-08-23 10:29:26 +08001470 {"HP L Playback", "Switch", "HP Amp"},
1471 {"HP R Playback", "Switch", "HP Amp"},
1472 {"HPOL", NULL, "HP L Playback"},
1473 {"HPOR", NULL, "HP R Playback"},
Bard Liao997b0522013-06-11 13:10:16 +08001474 {"LOUTL", NULL, "LOUT MIX"},
1475 {"LOUTR", NULL, "LOUT MIX"},
1476 {"MONOP", NULL, "Mono MIX"},
1477 {"MONON", NULL, "Mono MIX"},
1478 {"MONOP", NULL, "Improve MONO Amp Drv"},
1479};
1480
1481static int get_sdp_info(struct snd_soc_codec *codec, int dai_id)
1482{
1483 int ret = 0, val;
1484
1485 if (codec == NULL)
1486 return -EINVAL;
1487
1488 val = snd_soc_read(codec, RT5640_I2S1_SDP);
1489 val = (val & RT5640_I2S_IF_MASK) >> RT5640_I2S_IF_SFT;
1490 switch (dai_id) {
1491 case RT5640_AIF1:
1492 switch (val) {
1493 case RT5640_IF_123:
1494 case RT5640_IF_132:
1495 ret |= RT5640_U_IF1;
1496 break;
1497 case RT5640_IF_113:
1498 ret |= RT5640_U_IF1;
1499 case RT5640_IF_312:
1500 case RT5640_IF_213:
1501 ret |= RT5640_U_IF2;
1502 break;
1503 }
1504 break;
1505
1506 case RT5640_AIF2:
1507 switch (val) {
1508 case RT5640_IF_231:
1509 case RT5640_IF_213:
1510 ret |= RT5640_U_IF1;
1511 break;
1512 case RT5640_IF_223:
1513 ret |= RT5640_U_IF1;
1514 case RT5640_IF_123:
1515 case RT5640_IF_321:
1516 ret |= RT5640_U_IF2;
1517 break;
1518 }
1519 break;
1520
1521 default:
1522 ret = -EINVAL;
1523 break;
1524 }
1525
1526 return ret;
1527}
1528
1529static int get_clk_info(int sclk, int rate)
1530{
1531 int i, pd[] = {1, 2, 3, 4, 6, 8, 12, 16};
1532
1533 if (sclk <= 0 || rate <= 0)
1534 return -EINVAL;
1535
1536 rate = rate << 8;
1537 for (i = 0; i < ARRAY_SIZE(pd); i++)
1538 if (sclk == rate * pd[i])
1539 return i;
1540
1541 return -EINVAL;
1542}
1543
1544static int rt5640_hw_params(struct snd_pcm_substream *substream,
1545 struct snd_pcm_hw_params *params, struct snd_soc_dai *dai)
1546{
Lars-Peter Clausenab642462014-03-13 21:24:54 +01001547 struct snd_soc_codec *codec = dai->codec;
Bard Liao997b0522013-06-11 13:10:16 +08001548 struct rt5640_priv *rt5640 = snd_soc_codec_get_drvdata(codec);
Takashi Iwai5a7615c2013-10-30 08:35:06 +01001549 unsigned int val_len = 0, val_clk, mask_clk;
1550 int dai_sel, pre_div, bclk_ms, frame_size;
Bard Liao997b0522013-06-11 13:10:16 +08001551
1552 rt5640->lrck[dai->id] = params_rate(params);
1553 pre_div = get_clk_info(rt5640->sysclk, rt5640->lrck[dai->id]);
1554 if (pre_div < 0) {
Liam Girdwood9e9cb9b2013-09-13 17:57:35 +01001555 dev_err(codec->dev, "Unsupported clock setting %d for DAI %d\n",
1556 rt5640->lrck[dai->id], dai->id);
Bard Liao997b0522013-06-11 13:10:16 +08001557 return -EINVAL;
1558 }
1559 frame_size = snd_soc_params_to_frame_size(params);
1560 if (frame_size < 0) {
1561 dev_err(codec->dev, "Unsupported frame size: %d\n", frame_size);
1562 return frame_size;
1563 }
1564 if (frame_size > 32)
1565 bclk_ms = 1;
1566 else
1567 bclk_ms = 0;
1568 rt5640->bclk[dai->id] = rt5640->lrck[dai->id] * (32 << bclk_ms);
1569
1570 dev_dbg(dai->dev, "bclk is %dHz and lrck is %dHz\n",
1571 rt5640->bclk[dai->id], rt5640->lrck[dai->id]);
1572 dev_dbg(dai->dev, "bclk_ms is %d and pre_div is %d for iis %d\n",
1573 bclk_ms, pre_div, dai->id);
1574
Oder Chiou9bccae72014-03-27 19:34:51 +08001575 switch (params_width(params)) {
1576 case 16:
Bard Liao997b0522013-06-11 13:10:16 +08001577 break;
Oder Chiou9bccae72014-03-27 19:34:51 +08001578 case 20:
Bard Liao997b0522013-06-11 13:10:16 +08001579 val_len |= RT5640_I2S_DL_20;
1580 break;
Oder Chiou9bccae72014-03-27 19:34:51 +08001581 case 24:
Bard Liao997b0522013-06-11 13:10:16 +08001582 val_len |= RT5640_I2S_DL_24;
1583 break;
Oder Chiou9bccae72014-03-27 19:34:51 +08001584 case 8:
Bard Liao997b0522013-06-11 13:10:16 +08001585 val_len |= RT5640_I2S_DL_8;
1586 break;
1587 default:
1588 return -EINVAL;
1589 }
1590
1591 dai_sel = get_sdp_info(codec, dai->id);
1592 if (dai_sel < 0) {
1593 dev_err(codec->dev, "Failed to get sdp info: %d\n", dai_sel);
1594 return -EINVAL;
1595 }
1596 if (dai_sel & RT5640_U_IF1) {
1597 mask_clk = RT5640_I2S_BCLK_MS1_MASK | RT5640_I2S_PD1_MASK;
1598 val_clk = bclk_ms << RT5640_I2S_BCLK_MS1_SFT |
1599 pre_div << RT5640_I2S_PD1_SFT;
1600 snd_soc_update_bits(codec, RT5640_I2S1_SDP,
1601 RT5640_I2S_DL_MASK, val_len);
1602 snd_soc_update_bits(codec, RT5640_ADDA_CLK1, mask_clk, val_clk);
1603 }
1604 if (dai_sel & RT5640_U_IF2) {
1605 mask_clk = RT5640_I2S_BCLK_MS2_MASK | RT5640_I2S_PD2_MASK;
1606 val_clk = bclk_ms << RT5640_I2S_BCLK_MS2_SFT |
1607 pre_div << RT5640_I2S_PD2_SFT;
1608 snd_soc_update_bits(codec, RT5640_I2S2_SDP,
1609 RT5640_I2S_DL_MASK, val_len);
1610 snd_soc_update_bits(codec, RT5640_ADDA_CLK1, mask_clk, val_clk);
1611 }
1612
1613 return 0;
1614}
1615
1616static int rt5640_set_dai_fmt(struct snd_soc_dai *dai, unsigned int fmt)
1617{
1618 struct snd_soc_codec *codec = dai->codec;
1619 struct rt5640_priv *rt5640 = snd_soc_codec_get_drvdata(codec);
Takashi Iwai5a7615c2013-10-30 08:35:06 +01001620 unsigned int reg_val = 0;
1621 int dai_sel;
Bard Liao997b0522013-06-11 13:10:16 +08001622
1623 switch (fmt & SND_SOC_DAIFMT_MASTER_MASK) {
1624 case SND_SOC_DAIFMT_CBM_CFM:
1625 rt5640->master[dai->id] = 1;
1626 break;
1627 case SND_SOC_DAIFMT_CBS_CFS:
1628 reg_val |= RT5640_I2S_MS_S;
1629 rt5640->master[dai->id] = 0;
1630 break;
1631 default:
1632 return -EINVAL;
1633 }
1634
1635 switch (fmt & SND_SOC_DAIFMT_INV_MASK) {
1636 case SND_SOC_DAIFMT_NB_NF:
1637 break;
1638 case SND_SOC_DAIFMT_IB_NF:
1639 reg_val |= RT5640_I2S_BP_INV;
1640 break;
1641 default:
1642 return -EINVAL;
1643 }
1644
1645 switch (fmt & SND_SOC_DAIFMT_FORMAT_MASK) {
1646 case SND_SOC_DAIFMT_I2S:
1647 break;
1648 case SND_SOC_DAIFMT_LEFT_J:
1649 reg_val |= RT5640_I2S_DF_LEFT;
1650 break;
1651 case SND_SOC_DAIFMT_DSP_A:
1652 reg_val |= RT5640_I2S_DF_PCM_A;
1653 break;
1654 case SND_SOC_DAIFMT_DSP_B:
1655 reg_val |= RT5640_I2S_DF_PCM_B;
1656 break;
1657 default:
1658 return -EINVAL;
1659 }
1660
1661 dai_sel = get_sdp_info(codec, dai->id);
1662 if (dai_sel < 0) {
1663 dev_err(codec->dev, "Failed to get sdp info: %d\n", dai_sel);
1664 return -EINVAL;
1665 }
1666 if (dai_sel & RT5640_U_IF1) {
1667 snd_soc_update_bits(codec, RT5640_I2S1_SDP,
1668 RT5640_I2S_MS_MASK | RT5640_I2S_BP_MASK |
1669 RT5640_I2S_DF_MASK, reg_val);
1670 }
1671 if (dai_sel & RT5640_U_IF2) {
1672 snd_soc_update_bits(codec, RT5640_I2S2_SDP,
1673 RT5640_I2S_MS_MASK | RT5640_I2S_BP_MASK |
1674 RT5640_I2S_DF_MASK, reg_val);
1675 }
1676
1677 return 0;
1678}
1679
1680static int rt5640_set_dai_sysclk(struct snd_soc_dai *dai,
1681 int clk_id, unsigned int freq, int dir)
1682{
1683 struct snd_soc_codec *codec = dai->codec;
1684 struct rt5640_priv *rt5640 = snd_soc_codec_get_drvdata(codec);
1685 unsigned int reg_val = 0;
1686
1687 if (freq == rt5640->sysclk && clk_id == rt5640->sysclk_src)
1688 return 0;
1689
1690 switch (clk_id) {
1691 case RT5640_SCLK_S_MCLK:
1692 reg_val |= RT5640_SCLK_SRC_MCLK;
1693 break;
1694 case RT5640_SCLK_S_PLL1:
1695 reg_val |= RT5640_SCLK_SRC_PLL1;
1696 break;
Bard Liao997b0522013-06-11 13:10:16 +08001697 default:
1698 dev_err(codec->dev, "Invalid clock id (%d)\n", clk_id);
1699 return -EINVAL;
1700 }
1701 snd_soc_update_bits(codec, RT5640_GLB_CLK,
1702 RT5640_SCLK_SRC_MASK, reg_val);
1703 rt5640->sysclk = freq;
1704 rt5640->sysclk_src = clk_id;
1705
1706 dev_dbg(dai->dev, "Sysclk is %dHz and clock id is %d\n", freq, clk_id);
1707 return 0;
1708}
1709
1710/**
1711 * rt5640_pll_calc - Calculate PLL M/N/K code.
1712 * @freq_in: external clock provided to codec.
1713 * @freq_out: target clock which codec works on.
1714 * @pll_code: Pointer to structure with M, N, K and bypass flag.
1715 *
1716 * Calculate M/N/K code to configure PLL for codec. And K is assigned to 2
1717 * which make calculation more efficiently.
1718 *
1719 * Returns 0 for success or negative error code.
1720 */
1721static int rt5640_pll_calc(const unsigned int freq_in,
1722 const unsigned int freq_out, struct rt5640_pll_code *pll_code)
1723{
1724 int max_n = RT5640_PLL_N_MAX, max_m = RT5640_PLL_M_MAX;
1725 int n = 0, m = 0, red, n_t, m_t, in_t, out_t;
1726 int red_t = abs(freq_out - freq_in);
1727 bool bypass = false;
1728
1729 if (RT5640_PLL_INP_MAX < freq_in || RT5640_PLL_INP_MIN > freq_in)
1730 return -EINVAL;
1731
1732 for (n_t = 0; n_t <= max_n; n_t++) {
1733 in_t = (freq_in >> 1) + (freq_in >> 2) * n_t;
1734 if (in_t < 0)
1735 continue;
1736 if (in_t == freq_out) {
1737 bypass = true;
1738 n = n_t;
1739 goto code_find;
1740 }
1741 for (m_t = 0; m_t <= max_m; m_t++) {
1742 out_t = in_t / (m_t + 2);
1743 red = abs(out_t - freq_out);
1744 if (red < red_t) {
1745 n = n_t;
1746 m = m_t;
1747 if (red == 0)
1748 goto code_find;
1749 red_t = red;
1750 }
1751 }
1752 }
1753 pr_debug("Only get approximation about PLL\n");
1754
1755code_find:
1756 pll_code->m_bp = bypass;
1757 pll_code->m_code = m;
1758 pll_code->n_code = n;
1759 pll_code->k_code = 2;
1760 return 0;
1761}
1762
1763static int rt5640_set_dai_pll(struct snd_soc_dai *dai, int pll_id, int source,
1764 unsigned int freq_in, unsigned int freq_out)
1765{
1766 struct snd_soc_codec *codec = dai->codec;
1767 struct rt5640_priv *rt5640 = snd_soc_codec_get_drvdata(codec);
1768 struct rt5640_pll_code *pll_code = &rt5640->pll_code;
1769 int ret, dai_sel;
1770
1771 if (source == rt5640->pll_src && freq_in == rt5640->pll_in &&
1772 freq_out == rt5640->pll_out)
1773 return 0;
1774
1775 if (!freq_in || !freq_out) {
1776 dev_dbg(codec->dev, "PLL disabled\n");
1777
1778 rt5640->pll_in = 0;
1779 rt5640->pll_out = 0;
1780 snd_soc_update_bits(codec, RT5640_GLB_CLK,
1781 RT5640_SCLK_SRC_MASK, RT5640_SCLK_SRC_MCLK);
1782 return 0;
1783 }
1784
1785 switch (source) {
1786 case RT5640_PLL1_S_MCLK:
1787 snd_soc_update_bits(codec, RT5640_GLB_CLK,
1788 RT5640_PLL1_SRC_MASK, RT5640_PLL1_SRC_MCLK);
1789 break;
1790 case RT5640_PLL1_S_BCLK1:
1791 case RT5640_PLL1_S_BCLK2:
1792 dai_sel = get_sdp_info(codec, dai->id);
1793 if (dai_sel < 0) {
1794 dev_err(codec->dev,
1795 "Failed to get sdp info: %d\n", dai_sel);
1796 return -EINVAL;
1797 }
1798 if (dai_sel & RT5640_U_IF1) {
1799 snd_soc_update_bits(codec, RT5640_GLB_CLK,
1800 RT5640_PLL1_SRC_MASK, RT5640_PLL1_SRC_BCLK1);
1801 }
1802 if (dai_sel & RT5640_U_IF2) {
1803 snd_soc_update_bits(codec, RT5640_GLB_CLK,
1804 RT5640_PLL1_SRC_MASK, RT5640_PLL1_SRC_BCLK2);
1805 }
1806 break;
1807 default:
1808 dev_err(codec->dev, "Unknown PLL source %d\n", source);
1809 return -EINVAL;
1810 }
1811
1812 ret = rt5640_pll_calc(freq_in, freq_out, pll_code);
1813 if (ret < 0) {
1814 dev_err(codec->dev, "Unsupport input clock %d\n", freq_in);
1815 return ret;
1816 }
1817
1818 dev_dbg(codec->dev, "bypass=%d m=%d n=%d k=2\n", pll_code->m_bp,
1819 (pll_code->m_bp ? 0 : pll_code->m_code), pll_code->n_code);
1820
1821 snd_soc_write(codec, RT5640_PLL_CTRL1,
1822 pll_code->n_code << RT5640_PLL_N_SFT | pll_code->k_code);
1823 snd_soc_write(codec, RT5640_PLL_CTRL2,
1824 (pll_code->m_bp ? 0 : pll_code->m_code) << RT5640_PLL_M_SFT |
1825 pll_code->m_bp << RT5640_PLL_M_BP_SFT);
1826
1827 rt5640->pll_in = freq_in;
1828 rt5640->pll_out = freq_out;
1829 rt5640->pll_src = source;
1830
1831 return 0;
1832}
1833
1834static int rt5640_set_bias_level(struct snd_soc_codec *codec,
1835 enum snd_soc_bias_level level)
1836{
Bard Liao997b0522013-06-11 13:10:16 +08001837 switch (level) {
1838 case SND_SOC_BIAS_STANDBY:
1839 if (SND_SOC_BIAS_OFF == codec->dapm.bias_level) {
Bard Liao997b0522013-06-11 13:10:16 +08001840 snd_soc_update_bits(codec, RT5640_PWR_ANLG1,
1841 RT5640_PWR_VREF1 | RT5640_PWR_MB |
1842 RT5640_PWR_BG | RT5640_PWR_VREF2,
1843 RT5640_PWR_VREF1 | RT5640_PWR_MB |
1844 RT5640_PWR_BG | RT5640_PWR_VREF2);
Bard Liao246693b2013-08-23 10:29:26 +08001845 usleep_range(10000, 15000);
Bard Liao997b0522013-06-11 13:10:16 +08001846 snd_soc_update_bits(codec, RT5640_PWR_ANLG1,
1847 RT5640_PWR_FV1 | RT5640_PWR_FV2,
1848 RT5640_PWR_FV1 | RT5640_PWR_FV2);
Bard Liao997b0522013-06-11 13:10:16 +08001849 snd_soc_update_bits(codec, RT5640_DUMMY1,
1850 0x0301, 0x0301);
Bard Liao997b0522013-06-11 13:10:16 +08001851 snd_soc_update_bits(codec, RT5640_MICBIAS,
1852 0x0030, 0x0030);
1853 }
1854 break;
1855
1856 case SND_SOC_BIAS_OFF:
1857 snd_soc_write(codec, RT5640_DEPOP_M1, 0x0004);
1858 snd_soc_write(codec, RT5640_DEPOP_M2, 0x1100);
1859 snd_soc_update_bits(codec, RT5640_DUMMY1, 0x1, 0);
1860 snd_soc_write(codec, RT5640_PWR_DIG1, 0x0000);
1861 snd_soc_write(codec, RT5640_PWR_DIG2, 0x0000);
1862 snd_soc_write(codec, RT5640_PWR_VOL, 0x0000);
1863 snd_soc_write(codec, RT5640_PWR_MIXER, 0x0000);
1864 snd_soc_write(codec, RT5640_PWR_ANLG1, 0x0000);
1865 snd_soc_write(codec, RT5640_PWR_ANLG2, 0x0000);
1866 break;
1867
1868 default:
1869 break;
1870 }
1871 codec->dapm.bias_level = level;
1872
1873 return 0;
1874}
1875
1876static int rt5640_probe(struct snd_soc_codec *codec)
1877{
1878 struct rt5640_priv *rt5640 = snd_soc_codec_get_drvdata(codec);
Bard Liao997b0522013-06-11 13:10:16 +08001879
1880 rt5640->codec = codec;
Bard Liao997b0522013-06-11 13:10:16 +08001881
1882 codec->dapm.idle_bias_off = 1;
1883 rt5640_set_bias_level(codec, SND_SOC_BIAS_OFF);
1884
1885 snd_soc_update_bits(codec, RT5640_DUMMY1, 0x0301, 0x0301);
Bard Liao997b0522013-06-11 13:10:16 +08001886 snd_soc_update_bits(codec, RT5640_MICBIAS, 0x0030, 0x0030);
1887 snd_soc_update_bits(codec, RT5640_DSP_PATH2, 0xfc00, 0x0c00);
1888
1889 return 0;
1890}
1891
1892static int rt5640_remove(struct snd_soc_codec *codec)
1893{
1894 rt5640_reset(codec);
1895
1896 return 0;
1897}
1898
1899#ifdef CONFIG_PM
1900static int rt5640_suspend(struct snd_soc_codec *codec)
1901{
1902 struct rt5640_priv *rt5640 = snd_soc_codec_get_drvdata(codec);
1903
1904 rt5640_set_bias_level(codec, SND_SOC_BIAS_OFF);
1905 rt5640_reset(codec);
1906 regcache_cache_only(rt5640->regmap, true);
1907 regcache_mark_dirty(rt5640->regmap);
Mark Browne58f3012013-10-16 17:26:22 +01001908 if (gpio_is_valid(rt5640->pdata.ldo1_en))
1909 gpio_set_value_cansleep(rt5640->pdata.ldo1_en, 0);
Bard Liao997b0522013-06-11 13:10:16 +08001910
1911 return 0;
1912}
1913
1914static int rt5640_resume(struct snd_soc_codec *codec)
1915{
Mark Browne58f3012013-10-16 17:26:22 +01001916 struct rt5640_priv *rt5640 = snd_soc_codec_get_drvdata(codec);
1917
1918 if (gpio_is_valid(rt5640->pdata.ldo1_en)) {
1919 gpio_set_value_cansleep(rt5640->pdata.ldo1_en, 1);
1920 msleep(400);
1921 }
Bard Liao997b0522013-06-11 13:10:16 +08001922
Oder Chiou4c9185b2014-03-27 15:55:47 +08001923 regcache_cache_only(rt5640->regmap, false);
1924 regcache_sync(rt5640->regmap);
1925
Bard Liao997b0522013-06-11 13:10:16 +08001926 return 0;
1927}
1928#else
1929#define rt5640_suspend NULL
1930#define rt5640_resume NULL
1931#endif
1932
1933#define RT5640_STEREO_RATES SNDRV_PCM_RATE_8000_96000
1934#define RT5640_FORMATS (SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S20_3LE | \
1935 SNDRV_PCM_FMTBIT_S24_LE | SNDRV_PCM_FMTBIT_S8)
1936
Stephen Warren9be94ae2013-06-12 15:34:23 -06001937static const struct snd_soc_dai_ops rt5640_aif_dai_ops = {
Bard Liao997b0522013-06-11 13:10:16 +08001938 .hw_params = rt5640_hw_params,
1939 .set_fmt = rt5640_set_dai_fmt,
1940 .set_sysclk = rt5640_set_dai_sysclk,
1941 .set_pll = rt5640_set_dai_pll,
1942};
1943
Stephen Warren9be94ae2013-06-12 15:34:23 -06001944static struct snd_soc_dai_driver rt5640_dai[] = {
Bard Liao997b0522013-06-11 13:10:16 +08001945 {
1946 .name = "rt5640-aif1",
1947 .id = RT5640_AIF1,
1948 .playback = {
1949 .stream_name = "AIF1 Playback",
1950 .channels_min = 1,
1951 .channels_max = 2,
1952 .rates = RT5640_STEREO_RATES,
1953 .formats = RT5640_FORMATS,
1954 },
1955 .capture = {
1956 .stream_name = "AIF1 Capture",
1957 .channels_min = 1,
1958 .channels_max = 2,
1959 .rates = RT5640_STEREO_RATES,
1960 .formats = RT5640_FORMATS,
1961 },
1962 .ops = &rt5640_aif_dai_ops,
1963 },
1964 {
1965 .name = "rt5640-aif2",
1966 .id = RT5640_AIF2,
1967 .playback = {
1968 .stream_name = "AIF2 Playback",
1969 .channels_min = 1,
1970 .channels_max = 2,
1971 .rates = RT5640_STEREO_RATES,
1972 .formats = RT5640_FORMATS,
1973 },
1974 .capture = {
1975 .stream_name = "AIF2 Capture",
1976 .channels_min = 1,
1977 .channels_max = 2,
1978 .rates = RT5640_STEREO_RATES,
1979 .formats = RT5640_FORMATS,
1980 },
1981 .ops = &rt5640_aif_dai_ops,
1982 },
1983};
1984
1985static struct snd_soc_codec_driver soc_codec_dev_rt5640 = {
1986 .probe = rt5640_probe,
1987 .remove = rt5640_remove,
1988 .suspend = rt5640_suspend,
1989 .resume = rt5640_resume,
1990 .set_bias_level = rt5640_set_bias_level,
1991 .controls = rt5640_snd_controls,
1992 .num_controls = ARRAY_SIZE(rt5640_snd_controls),
1993 .dapm_widgets = rt5640_dapm_widgets,
1994 .num_dapm_widgets = ARRAY_SIZE(rt5640_dapm_widgets),
1995 .dapm_routes = rt5640_dapm_routes,
1996 .num_dapm_routes = ARRAY_SIZE(rt5640_dapm_routes),
1997};
1998
1999static const struct regmap_config rt5640_regmap = {
2000 .reg_bits = 8,
2001 .val_bits = 16,
2002
2003 .max_register = RT5640_VENDOR_ID2 + 1 + (ARRAY_SIZE(rt5640_ranges) *
2004 RT5640_PR_SPACING),
2005 .volatile_reg = rt5640_volatile_register,
2006 .readable_reg = rt5640_readable_register,
2007
2008 .cache_type = REGCACHE_RBTREE,
2009 .reg_defaults = rt5640_reg,
2010 .num_reg_defaults = ARRAY_SIZE(rt5640_reg),
2011 .ranges = rt5640_ranges,
2012 .num_ranges = ARRAY_SIZE(rt5640_ranges),
2013};
2014
2015static const struct i2c_device_id rt5640_i2c_id[] = {
2016 { "rt5640", 0 },
2017 { }
2018};
2019MODULE_DEVICE_TABLE(i2c, rt5640_i2c_id);
2020
Stephen Warren03a620d2014-03-31 11:05:17 -06002021#if defined(CONFIG_OF)
2022static const struct of_device_id rt5640_of_match[] = {
2023 { .compatible = "realtek,rt5640", },
2024 {},
2025};
2026MODULE_DEVICE_TABLE(of, rt5640_of_match);
2027#endif
2028
Thierry Reding32fcb972013-09-19 11:18:06 +02002029#ifdef CONFIG_ACPI
Liam Girdwood02b80772013-09-13 17:57:36 +01002030static struct acpi_device_id rt5640_acpi_match[] = {
2031 { "INT33CA", 0 },
Jarkko Nikulab31b2b62014-02-07 09:35:16 +02002032 { "10EC5640", 0 },
Liam Girdwood02b80772013-09-13 17:57:36 +01002033 { },
2034};
2035MODULE_DEVICE_TABLE(acpi, rt5640_acpi_match);
Thierry Reding32fcb972013-09-19 11:18:06 +02002036#endif
Liam Girdwood02b80772013-09-13 17:57:36 +01002037
Stephen Warrendcad9f02013-06-12 11:34:30 -06002038static int rt5640_parse_dt(struct rt5640_priv *rt5640, struct device_node *np)
2039{
2040 rt5640->pdata.in1_diff = of_property_read_bool(np,
2041 "realtek,in1-differential");
2042 rt5640->pdata.in2_diff = of_property_read_bool(np,
2043 "realtek,in2-differential");
2044
2045 rt5640->pdata.ldo1_en = of_get_named_gpio(np,
2046 "realtek,ldo1-en-gpios", 0);
2047 /*
2048 * LDO1_EN is optional (it may be statically tied on the board).
2049 * -ENOENT means that the property doesn't exist, i.e. there is no
2050 * GPIO, so is not an error. Any other error code means the property
2051 * exists, but could not be parsed.
2052 */
2053 if (!gpio_is_valid(rt5640->pdata.ldo1_en) &&
2054 (rt5640->pdata.ldo1_en != -ENOENT))
2055 return rt5640->pdata.ldo1_en;
2056
2057 return 0;
2058}
2059
Bard Liao997b0522013-06-11 13:10:16 +08002060static int rt5640_i2c_probe(struct i2c_client *i2c,
2061 const struct i2c_device_id *id)
2062{
2063 struct rt5640_platform_data *pdata = dev_get_platdata(&i2c->dev);
2064 struct rt5640_priv *rt5640;
2065 int ret;
2066 unsigned int val;
2067
2068 rt5640 = devm_kzalloc(&i2c->dev,
2069 sizeof(struct rt5640_priv),
2070 GFP_KERNEL);
2071 if (NULL == rt5640)
2072 return -ENOMEM;
Stephen Warrendcad9f02013-06-12 11:34:30 -06002073 i2c_set_clientdata(i2c, rt5640);
2074
2075 if (pdata) {
2076 rt5640->pdata = *pdata;
2077 /*
2078 * Translate zero'd out (default) pdata value to an invalid
2079 * GPIO ID. This makes the pdata and DT paths consistent in
2080 * terms of the value left in this field when no GPIO is
2081 * specified, but means we can't actually use GPIO 0.
2082 */
2083 if (!rt5640->pdata.ldo1_en)
2084 rt5640->pdata.ldo1_en = -EINVAL;
2085 } else if (i2c->dev.of_node) {
2086 ret = rt5640_parse_dt(rt5640, i2c->dev.of_node);
2087 if (ret)
2088 return ret;
2089 } else
2090 rt5640->pdata.ldo1_en = -EINVAL;
Bard Liao997b0522013-06-11 13:10:16 +08002091
2092 rt5640->regmap = devm_regmap_init_i2c(i2c, &rt5640_regmap);
2093 if (IS_ERR(rt5640->regmap)) {
2094 ret = PTR_ERR(rt5640->regmap);
2095 dev_err(&i2c->dev, "Failed to allocate register map: %d\n",
2096 ret);
2097 return ret;
2098 }
2099
Stephen Warrendcad9f02013-06-12 11:34:30 -06002100 if (gpio_is_valid(rt5640->pdata.ldo1_en)) {
Bard Liao997b0522013-06-11 13:10:16 +08002101 ret = devm_gpio_request_one(&i2c->dev, rt5640->pdata.ldo1_en,
2102 GPIOF_OUT_INIT_HIGH,
2103 "RT5640 LDO1_EN");
2104 if (ret < 0) {
2105 dev_err(&i2c->dev, "Failed to request LDO1_EN %d: %d\n",
2106 rt5640->pdata.ldo1_en, ret);
2107 return ret;
2108 }
2109 msleep(400);
2110 }
2111
2112 regmap_read(rt5640->regmap, RT5640_VENDOR_ID2, &val);
2113 if ((val != RT5640_DEVICE_ID)) {
2114 dev_err(&i2c->dev,
2115 "Device with ID register %x is not rt5640/39\n", val);
2116 return -ENODEV;
2117 }
2118
2119 regmap_write(rt5640->regmap, RT5640_RESET, 0);
2120
2121 ret = regmap_register_patch(rt5640->regmap, init_list,
2122 ARRAY_SIZE(init_list));
2123 if (ret != 0)
2124 dev_warn(&i2c->dev, "Failed to apply regmap patch: %d\n", ret);
2125
2126 if (rt5640->pdata.in1_diff)
2127 regmap_update_bits(rt5640->regmap, RT5640_IN1_IN2,
2128 RT5640_IN_DF1, RT5640_IN_DF1);
2129
2130 if (rt5640->pdata.in2_diff)
2131 regmap_update_bits(rt5640->regmap, RT5640_IN3_IN4,
2132 RT5640_IN_DF2, RT5640_IN_DF2);
2133
Oder Chiou71d97a792014-03-28 10:46:18 +08002134 if (rt5640->pdata.dmic_en) {
2135 regmap_update_bits(rt5640->regmap, RT5640_GPIO_CTRL1,
2136 RT5640_GP2_PIN_MASK, RT5640_GP2_PIN_DMIC1_SCL);
2137
2138 if (rt5640->pdata.dmic1_data_pin) {
2139 regmap_update_bits(rt5640->regmap, RT5640_DMIC,
2140 RT5640_DMIC_1_DP_MASK, RT5640_DMIC_1_DP_GPIO3);
2141 regmap_update_bits(rt5640->regmap, RT5640_GPIO_CTRL1,
2142 RT5640_GP3_PIN_MASK, RT5640_GP3_PIN_DMIC1_SDA);
2143 }
2144
2145 if (rt5640->pdata.dmic2_data_pin) {
2146 regmap_update_bits(rt5640->regmap, RT5640_DMIC,
2147 RT5640_DMIC_2_DP_MASK, RT5640_DMIC_2_DP_GPIO4);
2148 regmap_update_bits(rt5640->regmap, RT5640_GPIO_CTRL1,
2149 RT5640_GP4_PIN_MASK, RT5640_GP4_PIN_DMIC2_SDA);
2150 }
2151 }
2152
Bard Liao246693b2013-08-23 10:29:26 +08002153 rt5640->hp_mute = 1;
2154
Bard Liao997b0522013-06-11 13:10:16 +08002155 ret = snd_soc_register_codec(&i2c->dev, &soc_codec_dev_rt5640,
2156 rt5640_dai, ARRAY_SIZE(rt5640_dai));
2157 if (ret < 0)
2158 goto err;
2159
2160 return 0;
2161err:
2162 return ret;
2163}
2164
2165static int rt5640_i2c_remove(struct i2c_client *i2c)
2166{
2167 snd_soc_unregister_codec(&i2c->dev);
2168
2169 return 0;
2170}
2171
Stephen Warren9be94ae2013-06-12 15:34:23 -06002172static struct i2c_driver rt5640_i2c_driver = {
Bard Liao997b0522013-06-11 13:10:16 +08002173 .driver = {
2174 .name = "rt5640",
2175 .owner = THIS_MODULE,
Liam Girdwood02b80772013-09-13 17:57:36 +01002176 .acpi_match_table = ACPI_PTR(rt5640_acpi_match),
Stephen Warren03a620d2014-03-31 11:05:17 -06002177 .of_match_table = of_match_ptr(rt5640_of_match),
Bard Liao997b0522013-06-11 13:10:16 +08002178 },
2179 .probe = rt5640_i2c_probe,
2180 .remove = rt5640_i2c_remove,
2181 .id_table = rt5640_i2c_id,
2182};
2183module_i2c_driver(rt5640_i2c_driver);
2184
2185MODULE_DESCRIPTION("ASoC RT5640 driver");
2186MODULE_AUTHOR("Johnny Hsu <johnnyhsu@realtek.com>");
2187MODULE_LICENSE("GPL v2");