xref: /linux/sound/soc/codecs/max98390.c (revision d97e2634fbdcd238a51bc363267df0139c17f4da)
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3  * max98390.c  --  MAX98390 ALSA Soc Audio driver
4  *
5  * Copyright (C) 2020 Maxim Integrated Products
6  *
7  */
8 
9 #include <linux/acpi.h>
10 #include <linux/cdev.h>
11 #include <linux/dmi.h>
12 #include <linux/firmware.h>
13 #include <linux/gpio/consumer.h>
14 #include <linux/i2c.h>
15 #include <linux/module.h>
16 #include <linux/regmap.h>
17 #include <linux/slab.h>
18 #include <linux/time.h>
19 #include <sound/pcm.h>
20 #include <sound/pcm_params.h>
21 #include <sound/soc.h>
22 #include <sound/tlv.h>
23 
24 #include "max98390.h"
25 
26 static struct reg_default max98390_reg_defaults[] = {
27 	{MAX98390_INT_EN1, 0xf0},
28 	{MAX98390_INT_EN2, 0x00},
29 	{MAX98390_INT_EN3, 0x00},
30 	{MAX98390_INT_FLAG_CLR1, 0x00},
31 	{MAX98390_INT_FLAG_CLR2, 0x00},
32 	{MAX98390_INT_FLAG_CLR3, 0x00},
33 	{MAX98390_IRQ_CTRL, 0x01},
34 	{MAX98390_CLK_MON, 0x6d},
35 	{MAX98390_DAT_MON, 0x03},
36 	{MAX98390_WDOG_CTRL, 0x00},
37 	{MAX98390_WDOG_RST, 0x00},
38 	{MAX98390_MEAS_ADC_THERM_WARN_THRESH, 0x75},
39 	{MAX98390_MEAS_ADC_THERM_SHDN_THRESH, 0x8c},
40 	{MAX98390_MEAS_ADC_THERM_HYSTERESIS, 0x08},
41 	{MAX98390_PIN_CFG, 0x55},
42 	{MAX98390_PCM_RX_EN_A, 0x00},
43 	{MAX98390_PCM_RX_EN_B, 0x00},
44 	{MAX98390_PCM_TX_EN_A, 0x00},
45 	{MAX98390_PCM_TX_EN_B, 0x00},
46 	{MAX98390_PCM_TX_HIZ_CTRL_A, 0xff},
47 	{MAX98390_PCM_TX_HIZ_CTRL_B, 0xff},
48 	{MAX98390_PCM_CH_SRC_1, 0x00},
49 	{MAX98390_PCM_CH_SRC_2, 0x00},
50 	{MAX98390_PCM_CH_SRC_3, 0x00},
51 	{MAX98390_PCM_MODE_CFG, 0xc0},
52 	{MAX98390_PCM_MASTER_MODE, 0x1c},
53 	{MAX98390_PCM_CLK_SETUP, 0x44},
54 	{MAX98390_PCM_SR_SETUP, 0x08},
55 	{MAX98390_ICC_RX_EN_A, 0x00},
56 	{MAX98390_ICC_RX_EN_B, 0x00},
57 	{MAX98390_ICC_TX_EN_A, 0x00},
58 	{MAX98390_ICC_TX_EN_B, 0x00},
59 	{MAX98390_ICC_HIZ_MANUAL_MODE, 0x00},
60 	{MAX98390_ICC_TX_HIZ_EN_A, 0x00},
61 	{MAX98390_ICC_TX_HIZ_EN_B, 0x00},
62 	{MAX98390_ICC_LNK_EN, 0x00},
63 	{MAX98390_R2039_AMP_DSP_CFG, 0x0f},
64 	{MAX98390_R203A_AMP_EN, 0x81},
65 	{MAX98390_TONE_GEN_DC_CFG, 0x00},
66 	{MAX98390_SPK_SRC_SEL, 0x00},
67 	{MAX98390_SSM_CFG, 0x85},
68 	{MAX98390_MEAS_EN, 0x03},
69 	{MAX98390_MEAS_DSP_CFG, 0x0f},
70 	{MAX98390_BOOST_CTRL0, 0x1c},
71 	{MAX98390_BOOST_CTRL3, 0x01},
72 	{MAX98390_BOOST_CTRL1, 0x40},
73 	{MAX98390_MEAS_ADC_CFG, 0x07},
74 	{MAX98390_MEAS_ADC_BASE_MSB, 0x00},
75 	{MAX98390_MEAS_ADC_BASE_LSB, 0x23},
76 	{MAX98390_ADC_CH0_DIVIDE, 0x00},
77 	{MAX98390_ADC_CH1_DIVIDE, 0x00},
78 	{MAX98390_ADC_CH2_DIVIDE, 0x00},
79 	{MAX98390_ADC_CH0_FILT_CFG, 0x00},
80 	{MAX98390_ADC_CH1_FILT_CFG, 0x00},
81 	{MAX98390_ADC_CH2_FILT_CFG, 0x00},
82 	{MAX98390_PWR_GATE_CTL, 0x2c},
83 	{MAX98390_BROWNOUT_EN, 0x00},
84 	{MAX98390_BROWNOUT_INFINITE_HOLD, 0x00},
85 	{MAX98390_BROWNOUT_INFINITE_HOLD_CLR, 0x00},
86 	{MAX98390_BROWNOUT_LVL_HOLD, 0x00},
87 	{MAX98390_BROWNOUT_LVL1_THRESH, 0x00},
88 	{MAX98390_BROWNOUT_LVL2_THRESH, 0x00},
89 	{MAX98390_BROWNOUT_LVL3_THRESH, 0x00},
90 	{MAX98390_BROWNOUT_LVL4_THRESH, 0x00},
91 	{MAX98390_BROWNOUT_THRESH_HYSTERYSIS, 0x00},
92 	{MAX98390_BROWNOUT_AMP_LIMITER_ATK_REL, 0x1f},
93 	{MAX98390_BROWNOUT_AMP_GAIN_ATK_REL, 0x00},
94 	{MAX98390_BROWNOUT_AMP1_CLIP_MODE, 0x00},
95 	{MAX98390_BROWNOUT_LVL1_CUR_LIMIT, 0x00},
96 	{MAX98390_BROWNOUT_LVL1_AMP1_CTRL1, 0x00},
97 	{MAX98390_BROWNOUT_LVL1_AMP1_CTRL2, 0x00},
98 	{MAX98390_BROWNOUT_LVL1_AMP1_CTRL3, 0x00},
99 	{MAX98390_BROWNOUT_LVL2_CUR_LIMIT, 0x00},
100 	{MAX98390_BROWNOUT_LVL2_AMP1_CTRL1, 0x00},
101 	{MAX98390_BROWNOUT_LVL2_AMP1_CTRL2, 0x00},
102 	{MAX98390_BROWNOUT_LVL2_AMP1_CTRL3, 0x00},
103 	{MAX98390_BROWNOUT_LVL3_CUR_LIMIT, 0x00},
104 	{MAX98390_BROWNOUT_LVL3_AMP1_CTRL1, 0x00},
105 	{MAX98390_BROWNOUT_LVL3_AMP1_CTRL2, 0x00},
106 	{MAX98390_BROWNOUT_LVL3_AMP1_CTRL3, 0x00},
107 	{MAX98390_BROWNOUT_LVL4_CUR_LIMIT, 0x00},
108 	{MAX98390_BROWNOUT_LVL4_AMP1_CTRL1, 0x00},
109 	{MAX98390_BROWNOUT_LVL4_AMP1_CTRL2, 0x00},
110 	{MAX98390_BROWNOUT_LVL4_AMP1_CTRL3, 0x00},
111 	{MAX98390_BROWNOUT_ILIM_HLD, 0x00},
112 	{MAX98390_BROWNOUT_LIM_HLD, 0x00},
113 	{MAX98390_BROWNOUT_CLIP_HLD, 0x00},
114 	{MAX98390_BROWNOUT_GAIN_HLD, 0x00},
115 	{MAX98390_ENV_TRACK_VOUT_HEADROOM, 0x0f},
116 	{MAX98390_ENV_TRACK_BOOST_VOUT_DELAY, 0x80},
117 	{MAX98390_ENV_TRACK_REL_RATE, 0x07},
118 	{MAX98390_ENV_TRACK_HOLD_RATE, 0x07},
119 	{MAX98390_ENV_TRACK_CTRL, 0x01},
120 	{MAX98390_BOOST_BYPASS1, 0x49},
121 	{MAX98390_BOOST_BYPASS2, 0x2b},
122 	{MAX98390_BOOST_BYPASS3, 0x08},
123 	{MAX98390_FET_SCALING1, 0x00},
124 	{MAX98390_FET_SCALING2, 0x03},
125 	{MAX98390_FET_SCALING3, 0x00},
126 	{MAX98390_FET_SCALING4, 0x07},
127 	{MAX98390_SPK_SPEEDUP, 0x00},
128 	{DSMIG_WB_DRC_RELEASE_TIME_1, 0x00},
129 	{DSMIG_WB_DRC_RELEASE_TIME_2, 0x00},
130 	{DSMIG_WB_DRC_ATTACK_TIME_1, 0x00},
131 	{DSMIG_WB_DRC_ATTACK_TIME_2, 0x00},
132 	{DSMIG_WB_DRC_COMPRESSION_RATIO, 0x00},
133 	{DSMIG_WB_DRC_COMPRESSION_THRESHOLD, 0x00},
134 	{DSMIG_WB_DRC_MAKEUPGAIN, 0x00},
135 	{DSMIG_WB_DRC_NOISE_GATE_THRESHOLD, 0x00},
136 	{DSMIG_WBDRC_HPF_ENABLE, 0x00},
137 	{DSMIG_WB_DRC_TEST_SMOOTHER_OUT_EN, 0x00},
138 	{DSMIG_PPR_THRESHOLD, 0x00},
139 	{DSM_STEREO_BASS_CHANNEL_SELECT, 0x00},
140 	{DSM_TPROT_THRESHOLD_BYTE0, 0x00},
141 	{DSM_TPROT_THRESHOLD_BYTE1, 0x00},
142 	{DSM_TPROT_ROOM_TEMPERATURE_BYTE0, 0x00},
143 	{DSM_TPROT_ROOM_TEMPERATURE_BYTE1, 0x00},
144 	{DSM_TPROT_RECIP_RDC_ROOM_BYTE0, 0x00},
145 	{DSM_TPROT_RECIP_RDC_ROOM_BYTE1, 0x00},
146 	{DSM_TPROT_RECIP_RDC_ROOM_BYTE2, 0x00},
147 	{DSM_TPROT_RECIP_TCONST_BYTE0, 0x00},
148 	{DSM_TPROT_RECIP_TCONST_BYTE1, 0x00},
149 	{DSM_TPROT_RECIP_TCONST_BYTE2, 0x00},
150 	{DSM_THERMAL_ATTENUATION_SETTINGS, 0x00},
151 	{DSM_THERMAL_PILOT_TONE_ATTENUATION, 0x00},
152 	{DSM_TPROT_PG_TEMP_THRESH_BYTE0, 0x00},
153 	{DSM_TPROT_PG_TEMP_THRESH_BYTE1, 0x00},
154 	{DSMIG_DEBUZZER_THRESHOLD, 0x00},
155 	{DSMIG_DEBUZZER_ALPHA_COEF_TEST_ONLY, 0x08},
156 	{DSM_VOL_ENA, 0x20},
157 	{DSM_VOL_CTRL, 0xa0},
158 	{DSMIG_EN, 0x00},
159 	{MAX98390_R23E1_DSP_GLOBAL_EN, 0x00},
160 	{MAX98390_R23FF_GLOBAL_EN, 0x00},
161 };
162 
163 static int max98390_dai_set_fmt(struct snd_soc_dai *codec_dai, unsigned int fmt)
164 {
165 	struct snd_soc_component *component = codec_dai->component;
166 	struct max98390_priv *max98390 =
167 		snd_soc_component_get_drvdata(component);
168 	unsigned int mode;
169 	unsigned int format;
170 	unsigned int invert = 0;
171 
172 	dev_dbg(component->dev, "%s: fmt 0x%08X\n", __func__, fmt);
173 
174 	switch (fmt & SND_SOC_DAIFMT_CLOCK_PROVIDER_MASK) {
175 	case SND_SOC_DAIFMT_CBC_CFC:
176 		mode = MAX98390_PCM_MASTER_MODE_SLAVE;
177 		break;
178 	case SND_SOC_DAIFMT_CBP_CFP:
179 		max98390->provider = true;
180 		mode = MAX98390_PCM_MASTER_MODE_MASTER;
181 		break;
182 	default:
183 		dev_err(component->dev, "DAI clock mode unsupported\n");
184 		return -EINVAL;
185 	}
186 
187 	regmap_update_bits(max98390->regmap,
188 		MAX98390_PCM_MASTER_MODE,
189 		MAX98390_PCM_MASTER_MODE_MASK,
190 		mode);
191 
192 	switch (fmt & SND_SOC_DAIFMT_INV_MASK) {
193 	case SND_SOC_DAIFMT_NB_NF:
194 		break;
195 	case SND_SOC_DAIFMT_IB_NF:
196 		invert = MAX98390_PCM_MODE_CFG_PCM_BCLKEDGE;
197 		break;
198 	default:
199 		dev_err(component->dev, "DAI invert mode unsupported\n");
200 		return -EINVAL;
201 	}
202 
203 	regmap_update_bits(max98390->regmap,
204 		MAX98390_PCM_MODE_CFG,
205 		MAX98390_PCM_MODE_CFG_PCM_BCLKEDGE,
206 		invert);
207 
208 	/* interface format */
209 	switch (fmt & SND_SOC_DAIFMT_FORMAT_MASK) {
210 	case SND_SOC_DAIFMT_I2S:
211 		format = MAX98390_PCM_FORMAT_I2S;
212 		break;
213 	case SND_SOC_DAIFMT_LEFT_J:
214 		format = MAX98390_PCM_FORMAT_LJ;
215 		break;
216 	case SND_SOC_DAIFMT_DSP_A:
217 		format = MAX98390_PCM_FORMAT_TDM_MODE1;
218 		break;
219 	case SND_SOC_DAIFMT_DSP_B:
220 		format = MAX98390_PCM_FORMAT_TDM_MODE0;
221 		break;
222 	default:
223 		return -EINVAL;
224 	}
225 
226 	regmap_update_bits(max98390->regmap,
227 		MAX98390_PCM_MODE_CFG,
228 		MAX98390_PCM_MODE_CFG_FORMAT_MASK,
229 		format << MAX98390_PCM_MODE_CFG_FORMAT_SHIFT);
230 
231 	return 0;
232 }
233 
234 static int max98390_get_bclk_sel(int bclk)
235 {
236 	int i;
237 	/* BCLKs per LRCLK */
238 	static int bclk_sel_table[] = {
239 		32, 48, 64, 96, 128, 192, 256, 320, 384, 512,
240 	};
241 	/* match BCLKs per LRCLK */
242 	for (i = 0; i < ARRAY_SIZE(bclk_sel_table); i++) {
243 		if (bclk_sel_table[i] == bclk)
244 			return i + 2;
245 	}
246 	return 0;
247 }
248 
249 static int max98390_set_clock(struct snd_soc_component *component,
250 		struct snd_pcm_hw_params *params)
251 {
252 	struct max98390_priv *max98390 =
253 		snd_soc_component_get_drvdata(component);
254 	/* codec MCLK rate in master mode */
255 	static int rate_table[] = {
256 		5644800, 6000000, 6144000, 6500000,
257 		9600000, 11289600, 12000000, 12288000,
258 		13000000, 19200000,
259 	};
260 	/* BCLK/LRCLK ratio calculation */
261 	int blr_clk_ratio = params_channels(params)
262 		* snd_pcm_format_width(params_format(params));
263 	int value;
264 
265 	if (max98390->provider) {
266 		int i;
267 		/* match rate to closest value */
268 		for (i = 0; i < ARRAY_SIZE(rate_table); i++) {
269 			if (rate_table[i] >= max98390->sysclk)
270 				break;
271 		}
272 		if (i == ARRAY_SIZE(rate_table)) {
273 			dev_err(component->dev, "failed to find proper clock rate.\n");
274 			return -EINVAL;
275 		}
276 
277 		regmap_update_bits(max98390->regmap,
278 			MAX98390_PCM_MASTER_MODE,
279 			MAX98390_PCM_MASTER_MODE_MCLK_MASK,
280 			i << MAX98390_PCM_MASTER_MODE_MCLK_RATE_SHIFT);
281 	}
282 
283 	if (!max98390->tdm_mode) {
284 		/* BCLK configuration */
285 		value = max98390_get_bclk_sel(blr_clk_ratio);
286 		if (!value) {
287 			dev_err(component->dev, "format unsupported %d\n",
288 				params_format(params));
289 			return -EINVAL;
290 		}
291 
292 		regmap_update_bits(max98390->regmap,
293 			MAX98390_PCM_CLK_SETUP,
294 			MAX98390_PCM_CLK_SETUP_BSEL_MASK,
295 			value);
296 	}
297 	return 0;
298 }
299 
300 static int max98390_dai_hw_params(struct snd_pcm_substream *substream,
301 		struct snd_pcm_hw_params *params,
302 		struct snd_soc_dai *dai)
303 {
304 	struct snd_soc_component *component =
305 		dai->component;
306 	struct max98390_priv *max98390 =
307 		snd_soc_component_get_drvdata(component);
308 
309 	unsigned int sampling_rate;
310 	unsigned int chan_sz;
311 
312 	/* pcm mode configuration */
313 	switch (snd_pcm_format_width(params_format(params))) {
314 	case 16:
315 		chan_sz = MAX98390_PCM_MODE_CFG_CHANSZ_16;
316 		break;
317 	case 24:
318 		chan_sz = MAX98390_PCM_MODE_CFG_CHANSZ_24;
319 		break;
320 	case 32:
321 		chan_sz = MAX98390_PCM_MODE_CFG_CHANSZ_32;
322 		break;
323 	default:
324 		dev_err(component->dev, "format unsupported %d\n",
325 			params_format(params));
326 		goto err;
327 	}
328 
329 	regmap_update_bits(max98390->regmap,
330 		MAX98390_PCM_MODE_CFG,
331 		MAX98390_PCM_MODE_CFG_CHANSZ_MASK, chan_sz);
332 
333 	dev_dbg(component->dev, "format supported %d",
334 		params_format(params));
335 
336 	/* sampling rate configuration */
337 	switch (params_rate(params)) {
338 	case 8000:
339 		sampling_rate = MAX98390_PCM_SR_SET1_SR_8000;
340 		break;
341 	case 11025:
342 		sampling_rate = MAX98390_PCM_SR_SET1_SR_11025;
343 		break;
344 	case 12000:
345 		sampling_rate = MAX98390_PCM_SR_SET1_SR_12000;
346 		break;
347 	case 16000:
348 		sampling_rate = MAX98390_PCM_SR_SET1_SR_16000;
349 		break;
350 	case 22050:
351 		sampling_rate = MAX98390_PCM_SR_SET1_SR_22050;
352 		break;
353 	case 24000:
354 		sampling_rate = MAX98390_PCM_SR_SET1_SR_24000;
355 		break;
356 	case 32000:
357 		sampling_rate = MAX98390_PCM_SR_SET1_SR_32000;
358 		break;
359 	case 44100:
360 		sampling_rate = MAX98390_PCM_SR_SET1_SR_44100;
361 		break;
362 	case 48000:
363 		sampling_rate = MAX98390_PCM_SR_SET1_SR_48000;
364 		break;
365 	default:
366 		dev_err(component->dev, "rate %d not supported\n",
367 			params_rate(params));
368 		goto err;
369 	}
370 
371 	/* set DAI_SR to correct LRCLK frequency */
372 	regmap_update_bits(max98390->regmap,
373 		MAX98390_PCM_SR_SETUP,
374 		MAX98390_PCM_SR_SET1_SR_MASK,
375 		sampling_rate);
376 
377 	return max98390_set_clock(component, params);
378 err:
379 	return -EINVAL;
380 }
381 
382 static int max98390_dai_tdm_slot(struct snd_soc_dai *dai,
383 		unsigned int tx_mask, unsigned int rx_mask,
384 		int slots, int slot_width)
385 {
386 	struct snd_soc_component *component = dai->component;
387 	struct max98390_priv *max98390 =
388 		snd_soc_component_get_drvdata(component);
389 
390 	int bsel;
391 	unsigned int chan_sz;
392 
393 	if (!tx_mask && !rx_mask && !slots && !slot_width)
394 		max98390->tdm_mode = false;
395 	else
396 		max98390->tdm_mode = true;
397 
398 	dev_dbg(component->dev,
399 		"Tdm mode : %d\n", max98390->tdm_mode);
400 
401 	/* BCLK configuration */
402 	bsel = max98390_get_bclk_sel(slots * slot_width);
403 	if (!bsel) {
404 		dev_err(component->dev, "BCLK %d not supported\n",
405 			slots * slot_width);
406 		return -EINVAL;
407 	}
408 
409 	regmap_update_bits(max98390->regmap,
410 		MAX98390_PCM_CLK_SETUP,
411 		MAX98390_PCM_CLK_SETUP_BSEL_MASK,
412 		bsel);
413 
414 	/* Channel size configuration */
415 	switch (slot_width) {
416 	case 16:
417 		chan_sz = MAX98390_PCM_MODE_CFG_CHANSZ_16;
418 		break;
419 	case 24:
420 		chan_sz = MAX98390_PCM_MODE_CFG_CHANSZ_24;
421 		break;
422 	case 32:
423 		chan_sz = MAX98390_PCM_MODE_CFG_CHANSZ_32;
424 		break;
425 	default:
426 		dev_err(component->dev, "format unsupported %d\n",
427 			slot_width);
428 		return -EINVAL;
429 	}
430 
431 	regmap_update_bits(max98390->regmap,
432 		MAX98390_PCM_MODE_CFG,
433 		MAX98390_PCM_MODE_CFG_CHANSZ_MASK, chan_sz);
434 
435 	/* Rx slot configuration */
436 	regmap_write(max98390->regmap,
437 		MAX98390_PCM_RX_EN_A,
438 		rx_mask & 0xFF);
439 	regmap_write(max98390->regmap,
440 		MAX98390_PCM_RX_EN_B,
441 		(rx_mask & 0xFF00) >> 8);
442 
443 	/* Tx slot Hi-Z configuration */
444 	regmap_write(max98390->regmap,
445 		MAX98390_PCM_TX_HIZ_CTRL_A,
446 		~tx_mask & 0xFF);
447 	regmap_write(max98390->regmap,
448 		MAX98390_PCM_TX_HIZ_CTRL_B,
449 		(~tx_mask & 0xFF00) >> 8);
450 
451 	return 0;
452 }
453 
454 static int max98390_dai_set_sysclk(struct snd_soc_dai *dai,
455 		int clk_id, unsigned int freq, int dir)
456 {
457 	struct snd_soc_component *component = dai->component;
458 	struct max98390_priv *max98390 =
459 		snd_soc_component_get_drvdata(component);
460 
461 	max98390->sysclk = freq;
462 	return 0;
463 }
464 
465 static const struct snd_soc_dai_ops max98390_dai_ops = {
466 	.set_sysclk = max98390_dai_set_sysclk,
467 	.set_fmt = max98390_dai_set_fmt,
468 	.hw_params = max98390_dai_hw_params,
469 	.set_tdm_slot = max98390_dai_tdm_slot,
470 };
471 
472 static int max98390_dac_event(struct snd_soc_dapm_widget *w,
473 		struct snd_kcontrol *kcontrol, int event)
474 {
475 	struct snd_soc_component *component =
476 		snd_soc_dapm_to_component(w->dapm);
477 	struct max98390_priv *max98390 =
478 		snd_soc_component_get_drvdata(component);
479 
480 	switch (event) {
481 	case SND_SOC_DAPM_POST_PMU:
482 		regmap_update_bits(max98390->regmap,
483 			MAX98390_R203A_AMP_EN,
484 			MAX98390_AMP_EN_MASK, 1);
485 		regmap_update_bits(max98390->regmap,
486 			MAX98390_R23FF_GLOBAL_EN,
487 			MAX98390_GLOBAL_EN_MASK, 1);
488 		break;
489 	case SND_SOC_DAPM_POST_PMD:
490 		regmap_update_bits(max98390->regmap,
491 			MAX98390_R23FF_GLOBAL_EN,
492 			MAX98390_GLOBAL_EN_MASK, 0);
493 		regmap_update_bits(max98390->regmap,
494 			MAX98390_R203A_AMP_EN,
495 			MAX98390_AMP_EN_MASK, 0);
496 		break;
497 	}
498 	return 0;
499 }
500 
501 static const char * const max98390_switch_text[] = {
502 	"Left", "Right", "LeftRight"};
503 
504 static const char * const max98390_boost_voltage_text[] = {
505 	"6.5V", "6.625V", "6.75V", "6.875V", "7V", "7.125V", "7.25V", "7.375V",
506 	"7.5V", "7.625V", "7.75V", "7.875V", "8V", "8.125V", "8.25V", "8.375V",
507 	"8.5V", "8.625V", "8.75V", "8.875V", "9V", "9.125V", "9.25V", "9.375V",
508 	"9.5V", "9.625V", "9.75V", "9.875V", "10V"
509 };
510 
511 static SOC_ENUM_SINGLE_DECL(max98390_boost_voltage,
512 		MAX98390_BOOST_CTRL0, 0,
513 		max98390_boost_voltage_text);
514 
515 static DECLARE_TLV_DB_SCALE(max98390_spk_tlv, 300, 300, 0);
516 static DECLARE_TLV_DB_SCALE(max98390_digital_tlv, -8000, 50, 0);
517 
518 static const char * const max98390_current_limit_text[] = {
519 	"0.00A", "0.50A", "1.00A", "1.05A", "1.10A", "1.15A", "1.20A", "1.25A",
520 	"1.30A", "1.35A", "1.40A", "1.45A", "1.50A", "1.55A", "1.60A", "1.65A",
521 	"1.70A", "1.75A", "1.80A", "1.85A", "1.90A", "1.95A", "2.00A", "2.05A",
522 	"2.10A", "2.15A", "2.20A", "2.25A", "2.30A", "2.35A", "2.40A", "2.45A",
523 	"2.50A", "2.55A", "2.60A", "2.65A", "2.70A", "2.75A", "2.80A", "2.85A",
524 	"2.90A", "2.95A", "3.00A", "3.05A", "3.10A", "3.15A", "3.20A", "3.25A",
525 	"3.30A", "3.35A", "3.40A", "3.45A", "3.50A", "3.55A", "3.60A", "3.65A",
526 	"3.70A", "3.75A", "3.80A", "3.85A", "3.90A", "3.95A", "4.00A", "4.05A",
527 	"4.10A"
528 };
529 
530 static SOC_ENUM_SINGLE_DECL(max98390_current_limit,
531 		MAX98390_BOOST_CTRL1, 0,
532 		max98390_current_limit_text);
533 
534 static int max98390_ref_rdc_put(struct snd_kcontrol *kcontrol,
535 		struct snd_ctl_elem_value *ucontrol)
536 {
537 	struct snd_soc_component *component =
538 		snd_soc_kcontrol_component(kcontrol);
539 	struct max98390_priv *max98390 =
540 		snd_soc_component_get_drvdata(component);
541 
542 	max98390->ref_rdc_value = ucontrol->value.integer.value[0];
543 
544 	regmap_write(max98390->regmap, DSM_TPROT_RECIP_RDC_ROOM_BYTE0,
545 		max98390->ref_rdc_value & 0x000000ff);
546 	regmap_write(max98390->regmap, DSM_TPROT_RECIP_RDC_ROOM_BYTE1,
547 		(max98390->ref_rdc_value >> 8) & 0x000000ff);
548 	regmap_write(max98390->regmap, DSM_TPROT_RECIP_RDC_ROOM_BYTE2,
549 		(max98390->ref_rdc_value >> 16) & 0x000000ff);
550 
551 	return 0;
552 }
553 
554 static int max98390_ref_rdc_get(struct snd_kcontrol *kcontrol,
555 		struct snd_ctl_elem_value *ucontrol)
556 {
557 	struct snd_soc_component *component =
558 		snd_soc_kcontrol_component(kcontrol);
559 	struct max98390_priv *max98390 =
560 		snd_soc_component_get_drvdata(component);
561 
562 	ucontrol->value.integer.value[0] = max98390->ref_rdc_value;
563 
564 	return 0;
565 }
566 
567 static int max98390_ambient_temp_put(struct snd_kcontrol *kcontrol,
568 		struct snd_ctl_elem_value *ucontrol)
569 {
570 	struct snd_soc_component *component =
571 		snd_soc_kcontrol_component(kcontrol);
572 	struct max98390_priv *max98390 =
573 		snd_soc_component_get_drvdata(component);
574 
575 	max98390->ambient_temp_value = ucontrol->value.integer.value[0];
576 
577 	regmap_write(max98390->regmap, DSM_TPROT_ROOM_TEMPERATURE_BYTE1,
578 		(max98390->ambient_temp_value >> 8) & 0x000000ff);
579 	regmap_write(max98390->regmap, DSM_TPROT_ROOM_TEMPERATURE_BYTE0,
580 		(max98390->ambient_temp_value) & 0x000000ff);
581 
582 	return 0;
583 }
584 
585 static int max98390_ambient_temp_get(struct snd_kcontrol *kcontrol,
586 		struct snd_ctl_elem_value *ucontrol)
587 {
588 	struct snd_soc_component *component =
589 		snd_soc_kcontrol_component(kcontrol);
590 	struct max98390_priv *max98390 =
591 		snd_soc_component_get_drvdata(component);
592 
593 	ucontrol->value.integer.value[0] = max98390->ambient_temp_value;
594 
595 	return 0;
596 }
597 
598 static int max98390_adaptive_rdc_put(struct snd_kcontrol *kcontrol,
599 		struct snd_ctl_elem_value *ucontrol)
600 {
601 	struct snd_soc_component *component =
602 		snd_soc_kcontrol_component(kcontrol);
603 
604 	dev_warn(component->dev, "Put adaptive rdc not supported\n");
605 
606 	return 0;
607 }
608 
609 static int max98390_adaptive_rdc_get(struct snd_kcontrol *kcontrol,
610 		struct snd_ctl_elem_value *ucontrol)
611 {
612 	int rdc, rdc0;
613 	struct snd_soc_component *component =
614 		snd_soc_kcontrol_component(kcontrol);
615 	struct max98390_priv *max98390 =
616 		snd_soc_component_get_drvdata(component);
617 
618 	regmap_read(max98390->regmap, THERMAL_RDC_RD_BACK_BYTE1, &rdc);
619 	regmap_read(max98390->regmap, THERMAL_RDC_RD_BACK_BYTE0, &rdc0);
620 	ucontrol->value.integer.value[0] = rdc0 | rdc << 8;
621 
622 	return 0;
623 }
624 
625 static int max98390_dsm_calib_get(struct snd_kcontrol *kcontrol,
626 		struct snd_ctl_elem_value *ucontrol)
627 {
628 	/* Do nothing */
629 	return 0;
630 }
631 
632 static int max98390_dsm_calib_put(struct snd_kcontrol *kcontrol,
633 		struct snd_ctl_elem_value *ucontrol)
634 {
635 	struct snd_soc_component *component = snd_soc_kcontrol_component(kcontrol);
636 	struct max98390_priv *max98390 = snd_soc_component_get_drvdata(component);
637 	struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component);
638 	unsigned int rdc, rdc_cal_result, rdc_integer, rdc_factor, temp, val;
639 
640 	snd_soc_dapm_mutex_lock(dapm);
641 
642 	regmap_read(max98390->regmap, MAX98390_R23FF_GLOBAL_EN, &val);
643 	if (!val) {
644 		/* Enable the codec for the duration of calibration readout */
645 		regmap_update_bits(max98390->regmap, MAX98390_R203A_AMP_EN,
646 				   MAX98390_AMP_EN_MASK, 1);
647 		regmap_update_bits(max98390->regmap, MAX98390_R23FF_GLOBAL_EN,
648 				   MAX98390_GLOBAL_EN_MASK, 1);
649 	}
650 
651 	regmap_read(max98390->regmap, THERMAL_RDC_RD_BACK_BYTE1, &rdc);
652 	regmap_read(max98390->regmap, THERMAL_RDC_RD_BACK_BYTE0, &rdc_cal_result);
653 	regmap_read(max98390->regmap, MAX98390_MEAS_ADC_CH2_READ, &temp);
654 
655 	if (!val) {
656 		/* Disable the codec if it was disabled */
657 		regmap_update_bits(max98390->regmap, MAX98390_R23FF_GLOBAL_EN,
658 				   MAX98390_GLOBAL_EN_MASK, 0);
659 		regmap_update_bits(max98390->regmap, MAX98390_R203A_AMP_EN,
660 				   MAX98390_AMP_EN_MASK, 0);
661 	}
662 
663 	snd_soc_dapm_mutex_unlock(dapm);
664 
665 	rdc_cal_result |= (rdc << 8) & 0x0000FFFF;
666 	if (rdc_cal_result)
667 		max98390->ref_rdc_value = 268435456U / rdc_cal_result;
668 
669 	max98390->ambient_temp_value = temp * 52 - 1188;
670 
671 	rdc_integer =  rdc_cal_result * 937  / 65536;
672 	rdc_factor = ((rdc_cal_result * 937 * 100) / 65536) - (rdc_integer * 100);
673 
674 	dev_info(component->dev,
675 		 "rdc resistance about %d.%02d ohm, reg=0x%X temp reg=0x%X\n",
676 		 rdc_integer, rdc_factor, rdc_cal_result, temp);
677 
678 	return 0;
679 }
680 
681 static const struct snd_kcontrol_new max98390_snd_controls[] = {
682 	SOC_SINGLE_TLV("Digital Volume", DSM_VOL_CTRL,
683 		0, 184, 0,
684 		max98390_digital_tlv),
685 	SOC_SINGLE_TLV("Speaker Volume", MAX98390_R203D_SPK_GAIN,
686 		0, 6, 0,
687 		max98390_spk_tlv),
688 	SOC_SINGLE("Ramp Up Bypass Switch", MAX98390_R2039_AMP_DSP_CFG,
689 		MAX98390_AMP_DSP_CFG_RMP_UP_SHIFT, 1, 0),
690 	SOC_SINGLE("Ramp Down Bypass Switch", MAX98390_R2039_AMP_DSP_CFG,
691 		MAX98390_AMP_DSP_CFG_RMP_DN_SHIFT, 1, 0),
692 	SOC_SINGLE("Boost Clock Phase", MAX98390_BOOST_CTRL3,
693 		MAX98390_BOOST_CLK_PHASE_CFG_SHIFT, 3, 0),
694 	SOC_ENUM("Boost Output Voltage", max98390_boost_voltage),
695 	SOC_ENUM("Current Limit", max98390_current_limit),
696 	SOC_SINGLE_EXT("DSM Rdc", SND_SOC_NOPM, 0, 0xffffff, 0,
697 		max98390_ref_rdc_get, max98390_ref_rdc_put),
698 	SOC_SINGLE_EXT("DSM Ambient Temp", SND_SOC_NOPM, 0, 0xffff, 0,
699 		max98390_ambient_temp_get, max98390_ambient_temp_put),
700 	SOC_SINGLE_EXT("DSM Adaptive Rdc", SND_SOC_NOPM, 0, 0xffff, 0,
701 		max98390_adaptive_rdc_get, max98390_adaptive_rdc_put),
702 	SOC_SINGLE_EXT("DSM Calibration", SND_SOC_NOPM, 0, 1, 0,
703 		max98390_dsm_calib_get, max98390_dsm_calib_put),
704 };
705 
706 static const struct soc_enum dai_sel_enum =
707 	SOC_ENUM_SINGLE(MAX98390_PCM_CH_SRC_1,
708 		MAX98390_PCM_RX_CH_SRC_SHIFT,
709 		3, max98390_switch_text);
710 
711 static const struct snd_kcontrol_new max98390_dai_controls =
712 	SOC_DAPM_ENUM("DAI Sel", dai_sel_enum);
713 
714 static const struct snd_soc_dapm_widget max98390_dapm_widgets[] = {
715 	SND_SOC_DAPM_DAC_E("Amp Enable", "HiFi Playback",
716 		SND_SOC_NOPM, 0, 0, max98390_dac_event,
717 		SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_POST_PMD),
718 	SND_SOC_DAPM_MUX("DAI Sel Mux", SND_SOC_NOPM, 0, 0,
719 		&max98390_dai_controls),
720 	SND_SOC_DAPM_OUTPUT("BE_OUT"),
721 };
722 
723 static const struct snd_soc_dapm_route max98390_audio_map[] = {
724 	/* Plabyack */
725 	{"DAI Sel Mux", "Left", "Amp Enable"},
726 	{"DAI Sel Mux", "Right", "Amp Enable"},
727 	{"DAI Sel Mux", "LeftRight", "Amp Enable"},
728 	{"BE_OUT", NULL, "DAI Sel Mux"},
729 };
730 
731 static bool max98390_readable_register(struct device *dev, unsigned int reg)
732 {
733 	switch (reg) {
734 	case MAX98390_SOFTWARE_RESET ... MAX98390_INT_EN3:
735 	case MAX98390_IRQ_CTRL ... MAX98390_WDOG_CTRL:
736 	case MAX98390_MEAS_ADC_THERM_WARN_THRESH
737 		... MAX98390_BROWNOUT_INFINITE_HOLD:
738 	case MAX98390_BROWNOUT_LVL_HOLD ... DSMIG_DEBUZZER_THRESHOLD:
739 	case DSM_VOL_ENA ... MAX98390_R24FF_REV_ID:
740 		return true;
741 	default:
742 		return false;
743 	}
744 };
745 
746 static bool max98390_volatile_reg(struct device *dev, unsigned int reg)
747 {
748 	switch (reg) {
749 	case MAX98390_SOFTWARE_RESET ... MAX98390_INT_EN3:
750 	case MAX98390_MEAS_ADC_CH0_READ ... MAX98390_MEAS_ADC_CH2_READ:
751 	case MAX98390_PWR_GATE_STATUS ... MAX98390_BROWNOUT_STATUS:
752 	case MAX98390_BROWNOUT_LOWEST_STATUS:
753 	case MAX98390_ENV_TRACK_BOOST_VOUT_READ:
754 	case DSM_STBASS_HPF_B0_BYTE0 ... DSM_DEBUZZER_ATTACK_TIME_BYTE2:
755 	case THERMAL_RDC_RD_BACK_BYTE1 ... DSMIG_DEBUZZER_THRESHOLD:
756 	case DSM_THERMAL_GAIN ... DSM_WBDRC_GAIN:
757 		return true;
758 	default:
759 		return false;
760 	}
761 }
762 
763 #define MAX98390_RATES SNDRV_PCM_RATE_8000_48000
764 
765 #define MAX98390_FORMATS (SNDRV_PCM_FMTBIT_S16_LE | \
766 	SNDRV_PCM_FMTBIT_S24_LE | SNDRV_PCM_FMTBIT_S32_LE)
767 
768 static struct snd_soc_dai_driver max98390_dai[] = {
769 	{
770 		.name = "max98390-aif1",
771 		.playback = {
772 			.stream_name = "HiFi Playback",
773 			.channels_min = 1,
774 			.channels_max = 2,
775 			.rates = MAX98390_RATES,
776 			.formats = MAX98390_FORMATS,
777 		},
778 		.capture = {
779 			.stream_name = "HiFi Capture",
780 			.channels_min = 1,
781 			.channels_max = 2,
782 			.rates = MAX98390_RATES,
783 			.formats = MAX98390_FORMATS,
784 		},
785 		.ops = &max98390_dai_ops,
786 	}
787 };
788 
789 static int max98390_dsm_init(struct snd_soc_component *component)
790 {
791 	int ret;
792 	int param_size, param_start_addr;
793 	char filename[128];
794 	const char *vendor, *product;
795 	struct max98390_priv *max98390 =
796 		snd_soc_component_get_drvdata(component);
797 	const struct firmware *fw;
798 	char *dsm_param;
799 
800 	vendor = dmi_get_system_info(DMI_SYS_VENDOR);
801 	product = dmi_get_system_info(DMI_PRODUCT_NAME);
802 
803 	if (!strcmp(max98390->dsm_param_name, "default")) {
804 		if (vendor && product) {
805 			snprintf(filename, sizeof(filename),
806 				"dsm_param_%s_%s.bin", vendor, product);
807 		} else {
808 			sprintf(filename, "dsm_param.bin");
809 		}
810 	} else {
811 		snprintf(filename, sizeof(filename), "%s",
812 			max98390->dsm_param_name);
813 	}
814 	ret = request_firmware(&fw, filename, component->dev);
815 	if (ret) {
816 		ret = request_firmware(&fw, "dsm_param.bin", component->dev);
817 		if (ret) {
818 			ret = request_firmware(&fw, "dsmparam.bin",
819 				component->dev);
820 			if (ret)
821 				goto err;
822 		}
823 	}
824 
825 	dev_dbg(component->dev,
826 		"max98390: param fw size %zd\n",
827 		fw->size);
828 	if (fw->size < MAX98390_DSM_PARAM_MIN_SIZE) {
829 		dev_err(component->dev,
830 			"param fw is invalid.\n");
831 		ret = -EINVAL;
832 		goto err_alloc;
833 	}
834 	dsm_param = (char *)fw->data;
835 	param_start_addr = (dsm_param[0] & 0xff) | (dsm_param[1] & 0xff) << 8;
836 	param_size = (dsm_param[2] & 0xff) | (dsm_param[3] & 0xff) << 8;
837 	if (param_size > MAX98390_DSM_PARAM_MAX_SIZE ||
838 		param_start_addr < MAX98390_IRQ_CTRL ||
839 		fw->size < param_size + MAX98390_DSM_PAYLOAD_OFFSET) {
840 		dev_err(component->dev,
841 			"param fw is invalid.\n");
842 		ret = -EINVAL;
843 		goto err_alloc;
844 	}
845 	regmap_write(max98390->regmap, MAX98390_R203A_AMP_EN, 0x80);
846 	dsm_param += MAX98390_DSM_PAYLOAD_OFFSET;
847 	regmap_bulk_write(max98390->regmap, param_start_addr,
848 		dsm_param, param_size);
849 	regmap_write(max98390->regmap, MAX98390_R23E1_DSP_GLOBAL_EN, 0x01);
850 
851 err_alloc:
852 	release_firmware(fw);
853 err:
854 	return ret;
855 }
856 
857 static void max98390_init_regs(struct snd_soc_component *component)
858 {
859 	struct max98390_priv *max98390 =
860 		snd_soc_component_get_drvdata(component);
861 
862 	regmap_write(max98390->regmap, MAX98390_CLK_MON, 0x6f);
863 	regmap_write(max98390->regmap, MAX98390_DAT_MON, 0x00);
864 	regmap_write(max98390->regmap, MAX98390_PWR_GATE_CTL, 0x00);
865 	regmap_write(max98390->regmap, MAX98390_PCM_RX_EN_A, 0x03);
866 	regmap_write(max98390->regmap, MAX98390_ENV_TRACK_VOUT_HEADROOM, 0x0e);
867 	regmap_write(max98390->regmap, MAX98390_BOOST_BYPASS1, 0x46);
868 	regmap_write(max98390->regmap, MAX98390_FET_SCALING3, 0x03);
869 
870 	/* voltage, current slot configuration */
871 	regmap_write(max98390->regmap,
872 		MAX98390_PCM_CH_SRC_2,
873 		(max98390->i_l_slot << 4 |
874 		max98390->v_l_slot)&0xFF);
875 
876 	if (max98390->v_l_slot < 8) {
877 		regmap_update_bits(max98390->regmap,
878 			MAX98390_PCM_TX_HIZ_CTRL_A,
879 			1 << max98390->v_l_slot, 0);
880 		regmap_update_bits(max98390->regmap,
881 			MAX98390_PCM_TX_EN_A,
882 			1 << max98390->v_l_slot,
883 			1 << max98390->v_l_slot);
884 	} else {
885 		regmap_update_bits(max98390->regmap,
886 			MAX98390_PCM_TX_HIZ_CTRL_B,
887 			1 << (max98390->v_l_slot - 8), 0);
888 		regmap_update_bits(max98390->regmap,
889 			MAX98390_PCM_TX_EN_B,
890 			1 << (max98390->v_l_slot - 8),
891 			1 << (max98390->v_l_slot - 8));
892 	}
893 
894 	if (max98390->i_l_slot < 8) {
895 		regmap_update_bits(max98390->regmap,
896 			MAX98390_PCM_TX_HIZ_CTRL_A,
897 			1 << max98390->i_l_slot, 0);
898 		regmap_update_bits(max98390->regmap,
899 			MAX98390_PCM_TX_EN_A,
900 			1 << max98390->i_l_slot,
901 			1 << max98390->i_l_slot);
902 	} else {
903 		regmap_update_bits(max98390->regmap,
904 			MAX98390_PCM_TX_HIZ_CTRL_B,
905 			1 << (max98390->i_l_slot - 8), 0);
906 		regmap_update_bits(max98390->regmap,
907 			MAX98390_PCM_TX_EN_B,
908 			1 << (max98390->i_l_slot - 8),
909 			1 << (max98390->i_l_slot - 8));
910 	}
911 }
912 
913 static int max98390_probe(struct snd_soc_component *component)
914 {
915 	struct max98390_priv *max98390 =
916 		snd_soc_component_get_drvdata(component);
917 
918 	regmap_write(max98390->regmap, MAX98390_SOFTWARE_RESET, 0x01);
919 	/* Sleep reset settle time */
920 	msleep(20);
921 
922 	/* Amp init setting */
923 	max98390_init_regs(component);
924 	/* Update dsm bin param */
925 	max98390_dsm_init(component);
926 
927 	/* Dsm Setting */
928 	if (max98390->ref_rdc_value) {
929 		regmap_write(max98390->regmap, DSM_TPROT_RECIP_RDC_ROOM_BYTE0,
930 			max98390->ref_rdc_value & 0x000000ff);
931 		regmap_write(max98390->regmap, DSM_TPROT_RECIP_RDC_ROOM_BYTE1,
932 			(max98390->ref_rdc_value >> 8) & 0x000000ff);
933 		regmap_write(max98390->regmap, DSM_TPROT_RECIP_RDC_ROOM_BYTE2,
934 			(max98390->ref_rdc_value >> 16) & 0x000000ff);
935 	}
936 	if (max98390->ambient_temp_value) {
937 		regmap_write(max98390->regmap, DSM_TPROT_ROOM_TEMPERATURE_BYTE1,
938 			(max98390->ambient_temp_value >> 8) & 0x000000ff);
939 		regmap_write(max98390->regmap, DSM_TPROT_ROOM_TEMPERATURE_BYTE0,
940 			(max98390->ambient_temp_value) & 0x000000ff);
941 	}
942 
943 	return 0;
944 }
945 
946 static int max98390_suspend(struct device *dev)
947 {
948 	struct max98390_priv *max98390 = dev_get_drvdata(dev);
949 
950 	dev_dbg(dev, "%s:Enter\n", __func__);
951 
952 	regcache_cache_only(max98390->regmap, true);
953 	regcache_mark_dirty(max98390->regmap);
954 
955 	return 0;
956 }
957 
958 static int max98390_resume(struct device *dev)
959 {
960 	struct max98390_priv *max98390 = dev_get_drvdata(dev);
961 
962 	dev_dbg(dev, "%s:Enter\n", __func__);
963 
964 	regcache_cache_only(max98390->regmap, false);
965 	regcache_sync(max98390->regmap);
966 
967 	return 0;
968 }
969 
970 static const struct dev_pm_ops max98390_pm = {
971 	SYSTEM_SLEEP_PM_OPS(max98390_suspend, max98390_resume)
972 };
973 
974 static const struct snd_soc_component_driver soc_codec_dev_max98390 = {
975 	.probe			= max98390_probe,
976 	.controls		= max98390_snd_controls,
977 	.num_controls		= ARRAY_SIZE(max98390_snd_controls),
978 	.dapm_widgets		= max98390_dapm_widgets,
979 	.num_dapm_widgets	= ARRAY_SIZE(max98390_dapm_widgets),
980 	.dapm_routes		= max98390_audio_map,
981 	.num_dapm_routes	= ARRAY_SIZE(max98390_audio_map),
982 	.idle_bias_on		= 1,
983 	.use_pmdown_time	= 1,
984 	.endianness		= 1,
985 };
986 
987 static const struct regmap_config max98390_regmap = {
988 	.reg_bits         = 16,
989 	.val_bits         = 8,
990 	.max_register     = MAX98390_R24FF_REV_ID,
991 	.reg_defaults     = max98390_reg_defaults,
992 	.num_reg_defaults = ARRAY_SIZE(max98390_reg_defaults),
993 	.readable_reg	  = max98390_readable_register,
994 	.volatile_reg	  = max98390_volatile_reg,
995 	.cache_type       = REGCACHE_RBTREE,
996 };
997 
998 static void max98390_slot_config(struct i2c_client *i2c,
999 	struct max98390_priv *max98390)
1000 {
1001 	int value;
1002 	struct device *dev = &i2c->dev;
1003 
1004 	if (!device_property_read_u32(dev, "maxim,vmon-slot-no", &value))
1005 		max98390->v_l_slot = value & 0xF;
1006 	else
1007 		max98390->v_l_slot = 0;
1008 
1009 	if (!device_property_read_u32(dev, "maxim,imon-slot-no", &value))
1010 		max98390->i_l_slot = value & 0xF;
1011 	else
1012 		max98390->i_l_slot = 1;
1013 }
1014 
1015 static int max98390_i2c_probe(struct i2c_client *i2c)
1016 {
1017 	int ret = 0;
1018 	int reg = 0;
1019 
1020 	struct max98390_priv *max98390 = NULL;
1021 	struct i2c_adapter *adapter = i2c->adapter;
1022 	struct gpio_desc *reset_gpio;
1023 
1024 	ret = i2c_check_functionality(adapter,
1025 		I2C_FUNC_SMBUS_BYTE
1026 		| I2C_FUNC_SMBUS_BYTE_DATA);
1027 	if (!ret) {
1028 		dev_err(&i2c->dev, "I2C check functionality failed\n");
1029 		return -ENXIO;
1030 	}
1031 
1032 	max98390 = devm_kzalloc(&i2c->dev, sizeof(*max98390), GFP_KERNEL);
1033 	if (!max98390) {
1034 		ret = -ENOMEM;
1035 		return ret;
1036 	}
1037 	i2c_set_clientdata(i2c, max98390);
1038 
1039 	ret = device_property_read_u32(&i2c->dev, "maxim,temperature_calib",
1040 				       &max98390->ambient_temp_value);
1041 	if (ret) {
1042 		dev_info(&i2c->dev,
1043 			 "no optional property 'temperature_calib' found, default:\n");
1044 	}
1045 	ret = device_property_read_u32(&i2c->dev, "maxim,r0_calib",
1046 				       &max98390->ref_rdc_value);
1047 	if (ret) {
1048 		dev_info(&i2c->dev,
1049 			 "no optional property 'r0_calib' found, default:\n");
1050 	}
1051 
1052 	dev_info(&i2c->dev,
1053 		"%s: r0_calib: 0x%x,temperature_calib: 0x%x",
1054 		__func__, max98390->ref_rdc_value,
1055 		max98390->ambient_temp_value);
1056 
1057 	ret = device_property_read_string(&i2c->dev, "maxim,dsm_param_name",
1058 				       &max98390->dsm_param_name);
1059 	if (ret)
1060 		max98390->dsm_param_name = "default";
1061 
1062 	/* voltage/current slot configuration */
1063 	max98390_slot_config(i2c, max98390);
1064 
1065 	/* regmap initialization */
1066 	max98390->regmap = devm_regmap_init_i2c(i2c, &max98390_regmap);
1067 	if (IS_ERR(max98390->regmap)) {
1068 		ret = PTR_ERR(max98390->regmap);
1069 		dev_err(&i2c->dev,
1070 			"Failed to allocate regmap: %d\n", ret);
1071 		return ret;
1072 	}
1073 
1074 	reset_gpio = devm_gpiod_get_optional(&i2c->dev,
1075 					     "reset", GPIOD_OUT_HIGH);
1076 
1077 	/* Power on device */
1078 	if (reset_gpio) {
1079 		usleep_range(1000, 2000);
1080 		/* bring out of reset */
1081 		gpiod_set_value_cansleep(reset_gpio, 0);
1082 		usleep_range(1000, 2000);
1083 	}
1084 
1085 	/* Check Revision ID */
1086 	ret = regmap_read(max98390->regmap,
1087 		MAX98390_R24FF_REV_ID, &reg);
1088 	if (ret) {
1089 		dev_err(&i2c->dev,
1090 			"ret=%d, Failed to read: 0x%02X\n",
1091 			ret, MAX98390_R24FF_REV_ID);
1092 		return ret;
1093 	}
1094 	dev_info(&i2c->dev, "MAX98390 revisionID: 0x%02X\n", reg);
1095 
1096 	ret = devm_snd_soc_register_component(&i2c->dev,
1097 			&soc_codec_dev_max98390,
1098 			max98390_dai, ARRAY_SIZE(max98390_dai));
1099 
1100 	return ret;
1101 }
1102 
1103 static const struct i2c_device_id max98390_i2c_id[] = {
1104 	{ "max98390"},
1105 	{},
1106 };
1107 
1108 MODULE_DEVICE_TABLE(i2c, max98390_i2c_id);
1109 
1110 #if defined(CONFIG_OF)
1111 static const struct of_device_id max98390_of_match[] = {
1112 	{ .compatible = "maxim,max98390", },
1113 	{}
1114 };
1115 MODULE_DEVICE_TABLE(of, max98390_of_match);
1116 #endif
1117 
1118 #ifdef CONFIG_ACPI
1119 static const struct acpi_device_id max98390_acpi_match[] = {
1120 	{ "MX98390", 0 },
1121 	{},
1122 };
1123 MODULE_DEVICE_TABLE(acpi, max98390_acpi_match);
1124 #endif
1125 
1126 static struct i2c_driver max98390_i2c_driver = {
1127 	.driver = {
1128 		.name = "max98390",
1129 		.of_match_table = of_match_ptr(max98390_of_match),
1130 		.acpi_match_table = ACPI_PTR(max98390_acpi_match),
1131 		.pm = pm_ptr(&max98390_pm),
1132 	},
1133 	.probe = max98390_i2c_probe,
1134 	.id_table = max98390_i2c_id,
1135 };
1136 
1137 module_i2c_driver(max98390_i2c_driver)
1138 
1139 MODULE_DESCRIPTION("ALSA SoC MAX98390 driver");
1140 MODULE_AUTHOR("Steve Lee <steves.lee@maximintegrated.com>");
1141 MODULE_LICENSE("GPL");
1142