xref: /openbmc/linux/sound/soc/codecs/tlv320adc3xxx.c (revision f019679ea5f2ab650c3348a79e7d9c3625f62899)
1 // SPDX-License-Identifier: GPL-2.0-only
2 //
3 // Based on sound/soc/codecs/tlv320aic3x.c by  Vladimir Barinov
4 //
5 // Copyright (C) 2010 Mistral Solutions Pvt Ltd.
6 // Author: Shahina Shaik <shahina.s@mistralsolutions.com>
7 //
8 // Copyright (C) 2014-2018, Ambarella, Inc.
9 // Author: Dongge wu <dgwu@ambarella.com>
10 //
11 // Copyright (C) 2021 Axis Communications AB
12 // Author: Ricard Wanderlof <ricardw@axis.com>
13 //
14 
15 #include <dt-bindings/sound/tlv320adc3xxx.h>
16 #include <linux/clk.h>
17 #include <linux/module.h>
18 #include <linux/moduleparam.h>
19 #include <linux/io.h>
20 #include <linux/init.h>
21 #include <linux/delay.h>
22 #include <linux/gpio/driver.h>
23 #include <linux/pm.h>
24 #include <linux/i2c.h>
25 #include <linux/platform_device.h>
26 #include <linux/cdev.h>
27 #include <linux/of_gpio.h>
28 #include <linux/slab.h>
29 #include <sound/core.h>
30 #include <sound/pcm.h>
31 #include <sound/pcm_params.h>
32 #include <sound/soc.h>
33 #include <sound/soc-dapm.h>
34 #include <sound/tlv.h>
35 #include <sound/initval.h>
36 
37 /*
38  * General definitions defining exported functionality.
39  */
40 
41 #define ADC3XXX_MICBIAS_PINS		2
42 
43 /* Number of GPIO pins exposed via the gpiolib interface */
44 #define ADC3XXX_GPIOS_MAX		2
45 
46 #define ADC3XXX_RATES		SNDRV_PCM_RATE_8000_96000
47 #define ADC3XXX_FORMATS		(SNDRV_PCM_FMTBIT_S16_LE | \
48 				 SNDRV_PCM_FMTBIT_S20_3LE | \
49 				 SNDRV_PCM_FMTBIT_S24_3LE | \
50 				 SNDRV_PCM_FMTBIT_S32_LE)
51 
52 /*
53  * PLL modes, to be used for clk_id for set_sysclk callback.
54  *
55  * The default behavior (AUTO) is to take the first matching entry in the clock
56  * table, which is intended to be the PLL based one if there is more than one.
57  *
58  * Setting the clock source using simple-card (clocks or
59  * system-clock-frequency property) sets clk_id = 0 = ADC3XXX_PLL_AUTO.
60  */
61 #define ADC3XXX_PLL_AUTO	0 /* Use first available mode */
62 #define ADC3XXX_PLL_ENABLE	1 /* Use PLL for clock generation */
63 #define ADC3XXX_PLL_BYPASS	2 /* Don't use PLL for clock generation */
64 
65 /* Register definitions. */
66 
67 #define ADC3XXX_PAGE_SIZE		128
68 #define ADC3XXX_REG(page, reg)		((page * ADC3XXX_PAGE_SIZE) + reg)
69 
70 /*
71  * Page 0 registers.
72  */
73 
74 #define ADC3XXX_PAGE_SELECT			ADC3XXX_REG(0, 0)
75 #define ADC3XXX_RESET				ADC3XXX_REG(0, 1)
76 
77 /* 2-3 Reserved */
78 
79 #define ADC3XXX_CLKGEN_MUX			ADC3XXX_REG(0, 4)
80 #define ADC3XXX_PLL_PROG_PR			ADC3XXX_REG(0, 5)
81 #define ADC3XXX_PLL_PROG_J			ADC3XXX_REG(0, 6)
82 #define ADC3XXX_PLL_PROG_D_MSB			ADC3XXX_REG(0, 7)
83 #define ADC3XXX_PLL_PROG_D_LSB			ADC3XXX_REG(0, 8)
84 
85 /* 9-17 Reserved */
86 
87 #define ADC3XXX_ADC_NADC			ADC3XXX_REG(0, 18)
88 #define ADC3XXX_ADC_MADC			ADC3XXX_REG(0, 19)
89 #define ADC3XXX_ADC_AOSR			ADC3XXX_REG(0, 20)
90 #define ADC3XXX_ADC_IADC			ADC3XXX_REG(0, 21)
91 
92 /* 23-24 Reserved */
93 
94 #define ADC3XXX_CLKOUT_MUX			ADC3XXX_REG(0, 25)
95 #define ADC3XXX_CLKOUT_M_DIV			ADC3XXX_REG(0, 26)
96 #define ADC3XXX_INTERFACE_CTRL_1		ADC3XXX_REG(0, 27)
97 #define ADC3XXX_CH_OFFSET_1			ADC3XXX_REG(0, 28)
98 #define ADC3XXX_INTERFACE_CTRL_2		ADC3XXX_REG(0, 29)
99 #define ADC3XXX_BCLK_N_DIV			ADC3XXX_REG(0, 30)
100 #define ADC3XXX_INTERFACE_CTRL_3		ADC3XXX_REG(0, 31)
101 #define ADC3XXX_INTERFACE_CTRL_4		ADC3XXX_REG(0, 32)
102 #define ADC3XXX_INTERFACE_CTRL_5		ADC3XXX_REG(0, 33)
103 #define ADC3XXX_I2S_SYNC			ADC3XXX_REG(0, 34)
104 /* 35 Reserved */
105 #define ADC3XXX_ADC_FLAG			ADC3XXX_REG(0, 36)
106 #define ADC3XXX_CH_OFFSET_2			ADC3XXX_REG(0, 37)
107 #define ADC3XXX_I2S_TDM_CTRL			ADC3XXX_REG(0, 38)
108 /* 39-41 Reserved */
109 #define ADC3XXX_INTR_FLAG_1			ADC3XXX_REG(0, 42)
110 #define ADC3XXX_INTR_FLAG_2			ADC3XXX_REG(0, 43)
111 /* 44 Reserved */
112 #define ADC3XXX_INTR_FLAG_ADC1			ADC3XXX_REG(0, 45)
113 /* 46 Reserved */
114 #define ADC3XXX_INTR_FLAG_ADC2			ADC3XXX_REG(0, 47)
115 #define ADC3XXX_INT1_CTRL			ADC3XXX_REG(0, 48)
116 #define ADC3XXX_INT2_CTRL			ADC3XXX_REG(0, 49)
117 /* 50 Reserved */
118 #define ADC3XXX_GPIO2_CTRL			ADC3XXX_REG(0, 51)
119 #define ADC3XXX_GPIO1_CTRL			ADC3XXX_REG(0, 52)
120 #define ADC3XXX_DOUT_CTRL			ADC3XXX_REG(0, 53)
121 /* 54-56 Reserved */
122 #define ADC3XXX_SYNC_CTRL_1			ADC3XXX_REG(0, 57)
123 #define ADC3XXX_SYNC_CTRL_2			ADC3XXX_REG(0, 58)
124 #define ADC3XXX_CIC_GAIN_CTRL			ADC3XXX_REG(0, 59)
125 /* 60 Reserved */
126 #define ADC3XXX_PRB_SELECT			ADC3XXX_REG(0, 61)
127 #define ADC3XXX_INST_MODE_CTRL			ADC3XXX_REG(0, 62)
128 /* 63-79 Reserved */
129 #define ADC3XXX_MIC_POLARITY_CTRL		ADC3XXX_REG(0, 80)
130 #define ADC3XXX_ADC_DIGITAL			ADC3XXX_REG(0, 81)
131 #define	ADC3XXX_ADC_FGA				ADC3XXX_REG(0, 82)
132 #define ADC3XXX_LADC_VOL			ADC3XXX_REG(0, 83)
133 #define ADC3XXX_RADC_VOL			ADC3XXX_REG(0, 84)
134 #define ADC3XXX_ADC_PHASE_COMP			ADC3XXX_REG(0, 85)
135 #define ADC3XXX_LEFT_CHN_AGC_1			ADC3XXX_REG(0, 86)
136 #define ADC3XXX_LEFT_CHN_AGC_2			ADC3XXX_REG(0, 87)
137 #define ADC3XXX_LEFT_CHN_AGC_3			ADC3XXX_REG(0, 88)
138 #define ADC3XXX_LEFT_CHN_AGC_4			ADC3XXX_REG(0, 89)
139 #define ADC3XXX_LEFT_CHN_AGC_5			ADC3XXX_REG(0, 90)
140 #define ADC3XXX_LEFT_CHN_AGC_6			ADC3XXX_REG(0, 91)
141 #define ADC3XXX_LEFT_CHN_AGC_7			ADC3XXX_REG(0, 92)
142 #define ADC3XXX_LEFT_AGC_GAIN			ADC3XXX_REG(0, 93)
143 #define ADC3XXX_RIGHT_CHN_AGC_1			ADC3XXX_REG(0, 94)
144 #define ADC3XXX_RIGHT_CHN_AGC_2			ADC3XXX_REG(0, 95)
145 #define ADC3XXX_RIGHT_CHN_AGC_3			ADC3XXX_REG(0, 96)
146 #define ADC3XXX_RIGHT_CHN_AGC_4			ADC3XXX_REG(0, 97)
147 #define ADC3XXX_RIGHT_CHN_AGC_5			ADC3XXX_REG(0, 98)
148 #define ADC3XXX_RIGHT_CHN_AGC_6			ADC3XXX_REG(0, 99)
149 #define ADC3XXX_RIGHT_CHN_AGC_7			ADC3XXX_REG(0, 100)
150 #define ADC3XXX_RIGHT_AGC_GAIN			ADC3XXX_REG(0, 101)
151 /* 102-127 Reserved */
152 
153 /*
154  * Page 1 registers.
155  */
156 
157 /* 1-25 Reserved */
158 #define ADC3XXX_DITHER_CTRL			ADC3XXX_REG(1, 26)
159 /* 27-50 Reserved */
160 #define ADC3XXX_MICBIAS_CTRL			ADC3XXX_REG(1, 51)
161 #define ADC3XXX_LEFT_PGA_SEL_1			ADC3XXX_REG(1, 52)
162 /* 53 Reserved */
163 #define ADC3XXX_LEFT_PGA_SEL_2			ADC3XXX_REG(1, 54)
164 #define ADC3XXX_RIGHT_PGA_SEL_1			ADC3XXX_REG(1, 55)
165 #define ADC3XXX_RIGHT_PGA_SEL_2			ADC3XXX_REG(1, 57)
166 #define ADC3XXX_LEFT_APGA_CTRL			ADC3XXX_REG(1, 59)
167 #define ADC3XXX_RIGHT_APGA_CTRL			ADC3XXX_REG(1, 60)
168 #define ADC3XXX_LOW_CURRENT_MODES		ADC3XXX_REG(1, 61)
169 #define ADC3XXX_ANALOG_PGA_FLAGS		ADC3XXX_REG(1, 62)
170 /* 63-127 Reserved */
171 
172 /*
173  * Page 4 registers. First page of coefficient memory for the miniDSP.
174  */
175 #define ADC3XXX_LEFT_ADC_IIR_COEFF_N0_MSB	ADC3XXX_REG(4, 8)
176 #define ADC3XXX_LEFT_ADC_IIR_COEFF_N0_LSB	ADC3XXX_REG(4, 9)
177 #define ADC3XXX_LEFT_ADC_IIR_COEFF_N1_MSB	ADC3XXX_REG(4, 10)
178 #define ADC3XXX_LEFT_ADC_IIR_COEFF_N1_LSB	ADC3XXX_REG(4, 11)
179 #define ADC3XXX_LEFT_ADC_IIR_COEFF_D1_MSB	ADC3XXX_REG(4, 12)
180 #define ADC3XXX_LEFT_ADC_IIR_COEFF_D1_LSB	ADC3XXX_REG(4, 13)
181 
182 #define ADC3XXX_RIGHT_ADC_IIR_COEFF_N0_MSB	ADC3XXX_REG(4, 72)
183 #define ADC3XXX_RIGHT_ADC_IIR_COEFF_N0_LSB	ADC3XXX_REG(4, 73)
184 #define ADC3XXX_RIGHT_ADC_IIR_COEFF_N1_MSB	ADC3XXX_REG(4, 74)
185 #define ADC3XXX_RIGHT_ADC_IIR_COEFF_N1_LSB	ADC3XXX_REG(4, 75)
186 #define ADC3XXX_RIGHT_ADC_IIR_COEFF_D1_MSB	ADC3XXX_REG(4, 76)
187 #define ADC3XXX_RIGHT_ADC_IIR_COEFF_D1_LSB	ADC3XXX_REG(4, 77)
188 
189 /*
190  * Register bits.
191  */
192 
193 /* PLL Enable bits */
194 #define ADC3XXX_ENABLE_PLL_SHIFT	7
195 #define ADC3XXX_ENABLE_PLL		(1 << ADC3XXX_ENABLE_PLL_SHIFT)
196 #define ADC3XXX_ENABLE_NADC_SHIFT	7
197 #define ADC3XXX_ENABLE_NADC		(1 << ADC3XXX_ENABLE_NADC_SHIFT)
198 #define ADC3XXX_ENABLE_MADC_SHIFT	7
199 #define ADC3XXX_ENABLE_MADC		(1 << ADC3XXX_ENABLE_MADC_SHIFT)
200 #define ADC3XXX_ENABLE_BCLK_SHIFT	7
201 #define ADC3XXX_ENABLE_BCLK		(1 << ADC3XXX_ENABLE_BCLK_SHIFT)
202 
203 /* Power bits */
204 #define ADC3XXX_LADC_PWR_ON		0x80
205 #define ADC3XXX_RADC_PWR_ON		0x40
206 
207 #define ADC3XXX_SOFT_RESET		0x01
208 #define ADC3XXX_BCLK_MASTER		0x08
209 #define ADC3XXX_WCLK_MASTER		0x04
210 
211 /* Interface register masks */
212 #define ADC3XXX_FORMAT_MASK		0xc0
213 #define ADC3XXX_FORMAT_SHIFT		6
214 #define ADC3XXX_WLENGTH_MASK		0x30
215 #define ADC3XXX_WLENGTH_SHIFT		4
216 #define ADC3XXX_CLKDIR_MASK		0x0c
217 #define ADC3XXX_CLKDIR_SHIFT		2
218 
219 /* Interface register bit patterns */
220 #define ADC3XXX_FORMAT_I2S		(0 << ADC3XXX_FORMAT_SHIFT)
221 #define ADC3XXX_FORMAT_DSP		(1 << ADC3XXX_FORMAT_SHIFT)
222 #define ADC3XXX_FORMAT_RJF		(2 << ADC3XXX_FORMAT_SHIFT)
223 #define ADC3XXX_FORMAT_LJF		(3 << ADC3XXX_FORMAT_SHIFT)
224 
225 #define ADC3XXX_IFACE_16BITS		(0 << ADC3XXX_WLENGTH_SHIFT)
226 #define ADC3XXX_IFACE_20BITS		(1 << ADC3XXX_WLENGTH_SHIFT)
227 #define ADC3XXX_IFACE_24BITS		(2 << ADC3XXX_WLENGTH_SHIFT)
228 #define ADC3XXX_IFACE_32BITS		(3 << ADC3XXX_WLENGTH_SHIFT)
229 
230 /* PLL P/R bit offsets */
231 #define ADC3XXX_PLLP_SHIFT		4
232 #define ADC3XXX_PLLR_SHIFT		0
233 #define ADC3XXX_PLL_PR_MASK		0x7f
234 #define ADC3XXX_PLLJ_MASK		0x3f
235 #define ADC3XXX_PLLD_MSB_MASK		0x3f
236 #define ADC3XXX_PLLD_LSB_MASK		0xff
237 #define ADC3XXX_NADC_MASK		0x7f
238 #define ADC3XXX_MADC_MASK		0x7f
239 #define ADC3XXX_AOSR_MASK		0xff
240 #define ADC3XXX_IADC_MASK		0xff
241 #define ADC3XXX_BDIV_MASK		0x7f
242 
243 /* PLL_CLKIN bits */
244 #define ADC3XXX_PLL_CLKIN_SHIFT		2
245 #define ADC3XXX_PLL_CLKIN_MCLK		0x0
246 #define ADC3XXX_PLL_CLKIN_BCLK		0x1
247 #define ADC3XXX_PLL_CLKIN_ZERO		0x3
248 
249 /* CODEC_CLKIN bits */
250 #define ADC3XXX_CODEC_CLKIN_SHIFT	0
251 #define ADC3XXX_CODEC_CLKIN_MCLK	0x0
252 #define ADC3XXX_CODEC_CLKIN_BCLK	0x1
253 #define ADC3XXX_CODEC_CLKIN_PLL_CLK	0x3
254 
255 #define ADC3XXX_USE_PLL	((ADC3XXX_PLL_CLKIN_MCLK << ADC3XXX_PLL_CLKIN_SHIFT) | \
256 			 (ADC3XXX_CODEC_CLKIN_PLL_CLK << ADC3XXX_CODEC_CLKIN_SHIFT))
257 #define ADC3XXX_NO_PLL	((ADC3XXX_PLL_CLKIN_ZERO << ADC3XXX_PLL_CLKIN_SHIFT) | \
258 			 (ADC3XXX_CODEC_CLKIN_MCLK << ADC3XXX_CODEC_CLKIN_SHIFT))
259 
260 /*  Analog PGA control bits */
261 #define ADC3XXX_LPGA_MUTE		0x80
262 #define ADC3XXX_RPGA_MUTE		0x80
263 
264 #define ADC3XXX_LPGA_GAIN_MASK		0x7f
265 #define ADC3XXX_RPGA_GAIN_MASK		0x7f
266 
267 /* ADC current modes */
268 #define ADC3XXX_ADC_LOW_CURR_MODE	0x01
269 
270 /* Left ADC Input selection bits */
271 #define ADC3XXX_LCH_SEL1_SHIFT		0
272 #define ADC3XXX_LCH_SEL2_SHIFT		2
273 #define ADC3XXX_LCH_SEL3_SHIFT		4
274 #define ADC3XXX_LCH_SEL4_SHIFT		6
275 
276 #define ADC3XXX_LCH_SEL1X_SHIFT		0
277 #define ADC3XXX_LCH_SEL2X_SHIFT		2
278 #define ADC3XXX_LCH_SEL3X_SHIFT		4
279 #define ADC3XXX_LCH_COMMON_MODE		0x40
280 #define ADC3XXX_BYPASS_LPGA		0x80
281 
282 /* Right ADC Input selection bits */
283 #define ADC3XXX_RCH_SEL1_SHIFT		0
284 #define ADC3XXX_RCH_SEL2_SHIFT		2
285 #define ADC3XXX_RCH_SEL3_SHIFT		4
286 #define ADC3XXX_RCH_SEL4_SHIFT		6
287 
288 #define ADC3XXX_RCH_SEL1X_SHIFT		0
289 #define ADC3XXX_RCH_SEL2X_SHIFT		2
290 #define ADC3XXX_RCH_SEL3X_SHIFT		4
291 #define ADC3XXX_RCH_COMMON_MODE		0x40
292 #define ADC3XXX_BYPASS_RPGA		0x80
293 
294 /* MICBIAS control bits */
295 #define ADC3XXX_MICBIAS_MASK		0x2
296 #define ADC3XXX_MICBIAS1_SHIFT		5
297 #define ADC3XXX_MICBIAS2_SHIFT		3
298 
299 #define ADC3XXX_ADC_MAX_VOLUME		64
300 #define ADC3XXX_ADC_POS_VOL		24
301 
302 /* GPIO control bits (GPIO1_CTRL and GPIO2_CTRL) */
303 #define ADC3XXX_GPIO_CTRL_CFG_MASK		0x3c
304 #define ADC3XXX_GPIO_CTRL_CFG_SHIFT		2
305 #define ADC3XXX_GPIO_CTRL_OUTPUT_CTRL_MASK	0x01
306 #define ADC3XXX_GPIO_CTRL_OUTPUT_CTRL_SHIFT	0
307 #define ADC3XXX_GPIO_CTRL_INPUT_VALUE_MASK	0x02
308 #define ADC3XXX_GPIO_CTRL_INPUT_VALUE_SHIFT	1
309 
310 enum adc3xxx_type {
311 	ADC3001 = 0,
312 	ADC3101
313 };
314 
315 struct adc3xxx {
316 	struct device *dev;
317 	enum adc3xxx_type type;
318 	struct clk *mclk;
319 	struct regmap *regmap;
320 	struct gpio_desc *rst_pin;
321 	unsigned int pll_mode;
322 	unsigned int sysclk;
323 	unsigned int gpio_cfg[ADC3XXX_GPIOS_MAX]; /* value+1 (0 => not set)  */
324 	unsigned int micbias_vg[ADC3XXX_MICBIAS_PINS];
325 	int master;
326 	u8 page_no;
327 	int use_pll;
328 	struct gpio_chip gpio_chip;
329 };
330 
331 static const unsigned int adc3xxx_gpio_ctrl_reg[ADC3XXX_GPIOS_MAX] = {
332 	ADC3XXX_GPIO1_CTRL,
333 	ADC3XXX_GPIO2_CTRL
334 };
335 
336 static const unsigned int adc3xxx_micbias_shift[ADC3XXX_MICBIAS_PINS] = {
337 	ADC3XXX_MICBIAS1_SHIFT,
338 	ADC3XXX_MICBIAS2_SHIFT
339 };
340 
341 static const struct reg_default adc3xxx_defaults[] = {
342 	/* Page 0 */
343 	{ 0, 0x00 },    { 1, 0x00 },    { 2, 0x00 },    { 3, 0x00 },
344 	{ 4, 0x00 },    { 5, 0x11 },    { 6, 0x04 },    { 7, 0x00 },
345 	{ 8, 0x00 },    { 9, 0x00 },    { 10, 0x00 },   { 11, 0x00 },
346 	{ 12, 0x00 },   { 13, 0x00 },   { 14, 0x00 },   { 15, 0x00 },
347 	{ 16, 0x00 },   { 17, 0x00 },   { 18, 0x01 },   { 19, 0x01 },
348 	{ 20, 0x80 },   { 21, 0x80 },   { 22, 0x04 },   { 23, 0x00 },
349 	{ 24, 0x00 },   { 25, 0x00 },   { 26, 0x01 },   { 27, 0x00 },
350 	{ 28, 0x00 },   { 29, 0x02 },   { 30, 0x01 },   { 31, 0x00 },
351 	{ 32, 0x00 },   { 33, 0x10 },   { 34, 0x00 },   { 35, 0x00 },
352 	{ 36, 0x00 },   { 37, 0x00 },   { 38, 0x02 },   { 39, 0x00 },
353 	{ 40, 0x00 },   { 41, 0x00 },   { 42, 0x00 },   { 43, 0x00 },
354 	{ 44, 0x00 },   { 45, 0x00 },   { 46, 0x00 },   { 47, 0x00 },
355 	{ 48, 0x00 },   { 49, 0x00 },   { 50, 0x00 },   { 51, 0x00 },
356 	{ 52, 0x00 },   { 53, 0x12 },   { 54, 0x00 },   { 55, 0x00 },
357 	{ 56, 0x00 },   { 57, 0x00 },   { 58, 0x00 },   { 59, 0x44 },
358 	{ 60, 0x00 },   { 61, 0x01 },   { 62, 0x00 },   { 63, 0x00 },
359 	{ 64, 0x00 },   { 65, 0x00 },   { 66, 0x00 },   { 67, 0x00 },
360 	{ 68, 0x00 },   { 69, 0x00 },   { 70, 0x00 },   { 71, 0x00 },
361 	{ 72, 0x00 },   { 73, 0x00 },   { 74, 0x00 },   { 75, 0x00 },
362 	{ 76, 0x00 },   { 77, 0x00 },   { 78, 0x00 },   { 79, 0x00 },
363 	{ 80, 0x00 },   { 81, 0x00 },   { 82, 0x88 },   { 83, 0x00 },
364 	{ 84, 0x00 },   { 85, 0x00 },   { 86, 0x00 },   { 87, 0x00 },
365 	{ 88, 0x7f },   { 89, 0x00 },   { 90, 0x00 },   { 91, 0x00 },
366 	{ 92, 0x00 },   { 93, 0x00 },   { 94, 0x00 },   { 95, 0x00 },
367 	{ 96, 0x7f },   { 97, 0x00 },   { 98, 0x00 },   { 99, 0x00 },
368 	{ 100, 0x00 },  { 101, 0x00 },  { 102, 0x00 },  { 103, 0x00 },
369 	{ 104, 0x00 },  { 105, 0x00 },  { 106, 0x00 },  { 107, 0x00 },
370 	{ 108, 0x00 },  { 109, 0x00 },  { 110, 0x00 },  { 111, 0x00 },
371 	{ 112, 0x00 },  { 113, 0x00 },  { 114, 0x00 },  { 115, 0x00 },
372 	{ 116, 0x00 },  { 117, 0x00 },  { 118, 0x00 },  { 119, 0x00 },
373 	{ 120, 0x00 },  { 121, 0x00 },  { 122, 0x00 },  { 123, 0x00 },
374 	{ 124, 0x00 },  { 125, 0x00 },  { 126, 0x00 },  { 127, 0x00 },
375 
376 	/* Page 1 */
377 	{ 128, 0x00 },  { 129, 0x00 },  { 130, 0x00 },  { 131, 0x00 },
378 	{ 132, 0x00 },  { 133, 0x00 },  { 134, 0x00 },  { 135, 0x00 },
379 	{ 136, 0x00 },  { 137, 0x00 },  { 138, 0x00 },  { 139, 0x00 },
380 	{ 140, 0x00 },  { 141, 0x00 },  { 142, 0x00 },  { 143, 0x00 },
381 	{ 144, 0x00 },  { 145, 0x00 },  { 146, 0x00 },  { 147, 0x00 },
382 	{ 148, 0x00 },  { 149, 0x00 },  { 150, 0x00 },  { 151, 0x00 },
383 	{ 152, 0x00 },  { 153, 0x00 },  { 154, 0x00 },  { 155, 0x00 },
384 	{ 156, 0x00 },  { 157, 0x00 },  { 158, 0x00 },  { 159, 0x00 },
385 	{ 160, 0x00 },  { 161, 0x00 },  { 162, 0x00 },  { 163, 0x00 },
386 	{ 164, 0x00 },  { 165, 0x00 },  { 166, 0x00 },  { 167, 0x00 },
387 	{ 168, 0x00 },  { 169, 0x00 },  { 170, 0x00 },  { 171, 0x00 },
388 	{ 172, 0x00 },  { 173, 0x00 },  { 174, 0x00 },  { 175, 0x00 },
389 	{ 176, 0x00 },  { 177, 0x00 },  { 178, 0x00 },  { 179, 0x00 },
390 	{ 180, 0xff },  { 181, 0x00 },  { 182, 0x3f },  { 183, 0xff },
391 	{ 184, 0x00 },  { 185, 0x3f },  { 186, 0x00 },  { 187, 0x80 },
392 	{ 188, 0x80 },  { 189, 0x00 },  { 190, 0x00 },  { 191, 0x00 },
393 
394 	/* Page 4 */
395 	{ 1024, 0x00 },			{ 1026, 0x01 },	{ 1027, 0x17 },
396 	{ 1028, 0x01 }, { 1029, 0x17 }, { 1030, 0x7d }, { 1031, 0xd3 },
397 	{ 1032, 0x7f }, { 1033, 0xff }, { 1034, 0x00 }, { 1035, 0x00 },
398 	{ 1036, 0x00 }, { 1037, 0x00 }, { 1038, 0x7f }, { 1039, 0xff },
399 	{ 1040, 0x00 }, { 1041, 0x00 }, { 1042, 0x00 }, { 1043, 0x00 },
400 	{ 1044, 0x00 }, { 1045, 0x00 }, { 1046, 0x00 }, { 1047, 0x00 },
401 	{ 1048, 0x7f }, { 1049, 0xff }, { 1050, 0x00 }, { 1051, 0x00 },
402 	{ 1052, 0x00 }, { 1053, 0x00 }, { 1054, 0x00 }, { 1055, 0x00 },
403 	{ 1056, 0x00 }, { 1057, 0x00 }, { 1058, 0x7f }, { 1059, 0xff },
404 	{ 1060, 0x00 }, { 1061, 0x00 }, { 1062, 0x00 }, { 1063, 0x00 },
405 	{ 1064, 0x00 }, { 1065, 0x00 }, { 1066, 0x00 }, { 1067, 0x00 },
406 	{ 1068, 0x7f }, { 1069, 0xff }, { 1070, 0x00 }, { 1071, 0x00 },
407 	{ 1072, 0x00 }, { 1073, 0x00 }, { 1074, 0x00 }, { 1075, 0x00 },
408 	{ 1076, 0x00 }, { 1077, 0x00 }, { 1078, 0x7f }, { 1079, 0xff },
409 	{ 1080, 0x00 }, { 1081, 0x00 }, { 1082, 0x00 }, { 1083, 0x00 },
410 	{ 1084, 0x00 }, { 1085, 0x00 }, { 1086, 0x00 }, { 1087, 0x00 },
411 	{ 1088, 0x00 }, { 1089, 0x00 }, { 1090, 0x00 }, { 1091, 0x00 },
412 	{ 1092, 0x00 }, { 1093, 0x00 }, { 1094, 0x00 }, { 1095, 0x00 },
413 	{ 1096, 0x00 }, { 1097, 0x00 }, { 1098, 0x00 }, { 1099, 0x00 },
414 	{ 1100, 0x00 }, { 1101, 0x00 }, { 1102, 0x00 }, { 1103, 0x00 },
415 	{ 1104, 0x00 }, { 1105, 0x00 }, { 1106, 0x00 }, { 1107, 0x00 },
416 	{ 1108, 0x00 }, { 1109, 0x00 }, { 1110, 0x00 }, { 1111, 0x00 },
417 	{ 1112, 0x00 }, { 1113, 0x00 }, { 1114, 0x00 }, { 1115, 0x00 },
418 	{ 1116, 0x00 }, { 1117, 0x00 }, { 1118, 0x00 }, { 1119, 0x00 },
419 	{ 1120, 0x00 }, { 1121, 0x00 }, { 1122, 0x00 }, { 1123, 0x00 },
420 	{ 1124, 0x00 }, { 1125, 0x00 }, { 1126, 0x00 }, { 1127, 0x00 },
421 	{ 1128, 0x00 }, { 1129, 0x00 }, { 1130, 0x00 }, { 1131, 0x00 },
422 	{ 1132, 0x00 }, { 1133, 0x00 }, { 1134, 0x00 }, { 1135, 0x00 },
423 	{ 1136, 0x00 }, { 1137, 0x00 }, { 1138, 0x00 }, { 1139, 0x00 },
424 	{ 1140, 0x00 }, { 1141, 0x00 }, { 1142, 0x00 }, { 1143, 0x00 },
425 	{ 1144, 0x00 }, { 1145, 0x00 }, { 1146, 0x00 }, { 1147, 0x00 },
426 	{ 1148, 0x00 }, { 1149, 0x00 }, { 1150, 0x00 }, { 1151, 0x00 },
427 };
428 
429 static bool adc3xxx_volatile_reg(struct device *dev, unsigned int reg)
430 {
431 	switch (reg) {
432 	case ADC3XXX_RESET:
433 		return true;
434 	default:
435 		return false;
436 	}
437 }
438 
439 static const struct regmap_range_cfg adc3xxx_ranges[] = {
440 	{
441 		.range_min = 0,
442 		.range_max = 5 * ADC3XXX_PAGE_SIZE,
443 		.selector_reg = ADC3XXX_PAGE_SELECT,
444 		.selector_mask = 0xff,
445 		.selector_shift = 0,
446 		.window_start = 0,
447 		.window_len = ADC3XXX_PAGE_SIZE,
448 	}
449 };
450 
451 static const struct regmap_config adc3xxx_regmap = {
452 	.reg_bits = 8,
453 	.val_bits = 8,
454 
455 	.reg_defaults = adc3xxx_defaults,
456 	.num_reg_defaults = ARRAY_SIZE(adc3xxx_defaults),
457 
458 	.volatile_reg = adc3xxx_volatile_reg,
459 
460 	.cache_type = REGCACHE_RBTREE,
461 
462 	.ranges = adc3xxx_ranges,
463 	.num_ranges = ARRAY_SIZE(adc3xxx_ranges),
464 	.max_register = 5 * ADC3XXX_PAGE_SIZE,
465 };
466 
467 struct adc3xxx_rate_divs {
468 	u32 mclk;
469 	u32 rate;
470 	u8 pll_p;
471 	u8 pll_r;
472 	u8 pll_j;
473 	u16 pll_d;
474 	u8 nadc;
475 	u8 madc;
476 	u8 aosr;
477 };
478 
479 /*
480  * PLL and Clock settings.
481  * If p member is 0, PLL is not used.
482  * The order of the entries in this table have the PLL entries before
483  * the non-PLL entries, so that the PLL modes are preferred unless
484  * the PLL mode setting says otherwise.
485  */
486 static const struct adc3xxx_rate_divs adc3xxx_divs[] = {
487 	/* mclk, rate, p, r, j, d, nadc, madc, aosr */
488 	/* 8k rate */
489 	{ 12000000, 8000, 1, 1, 7, 1680, 42, 2, 128 },
490 	{ 12288000, 8000, 1, 1, 7, 0000, 42, 2, 128 },
491 	/* 11.025k rate */
492 	{ 12000000, 11025, 1, 1, 6, 8208, 29, 2, 128 },
493 	/* 16k rate */
494 	{ 12000000, 16000, 1, 1, 7, 1680, 21, 2, 128 },
495 	{ 12288000, 16000, 1, 1, 7, 0000, 21, 2, 128 },
496 	/* 22.05k rate */
497 	{ 12000000, 22050, 1, 1, 7, 560, 15, 2, 128 },
498 	/* 32k rate */
499 	{ 12000000, 32000, 1, 1, 8, 1920, 12, 2, 128 },
500 	{ 12288000, 32000, 1, 1, 8, 0000, 12, 2, 128 },
501 	/* 44.1k rate */
502 	{ 12000000, 44100, 1, 1, 7, 5264, 8, 2, 128 },
503 	/* 48k rate */
504 	{ 12000000, 48000, 1, 1, 7, 1680, 7, 2, 128 },
505 	{ 12288000, 48000, 1, 1, 7, 0000, 7, 2, 128 },
506 	{ 24576000, 48000, 1, 1, 3, 5000, 7, 2, 128 }, /* With PLL */
507 	{ 24576000, 48000, 0, 0, 0, 0000, 2, 2, 128 }, /* Without PLL */
508 	/* 88.2k rate */
509 	{ 12000000, 88200, 1, 1, 7, 5264, 4, 4, 64 },
510 	/* 96k rate */
511 	{ 12000000, 96000, 1, 1, 8, 1920, 4, 4, 64 },
512 };
513 
514 static int adc3xxx_get_divs(struct device *dev, int mclk, int rate, int pll_mode)
515 {
516 	int i;
517 
518 	dev_dbg(dev, "mclk = %d, rate = %d, clock mode %u\n",
519 		mclk, rate, pll_mode);
520 	for (i = 0; i < ARRAY_SIZE(adc3xxx_divs); i++) {
521 		const struct adc3xxx_rate_divs *mode = &adc3xxx_divs[i];
522 
523 		/* Skip this entry if it doesn't fulfill the intended clock
524 		 * mode requirement. We consider anything besides the two
525 		 * modes below to be the same as ADC3XXX_PLL_AUTO.
526 		 */
527 		if ((pll_mode == ADC3XXX_PLL_BYPASS && mode->pll_p) ||
528 		    (pll_mode == ADC3XXX_PLL_ENABLE && !mode->pll_p))
529 			continue;
530 
531 		if (mode->rate == rate && mode->mclk == mclk)
532 			return i;
533 	}
534 
535 	dev_info(dev, "Master clock rate %d and sample rate %d is not supported\n",
536 		 mclk, rate);
537 	return -EINVAL;
538 }
539 
540 static int adc3xxx_pll_delay(struct snd_soc_dapm_widget *w,
541 			     struct snd_kcontrol *kcontrol, int event)
542 {
543 	/* 10msec delay needed after PLL power-up to allow
544 	 * PLL and dividers to stabilize (datasheet p13).
545 	 */
546 	usleep_range(10000, 20000);
547 
548 	return 0;
549 }
550 
551 static int adc3xxx_coefficient_info(struct snd_kcontrol *kcontrol,
552 				    struct snd_ctl_elem_info *uinfo)
553 {
554 	int numcoeff = kcontrol->private_value >> 16;
555 
556 	uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
557 	uinfo->count = numcoeff;
558 	uinfo->value.integer.min = 0;
559 	uinfo->value.integer.max = 0xffff; /* all coefficients are 16 bit */
560 	return 0;
561 }
562 
563 static int adc3xxx_coefficient_get(struct snd_kcontrol *kcontrol,
564 				   struct snd_ctl_elem_value *ucontrol)
565 {
566 	struct snd_soc_component *component = snd_soc_kcontrol_component(kcontrol);
567 	int numcoeff  = kcontrol->private_value >> 16;
568 	int reg = kcontrol->private_value & 0xffff;
569 	int index = 0;
570 
571 	for (index = 0; index < numcoeff; index++) {
572 		unsigned int value_msb, value_lsb, value;
573 
574 		value_msb = snd_soc_component_read(component, reg++);
575 		if ((int)value_msb < 0)
576 			return (int)value_msb;
577 
578 		value_lsb = snd_soc_component_read(component, reg++);
579 		if ((int)value_lsb < 0)
580 			return (int)value_lsb;
581 
582 		value = (value_msb << 8) | value_lsb;
583 		ucontrol->value.integer.value[index] = value;
584 	}
585 
586 	return 0;
587 }
588 
589 static int adc3xxx_coefficient_put(struct snd_kcontrol *kcontrol,
590 				   struct snd_ctl_elem_value *ucontrol)
591 {
592 	struct snd_soc_component *component = snd_soc_kcontrol_component(kcontrol);
593 	int numcoeff  = kcontrol->private_value >> 16;
594 	int reg = kcontrol->private_value & 0xffff;
595 	int index = 0;
596 	int ret;
597 
598 	for (index = 0; index < numcoeff; index++) {
599 		unsigned int value = ucontrol->value.integer.value[index];
600 		unsigned int value_msb = (value >> 8) & 0xff;
601 		unsigned int value_lsb = value & 0xff;
602 
603 		ret = snd_soc_component_write(component, reg++, value_msb);
604 		if (ret)
605 			return ret;
606 
607 		ret = snd_soc_component_write(component, reg++, value_lsb);
608 		if (ret)
609 			return ret;
610 	}
611 
612 	return 0;
613 }
614 
615 /* All on-chip filters have coefficients which are expressed in terms of
616  * 16 bit values, so represent them as strings of 16-bit integers.
617  */
618 #define TI_COEFFICIENTS(xname, reg, numcoeffs) { \
619 	.iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
620 	.name = xname, \
621 	.info = adc3xxx_coefficient_info, \
622 	.get = adc3xxx_coefficient_get,\
623 	.put = adc3xxx_coefficient_put, \
624 	.access = SNDRV_CTL_ELEM_ACCESS_READWRITE, \
625 	.private_value = reg | (numcoeffs << 16) \
626 }
627 
628 static const char * const adc_softstepping_text[] = { "1 step", "2 step", "off" };
629 static SOC_ENUM_SINGLE_DECL(adc_softstepping_enum, ADC3XXX_ADC_DIGITAL, 0,
630 			    adc_softstepping_text);
631 
632 static const char * const multiplier_text[] = { "1", "2", "4", "8", "16", "32", "64", "128" };
633 static SOC_ENUM_SINGLE_DECL(left_agc_attack_mult_enum,
634 			    ADC3XXX_LEFT_CHN_AGC_4, 0, multiplier_text);
635 static SOC_ENUM_SINGLE_DECL(right_agc_attack_mult_enum,
636 			    ADC3XXX_RIGHT_CHN_AGC_4, 0, multiplier_text);
637 static SOC_ENUM_SINGLE_DECL(left_agc_decay_mult_enum,
638 			    ADC3XXX_LEFT_CHN_AGC_5, 0, multiplier_text);
639 static SOC_ENUM_SINGLE_DECL(right_agc_decay_mult_enum,
640 			    ADC3XXX_RIGHT_CHN_AGC_5, 0, multiplier_text);
641 
642 static const char * const dither_dc_offset_text[] = {
643 	"0mV", "15mV", "30mV", "45mV", "60mV", "75mV", "90mV", "105mV",
644 	"-15mV", "-30mV", "-45mV", "-60mV", "-75mV", "-90mV", "-105mV"
645 };
646 static const unsigned int dither_dc_offset_values[] = {
647 	0, 1, 2, 3, 4, 5, 6, 7, 9, 10, 11, 12, 13, 14, 15
648 };
649 static SOC_VALUE_ENUM_DOUBLE_DECL(dither_dc_offset_enum,
650 				  ADC3XXX_DITHER_CTRL,
651 				  4, 0, 0xf, dither_dc_offset_text,
652 				  dither_dc_offset_values);
653 
654 static const DECLARE_TLV_DB_SCALE(pga_tlv, 0, 50, 0);
655 static const DECLARE_TLV_DB_SCALE(adc_tlv, -1200, 50, 0);
656 static const DECLARE_TLV_DB_SCALE(adc_fine_tlv, -40, 10, 0);
657 /* AGC target: 8 values: -5.5, -8, -10, -12, -14, -17, -20, -24 dB */
658 /* It would be nice to declare these in the order above, but empirically
659  * TLV_DB_SCALE_ITEM doesn't take lightly to the increment (second) parameter
660  * being negative, despite there being examples to the contrary in other
661  * drivers. So declare these in the order from lowest to highest, and
662  * set the invert flag in the SOC_DOUBLE_R_TLV declaration instead.
663  */
664 static const DECLARE_TLV_DB_RANGE(agc_target_tlv,
665 	0, 0, TLV_DB_SCALE_ITEM(-2400, 0, 0),
666 	1, 3, TLV_DB_SCALE_ITEM(-2000, 300, 0),
667 	4, 6, TLV_DB_SCALE_ITEM(-1200, 200, 0),
668 	7, 7, TLV_DB_SCALE_ITEM(-550, 0, 0));
669 /* Since the 'disabled' value (mute) is at the highest value in the dB
670  * range (i.e. just before -32 dB) rather than the lowest, we need to resort
671  * to using a TLV_DB_RANGE in order to get the mute value in the right place.
672  */
673 static const DECLARE_TLV_DB_RANGE(agc_thresh_tlv,
674 	0, 30, TLV_DB_SCALE_ITEM(-9000, 200, 0),
675 	31, 31, TLV_DB_SCALE_ITEM(0, 0, 1)); /* disabled = mute */
676 /* AGC hysteresis: 4 values: 1, 2, 4 dB, disabled (= mute) */
677 static const DECLARE_TLV_DB_RANGE(agc_hysteresis_tlv,
678 	0, 1, TLV_DB_SCALE_ITEM(100, 100, 0),
679 	2, 2, TLV_DB_SCALE_ITEM(400, 0, 0),
680 	3, 3, TLV_DB_SCALE_ITEM(0, 0, 1)); /* disabled = mute */
681 static const DECLARE_TLV_DB_SCALE(agc_max_tlv, 0, 50, 0);
682 /* Input attenuation: -6 dB or 0 dB */
683 static const DECLARE_TLV_DB_SCALE(input_attenuation_tlv, -600, 600, 0);
684 
685 static const struct snd_kcontrol_new adc3xxx_snd_controls[] = {
686 	SOC_DOUBLE_R_TLV("PGA Capture Volume", ADC3XXX_LEFT_APGA_CTRL,
687 			 ADC3XXX_RIGHT_APGA_CTRL, 0, 80, 0, pga_tlv),
688 	SOC_DOUBLE("PGA Capture Switch", ADC3XXX_ADC_FGA, 7, 3, 1, 1),
689 	SOC_DOUBLE_R("AGC Capture Switch", ADC3XXX_LEFT_CHN_AGC_1,
690 		     ADC3XXX_RIGHT_CHN_AGC_1, 7, 1, 0),
691 	SOC_DOUBLE_R_TLV("AGC Target Level Capture Volume", ADC3XXX_LEFT_CHN_AGC_1,
692 		     ADC3XXX_RIGHT_CHN_AGC_2, 4, 0x07, 1, agc_target_tlv),
693 	SOC_DOUBLE_R_TLV("AGC Noise Threshold Capture Volume", ADC3XXX_LEFT_CHN_AGC_2,
694 		     ADC3XXX_RIGHT_CHN_AGC_2, 1, 0x1f, 1, agc_thresh_tlv),
695 	SOC_DOUBLE_R_TLV("AGC Hysteresis Capture Volume", ADC3XXX_LEFT_CHN_AGC_2,
696 		     ADC3XXX_RIGHT_CHN_AGC_2, 6, 3, 0, agc_hysteresis_tlv),
697 	SOC_DOUBLE_R("AGC Clip Stepping Capture Switch", ADC3XXX_LEFT_CHN_AGC_2,
698 		     ADC3XXX_RIGHT_CHN_AGC_2, 0, 1, 0),
699 	/*
700 	 * Oddly enough, the data sheet says the default value
701 	 * for the left/right AGC maximum gain register field
702 	 * (ADC3XXX_LEFT/RIGHT_CHN_AGC_3 bits 0..6) is 0x7f = 127
703 	 * (verified empirically) even though this value (indeed, above
704 	 * 0x50) is specified as 'Reserved. Do not use.' in the accompanying
705 	 * table in the data sheet.
706 	 */
707 	SOC_DOUBLE_R_TLV("AGC Maximum Capture Volume", ADC3XXX_LEFT_CHN_AGC_3,
708 		     ADC3XXX_RIGHT_CHN_AGC_3, 0, 0x50, 0, agc_max_tlv),
709 	SOC_DOUBLE_R("AGC Attack Time", ADC3XXX_LEFT_CHN_AGC_4,
710 		     ADC3XXX_RIGHT_CHN_AGC_4, 3, 0x1f, 0),
711 	/* Would like to have the multipliers as LR pairs, but there is
712 	 * no SOC_ENUM_foo which accepts two values in separate registers.
713 	 */
714 	SOC_ENUM("AGC Left Attack Time Multiplier", left_agc_attack_mult_enum),
715 	SOC_ENUM("AGC Right Attack Time Multiplier", right_agc_attack_mult_enum),
716 	SOC_DOUBLE_R("AGC Decay Time", ADC3XXX_LEFT_CHN_AGC_5,
717 		     ADC3XXX_RIGHT_CHN_AGC_5, 3, 0x1f, 0),
718 	SOC_ENUM("AGC Left Decay Time Multiplier", left_agc_decay_mult_enum),
719 	SOC_ENUM("AGC Right Decay Time Multiplier", right_agc_decay_mult_enum),
720 	SOC_DOUBLE_R("AGC Noise Debounce", ADC3XXX_LEFT_CHN_AGC_6,
721 		     ADC3XXX_RIGHT_CHN_AGC_6, 0, 0x1f, 0),
722 	SOC_DOUBLE_R("AGC Signal Debounce", ADC3XXX_LEFT_CHN_AGC_7,
723 		     ADC3XXX_RIGHT_CHN_AGC_7, 0, 0x0f, 0),
724 	/* Read only register */
725 	SOC_DOUBLE_R_S_TLV("AGC Applied Capture Volume", ADC3XXX_LEFT_AGC_GAIN,
726 			   ADC3XXX_RIGHT_AGC_GAIN, 0, -24, 40, 6, 0, adc_tlv),
727 	/* ADC soft stepping */
728 	SOC_ENUM("ADC Soft Stepping", adc_softstepping_enum),
729 	/* Left/Right Input attenuation */
730 	SOC_SINGLE_TLV("Left Input IN_1L Capture Volume",
731 		       ADC3XXX_LEFT_PGA_SEL_1, 0, 1, 1, input_attenuation_tlv),
732 	SOC_SINGLE_TLV("Left Input IN_2L Capture Volume",
733 		       ADC3XXX_LEFT_PGA_SEL_1, 2, 1, 1, input_attenuation_tlv),
734 	SOC_SINGLE_TLV("Left Input IN_3L Capture Volume",
735 		       ADC3XXX_LEFT_PGA_SEL_1, 4, 1, 1, input_attenuation_tlv),
736 	SOC_SINGLE_TLV("Left Input IN_1R Capture Volume",
737 		       ADC3XXX_LEFT_PGA_SEL_2, 0, 1, 1, input_attenuation_tlv),
738 	SOC_SINGLE_TLV("Left Input DIF_2L_3L Capture Volume",
739 		       ADC3XXX_LEFT_PGA_SEL_1, 6, 1, 1, input_attenuation_tlv),
740 	SOC_SINGLE_TLV("Left Input DIF_1L_1R Capture Volume",
741 		       ADC3XXX_LEFT_PGA_SEL_2, 4, 1, 1, input_attenuation_tlv),
742 	SOC_SINGLE_TLV("Left Input DIF_2R_3R Capture Volume",
743 		       ADC3XXX_LEFT_PGA_SEL_2, 2, 1, 1, input_attenuation_tlv),
744 	SOC_SINGLE_TLV("Right Input IN_1R Capture Volume",
745 		       ADC3XXX_RIGHT_PGA_SEL_1, 0, 1, 1, input_attenuation_tlv),
746 	SOC_SINGLE_TLV("Right Input IN_2R Capture Volume",
747 		       ADC3XXX_RIGHT_PGA_SEL_1, 2, 1, 1, input_attenuation_tlv),
748 	SOC_SINGLE_TLV("Right Input IN_3R Capture Volume",
749 		       ADC3XXX_RIGHT_PGA_SEL_1, 4, 1, 1, input_attenuation_tlv),
750 	SOC_SINGLE_TLV("Right Input IN_1L Capture Volume",
751 		       ADC3XXX_RIGHT_PGA_SEL_2, 0, 1, 1, input_attenuation_tlv),
752 	SOC_SINGLE_TLV("Right Input DIF_2R_3R Capture Volume",
753 		       ADC3XXX_RIGHT_PGA_SEL_1, 6, 1, 1, input_attenuation_tlv),
754 	SOC_SINGLE_TLV("Right Input DIF_1L_1R Capture Volume",
755 		       ADC3XXX_RIGHT_PGA_SEL_2, 4, 1, 1, input_attenuation_tlv),
756 	SOC_SINGLE_TLV("Right Input DIF_2L_3L Capture Volume",
757 		       ADC3XXX_RIGHT_PGA_SEL_2, 2, 1, 1, input_attenuation_tlv),
758 	SOC_DOUBLE_R_S_TLV("ADC Volume Control Capture Volume", ADC3XXX_LADC_VOL,
759 			   ADC3XXX_RADC_VOL, 0, -24, 40, 6, 0, adc_tlv),
760 	/* Empirically, the following doesn't work the way it's supposed
761 	 * to. Values 0, -0.1, -0.2 and -0.3 dB result in the same level, and
762 	 * -0.4 dB drops about 0.12 dB on a specific chip.
763 	 */
764 	SOC_DOUBLE_TLV("ADC Fine Volume Control Capture Volume", ADC3XXX_ADC_FGA,
765 		       4, 0, 4, 1, adc_fine_tlv),
766 	SOC_SINGLE("Left ADC Unselected CM Bias Capture Switch",
767 		   ADC3XXX_LEFT_PGA_SEL_2, 6, 1, 0),
768 	SOC_SINGLE("Right ADC Unselected CM Bias Capture Switch",
769 		   ADC3XXX_RIGHT_PGA_SEL_2, 6, 1, 0),
770 	SOC_ENUM("Dither Control DC Offset", dither_dc_offset_enum),
771 
772 	/* Coefficient memory for miniDSP. */
773 	/* For the default PRB_R1 processing block, the only available
774 	 * filter is the first order IIR.
775 	 */
776 
777 	TI_COEFFICIENTS("Left ADC IIR Coefficients N0 N1 D1",
778 			ADC3XXX_LEFT_ADC_IIR_COEFF_N0_MSB, 3),
779 
780 	TI_COEFFICIENTS("Right ADC IIR Coefficients N0 N1 D1",
781 			ADC3XXX_RIGHT_ADC_IIR_COEFF_N0_MSB, 3),
782 };
783 
784 /* Left input selection, Single Ended inputs and Differential inputs */
785 static const struct snd_kcontrol_new left_input_mixer_controls[] = {
786 	SOC_DAPM_SINGLE("IN_1L Capture Switch",
787 			ADC3XXX_LEFT_PGA_SEL_1, 1, 0x1, 1),
788 	SOC_DAPM_SINGLE("IN_2L Capture Switch",
789 			ADC3XXX_LEFT_PGA_SEL_1, 3, 0x1, 1),
790 	SOC_DAPM_SINGLE("IN_3L Capture Switch",
791 			ADC3XXX_LEFT_PGA_SEL_1, 5, 0x1, 1),
792 	SOC_DAPM_SINGLE("DIF_2L_3L Capture Switch",
793 			ADC3XXX_LEFT_PGA_SEL_1, 7, 0x1, 1),
794 	SOC_DAPM_SINGLE("DIF_1L_1R Capture Switch",
795 			ADC3XXX_LEFT_PGA_SEL_2, 5, 0x1, 1),
796 	SOC_DAPM_SINGLE("DIF_2R_3R Capture Switch",
797 			ADC3XXX_LEFT_PGA_SEL_2, 3, 0x1, 1),
798 	SOC_DAPM_SINGLE("IN_1R Capture Switch",
799 			ADC3XXX_LEFT_PGA_SEL_2, 1, 0x1, 1),
800 };
801 
802 /* Right input selection, Single Ended inputs and Differential inputs */
803 static const struct snd_kcontrol_new right_input_mixer_controls[] = {
804 	SOC_DAPM_SINGLE("IN_1R Capture Switch",
805 			ADC3XXX_RIGHT_PGA_SEL_1, 1, 0x1, 1),
806 	SOC_DAPM_SINGLE("IN_2R Capture Switch",
807 			ADC3XXX_RIGHT_PGA_SEL_1, 3, 0x1, 1),
808 	SOC_DAPM_SINGLE("IN_3R Capture Switch",
809 			 ADC3XXX_RIGHT_PGA_SEL_1, 5, 0x1, 1),
810 	SOC_DAPM_SINGLE("DIF_2R_3R Capture Switch",
811 			 ADC3XXX_RIGHT_PGA_SEL_1, 7, 0x1, 1),
812 	SOC_DAPM_SINGLE("DIF_1L_1R Capture Switch",
813 			 ADC3XXX_RIGHT_PGA_SEL_2, 5, 0x1, 1),
814 	SOC_DAPM_SINGLE("DIF_2L_3L Capture Switch",
815 			 ADC3XXX_RIGHT_PGA_SEL_2, 3, 0x1, 1),
816 	SOC_DAPM_SINGLE("IN_1L Capture Switch",
817 			 ADC3XXX_RIGHT_PGA_SEL_2, 1, 0x1, 1),
818 };
819 
820 /* Left Digital Mic input for left ADC */
821 static const struct snd_kcontrol_new left_input_dmic_controls[] = {
822 	SOC_DAPM_SINGLE("Left ADC Capture Switch",
823 			ADC3XXX_ADC_DIGITAL, 3, 0x1, 0),
824 };
825 
826 /* Right Digital Mic input for Right ADC */
827 static const struct snd_kcontrol_new right_input_dmic_controls[] = {
828 	SOC_DAPM_SINGLE("Right ADC Capture Switch",
829 			ADC3XXX_ADC_DIGITAL, 2, 0x1, 0),
830 };
831 
832 /* DAPM widgets */
833 static const struct snd_soc_dapm_widget adc3xxx_dapm_widgets[] = {
834 
835 	/* Left Input Selection */
836 	SND_SOC_DAPM_MIXER("Left Input", SND_SOC_NOPM, 0, 0,
837 			   &left_input_mixer_controls[0],
838 			   ARRAY_SIZE(left_input_mixer_controls)),
839 	/* Right Input Selection */
840 	SND_SOC_DAPM_MIXER("Right Input", SND_SOC_NOPM, 0, 0,
841 			   &right_input_mixer_controls[0],
842 			   ARRAY_SIZE(right_input_mixer_controls)),
843 	/* PGA selection */
844 	SND_SOC_DAPM_PGA("Left PGA", ADC3XXX_LEFT_APGA_CTRL, 7, 1, NULL, 0),
845 	SND_SOC_DAPM_PGA("Right PGA", ADC3XXX_RIGHT_APGA_CTRL, 7, 1, NULL, 0),
846 
847 	/* Digital Microphone Input Control for Left/Right ADC */
848 	SND_SOC_DAPM_MIXER("Left DMic Input", SND_SOC_NOPM, 0, 0,
849 			&left_input_dmic_controls[0],
850 			ARRAY_SIZE(left_input_dmic_controls)),
851 	SND_SOC_DAPM_MIXER("Right DMic Input", SND_SOC_NOPM, 0, 0,
852 			&right_input_dmic_controls[0],
853 			ARRAY_SIZE(right_input_dmic_controls)),
854 
855 	/* Left/Right ADC */
856 	SND_SOC_DAPM_ADC("Left ADC", "Left Capture", ADC3XXX_ADC_DIGITAL, 7, 0),
857 	SND_SOC_DAPM_ADC("Right ADC", "Right Capture", ADC3XXX_ADC_DIGITAL, 6, 0),
858 
859 	/* Inputs */
860 	SND_SOC_DAPM_INPUT("IN_1L"),
861 	SND_SOC_DAPM_INPUT("IN_1R"),
862 	SND_SOC_DAPM_INPUT("IN_2L"),
863 	SND_SOC_DAPM_INPUT("IN_2R"),
864 	SND_SOC_DAPM_INPUT("IN_3L"),
865 	SND_SOC_DAPM_INPUT("IN_3R"),
866 	SND_SOC_DAPM_INPUT("DIFL_1L_1R"),
867 	SND_SOC_DAPM_INPUT("DIFL_2L_3L"),
868 	SND_SOC_DAPM_INPUT("DIFL_2R_3R"),
869 	SND_SOC_DAPM_INPUT("DIFR_1L_1R"),
870 	SND_SOC_DAPM_INPUT("DIFR_2L_3L"),
871 	SND_SOC_DAPM_INPUT("DIFR_2R_3R"),
872 	SND_SOC_DAPM_INPUT("DMic_L"),
873 	SND_SOC_DAPM_INPUT("DMic_R"),
874 
875 	/* Digital audio interface output */
876 	SND_SOC_DAPM_AIF_OUT("AIF_OUT", "Capture", 0, SND_SOC_NOPM, 0, 0),
877 
878 	/* Clocks */
879 	SND_SOC_DAPM_SUPPLY("PLL_CLK", ADC3XXX_PLL_PROG_PR, ADC3XXX_ENABLE_PLL_SHIFT,
880 			    0, adc3xxx_pll_delay, SND_SOC_DAPM_POST_PMU),
881 
882 	SND_SOC_DAPM_SUPPLY("ADC_CLK", ADC3XXX_ADC_NADC, ADC3XXX_ENABLE_NADC_SHIFT,
883 			    0, NULL, 0),
884 	SND_SOC_DAPM_SUPPLY("ADC_MOD_CLK", ADC3XXX_ADC_MADC, ADC3XXX_ENABLE_MADC_SHIFT,
885 			    0, NULL, 0),
886 
887 	/* This refers to the generated BCLK in master mode. */
888 	SND_SOC_DAPM_SUPPLY("BCLK", ADC3XXX_BCLK_N_DIV, ADC3XXX_ENABLE_BCLK_SHIFT,
889 			    0, NULL, 0),
890 };
891 
892 static const struct snd_soc_dapm_route adc3xxx_intercon[] = {
893 	/* Left input selection from switches */
894 	{ "Left Input", "IN_1L Capture Switch", "IN_1L" },
895 	{ "Left Input", "IN_2L Capture Switch", "IN_2L" },
896 	{ "Left Input", "IN_3L Capture Switch", "IN_3L" },
897 	{ "Left Input", "DIF_2L_3L Capture Switch", "DIFL_2L_3L" },
898 	{ "Left Input", "DIF_1L_1R Capture Switch", "DIFL_1L_1R" },
899 	{ "Left Input", "DIF_2R_3R Capture Switch", "DIFL_2R_3R" },
900 	{ "Left Input", "IN_1R Capture Switch", "IN_1R" },
901 
902 	/* Left input selection to left PGA */
903 	{ "Left PGA", NULL, "Left Input" },
904 
905 	/* Left PGA to left ADC */
906 	{ "Left ADC", NULL, "Left PGA" },
907 
908 	/* Right input selection from switches */
909 	{ "Right Input", "IN_1R Capture Switch", "IN_1R" },
910 	{ "Right Input", "IN_2R Capture Switch", "IN_2R" },
911 	{ "Right Input", "IN_3R Capture Switch", "IN_3R" },
912 	{ "Right Input", "DIF_2R_3R Capture Switch", "DIFR_2R_3R" },
913 	{ "Right Input", "DIF_1L_1R Capture Switch", "DIFR_1L_1R" },
914 	{ "Right Input", "DIF_2L_3L Capture Switch", "DIFR_2L_3L" },
915 	{ "Right Input", "IN_1L Capture Switch", "IN_1L" },
916 
917 	/* Right input selection to right PGA */
918 	{ "Right PGA", NULL, "Right Input" },
919 
920 	/* Right PGA to right ADC */
921 	{ "Right ADC", NULL, "Right PGA" },
922 
923 	/* Left DMic Input selection from switch */
924 	{ "Left DMic Input", "Left ADC Capture Switch", "DMic_L" },
925 
926 	/* Left DMic to left ADC */
927 	{ "Left ADC", NULL, "Left DMic Input" },
928 
929 	/* Right DMic Input selection from switch */
930 	{ "Right DMic Input", "Right ADC Capture Switch", "DMic_R" },
931 
932 	/* Right DMic to right ADC */
933 	{ "Right ADC", NULL, "Right DMic Input" },
934 
935 	/* ADC to AIF output */
936 	{ "AIF_OUT", NULL, "Left ADC" },
937 	{ "AIF_OUT", NULL, "Right ADC" },
938 
939 	/* Clocking */
940 	{ "ADC_MOD_CLK", NULL, "ADC_CLK" },
941 	{ "Left ADC", NULL, "ADC_MOD_CLK" },
942 	{ "Right ADC", NULL, "ADC_MOD_CLK" },
943 
944 	{ "BCLK", NULL, "ADC_CLK" },
945 };
946 
947 static const struct snd_soc_dapm_route adc3xxx_pll_intercon[] = {
948 	{ "ADC_CLK", NULL, "PLL_CLK" },
949 };
950 
951 static const struct snd_soc_dapm_route adc3xxx_bclk_out_intercon[] = {
952 	{ "AIF_OUT", NULL, "BCLK" }
953 };
954 
955 static int adc3xxx_gpio_request(struct gpio_chip *chip, unsigned int offset)
956 {
957 	struct adc3xxx *adc3xxx = gpiochip_get_data(chip);
958 
959 	if (offset >= ADC3XXX_GPIOS_MAX)
960 		return -EINVAL;
961 
962 	/* GPIO1 is offset 0, GPIO2 is offset 1 */
963 	/* We check here that the GPIO pins are either not configured in the
964 	 * DT, or that they purposely are set as outputs.
965 	 * (Input mode not yet implemented).
966 	 */
967 	if (adc3xxx->gpio_cfg[offset] != 0 &&
968 	    adc3xxx->gpio_cfg[offset] != ADC3XXX_GPIO_GPO + 1)
969 		return -EINVAL;
970 
971 	return 0;
972 }
973 
974 static int adc3xxx_gpio_direction_out(struct gpio_chip *chip,
975 				      unsigned int offset, int value)
976 {
977 	struct adc3xxx *adc3xxx = gpiochip_get_data(chip);
978 
979 	/* Set GPIO output function. */
980 	return regmap_update_bits(adc3xxx->regmap,
981 				  adc3xxx_gpio_ctrl_reg[offset],
982 				  ADC3XXX_GPIO_CTRL_CFG_MASK |
983 				  ADC3XXX_GPIO_CTRL_OUTPUT_CTRL_MASK,
984 				  ADC3XXX_GPIO_GPO << ADC3XXX_GPIO_CTRL_CFG_SHIFT |
985 				  !!value << ADC3XXX_GPIO_CTRL_OUTPUT_CTRL_SHIFT);
986 }
987 
988 /* With only GPIO outputs configured, we never get the .direction_out call,
989  * so we set the output mode and output value in the same call. Hence
990  * .set in practice does the same thing as .direction_out .
991  */
992 static void adc3xxx_gpio_set(struct gpio_chip *chip, unsigned int offset,
993 			     int value)
994 {
995 	(void) adc3xxx_gpio_direction_out(chip, offset, value);
996 }
997 
998 /* Even though we only support GPIO output for now, some GPIO clients
999  * want to read the current pin state using the .get callback.
1000  */
1001 static int adc3xxx_gpio_get(struct gpio_chip *chip, unsigned int offset)
1002 {
1003 	struct adc3xxx *adc3xxx = gpiochip_get_data(chip);
1004 	unsigned int regval;
1005 	int ret;
1006 
1007 	/* We only allow output pins, so just read the value set in the output
1008 	 * pin register field.
1009 	 */
1010 	ret = regmap_read(adc3xxx->regmap, adc3xxx_gpio_ctrl_reg[offset], &regval);
1011 	if (ret)
1012 		return ret;
1013 	return !!(regval & ADC3XXX_GPIO_CTRL_OUTPUT_CTRL_MASK);
1014 }
1015 
1016 static const struct gpio_chip adc3xxx_gpio_chip = {
1017 	.label			= "adc3xxx",
1018 	.owner			= THIS_MODULE,
1019 	.request		= adc3xxx_gpio_request,
1020 	.direction_output	= adc3xxx_gpio_direction_out,
1021 	.set			= adc3xxx_gpio_set,
1022 	.get			= adc3xxx_gpio_get,
1023 	.can_sleep		= 1,
1024 };
1025 
1026 static void adc3xxx_free_gpio(struct adc3xxx *adc3xxx)
1027 {
1028 	gpiochip_remove(&adc3xxx->gpio_chip);
1029 }
1030 
1031 static void adc3xxx_init_gpio(struct adc3xxx *adc3xxx)
1032 {
1033 	int gpio, micbias;
1034 	int ret;
1035 
1036 	adc3xxx->gpio_chip = adc3xxx_gpio_chip;
1037 	adc3xxx->gpio_chip.ngpio = ADC3XXX_GPIOS_MAX;
1038 	adc3xxx->gpio_chip.parent = adc3xxx->dev;
1039 	adc3xxx->gpio_chip.base = -1;
1040 
1041 	ret = gpiochip_add_data(&adc3xxx->gpio_chip, adc3xxx);
1042 	if (ret)
1043 		dev_err(adc3xxx->dev, "Failed to add gpios: %d\n", ret);
1044 
1045 	/* Set up potential GPIO configuration from the devicetree.
1046 	 * This allows us to set up things which are not software
1047 	 * controllable GPIOs, such as PDM microphone I/O,
1048 	 */
1049 	for (gpio = 0; gpio < ADC3XXX_GPIOS_MAX; gpio++) {
1050 		unsigned int cfg = adc3xxx->gpio_cfg[gpio];
1051 
1052 		if (cfg) {
1053 			cfg--; /* actual value to use is stored +1 */
1054 			regmap_update_bits(adc3xxx->regmap,
1055 					   adc3xxx_gpio_ctrl_reg[gpio],
1056 					   ADC3XXX_GPIO_CTRL_CFG_MASK,
1057 					   cfg << ADC3XXX_GPIO_CTRL_CFG_SHIFT);
1058 		}
1059 	}
1060 
1061 	/* Set up micbias voltage */
1062 	for (micbias = 0; micbias < ADC3XXX_MICBIAS_PINS; micbias++) {
1063 		unsigned int vg = adc3xxx->micbias_vg[micbias];
1064 
1065 		regmap_update_bits(adc3xxx->regmap,
1066 				   ADC3XXX_MICBIAS_CTRL,
1067 				   ADC3XXX_MICBIAS_MASK << adc3xxx_micbias_shift[micbias],
1068 				   vg << adc3xxx_micbias_shift[micbias]);
1069 	}
1070 }
1071 
1072 static int adc3xxx_parse_dt_gpio(struct adc3xxx *adc3xxx,
1073 				 const char *propname, unsigned int *cfg)
1074 {
1075 	struct device *dev = adc3xxx->dev;
1076 	struct device_node *np = dev->of_node;
1077 	unsigned int val;
1078 
1079 	if (!of_property_read_u32(np, propname, &val)) {
1080 		if (val & ~15 || val == 7 || val >= 11) {
1081 			dev_err(dev, "Invalid property value for '%s'\n", propname);
1082 			return -EINVAL;
1083 		}
1084 		if (val == ADC3XXX_GPIO_GPI)
1085 			dev_warn(dev, "GPIO Input read not yet implemented\n");
1086 		*cfg = val + 1; /* 0 => not set up, all others shifted +1 */
1087 	}
1088 	return 0;
1089 }
1090 
1091 static int adc3xxx_parse_dt_micbias(struct adc3xxx *adc3xxx,
1092 				    const char *propname, unsigned int *vg)
1093 {
1094 	struct device *dev = adc3xxx->dev;
1095 	struct device_node *np = dev->of_node;
1096 	unsigned int val;
1097 
1098 	if (!of_property_read_u32(np, propname, &val)) {
1099 		if (val >= ADC3XXX_MICBIAS_AVDD) {
1100 			dev_err(dev, "Invalid property value for '%s'\n", propname);
1101 			return -EINVAL;
1102 		}
1103 		*vg = val;
1104 	}
1105 	return 0;
1106 }
1107 
1108 static int adc3xxx_parse_pll_mode(uint32_t val, unsigned int *pll_mode)
1109 {
1110 	if (val != ADC3XXX_PLL_ENABLE && val != ADC3XXX_PLL_BYPASS &&
1111 	    val != ADC3XXX_PLL_AUTO)
1112 		return -EINVAL;
1113 
1114 	*pll_mode = val;
1115 
1116 	return 0;
1117 }
1118 
1119 static void adc3xxx_setup_pll(struct snd_soc_component *component,
1120 			      int div_entry)
1121 {
1122 	int i = div_entry;
1123 
1124 	/* P & R values */
1125 	snd_soc_component_write(component, ADC3XXX_PLL_PROG_PR,
1126 				(adc3xxx_divs[i].pll_p << ADC3XXX_PLLP_SHIFT) |
1127 				(adc3xxx_divs[i].pll_r << ADC3XXX_PLLR_SHIFT));
1128 	/* J value */
1129 	snd_soc_component_write(component, ADC3XXX_PLL_PROG_J,
1130 				adc3xxx_divs[i].pll_j & ADC3XXX_PLLJ_MASK);
1131 	/* D value */
1132 	snd_soc_component_write(component, ADC3XXX_PLL_PROG_D_LSB,
1133 				adc3xxx_divs[i].pll_d & ADC3XXX_PLLD_LSB_MASK);
1134 	snd_soc_component_write(component, ADC3XXX_PLL_PROG_D_MSB,
1135 				(adc3xxx_divs[i].pll_d >> 8) & ADC3XXX_PLLD_MSB_MASK);
1136 }
1137 
1138 static int adc3xxx_hw_params(struct snd_pcm_substream *substream,
1139 			     struct snd_pcm_hw_params *params,
1140 			     struct snd_soc_dai *dai)
1141 {
1142 	struct snd_soc_component *component = dai->component;
1143 	struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(dai->component);
1144 	struct adc3xxx *adc3xxx = snd_soc_component_get_drvdata(component);
1145 	int i, width = 16;
1146 	u8 iface_len, bdiv;
1147 
1148 	i = adc3xxx_get_divs(component->dev, adc3xxx->sysclk,
1149 			     params_rate(params), adc3xxx->pll_mode);
1150 
1151 	if (i < 0)
1152 		return i;
1153 
1154 	/* select data word length */
1155 	switch (params_width(params)) {
1156 	case 16:
1157 		iface_len = ADC3XXX_IFACE_16BITS;
1158 		width = 16;
1159 		break;
1160 	case 20:
1161 		iface_len = ADC3XXX_IFACE_20BITS;
1162 		width = 20;
1163 		break;
1164 	case 24:
1165 		iface_len = ADC3XXX_IFACE_24BITS;
1166 		width = 24;
1167 		break;
1168 	case 32:
1169 		iface_len = ADC3XXX_IFACE_32BITS;
1170 		width = 32;
1171 		break;
1172 	default:
1173 		dev_err(component->dev, "Unsupported serial data format\n");
1174 		return -EINVAL;
1175 	}
1176 	snd_soc_component_update_bits(component, ADC3XXX_INTERFACE_CTRL_1,
1177 				      ADC3XXX_WLENGTH_MASK, iface_len);
1178 	if (adc3xxx_divs[i].pll_p) { /* If PLL used for this mode */
1179 		adc3xxx_setup_pll(component, i);
1180 		snd_soc_component_write(component, ADC3XXX_CLKGEN_MUX, ADC3XXX_USE_PLL);
1181 		if (!adc3xxx->use_pll) {
1182 			snd_soc_dapm_add_routes(dapm, adc3xxx_pll_intercon,
1183 						ARRAY_SIZE(adc3xxx_pll_intercon));
1184 			adc3xxx->use_pll = 1;
1185 		}
1186 	} else {
1187 		snd_soc_component_write(component, ADC3XXX_CLKGEN_MUX, ADC3XXX_NO_PLL);
1188 		if (adc3xxx->use_pll) {
1189 			snd_soc_dapm_del_routes(dapm, adc3xxx_pll_intercon,
1190 						ARRAY_SIZE(adc3xxx_pll_intercon));
1191 			adc3xxx->use_pll = 0;
1192 		}
1193 	}
1194 
1195 	/* NADC */
1196 	snd_soc_component_update_bits(component, ADC3XXX_ADC_NADC,
1197 				      ADC3XXX_NADC_MASK, adc3xxx_divs[i].nadc);
1198 	/* MADC */
1199 	snd_soc_component_update_bits(component, ADC3XXX_ADC_MADC,
1200 				      ADC3XXX_MADC_MASK, adc3xxx_divs[i].madc);
1201 	/* AOSR */
1202 	snd_soc_component_update_bits(component, ADC3XXX_ADC_AOSR,
1203 				      ADC3XXX_AOSR_MASK, adc3xxx_divs[i].aosr);
1204 	/* BDIV N Value */
1205 	/* BCLK is (by default) set up to be derived from ADC_CLK */
1206 	bdiv = (adc3xxx_divs[i].aosr * adc3xxx_divs[i].madc) / (2 * width);
1207 	snd_soc_component_update_bits(component, ADC3XXX_BCLK_N_DIV,
1208 				      ADC3XXX_BDIV_MASK, bdiv);
1209 
1210 	return 0;
1211 }
1212 
1213 static const char *adc3xxx_pll_mode_text(int pll_mode)
1214 {
1215 	switch (pll_mode) {
1216 	case ADC3XXX_PLL_AUTO:
1217 		return "PLL auto";
1218 	case ADC3XXX_PLL_ENABLE:
1219 		return "PLL enable";
1220 	case ADC3XXX_PLL_BYPASS:
1221 		return "PLL bypass";
1222 	default:
1223 		break;
1224 	}
1225 
1226 	return "PLL unknown";
1227 }
1228 
1229 static int adc3xxx_set_dai_sysclk(struct snd_soc_dai *codec_dai,
1230 				  int clk_id, unsigned int freq, int dir)
1231 {
1232 	struct snd_soc_component *component = codec_dai->component;
1233 	struct adc3xxx *adc3xxx = snd_soc_component_get_drvdata(component);
1234 	int ret;
1235 
1236 	ret = adc3xxx_parse_pll_mode(clk_id, &adc3xxx->pll_mode);
1237 	if (ret < 0)
1238 		return ret;
1239 
1240 	adc3xxx->sysclk = freq;
1241 	dev_dbg(component->dev, "Set sysclk to %u Hz, %s\n",
1242 		freq, adc3xxx_pll_mode_text(adc3xxx->pll_mode));
1243 	return 0;
1244 }
1245 
1246 static int adc3xxx_set_dai_fmt(struct snd_soc_dai *codec_dai, unsigned int fmt)
1247 {
1248 	struct snd_soc_component *component = codec_dai->component;
1249 	struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component);
1250 	struct adc3xxx *adc3xxx = snd_soc_component_get_drvdata(component);
1251 	u8 clkdir = 0, format = 0;
1252 	int master = 0;
1253 	int ret;
1254 
1255 	/* set master/slave audio interface */
1256 	switch (fmt & SND_SOC_DAIFMT_MASTER_MASK) {
1257 	case SND_SOC_DAIFMT_CBP_CFP:
1258 		master = 1;
1259 		clkdir = ADC3XXX_BCLK_MASTER | ADC3XXX_WCLK_MASTER;
1260 		break;
1261 	case SND_SOC_DAIFMT_CBC_CFC:
1262 		master = 0;
1263 		break;
1264 	default:
1265 		dev_err(component->dev, "Invalid DAI clock setup\n");
1266 		return -EINVAL;
1267 	}
1268 
1269 	/*
1270 	 * match both interface format and signal polarities since they
1271 	 * are fixed
1272 	 */
1273 	switch (fmt & (SND_SOC_DAIFMT_FORMAT_MASK | SND_SOC_DAIFMT_INV_MASK)) {
1274 	case SND_SOC_DAIFMT_I2S | SND_SOC_DAIFMT_NB_NF:
1275 		format = ADC3XXX_FORMAT_I2S;
1276 		break;
1277 	case SND_SOC_DAIFMT_DSP_A | SND_SOC_DAIFMT_IB_NF:
1278 		format = ADC3XXX_FORMAT_DSP;
1279 		break;
1280 	case SND_SOC_DAIFMT_DSP_B | SND_SOC_DAIFMT_IB_NF:
1281 		format = ADC3XXX_FORMAT_DSP;
1282 		break;
1283 	case SND_SOC_DAIFMT_RIGHT_J | SND_SOC_DAIFMT_NB_NF:
1284 		format = ADC3XXX_FORMAT_RJF;
1285 		break;
1286 	case SND_SOC_DAIFMT_LEFT_J | SND_SOC_DAIFMT_NB_NF:
1287 		format = ADC3XXX_FORMAT_LJF;
1288 		break;
1289 	default:
1290 		dev_err(component->dev, "Invalid DAI format\n");
1291 		return -EINVAL;
1292 	}
1293 
1294 	/* Add/del route enabling BCLK output as applicable */
1295 	if (master && !adc3xxx->master)
1296 		snd_soc_dapm_add_routes(dapm, adc3xxx_bclk_out_intercon,
1297 					ARRAY_SIZE(adc3xxx_bclk_out_intercon));
1298 	else if (!master && adc3xxx->master)
1299 		snd_soc_dapm_del_routes(dapm, adc3xxx_bclk_out_intercon,
1300 					ARRAY_SIZE(adc3xxx_bclk_out_intercon));
1301 	adc3xxx->master = master;
1302 
1303 	/* set clock direction and format */
1304 	ret = snd_soc_component_update_bits(component,
1305 					    ADC3XXX_INTERFACE_CTRL_1,
1306 					    ADC3XXX_CLKDIR_MASK | ADC3XXX_FORMAT_MASK,
1307 					    clkdir | format);
1308 	if (ret < 0)
1309 		return ret;
1310 	return 0;
1311 }
1312 
1313 static const struct snd_soc_dai_ops adc3xxx_dai_ops = {
1314 	.hw_params	= adc3xxx_hw_params,
1315 	.set_sysclk	= adc3xxx_set_dai_sysclk,
1316 	.set_fmt	= adc3xxx_set_dai_fmt,
1317 };
1318 
1319 static struct snd_soc_dai_driver adc3xxx_dai = {
1320 	.name = "tlv320adc3xxx-hifi",
1321 	.capture = {
1322 		    .stream_name = "Capture",
1323 		    .channels_min = 1,
1324 		    .channels_max = 2,
1325 		    .rates = ADC3XXX_RATES,
1326 		    .formats = ADC3XXX_FORMATS,
1327 		   },
1328 	.ops = &adc3xxx_dai_ops,
1329 };
1330 
1331 static const struct snd_soc_component_driver soc_component_dev_adc3xxx = {
1332 	.controls		= adc3xxx_snd_controls,
1333 	.num_controls		= ARRAY_SIZE(adc3xxx_snd_controls),
1334 	.dapm_widgets		= adc3xxx_dapm_widgets,
1335 	.num_dapm_widgets	= ARRAY_SIZE(adc3xxx_dapm_widgets),
1336 	.dapm_routes		= adc3xxx_intercon,
1337 	.num_dapm_routes	= ARRAY_SIZE(adc3xxx_intercon),
1338 	.endianness		= 1,
1339 };
1340 
1341 static const struct i2c_device_id adc3xxx_i2c_id[] = {
1342 	{ "tlv320adc3001", ADC3001 },
1343 	{ "tlv320adc3101", ADC3101 },
1344 	{}
1345 };
1346 MODULE_DEVICE_TABLE(i2c, adc3xxx_i2c_id);
1347 
1348 static int adc3xxx_i2c_probe(struct i2c_client *i2c)
1349 {
1350 	struct device *dev = &i2c->dev;
1351 	struct adc3xxx *adc3xxx = NULL;
1352 	const struct i2c_device_id *id;
1353 	int ret;
1354 
1355 	adc3xxx = devm_kzalloc(dev, sizeof(struct adc3xxx), GFP_KERNEL);
1356 	if (!adc3xxx)
1357 		return -ENOMEM;
1358 	adc3xxx->dev = dev;
1359 
1360 	adc3xxx->rst_pin = devm_gpiod_get(dev, "reset", GPIOD_OUT_LOW);
1361 	if (IS_ERR(adc3xxx->rst_pin)) {
1362 		return dev_err_probe(dev, PTR_ERR(adc3xxx->rst_pin),
1363 				     "Failed to request rst_pin\n");
1364 	}
1365 
1366 	adc3xxx->mclk = devm_clk_get(dev, NULL);
1367 	if (IS_ERR(adc3xxx->mclk)) {
1368 		/*
1369 		 * The chip itself supports running off the BCLK either
1370 		 * directly or via the PLL, but the driver does not (yet), so
1371 		 * having a specified mclk is required. Otherwise, we could
1372 		 * use the lack of a clocks property to indicate when BCLK is
1373 		 * intended as the clock source.
1374 		 */
1375 		return dev_err_probe(dev, PTR_ERR(adc3xxx->mclk),
1376 				     "Failed to acquire MCLK\n");
1377 	} else if (adc3xxx->mclk) {
1378 		ret = clk_prepare_enable(adc3xxx->mclk);
1379 		if (ret < 0)
1380 			return ret;
1381 		dev_dbg(dev, "Enabled MCLK, freq %lu Hz\n", clk_get_rate(adc3xxx->mclk));
1382 	}
1383 
1384 	ret = adc3xxx_parse_dt_gpio(adc3xxx, "ti,dmdin-gpio1", &adc3xxx->gpio_cfg[0]);
1385 	if (ret < 0)
1386 		goto err_unprepare_mclk;
1387 	ret = adc3xxx_parse_dt_gpio(adc3xxx, "ti,dmclk-gpio2", &adc3xxx->gpio_cfg[1]);
1388 	if (ret < 0)
1389 		goto err_unprepare_mclk;
1390 	ret = adc3xxx_parse_dt_micbias(adc3xxx, "ti,micbias1-vg", &adc3xxx->micbias_vg[0]);
1391 	if (ret < 0)
1392 		goto err_unprepare_mclk;
1393 	ret = adc3xxx_parse_dt_micbias(adc3xxx, "ti,micbias2-vg", &adc3xxx->micbias_vg[1]);
1394 	if (ret < 0)
1395 		goto err_unprepare_mclk;
1396 
1397 	adc3xxx->regmap = devm_regmap_init_i2c(i2c, &adc3xxx_regmap);
1398 	if (IS_ERR(adc3xxx->regmap)) {
1399 		ret = PTR_ERR(adc3xxx->regmap);
1400 		goto err_unprepare_mclk;
1401 	}
1402 
1403 	i2c_set_clientdata(i2c, adc3xxx);
1404 
1405 	id = i2c_match_id(adc3xxx_i2c_id, i2c);
1406 	adc3xxx->type = id->driver_data;
1407 
1408 	/* Reset codec chip */
1409 	gpiod_set_value_cansleep(adc3xxx->rst_pin, 1);
1410 	usleep_range(2000, 100000); /* Requirement: > 10 ns (datasheet p13) */
1411 	gpiod_set_value_cansleep(adc3xxx->rst_pin, 0);
1412 
1413 	/* Potentially set up pins used as GPIOs */
1414 	adc3xxx_init_gpio(adc3xxx);
1415 
1416 	ret = snd_soc_register_component(dev,
1417 			&soc_component_dev_adc3xxx, &adc3xxx_dai, 1);
1418 	if (ret < 0) {
1419 		dev_err(dev, "Failed to register codec: %d\n", ret);
1420 		goto err_unprepare_mclk;
1421 	}
1422 
1423 	return 0;
1424 
1425 err_unprepare_mclk:
1426 	clk_disable_unprepare(adc3xxx->mclk);
1427 	return ret;
1428 }
1429 
1430 static int __exit adc3xxx_i2c_remove(struct i2c_client *client)
1431 {
1432 	struct adc3xxx *adc3xxx = i2c_get_clientdata(client);
1433 
1434 	if (adc3xxx->mclk)
1435 		clk_disable_unprepare(adc3xxx->mclk);
1436 	adc3xxx_free_gpio(adc3xxx);
1437 	snd_soc_unregister_component(&client->dev);
1438 	return 0;
1439 }
1440 
1441 static const struct of_device_id tlv320adc3xxx_of_match[] = {
1442 	{ .compatible = "ti,tlv320adc3001", },
1443 	{ .compatible = "ti,tlv320adc3101", },
1444 	{},
1445 };
1446 MODULE_DEVICE_TABLE(of, tlv320adc3xxx_of_match);
1447 
1448 static struct i2c_driver adc3xxx_i2c_driver = {
1449 	.driver = {
1450 		   .name = "tlv320adc3xxx-codec",
1451 		   .of_match_table = tlv320adc3xxx_of_match,
1452 		  },
1453 	.probe_new = adc3xxx_i2c_probe,
1454 	.remove = adc3xxx_i2c_remove,
1455 	.id_table = adc3xxx_i2c_id,
1456 };
1457 
1458 module_i2c_driver(adc3xxx_i2c_driver);
1459 
1460 MODULE_DESCRIPTION("ASoC TLV320ADC3xxx codec driver");
1461 MODULE_AUTHOR("shahina.s@mistralsolutions.com");
1462 MODULE_LICENSE("GPL v2");
1463