1// SPDX-License-Identifier: GPL-2.0-only
2// Copyright (c) 2018-2020, The Linux Foundation. All rights reserved.
3
4#include <linux/module.h>
5#include <linux/init.h>
6#include <linux/clk.h>
7#include <linux/io.h>
8#include <linux/platform_device.h>
9#include <linux/pm_runtime.h>
10#include <linux/regmap.h>
11#include <sound/soc.h>
12#include <sound/soc-dapm.h>
13#include <sound/tlv.h>
14#include <linux/of_clk.h>
15#include <linux/clk-provider.h>
16
17#include "lpass-macro-common.h"
18
19#define CDC_TX_CLK_RST_CTRL_MCLK_CONTROL (0x0000)
20#define CDC_TX_MCLK_EN_MASK		BIT(0)
21#define CDC_TX_MCLK_ENABLE		BIT(0)
22#define CDC_TX_CLK_RST_CTRL_FS_CNT_CONTROL (0x0004)
23#define CDC_TX_FS_CNT_EN_MASK		BIT(0)
24#define CDC_TX_FS_CNT_ENABLE		BIT(0)
25#define CDC_TX_CLK_RST_CTRL_SWR_CONTROL	(0x0008)
26#define CDC_TX_SWR_RESET_MASK		BIT(1)
27#define CDC_TX_SWR_RESET_ENABLE		BIT(1)
28#define CDC_TX_SWR_CLK_EN_MASK		BIT(0)
29#define CDC_TX_SWR_CLK_ENABLE		BIT(0)
30#define CDC_TX_TOP_CSR_TOP_CFG0		(0x0080)
31#define CDC_TX_TOP_CSR_ANC_CFG		(0x0084)
32#define CDC_TX_TOP_CSR_SWR_CTRL		(0x0088)
33#define CDC_TX_TOP_CSR_FREQ_MCLK	(0x0090)
34#define CDC_TX_TOP_CSR_DEBUG_BUS	(0x0094)
35#define CDC_TX_TOP_CSR_DEBUG_EN		(0x0098)
36#define CDC_TX_TOP_CSR_TX_I2S_CTL	(0x00A4)
37#define CDC_TX_TOP_CSR_I2S_CLK		(0x00A8)
38#define CDC_TX_TOP_CSR_I2S_RESET	(0x00AC)
39#define CDC_TX_TOP_CSR_SWR_DMICn_CTL(n)	(0x00C0 + n * 0x4)
40#define CDC_TX_TOP_CSR_SWR_DMIC0_CTL	(0x00C0)
41/* Default divider for AMIC and DMIC clock: DIV2 */
42#define CDC_TX_SWR_MIC_CLK_DEFAULT	0
43#define CDC_TX_SWR_DMIC_CLK_SEL_MASK	GENMASK(3, 1)
44#define CDC_TX_TOP_CSR_SWR_DMIC1_CTL	(0x00C4)
45#define CDC_TX_TOP_CSR_SWR_DMIC2_CTL	(0x00C8)
46#define CDC_TX_TOP_CSR_SWR_DMIC3_CTL	(0x00CC)
47#define CDC_TX_TOP_CSR_SWR_AMIC0_CTL	(0x00D0)
48#define CDC_TX_TOP_CSR_SWR_AMIC1_CTL	(0x00D4)
49#define CDC_TX_INP_MUX_ADC_MUXn_CFG0(n)	(0x0100 + 0x8 * n)
50#define CDC_TX_MACRO_SWR_MIC_MUX_SEL_MASK GENMASK(3, 0)
51#define CDC_TX_MACRO_DMIC_MUX_SEL_MASK GENMASK(7, 4)
52#define CDC_TX_INP_MUX_ADC_MUX0_CFG0	(0x0100)
53#define CDC_TX_INP_MUX_ADC_MUXn_CFG1(n)	(0x0104 + 0x8 * n)
54#define CDC_TX_INP_MUX_ADC_MUX0_CFG1	(0x0104)
55#define CDC_TX_INP_MUX_ADC_MUX1_CFG0	(0x0108)
56#define CDC_TX_INP_MUX_ADC_MUX1_CFG1	(0x010C)
57#define CDC_TX_INP_MUX_ADC_MUX2_CFG0	(0x0110)
58#define CDC_TX_INP_MUX_ADC_MUX2_CFG1	(0x0114)
59#define CDC_TX_INP_MUX_ADC_MUX3_CFG0	(0x0118)
60#define CDC_TX_INP_MUX_ADC_MUX3_CFG1	(0x011C)
61#define CDC_TX_INP_MUX_ADC_MUX4_CFG0	(0x0120)
62#define CDC_TX_INP_MUX_ADC_MUX4_CFG1	(0x0124)
63#define CDC_TX_INP_MUX_ADC_MUX5_CFG0	(0x0128)
64#define CDC_TX_INP_MUX_ADC_MUX5_CFG1	(0x012C)
65#define CDC_TX_INP_MUX_ADC_MUX6_CFG0	(0x0130)
66#define CDC_TX_INP_MUX_ADC_MUX6_CFG1	(0x0134)
67#define CDC_TX_INP_MUX_ADC_MUX7_CFG0	(0x0138)
68#define CDC_TX_INP_MUX_ADC_MUX7_CFG1	(0x013C)
69#define CDC_TX_ANC0_CLK_RESET_CTL	(0x0200)
70#define CDC_TX_ANC0_MODE_1_CTL		(0x0204)
71#define CDC_TX_ANC0_MODE_2_CTL		(0x0208)
72#define CDC_TX_ANC0_FF_SHIFT		(0x020C)
73#define CDC_TX_ANC0_FB_SHIFT		(0x0210)
74#define CDC_TX_ANC0_LPF_FF_A_CTL	(0x0214)
75#define CDC_TX_ANC0_LPF_FF_B_CTL	(0x0218)
76#define CDC_TX_ANC0_LPF_FB_CTL		(0x021C)
77#define CDC_TX_ANC0_SMLPF_CTL		(0x0220)
78#define CDC_TX_ANC0_DCFLT_SHIFT_CTL	(0x0224)
79#define CDC_TX_ANC0_IIR_ADAPT_CTL	(0x0228)
80#define CDC_TX_ANC0_IIR_COEFF_1_CTL	(0x022C)
81#define CDC_TX_ANC0_IIR_COEFF_2_CTL	(0x0230)
82#define CDC_TX_ANC0_FF_A_GAIN_CTL	(0x0234)
83#define CDC_TX_ANC0_FF_B_GAIN_CTL	(0x0238)
84#define CDC_TX_ANC0_FB_GAIN_CTL		(0x023C)
85#define CDC_TXn_TX_PATH_CTL(n)		(0x0400 + 0x80 * n)
86#define CDC_TXn_PCM_RATE_MASK		GENMASK(3, 0)
87#define CDC_TXn_PGA_MUTE_MASK		BIT(4)
88#define CDC_TXn_CLK_EN_MASK		BIT(5)
89#define CDC_TX0_TX_PATH_CTL		(0x0400)
90#define CDC_TXn_TX_PATH_CFG0(n)		(0x0404 + 0x80 * n)
91#define CDC_TX0_TX_PATH_CFG0		(0x0404)
92#define CDC_TXn_PH_EN_MASK		BIT(0)
93#define CDC_TXn_ADC_MODE_MASK		GENMASK(2, 1)
94#define CDC_TXn_HPF_CUT_FREQ_MASK	GENMASK(6, 5)
95#define CDC_TXn_ADC_DMIC_SEL_MASK	BIT(7)
96#define CDC_TX0_TX_PATH_CFG1		(0x0408)
97#define CDC_TXn_TX_VOL_CTL(n)		(0x040C + 0x80 * n)
98#define CDC_TX0_TX_VOL_CTL		(0x040C)
99#define CDC_TX0_TX_PATH_SEC0		(0x0410)
100#define CDC_TX0_TX_PATH_SEC1		(0x0414)
101#define CDC_TXn_TX_PATH_SEC2(n)		(0x0418 + 0x80 * n)
102#define CDC_TXn_HPF_F_CHANGE_MASK	 BIT(1)
103#define CDC_TXn_HPF_ZERO_GATE_MASK	 BIT(0)
104#define CDC_TX0_TX_PATH_SEC2		(0x0418)
105#define CDC_TX0_TX_PATH_SEC3		(0x041C)
106#define CDC_TX0_TX_PATH_SEC4		(0x0420)
107#define CDC_TX0_TX_PATH_SEC5		(0x0424)
108#define CDC_TX0_TX_PATH_SEC6		(0x0428)
109#define CDC_TX0_TX_PATH_SEC7		(0x042C)
110#define CDC_TX0_MBHC_CTL_EN_MASK	BIT(6)
111#define CDC_TX1_TX_PATH_CTL		(0x0480)
112#define CDC_TX1_TX_PATH_CFG0		(0x0484)
113#define CDC_TX1_TX_PATH_CFG1		(0x0488)
114#define CDC_TX1_TX_VOL_CTL		(0x048C)
115#define CDC_TX1_TX_PATH_SEC0		(0x0490)
116#define CDC_TX1_TX_PATH_SEC1		(0x0494)
117#define CDC_TX1_TX_PATH_SEC2		(0x0498)
118#define CDC_TX1_TX_PATH_SEC3		(0x049C)
119#define CDC_TX1_TX_PATH_SEC4		(0x04A0)
120#define CDC_TX1_TX_PATH_SEC5		(0x04A4)
121#define CDC_TX1_TX_PATH_SEC6		(0x04A8)
122#define CDC_TX2_TX_PATH_CTL		(0x0500)
123#define CDC_TX2_TX_PATH_CFG0		(0x0504)
124#define CDC_TX2_TX_PATH_CFG1		(0x0508)
125#define CDC_TX2_TX_VOL_CTL		(0x050C)
126#define CDC_TX2_TX_PATH_SEC0		(0x0510)
127#define CDC_TX2_TX_PATH_SEC1		(0x0514)
128#define CDC_TX2_TX_PATH_SEC2		(0x0518)
129#define CDC_TX2_TX_PATH_SEC3		(0x051C)
130#define CDC_TX2_TX_PATH_SEC4		(0x0520)
131#define CDC_TX2_TX_PATH_SEC5		(0x0524)
132#define CDC_TX2_TX_PATH_SEC6		(0x0528)
133#define CDC_TX3_TX_PATH_CTL		(0x0580)
134#define CDC_TX3_TX_PATH_CFG0		(0x0584)
135#define CDC_TX3_TX_PATH_CFG1		(0x0588)
136#define CDC_TX3_TX_VOL_CTL		(0x058C)
137#define CDC_TX3_TX_PATH_SEC0		(0x0590)
138#define CDC_TX3_TX_PATH_SEC1		(0x0594)
139#define CDC_TX3_TX_PATH_SEC2		(0x0598)
140#define CDC_TX3_TX_PATH_SEC3		(0x059C)
141#define CDC_TX3_TX_PATH_SEC4		(0x05A0)
142#define CDC_TX3_TX_PATH_SEC5		(0x05A4)
143#define CDC_TX3_TX_PATH_SEC6		(0x05A8)
144#define CDC_TX4_TX_PATH_CTL		(0x0600)
145#define CDC_TX4_TX_PATH_CFG0		(0x0604)
146#define CDC_TX4_TX_PATH_CFG1		(0x0608)
147#define CDC_TX4_TX_VOL_CTL		(0x060C)
148#define CDC_TX4_TX_PATH_SEC0		(0x0610)
149#define CDC_TX4_TX_PATH_SEC1		(0x0614)
150#define CDC_TX4_TX_PATH_SEC2		(0x0618)
151#define CDC_TX4_TX_PATH_SEC3		(0x061C)
152#define CDC_TX4_TX_PATH_SEC4		(0x0620)
153#define CDC_TX4_TX_PATH_SEC5		(0x0624)
154#define CDC_TX4_TX_PATH_SEC6		(0x0628)
155#define CDC_TX5_TX_PATH_CTL		(0x0680)
156#define CDC_TX5_TX_PATH_CFG0		(0x0684)
157#define CDC_TX5_TX_PATH_CFG1		(0x0688)
158#define CDC_TX5_TX_VOL_CTL		(0x068C)
159#define CDC_TX5_TX_PATH_SEC0		(0x0690)
160#define CDC_TX5_TX_PATH_SEC1		(0x0694)
161#define CDC_TX5_TX_PATH_SEC2		(0x0698)
162#define CDC_TX5_TX_PATH_SEC3		(0x069C)
163#define CDC_TX5_TX_PATH_SEC4		(0x06A0)
164#define CDC_TX5_TX_PATH_SEC5		(0x06A4)
165#define CDC_TX5_TX_PATH_SEC6		(0x06A8)
166#define CDC_TX6_TX_PATH_CTL		(0x0700)
167#define CDC_TX6_TX_PATH_CFG0		(0x0704)
168#define CDC_TX6_TX_PATH_CFG1		(0x0708)
169#define CDC_TX6_TX_VOL_CTL		(0x070C)
170#define CDC_TX6_TX_PATH_SEC0		(0x0710)
171#define CDC_TX6_TX_PATH_SEC1		(0x0714)
172#define CDC_TX6_TX_PATH_SEC2		(0x0718)
173#define CDC_TX6_TX_PATH_SEC3		(0x071C)
174#define CDC_TX6_TX_PATH_SEC4		(0x0720)
175#define CDC_TX6_TX_PATH_SEC5		(0x0724)
176#define CDC_TX6_TX_PATH_SEC6		(0x0728)
177#define CDC_TX7_TX_PATH_CTL		(0x0780)
178#define CDC_TX7_TX_PATH_CFG0		(0x0784)
179#define CDC_TX7_TX_PATH_CFG1		(0x0788)
180#define CDC_TX7_TX_VOL_CTL		(0x078C)
181#define CDC_TX7_TX_PATH_SEC0		(0x0790)
182#define CDC_TX7_TX_PATH_SEC1		(0x0794)
183#define CDC_TX7_TX_PATH_SEC2		(0x0798)
184#define CDC_TX7_TX_PATH_SEC3		(0x079C)
185#define CDC_TX7_TX_PATH_SEC4		(0x07A0)
186#define CDC_TX7_TX_PATH_SEC5		(0x07A4)
187#define CDC_TX7_TX_PATH_SEC6		(0x07A8)
188#define TX_MAX_OFFSET			(0x07A8)
189
190#define TX_MACRO_RATES (SNDRV_PCM_RATE_8000 | SNDRV_PCM_RATE_16000 |\
191			SNDRV_PCM_RATE_32000 | SNDRV_PCM_RATE_48000 |\
192			SNDRV_PCM_RATE_96000 | SNDRV_PCM_RATE_192000)
193#define TX_MACRO_FORMATS (SNDRV_PCM_FMTBIT_S16_LE |\
194			SNDRV_PCM_FMTBIT_S24_LE |\
195			SNDRV_PCM_FMTBIT_S24_3LE)
196
197#define  CF_MIN_3DB_4HZ			0x0
198#define  CF_MIN_3DB_75HZ		0x1
199#define  CF_MIN_3DB_150HZ		0x2
200#define	TX_ADC_MAX	5
201#define TX_ADC_TO_DMIC(n) ((n - TX_ADC_MAX)/2)
202#define NUM_DECIMATORS 8
203#define TX_NUM_CLKS_MAX	5
204#define TX_MACRO_DMIC_UNMUTE_DELAY_MS	40
205#define TX_MACRO_AMIC_UNMUTE_DELAY_MS	100
206#define TX_MACRO_DMIC_HPF_DELAY_MS	300
207#define TX_MACRO_AMIC_HPF_DELAY_MS	300
208#define MCLK_FREQ		19200000
209
210enum {
211	TX_MACRO_AIF_INVALID = 0,
212	TX_MACRO_AIF1_CAP,
213	TX_MACRO_AIF2_CAP,
214	TX_MACRO_AIF3_CAP,
215	TX_MACRO_MAX_DAIS
216};
217
218enum {
219	TX_MACRO_DEC0,
220	TX_MACRO_DEC1,
221	TX_MACRO_DEC2,
222	TX_MACRO_DEC3,
223	TX_MACRO_DEC4,
224	TX_MACRO_DEC5,
225	TX_MACRO_DEC6,
226	TX_MACRO_DEC7,
227	TX_MACRO_DEC_MAX,
228};
229
230enum {
231	TX_MACRO_CLK_DIV_2,
232	TX_MACRO_CLK_DIV_3,
233	TX_MACRO_CLK_DIV_4,
234	TX_MACRO_CLK_DIV_6,
235	TX_MACRO_CLK_DIV_8,
236	TX_MACRO_CLK_DIV_16,
237};
238
239enum {
240	MSM_DMIC,
241	SWR_MIC,
242	ANC_FB_TUNE1
243};
244
245struct tx_mute_work {
246	struct tx_macro *tx;
247	u8 decimator;
248	struct delayed_work dwork;
249};
250
251struct hpf_work {
252	struct tx_macro *tx;
253	u8 decimator;
254	u8 hpf_cut_off_freq;
255	struct delayed_work dwork;
256};
257
258struct tx_macro_data {
259	unsigned int flags;
260	unsigned int ver;
261	const struct snd_soc_dapm_widget *extra_widgets;
262	size_t extra_widgets_num;
263	const struct snd_soc_dapm_route *extra_routes;
264	size_t extra_routes_num;
265};
266
267struct tx_macro {
268	struct device *dev;
269	const struct tx_macro_data *data;
270	struct snd_soc_component *component;
271	struct hpf_work tx_hpf_work[NUM_DECIMATORS];
272	struct tx_mute_work tx_mute_dwork[NUM_DECIMATORS];
273	unsigned long active_ch_mask[TX_MACRO_MAX_DAIS];
274	unsigned long active_ch_cnt[TX_MACRO_MAX_DAIS];
275	int active_decimator[TX_MACRO_MAX_DAIS];
276	struct regmap *regmap;
277	struct clk *mclk;
278	struct clk *npl;
279	struct clk *macro;
280	struct clk *dcodec;
281	struct clk *fsgen;
282	struct clk_hw hw;
283	bool dec_active[NUM_DECIMATORS];
284	int tx_mclk_users;
285	bool bcs_enable;
286	int dec_mode[NUM_DECIMATORS];
287	struct lpass_macro *pds;
288	bool bcs_clk_en;
289};
290#define to_tx_macro(_hw) container_of(_hw, struct tx_macro, hw)
291
292static const DECLARE_TLV_DB_SCALE(digital_gain, -8400, 100, -8400);
293
294static struct reg_default tx_defaults[] = {
295	/* TX Macro */
296	{ CDC_TX_CLK_RST_CTRL_MCLK_CONTROL, 0x00 },
297	{ CDC_TX_CLK_RST_CTRL_FS_CNT_CONTROL, 0x00 },
298	{ CDC_TX_CLK_RST_CTRL_SWR_CONTROL, 0x00},
299	{ CDC_TX_TOP_CSR_TOP_CFG0, 0x00},
300	{ CDC_TX_TOP_CSR_ANC_CFG, 0x00},
301	{ CDC_TX_TOP_CSR_SWR_CTRL, 0x00},
302	{ CDC_TX_TOP_CSR_FREQ_MCLK, 0x00},
303	{ CDC_TX_TOP_CSR_DEBUG_BUS, 0x00},
304	{ CDC_TX_TOP_CSR_DEBUG_EN, 0x00},
305	{ CDC_TX_TOP_CSR_TX_I2S_CTL, 0x0C},
306	{ CDC_TX_TOP_CSR_I2S_CLK, 0x00},
307	{ CDC_TX_TOP_CSR_I2S_RESET, 0x00},
308	{ CDC_TX_TOP_CSR_SWR_DMIC0_CTL, 0x00},
309	{ CDC_TX_TOP_CSR_SWR_DMIC1_CTL, 0x00},
310	{ CDC_TX_TOP_CSR_SWR_DMIC2_CTL, 0x00},
311	{ CDC_TX_TOP_CSR_SWR_DMIC3_CTL, 0x00},
312	{ CDC_TX_TOP_CSR_SWR_AMIC0_CTL, 0x00},
313	{ CDC_TX_TOP_CSR_SWR_AMIC1_CTL, 0x00},
314	{ CDC_TX_INP_MUX_ADC_MUX0_CFG0, 0x00},
315	{ CDC_TX_INP_MUX_ADC_MUX0_CFG1, 0x00},
316	{ CDC_TX_INP_MUX_ADC_MUX1_CFG0, 0x00},
317	{ CDC_TX_INP_MUX_ADC_MUX1_CFG1, 0x00},
318	{ CDC_TX_INP_MUX_ADC_MUX2_CFG0, 0x00},
319	{ CDC_TX_INP_MUX_ADC_MUX2_CFG1, 0x00},
320	{ CDC_TX_INP_MUX_ADC_MUX3_CFG0, 0x00},
321	{ CDC_TX_INP_MUX_ADC_MUX3_CFG1, 0x00},
322	{ CDC_TX_INP_MUX_ADC_MUX4_CFG0, 0x00},
323	{ CDC_TX_INP_MUX_ADC_MUX4_CFG1, 0x00},
324	{ CDC_TX_INP_MUX_ADC_MUX5_CFG0, 0x00},
325	{ CDC_TX_INP_MUX_ADC_MUX5_CFG1, 0x00},
326	{ CDC_TX_INP_MUX_ADC_MUX6_CFG0, 0x00},
327	{ CDC_TX_INP_MUX_ADC_MUX6_CFG1, 0x00},
328	{ CDC_TX_INP_MUX_ADC_MUX7_CFG0, 0x00},
329	{ CDC_TX_INP_MUX_ADC_MUX7_CFG1, 0x00},
330	{ CDC_TX_ANC0_CLK_RESET_CTL, 0x00},
331	{ CDC_TX_ANC0_MODE_1_CTL, 0x00},
332	{ CDC_TX_ANC0_MODE_2_CTL, 0x00},
333	{ CDC_TX_ANC0_FF_SHIFT, 0x00},
334	{ CDC_TX_ANC0_FB_SHIFT, 0x00},
335	{ CDC_TX_ANC0_LPF_FF_A_CTL, 0x00},
336	{ CDC_TX_ANC0_LPF_FF_B_CTL, 0x00},
337	{ CDC_TX_ANC0_LPF_FB_CTL, 0x00},
338	{ CDC_TX_ANC0_SMLPF_CTL, 0x00},
339	{ CDC_TX_ANC0_DCFLT_SHIFT_CTL, 0x00},
340	{ CDC_TX_ANC0_IIR_ADAPT_CTL, 0x00},
341	{ CDC_TX_ANC0_IIR_COEFF_1_CTL, 0x00},
342	{ CDC_TX_ANC0_IIR_COEFF_2_CTL, 0x00},
343	{ CDC_TX_ANC0_FF_A_GAIN_CTL, 0x00},
344	{ CDC_TX_ANC0_FF_B_GAIN_CTL, 0x00},
345	{ CDC_TX_ANC0_FB_GAIN_CTL, 0x00},
346	{ CDC_TX0_TX_PATH_CTL, 0x04},
347	{ CDC_TX0_TX_PATH_CFG0, 0x10},
348	{ CDC_TX0_TX_PATH_CFG1, 0x0B},
349	{ CDC_TX0_TX_VOL_CTL, 0x00},
350	{ CDC_TX0_TX_PATH_SEC0, 0x00},
351	{ CDC_TX0_TX_PATH_SEC1, 0x00},
352	{ CDC_TX0_TX_PATH_SEC2, 0x01},
353	{ CDC_TX0_TX_PATH_SEC3, 0x3C},
354	{ CDC_TX0_TX_PATH_SEC4, 0x20},
355	{ CDC_TX0_TX_PATH_SEC5, 0x00},
356	{ CDC_TX0_TX_PATH_SEC6, 0x00},
357	{ CDC_TX0_TX_PATH_SEC7, 0x25},
358	{ CDC_TX1_TX_PATH_CTL, 0x04},
359	{ CDC_TX1_TX_PATH_CFG0, 0x10},
360	{ CDC_TX1_TX_PATH_CFG1, 0x0B},
361	{ CDC_TX1_TX_VOL_CTL, 0x00},
362	{ CDC_TX1_TX_PATH_SEC0, 0x00},
363	{ CDC_TX1_TX_PATH_SEC1, 0x00},
364	{ CDC_TX1_TX_PATH_SEC2, 0x01},
365	{ CDC_TX1_TX_PATH_SEC3, 0x3C},
366	{ CDC_TX1_TX_PATH_SEC4, 0x20},
367	{ CDC_TX1_TX_PATH_SEC5, 0x00},
368	{ CDC_TX1_TX_PATH_SEC6, 0x00},
369	{ CDC_TX2_TX_PATH_CTL, 0x04},
370	{ CDC_TX2_TX_PATH_CFG0, 0x10},
371	{ CDC_TX2_TX_PATH_CFG1, 0x0B},
372	{ CDC_TX2_TX_VOL_CTL, 0x00},
373	{ CDC_TX2_TX_PATH_SEC0, 0x00},
374	{ CDC_TX2_TX_PATH_SEC1, 0x00},
375	{ CDC_TX2_TX_PATH_SEC2, 0x01},
376	{ CDC_TX2_TX_PATH_SEC3, 0x3C},
377	{ CDC_TX2_TX_PATH_SEC4, 0x20},
378	{ CDC_TX2_TX_PATH_SEC5, 0x00},
379	{ CDC_TX2_TX_PATH_SEC6, 0x00},
380	{ CDC_TX3_TX_PATH_CTL, 0x04},
381	{ CDC_TX3_TX_PATH_CFG0, 0x10},
382	{ CDC_TX3_TX_PATH_CFG1, 0x0B},
383	{ CDC_TX3_TX_VOL_CTL, 0x00},
384	{ CDC_TX3_TX_PATH_SEC0, 0x00},
385	{ CDC_TX3_TX_PATH_SEC1, 0x00},
386	{ CDC_TX3_TX_PATH_SEC2, 0x01},
387	{ CDC_TX3_TX_PATH_SEC3, 0x3C},
388	{ CDC_TX3_TX_PATH_SEC4, 0x20},
389	{ CDC_TX3_TX_PATH_SEC5, 0x00},
390	{ CDC_TX3_TX_PATH_SEC6, 0x00},
391	{ CDC_TX4_TX_PATH_CTL, 0x04},
392	{ CDC_TX4_TX_PATH_CFG0, 0x10},
393	{ CDC_TX4_TX_PATH_CFG1, 0x0B},
394	{ CDC_TX4_TX_VOL_CTL, 0x00},
395	{ CDC_TX4_TX_PATH_SEC0, 0x00},
396	{ CDC_TX4_TX_PATH_SEC1, 0x00},
397	{ CDC_TX4_TX_PATH_SEC2, 0x01},
398	{ CDC_TX4_TX_PATH_SEC3, 0x3C},
399	{ CDC_TX4_TX_PATH_SEC4, 0x20},
400	{ CDC_TX4_TX_PATH_SEC5, 0x00},
401	{ CDC_TX4_TX_PATH_SEC6, 0x00},
402	{ CDC_TX5_TX_PATH_CTL, 0x04},
403	{ CDC_TX5_TX_PATH_CFG0, 0x10},
404	{ CDC_TX5_TX_PATH_CFG1, 0x0B},
405	{ CDC_TX5_TX_VOL_CTL, 0x00},
406	{ CDC_TX5_TX_PATH_SEC0, 0x00},
407	{ CDC_TX5_TX_PATH_SEC1, 0x00},
408	{ CDC_TX5_TX_PATH_SEC2, 0x01},
409	{ CDC_TX5_TX_PATH_SEC3, 0x3C},
410	{ CDC_TX5_TX_PATH_SEC4, 0x20},
411	{ CDC_TX5_TX_PATH_SEC5, 0x00},
412	{ CDC_TX5_TX_PATH_SEC6, 0x00},
413	{ CDC_TX6_TX_PATH_CTL, 0x04},
414	{ CDC_TX6_TX_PATH_CFG0, 0x10},
415	{ CDC_TX6_TX_PATH_CFG1, 0x0B},
416	{ CDC_TX6_TX_VOL_CTL, 0x00},
417	{ CDC_TX6_TX_PATH_SEC0, 0x00},
418	{ CDC_TX6_TX_PATH_SEC1, 0x00},
419	{ CDC_TX6_TX_PATH_SEC2, 0x01},
420	{ CDC_TX6_TX_PATH_SEC3, 0x3C},
421	{ CDC_TX6_TX_PATH_SEC4, 0x20},
422	{ CDC_TX6_TX_PATH_SEC5, 0x00},
423	{ CDC_TX6_TX_PATH_SEC6, 0x00},
424	{ CDC_TX7_TX_PATH_CTL, 0x04},
425	{ CDC_TX7_TX_PATH_CFG0, 0x10},
426	{ CDC_TX7_TX_PATH_CFG1, 0x0B},
427	{ CDC_TX7_TX_VOL_CTL, 0x00},
428	{ CDC_TX7_TX_PATH_SEC0, 0x00},
429	{ CDC_TX7_TX_PATH_SEC1, 0x00},
430	{ CDC_TX7_TX_PATH_SEC2, 0x01},
431	{ CDC_TX7_TX_PATH_SEC3, 0x3C},
432	{ CDC_TX7_TX_PATH_SEC4, 0x20},
433	{ CDC_TX7_TX_PATH_SEC5, 0x00},
434	{ CDC_TX7_TX_PATH_SEC6, 0x00},
435};
436
437static bool tx_is_volatile_register(struct device *dev, unsigned int reg)
438{
439	/* Update volatile list for tx/tx macros */
440	switch (reg) {
441	case CDC_TX_TOP_CSR_SWR_DMIC0_CTL:
442	case CDC_TX_TOP_CSR_SWR_DMIC1_CTL:
443	case CDC_TX_TOP_CSR_SWR_DMIC2_CTL:
444	case CDC_TX_TOP_CSR_SWR_DMIC3_CTL:
445	case CDC_TX_TOP_CSR_SWR_AMIC0_CTL:
446	case CDC_TX_TOP_CSR_SWR_AMIC1_CTL:
447		return true;
448	}
449	return false;
450}
451
452static bool tx_is_rw_register(struct device *dev, unsigned int reg)
453{
454	switch (reg) {
455	case CDC_TX_CLK_RST_CTRL_MCLK_CONTROL:
456	case CDC_TX_CLK_RST_CTRL_FS_CNT_CONTROL:
457	case CDC_TX_CLK_RST_CTRL_SWR_CONTROL:
458	case CDC_TX_TOP_CSR_TOP_CFG0:
459	case CDC_TX_TOP_CSR_ANC_CFG:
460	case CDC_TX_TOP_CSR_SWR_CTRL:
461	case CDC_TX_TOP_CSR_FREQ_MCLK:
462	case CDC_TX_TOP_CSR_DEBUG_BUS:
463	case CDC_TX_TOP_CSR_DEBUG_EN:
464	case CDC_TX_TOP_CSR_TX_I2S_CTL:
465	case CDC_TX_TOP_CSR_I2S_CLK:
466	case CDC_TX_TOP_CSR_I2S_RESET:
467	case CDC_TX_TOP_CSR_SWR_DMIC0_CTL:
468	case CDC_TX_TOP_CSR_SWR_DMIC1_CTL:
469	case CDC_TX_TOP_CSR_SWR_DMIC2_CTL:
470	case CDC_TX_TOP_CSR_SWR_DMIC3_CTL:
471	case CDC_TX_TOP_CSR_SWR_AMIC0_CTL:
472	case CDC_TX_TOP_CSR_SWR_AMIC1_CTL:
473	case CDC_TX_ANC0_CLK_RESET_CTL:
474	case CDC_TX_ANC0_MODE_1_CTL:
475	case CDC_TX_ANC0_MODE_2_CTL:
476	case CDC_TX_ANC0_FF_SHIFT:
477	case CDC_TX_ANC0_FB_SHIFT:
478	case CDC_TX_ANC0_LPF_FF_A_CTL:
479	case CDC_TX_ANC0_LPF_FF_B_CTL:
480	case CDC_TX_ANC0_LPF_FB_CTL:
481	case CDC_TX_ANC0_SMLPF_CTL:
482	case CDC_TX_ANC0_DCFLT_SHIFT_CTL:
483	case CDC_TX_ANC0_IIR_ADAPT_CTL:
484	case CDC_TX_ANC0_IIR_COEFF_1_CTL:
485	case CDC_TX_ANC0_IIR_COEFF_2_CTL:
486	case CDC_TX_ANC0_FF_A_GAIN_CTL:
487	case CDC_TX_ANC0_FF_B_GAIN_CTL:
488	case CDC_TX_ANC0_FB_GAIN_CTL:
489	case CDC_TX_INP_MUX_ADC_MUX0_CFG0:
490	case CDC_TX_INP_MUX_ADC_MUX0_CFG1:
491	case CDC_TX_INP_MUX_ADC_MUX1_CFG0:
492	case CDC_TX_INP_MUX_ADC_MUX1_CFG1:
493	case CDC_TX_INP_MUX_ADC_MUX2_CFG0:
494	case CDC_TX_INP_MUX_ADC_MUX2_CFG1:
495	case CDC_TX_INP_MUX_ADC_MUX3_CFG0:
496	case CDC_TX_INP_MUX_ADC_MUX3_CFG1:
497	case CDC_TX_INP_MUX_ADC_MUX4_CFG0:
498	case CDC_TX_INP_MUX_ADC_MUX4_CFG1:
499	case CDC_TX_INP_MUX_ADC_MUX5_CFG0:
500	case CDC_TX_INP_MUX_ADC_MUX5_CFG1:
501	case CDC_TX_INP_MUX_ADC_MUX6_CFG0:
502	case CDC_TX_INP_MUX_ADC_MUX6_CFG1:
503	case CDC_TX_INP_MUX_ADC_MUX7_CFG0:
504	case CDC_TX_INP_MUX_ADC_MUX7_CFG1:
505	case CDC_TX0_TX_PATH_CTL:
506	case CDC_TX0_TX_PATH_CFG0:
507	case CDC_TX0_TX_PATH_CFG1:
508	case CDC_TX0_TX_VOL_CTL:
509	case CDC_TX0_TX_PATH_SEC0:
510	case CDC_TX0_TX_PATH_SEC1:
511	case CDC_TX0_TX_PATH_SEC2:
512	case CDC_TX0_TX_PATH_SEC3:
513	case CDC_TX0_TX_PATH_SEC4:
514	case CDC_TX0_TX_PATH_SEC5:
515	case CDC_TX0_TX_PATH_SEC6:
516	case CDC_TX0_TX_PATH_SEC7:
517	case CDC_TX1_TX_PATH_CTL:
518	case CDC_TX1_TX_PATH_CFG0:
519	case CDC_TX1_TX_PATH_CFG1:
520	case CDC_TX1_TX_VOL_CTL:
521	case CDC_TX1_TX_PATH_SEC0:
522	case CDC_TX1_TX_PATH_SEC1:
523	case CDC_TX1_TX_PATH_SEC2:
524	case CDC_TX1_TX_PATH_SEC3:
525	case CDC_TX1_TX_PATH_SEC4:
526	case CDC_TX1_TX_PATH_SEC5:
527	case CDC_TX1_TX_PATH_SEC6:
528	case CDC_TX2_TX_PATH_CTL:
529	case CDC_TX2_TX_PATH_CFG0:
530	case CDC_TX2_TX_PATH_CFG1:
531	case CDC_TX2_TX_VOL_CTL:
532	case CDC_TX2_TX_PATH_SEC0:
533	case CDC_TX2_TX_PATH_SEC1:
534	case CDC_TX2_TX_PATH_SEC2:
535	case CDC_TX2_TX_PATH_SEC3:
536	case CDC_TX2_TX_PATH_SEC4:
537	case CDC_TX2_TX_PATH_SEC5:
538	case CDC_TX2_TX_PATH_SEC6:
539	case CDC_TX3_TX_PATH_CTL:
540	case CDC_TX3_TX_PATH_CFG0:
541	case CDC_TX3_TX_PATH_CFG1:
542	case CDC_TX3_TX_VOL_CTL:
543	case CDC_TX3_TX_PATH_SEC0:
544	case CDC_TX3_TX_PATH_SEC1:
545	case CDC_TX3_TX_PATH_SEC2:
546	case CDC_TX3_TX_PATH_SEC3:
547	case CDC_TX3_TX_PATH_SEC4:
548	case CDC_TX3_TX_PATH_SEC5:
549	case CDC_TX3_TX_PATH_SEC6:
550	case CDC_TX4_TX_PATH_CTL:
551	case CDC_TX4_TX_PATH_CFG0:
552	case CDC_TX4_TX_PATH_CFG1:
553	case CDC_TX4_TX_VOL_CTL:
554	case CDC_TX4_TX_PATH_SEC0:
555	case CDC_TX4_TX_PATH_SEC1:
556	case CDC_TX4_TX_PATH_SEC2:
557	case CDC_TX4_TX_PATH_SEC3:
558	case CDC_TX4_TX_PATH_SEC4:
559	case CDC_TX4_TX_PATH_SEC5:
560	case CDC_TX4_TX_PATH_SEC6:
561	case CDC_TX5_TX_PATH_CTL:
562	case CDC_TX5_TX_PATH_CFG0:
563	case CDC_TX5_TX_PATH_CFG1:
564	case CDC_TX5_TX_VOL_CTL:
565	case CDC_TX5_TX_PATH_SEC0:
566	case CDC_TX5_TX_PATH_SEC1:
567	case CDC_TX5_TX_PATH_SEC2:
568	case CDC_TX5_TX_PATH_SEC3:
569	case CDC_TX5_TX_PATH_SEC4:
570	case CDC_TX5_TX_PATH_SEC5:
571	case CDC_TX5_TX_PATH_SEC6:
572	case CDC_TX6_TX_PATH_CTL:
573	case CDC_TX6_TX_PATH_CFG0:
574	case CDC_TX6_TX_PATH_CFG1:
575	case CDC_TX6_TX_VOL_CTL:
576	case CDC_TX6_TX_PATH_SEC0:
577	case CDC_TX6_TX_PATH_SEC1:
578	case CDC_TX6_TX_PATH_SEC2:
579	case CDC_TX6_TX_PATH_SEC3:
580	case CDC_TX6_TX_PATH_SEC4:
581	case CDC_TX6_TX_PATH_SEC5:
582	case CDC_TX6_TX_PATH_SEC6:
583	case CDC_TX7_TX_PATH_CTL:
584	case CDC_TX7_TX_PATH_CFG0:
585	case CDC_TX7_TX_PATH_CFG1:
586	case CDC_TX7_TX_VOL_CTL:
587	case CDC_TX7_TX_PATH_SEC0:
588	case CDC_TX7_TX_PATH_SEC1:
589	case CDC_TX7_TX_PATH_SEC2:
590	case CDC_TX7_TX_PATH_SEC3:
591	case CDC_TX7_TX_PATH_SEC4:
592	case CDC_TX7_TX_PATH_SEC5:
593	case CDC_TX7_TX_PATH_SEC6:
594		return true;
595	}
596
597	return false;
598}
599
600static const struct regmap_config tx_regmap_config = {
601	.name = "tx_macro",
602	.reg_bits = 16,
603	.val_bits = 32,
604	.reg_stride = 4,
605	.cache_type = REGCACHE_FLAT,
606	.max_register = TX_MAX_OFFSET,
607	.reg_defaults = tx_defaults,
608	.num_reg_defaults = ARRAY_SIZE(tx_defaults),
609	.writeable_reg = tx_is_rw_register,
610	.volatile_reg = tx_is_volatile_register,
611	.readable_reg = tx_is_rw_register,
612};
613
614static int tx_macro_mclk_enable(struct tx_macro *tx,
615				bool mclk_enable)
616{
617	struct regmap *regmap = tx->regmap;
618
619	if (mclk_enable) {
620		if (tx->tx_mclk_users == 0) {
621			/* 9.6MHz MCLK, set value 0x00 if other frequency */
622			regmap_update_bits(regmap, CDC_TX_TOP_CSR_FREQ_MCLK, 0x01, 0x01);
623			regmap_update_bits(regmap, CDC_TX_CLK_RST_CTRL_MCLK_CONTROL,
624					   CDC_TX_MCLK_EN_MASK,
625					   CDC_TX_MCLK_ENABLE);
626			regmap_update_bits(regmap, CDC_TX_CLK_RST_CTRL_FS_CNT_CONTROL,
627					   CDC_TX_FS_CNT_EN_MASK,
628					   CDC_TX_FS_CNT_ENABLE);
629			regcache_mark_dirty(regmap);
630			regcache_sync(regmap);
631		}
632		tx->tx_mclk_users++;
633	} else {
634		if (tx->tx_mclk_users <= 0) {
635			dev_err(tx->dev, "clock already disabled\n");
636			tx->tx_mclk_users = 0;
637			goto exit;
638		}
639		tx->tx_mclk_users--;
640		if (tx->tx_mclk_users == 0) {
641			regmap_update_bits(regmap, CDC_TX_CLK_RST_CTRL_FS_CNT_CONTROL,
642					   CDC_TX_FS_CNT_EN_MASK, 0x0);
643			regmap_update_bits(regmap, CDC_TX_CLK_RST_CTRL_MCLK_CONTROL,
644					   CDC_TX_MCLK_EN_MASK, 0x0);
645		}
646	}
647exit:
648	return 0;
649}
650
651static bool is_amic_enabled(struct snd_soc_component *component,
652			    struct tx_macro *tx, u8 decimator)
653{
654	u16 adc_mux_reg, adc_reg, adc_n;
655
656	adc_mux_reg = CDC_TX_INP_MUX_ADC_MUXn_CFG1(decimator);
657
658	if (snd_soc_component_read(component, adc_mux_reg) & SWR_MIC) {
659		if (tx->data->ver > LPASS_VER_9_0_0)
660			return true;
661
662		/* else: LPASS <= v9.0.0 */
663		adc_reg = CDC_TX_INP_MUX_ADC_MUXn_CFG0(decimator);
664		adc_n = snd_soc_component_read_field(component, adc_reg,
665					     CDC_TX_MACRO_SWR_MIC_MUX_SEL_MASK);
666		if (adc_n < TX_ADC_MAX)
667			return true;
668	}
669
670	return false;
671}
672
673static void tx_macro_tx_hpf_corner_freq_callback(struct work_struct *work)
674{
675	struct delayed_work *hpf_delayed_work;
676	struct hpf_work *hpf_work;
677	struct tx_macro *tx;
678	struct snd_soc_component *component;
679	u16 dec_cfg_reg, hpf_gate_reg;
680	u8 hpf_cut_off_freq;
681
682	hpf_delayed_work = to_delayed_work(work);
683	hpf_work = container_of(hpf_delayed_work, struct hpf_work, dwork);
684	tx = hpf_work->tx;
685	component = tx->component;
686	hpf_cut_off_freq = hpf_work->hpf_cut_off_freq;
687
688	dec_cfg_reg = CDC_TXn_TX_PATH_CFG0(hpf_work->decimator);
689	hpf_gate_reg = CDC_TXn_TX_PATH_SEC2(hpf_work->decimator);
690
691	if (is_amic_enabled(component, tx, hpf_work->decimator)) {
692		snd_soc_component_write_field(component,
693				dec_cfg_reg,
694				CDC_TXn_HPF_CUT_FREQ_MASK,
695				hpf_cut_off_freq);
696		snd_soc_component_update_bits(component, hpf_gate_reg,
697					      CDC_TXn_HPF_F_CHANGE_MASK |
698					      CDC_TXn_HPF_ZERO_GATE_MASK,
699					      0x02);
700		snd_soc_component_update_bits(component, hpf_gate_reg,
701					      CDC_TXn_HPF_F_CHANGE_MASK |
702					      CDC_TXn_HPF_ZERO_GATE_MASK,
703					      0x01);
704	} else {
705		snd_soc_component_write_field(component, dec_cfg_reg,
706					      CDC_TXn_HPF_CUT_FREQ_MASK,
707					      hpf_cut_off_freq);
708		snd_soc_component_write_field(component, hpf_gate_reg,
709					      CDC_TXn_HPF_F_CHANGE_MASK, 0x1);
710		/* Minimum 1 clk cycle delay is required as per HW spec */
711		usleep_range(1000, 1010);
712		snd_soc_component_write_field(component, hpf_gate_reg,
713					      CDC_TXn_HPF_F_CHANGE_MASK, 0x0);
714	}
715}
716
717static void tx_macro_mute_update_callback(struct work_struct *work)
718{
719	struct tx_mute_work *tx_mute_dwork;
720	struct snd_soc_component *component;
721	struct tx_macro *tx;
722	struct delayed_work *delayed_work;
723	u8 decimator;
724
725	delayed_work = to_delayed_work(work);
726	tx_mute_dwork = container_of(delayed_work, struct tx_mute_work, dwork);
727	tx = tx_mute_dwork->tx;
728	component = tx->component;
729	decimator = tx_mute_dwork->decimator;
730
731	snd_soc_component_write_field(component, CDC_TXn_TX_PATH_CTL(decimator),
732				      CDC_TXn_PGA_MUTE_MASK, 0x0);
733}
734
735static int tx_macro_mclk_event(struct snd_soc_dapm_widget *w,
736			       struct snd_kcontrol *kcontrol, int event)
737{
738	struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm);
739	struct tx_macro *tx = snd_soc_component_get_drvdata(component);
740
741	switch (event) {
742	case SND_SOC_DAPM_PRE_PMU:
743		tx_macro_mclk_enable(tx, true);
744		break;
745	case SND_SOC_DAPM_POST_PMD:
746		tx_macro_mclk_enable(tx, false);
747		break;
748	default:
749		break;
750	}
751
752	return 0;
753}
754
755static void tx_macro_update_smic_sel_v9(struct snd_soc_component *component,
756					struct snd_soc_dapm_widget *widget,
757					struct tx_macro *tx, u16 mic_sel_reg,
758					unsigned int val)
759{
760	unsigned int dmic;
761	u16 dmic_clk_reg;
762
763	if (val < 5) {
764		snd_soc_component_write_field(component, mic_sel_reg,
765					      CDC_TXn_ADC_DMIC_SEL_MASK, 0);
766	} else {
767		snd_soc_component_write_field(component, mic_sel_reg,
768					      CDC_TXn_ADC_DMIC_SEL_MASK, 1);
769		dmic = TX_ADC_TO_DMIC(val);
770		dmic_clk_reg = CDC_TX_TOP_CSR_SWR_DMICn_CTL(dmic);
771		snd_soc_component_write_field(component, dmic_clk_reg,
772					      CDC_TX_SWR_DMIC_CLK_SEL_MASK,
773					      CDC_TX_SWR_MIC_CLK_DEFAULT);
774	}
775}
776
777static void tx_macro_update_smic_sel_v9_2(struct snd_soc_component *component,
778					  struct snd_soc_dapm_widget *widget,
779					  struct tx_macro *tx, u16 mic_sel_reg,
780					  unsigned int val)
781{
782	unsigned int dmic;
783	u16 dmic_clk_reg;
784
785	if (widget->shift) {
786		/* MSM DMIC */
787		snd_soc_component_write_field(component, mic_sel_reg,
788					      CDC_TXn_ADC_DMIC_SEL_MASK, 1);
789
790		dmic = TX_ADC_TO_DMIC(val);
791		dmic_clk_reg = CDC_TX_TOP_CSR_SWR_DMICn_CTL(dmic);
792		snd_soc_component_write_field(component, dmic_clk_reg,
793					      CDC_TX_SWR_DMIC_CLK_SEL_MASK,
794					      CDC_TX_SWR_MIC_CLK_DEFAULT);
795	} else {
796		snd_soc_component_write_field(component, mic_sel_reg,
797					      CDC_TXn_ADC_DMIC_SEL_MASK, 0);
798	}
799}
800
801static int tx_macro_put_dec_enum(struct snd_kcontrol *kcontrol,
802				 struct snd_ctl_elem_value *ucontrol)
803{
804	struct snd_soc_dapm_widget *widget = snd_soc_dapm_kcontrol_widget(kcontrol);
805	struct snd_soc_component *component = snd_soc_dapm_to_component(widget->dapm);
806	struct soc_enum *e = (struct soc_enum *)kcontrol->private_value;
807	struct tx_macro *tx = snd_soc_component_get_drvdata(component);
808	unsigned int val;
809	u16 mic_sel_reg;
810
811	val = ucontrol->value.enumerated.item[0];
812	if (val >= e->items)
813		return -EINVAL;
814
815	switch (e->reg) {
816	case CDC_TX_INP_MUX_ADC_MUX0_CFG0:
817		mic_sel_reg = CDC_TX0_TX_PATH_CFG0;
818		break;
819	case CDC_TX_INP_MUX_ADC_MUX1_CFG0:
820		mic_sel_reg = CDC_TX1_TX_PATH_CFG0;
821		break;
822	case CDC_TX_INP_MUX_ADC_MUX2_CFG0:
823		mic_sel_reg = CDC_TX2_TX_PATH_CFG0;
824		break;
825	case CDC_TX_INP_MUX_ADC_MUX3_CFG0:
826		mic_sel_reg = CDC_TX3_TX_PATH_CFG0;
827		break;
828	case CDC_TX_INP_MUX_ADC_MUX4_CFG0:
829		mic_sel_reg = CDC_TX4_TX_PATH_CFG0;
830		break;
831	case CDC_TX_INP_MUX_ADC_MUX5_CFG0:
832		mic_sel_reg = CDC_TX5_TX_PATH_CFG0;
833		break;
834	case CDC_TX_INP_MUX_ADC_MUX6_CFG0:
835		mic_sel_reg = CDC_TX6_TX_PATH_CFG0;
836		break;
837	case CDC_TX_INP_MUX_ADC_MUX7_CFG0:
838		mic_sel_reg = CDC_TX7_TX_PATH_CFG0;
839		break;
840	default:
841		dev_err(component->dev, "Error in configuration!!\n");
842		return -EINVAL;
843	}
844
845	if (val != 0) {
846		if (widget->shift) /* MSM DMIC */
847			snd_soc_component_write_field(component, mic_sel_reg,
848						      CDC_TXn_ADC_DMIC_SEL_MASK, 1);
849		else if (tx->data->ver <= LPASS_VER_9_0_0)
850			tx_macro_update_smic_sel_v9(component, widget, tx,
851						    mic_sel_reg, val);
852		else
853			tx_macro_update_smic_sel_v9_2(component, widget, tx,
854						      mic_sel_reg, val);
855	}
856
857	return snd_soc_dapm_put_enum_double(kcontrol, ucontrol);
858}
859
860static int tx_macro_tx_mixer_get(struct snd_kcontrol *kcontrol,
861				 struct snd_ctl_elem_value *ucontrol)
862{
863	struct snd_soc_dapm_widget *widget = snd_soc_dapm_kcontrol_widget(kcontrol);
864	struct snd_soc_component *component = snd_soc_dapm_to_component(widget->dapm);
865	struct soc_mixer_control *mc = (struct soc_mixer_control *)kcontrol->private_value;
866	u32 dai_id = widget->shift;
867	u32 dec_id = mc->shift;
868	struct tx_macro *tx = snd_soc_component_get_drvdata(component);
869
870	if (test_bit(dec_id, &tx->active_ch_mask[dai_id]))
871		ucontrol->value.integer.value[0] = 1;
872	else
873		ucontrol->value.integer.value[0] = 0;
874
875	return 0;
876}
877
878static int tx_macro_tx_mixer_put(struct snd_kcontrol *kcontrol,
879				 struct snd_ctl_elem_value *ucontrol)
880{
881	struct snd_soc_dapm_widget *widget = snd_soc_dapm_kcontrol_widget(kcontrol);
882	struct snd_soc_component *component = snd_soc_dapm_to_component(widget->dapm);
883	struct snd_soc_dapm_update *update = NULL;
884	struct soc_mixer_control *mc = (struct soc_mixer_control *)kcontrol->private_value;
885	u32 dai_id = widget->shift;
886	u32 dec_id = mc->shift;
887	u32 enable = ucontrol->value.integer.value[0];
888	struct tx_macro *tx = snd_soc_component_get_drvdata(component);
889
890	if (enable) {
891		if (tx->active_decimator[dai_id] == dec_id)
892			return 0;
893
894		set_bit(dec_id, &tx->active_ch_mask[dai_id]);
895		tx->active_ch_cnt[dai_id]++;
896		tx->active_decimator[dai_id] = dec_id;
897	} else {
898		if (tx->active_decimator[dai_id] == -1)
899			return 0;
900
901		tx->active_ch_cnt[dai_id]--;
902		clear_bit(dec_id, &tx->active_ch_mask[dai_id]);
903		tx->active_decimator[dai_id] = -1;
904	}
905	snd_soc_dapm_mixer_update_power(widget->dapm, kcontrol, enable, update);
906
907	return 1;
908}
909
910static int tx_macro_enable_dec(struct snd_soc_dapm_widget *w,
911			       struct snd_kcontrol *kcontrol, int event)
912{
913	struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm);
914	u8 decimator;
915	u16 tx_vol_ctl_reg, dec_cfg_reg, hpf_gate_reg, tx_gain_ctl_reg;
916	u8 hpf_cut_off_freq;
917	int hpf_delay = TX_MACRO_DMIC_HPF_DELAY_MS;
918	int unmute_delay = TX_MACRO_DMIC_UNMUTE_DELAY_MS;
919	u16 adc_mux_reg, adc_reg, adc_n, dmic;
920	u16 dmic_clk_reg;
921	struct tx_macro *tx = snd_soc_component_get_drvdata(component);
922
923	decimator = w->shift;
924	tx_vol_ctl_reg = CDC_TXn_TX_PATH_CTL(decimator);
925	hpf_gate_reg = CDC_TXn_TX_PATH_SEC2(decimator);
926	dec_cfg_reg = CDC_TXn_TX_PATH_CFG0(decimator);
927	tx_gain_ctl_reg = CDC_TXn_TX_VOL_CTL(decimator);
928
929	switch (event) {
930	case SND_SOC_DAPM_PRE_PMU:
931		adc_mux_reg = CDC_TX_INP_MUX_ADC_MUXn_CFG1(decimator);
932		if (snd_soc_component_read(component, adc_mux_reg) & SWR_MIC) {
933			adc_reg = CDC_TX_INP_MUX_ADC_MUXn_CFG0(decimator);
934			adc_n = snd_soc_component_read(component, adc_reg) &
935				CDC_TX_MACRO_SWR_MIC_MUX_SEL_MASK;
936			if (adc_n >= TX_ADC_MAX) {
937				dmic = TX_ADC_TO_DMIC(adc_n);
938				dmic_clk_reg = CDC_TX_TOP_CSR_SWR_DMICn_CTL(dmic);
939
940				snd_soc_component_write_field(component, dmic_clk_reg,
941							CDC_TX_SWR_DMIC_CLK_SEL_MASK,
942							CDC_TX_SWR_MIC_CLK_DEFAULT);
943			}
944		}
945		snd_soc_component_write_field(component, dec_cfg_reg,
946					      CDC_TXn_ADC_MODE_MASK,
947					      tx->dec_mode[decimator]);
948		/* Enable TX PGA Mute */
949		snd_soc_component_write_field(component, tx_vol_ctl_reg,
950					      CDC_TXn_PGA_MUTE_MASK, 0x1);
951		break;
952	case SND_SOC_DAPM_POST_PMU:
953		snd_soc_component_write_field(component, tx_vol_ctl_reg,
954					     CDC_TXn_CLK_EN_MASK, 0x1);
955		if (!is_amic_enabled(component, tx, decimator)) {
956			snd_soc_component_update_bits(component, hpf_gate_reg, 0x01, 0x00);
957			/* Minimum 1 clk cycle delay is required as per HW spec */
958			usleep_range(1000, 1010);
959		}
960		hpf_cut_off_freq = snd_soc_component_read_field(component, dec_cfg_reg,
961								CDC_TXn_HPF_CUT_FREQ_MASK);
962
963		tx->tx_hpf_work[decimator].hpf_cut_off_freq =
964						hpf_cut_off_freq;
965
966		if (hpf_cut_off_freq != CF_MIN_3DB_150HZ)
967			snd_soc_component_write_field(component, dec_cfg_reg,
968						      CDC_TXn_HPF_CUT_FREQ_MASK,
969						      CF_MIN_3DB_150HZ);
970
971		if (is_amic_enabled(component, tx, decimator)) {
972			hpf_delay = TX_MACRO_AMIC_HPF_DELAY_MS;
973			unmute_delay = TX_MACRO_AMIC_UNMUTE_DELAY_MS;
974		}
975		/* schedule work queue to Remove Mute */
976		queue_delayed_work(system_freezable_wq,
977				   &tx->tx_mute_dwork[decimator].dwork,
978				   msecs_to_jiffies(unmute_delay));
979		if (tx->tx_hpf_work[decimator].hpf_cut_off_freq != CF_MIN_3DB_150HZ) {
980			queue_delayed_work(system_freezable_wq,
981				&tx->tx_hpf_work[decimator].dwork,
982				msecs_to_jiffies(hpf_delay));
983			snd_soc_component_update_bits(component, hpf_gate_reg,
984					      CDC_TXn_HPF_F_CHANGE_MASK |
985					      CDC_TXn_HPF_ZERO_GATE_MASK,
986					      0x02);
987			if (!is_amic_enabled(component, tx, decimator))
988				snd_soc_component_update_bits(component, hpf_gate_reg,
989						      CDC_TXn_HPF_F_CHANGE_MASK |
990						      CDC_TXn_HPF_ZERO_GATE_MASK,
991						      0x00);
992			snd_soc_component_update_bits(component, hpf_gate_reg,
993					      CDC_TXn_HPF_F_CHANGE_MASK |
994					      CDC_TXn_HPF_ZERO_GATE_MASK,
995					      0x01);
996
997			/*
998			 * 6ms delay is required as per HW spec
999			 */
1000			usleep_range(6000, 6010);
1001		}
1002		/* apply gain after decimator is enabled */
1003		snd_soc_component_write(component, tx_gain_ctl_reg,
1004			      snd_soc_component_read(component,
1005					tx_gain_ctl_reg));
1006		if (tx->bcs_enable) {
1007			snd_soc_component_update_bits(component, dec_cfg_reg,
1008					0x01, 0x01);
1009			tx->bcs_clk_en = true;
1010		}
1011		break;
1012	case SND_SOC_DAPM_PRE_PMD:
1013		hpf_cut_off_freq =
1014			tx->tx_hpf_work[decimator].hpf_cut_off_freq;
1015		snd_soc_component_write_field(component, tx_vol_ctl_reg,
1016					      CDC_TXn_PGA_MUTE_MASK, 0x1);
1017		if (cancel_delayed_work_sync(
1018		    &tx->tx_hpf_work[decimator].dwork)) {
1019			if (hpf_cut_off_freq != CF_MIN_3DB_150HZ) {
1020				snd_soc_component_write_field(
1021						component, dec_cfg_reg,
1022						CDC_TXn_HPF_CUT_FREQ_MASK,
1023						hpf_cut_off_freq);
1024				if (is_amic_enabled(component, tx, decimator))
1025					snd_soc_component_update_bits(component,
1026					      hpf_gate_reg,
1027					      CDC_TXn_HPF_F_CHANGE_MASK |
1028					      CDC_TXn_HPF_ZERO_GATE_MASK,
1029					      0x02);
1030				else
1031					snd_soc_component_update_bits(component,
1032					      hpf_gate_reg,
1033					      CDC_TXn_HPF_F_CHANGE_MASK |
1034					      CDC_TXn_HPF_ZERO_GATE_MASK,
1035					      0x03);
1036
1037				/*
1038				 * Minimum 1 clk cycle delay is required
1039				 * as per HW spec
1040				 */
1041				usleep_range(1000, 1010);
1042				snd_soc_component_update_bits(component, hpf_gate_reg,
1043					      CDC_TXn_HPF_F_CHANGE_MASK |
1044					      CDC_TXn_HPF_ZERO_GATE_MASK,
1045					      0x1);
1046			}
1047		}
1048		cancel_delayed_work_sync(&tx->tx_mute_dwork[decimator].dwork);
1049		break;
1050	case SND_SOC_DAPM_POST_PMD:
1051		snd_soc_component_write_field(component, tx_vol_ctl_reg,
1052					      CDC_TXn_CLK_EN_MASK, 0x0);
1053		snd_soc_component_write_field(component, dec_cfg_reg,
1054					      CDC_TXn_ADC_MODE_MASK, 0x0);
1055		snd_soc_component_write_field(component, tx_vol_ctl_reg,
1056					      CDC_TXn_PGA_MUTE_MASK, 0x0);
1057		if (tx->bcs_enable) {
1058			snd_soc_component_write_field(component, dec_cfg_reg,
1059						      CDC_TXn_PH_EN_MASK, 0x0);
1060			snd_soc_component_write_field(component,
1061						      CDC_TX0_TX_PATH_SEC7,
1062						      CDC_TX0_MBHC_CTL_EN_MASK,
1063						      0x0);
1064			tx->bcs_clk_en = false;
1065		}
1066		break;
1067	}
1068	return 0;
1069}
1070
1071static int tx_macro_dec_mode_get(struct snd_kcontrol *kcontrol,
1072				 struct snd_ctl_elem_value *ucontrol)
1073{
1074	struct snd_soc_component *component = snd_soc_kcontrol_component(kcontrol);
1075	struct tx_macro *tx = snd_soc_component_get_drvdata(component);
1076	struct soc_enum *e = (struct soc_enum *)kcontrol->private_value;
1077	int path = e->shift_l;
1078
1079	ucontrol->value.integer.value[0] = tx->dec_mode[path];
1080
1081	return 0;
1082}
1083
1084static int tx_macro_dec_mode_put(struct snd_kcontrol *kcontrol,
1085				 struct snd_ctl_elem_value *ucontrol)
1086{
1087	struct snd_soc_component *component = snd_soc_kcontrol_component(kcontrol);
1088	int value = ucontrol->value.integer.value[0];
1089	struct soc_enum *e = (struct soc_enum *)kcontrol->private_value;
1090	int path = e->shift_l;
1091	struct tx_macro *tx = snd_soc_component_get_drvdata(component);
1092
1093	if (tx->dec_mode[path] == value)
1094		return 0;
1095
1096	tx->dec_mode[path] = value;
1097
1098	return 1;
1099}
1100
1101static int tx_macro_get_bcs(struct snd_kcontrol *kcontrol,
1102			    struct snd_ctl_elem_value *ucontrol)
1103{
1104	struct snd_soc_component *component = snd_soc_kcontrol_component(kcontrol);
1105	struct tx_macro *tx = snd_soc_component_get_drvdata(component);
1106
1107	ucontrol->value.integer.value[0] = tx->bcs_enable;
1108
1109	return 0;
1110}
1111
1112static int tx_macro_set_bcs(struct snd_kcontrol *kcontrol,
1113			    struct snd_ctl_elem_value *ucontrol)
1114{
1115	struct snd_soc_component *component = snd_soc_kcontrol_component(kcontrol);
1116	int value = ucontrol->value.integer.value[0];
1117	struct tx_macro *tx = snd_soc_component_get_drvdata(component);
1118
1119	tx->bcs_enable = value;
1120
1121	return 0;
1122}
1123
1124static int tx_macro_hw_params(struct snd_pcm_substream *substream,
1125			      struct snd_pcm_hw_params *params,
1126			      struct snd_soc_dai *dai)
1127{
1128	struct snd_soc_component *component = dai->component;
1129	u32 sample_rate;
1130	u8 decimator;
1131	int tx_fs_rate;
1132	struct tx_macro *tx = snd_soc_component_get_drvdata(component);
1133
1134	sample_rate = params_rate(params);
1135	switch (sample_rate) {
1136	case 8000:
1137		tx_fs_rate = 0;
1138		break;
1139	case 16000:
1140		tx_fs_rate = 1;
1141		break;
1142	case 32000:
1143		tx_fs_rate = 3;
1144		break;
1145	case 48000:
1146		tx_fs_rate = 4;
1147		break;
1148	case 96000:
1149		tx_fs_rate = 5;
1150		break;
1151	case 192000:
1152		tx_fs_rate = 6;
1153		break;
1154	case 384000:
1155		tx_fs_rate = 7;
1156		break;
1157	default:
1158		dev_err(component->dev, "%s: Invalid TX sample rate: %d\n",
1159			__func__, params_rate(params));
1160		return -EINVAL;
1161	}
1162
1163	for_each_set_bit(decimator, &tx->active_ch_mask[dai->id], TX_MACRO_DEC_MAX)
1164		snd_soc_component_update_bits(component, CDC_TXn_TX_PATH_CTL(decimator),
1165					      CDC_TXn_PCM_RATE_MASK,
1166					      tx_fs_rate);
1167	return 0;
1168}
1169
1170static int tx_macro_get_channel_map(struct snd_soc_dai *dai,
1171				    unsigned int *tx_num, unsigned int *tx_slot,
1172				    unsigned int *rx_num, unsigned int *rx_slot)
1173{
1174	struct snd_soc_component *component = dai->component;
1175	struct tx_macro *tx = snd_soc_component_get_drvdata(component);
1176
1177	switch (dai->id) {
1178	case TX_MACRO_AIF1_CAP:
1179	case TX_MACRO_AIF2_CAP:
1180	case TX_MACRO_AIF3_CAP:
1181		*tx_slot = tx->active_ch_mask[dai->id];
1182		*tx_num = tx->active_ch_cnt[dai->id];
1183		break;
1184	default:
1185		break;
1186	}
1187	return 0;
1188}
1189
1190static int tx_macro_digital_mute(struct snd_soc_dai *dai, int mute, int stream)
1191{
1192	struct snd_soc_component *component = dai->component;
1193	struct tx_macro *tx = snd_soc_component_get_drvdata(component);
1194	u8 decimator;
1195
1196	/* active decimator not set yet */
1197	if (tx->active_decimator[dai->id] == -1)
1198		return 0;
1199
1200	decimator = tx->active_decimator[dai->id];
1201
1202	if (mute)
1203		snd_soc_component_write_field(component,
1204					      CDC_TXn_TX_PATH_CTL(decimator),
1205					      CDC_TXn_PGA_MUTE_MASK, 0x1);
1206	else
1207		snd_soc_component_update_bits(component,
1208					      CDC_TXn_TX_PATH_CTL(decimator),
1209					      CDC_TXn_PGA_MUTE_MASK, 0x0);
1210
1211	return 0;
1212}
1213
1214static const struct snd_soc_dai_ops tx_macro_dai_ops = {
1215	.hw_params = tx_macro_hw_params,
1216	.get_channel_map = tx_macro_get_channel_map,
1217	.mute_stream = tx_macro_digital_mute,
1218};
1219
1220static struct snd_soc_dai_driver tx_macro_dai[] = {
1221	{
1222		.name = "tx_macro_tx1",
1223		.id = TX_MACRO_AIF1_CAP,
1224		.capture = {
1225			.stream_name = "TX_AIF1 Capture",
1226			.rates = TX_MACRO_RATES,
1227			.formats = TX_MACRO_FORMATS,
1228			.rate_max = 192000,
1229			.rate_min = 8000,
1230			.channels_min = 1,
1231			.channels_max = 8,
1232		},
1233		.ops = &tx_macro_dai_ops,
1234	},
1235	{
1236		.name = "tx_macro_tx2",
1237		.id = TX_MACRO_AIF2_CAP,
1238		.capture = {
1239			.stream_name = "TX_AIF2 Capture",
1240			.rates = TX_MACRO_RATES,
1241			.formats = TX_MACRO_FORMATS,
1242			.rate_max = 192000,
1243			.rate_min = 8000,
1244			.channels_min = 1,
1245			.channels_max = 8,
1246		},
1247		.ops = &tx_macro_dai_ops,
1248	},
1249	{
1250		.name = "tx_macro_tx3",
1251		.id = TX_MACRO_AIF3_CAP,
1252		.capture = {
1253			.stream_name = "TX_AIF3 Capture",
1254			.rates = TX_MACRO_RATES,
1255			.formats = TX_MACRO_FORMATS,
1256			.rate_max = 192000,
1257			.rate_min = 8000,
1258			.channels_min = 1,
1259			.channels_max = 8,
1260		},
1261		.ops = &tx_macro_dai_ops,
1262	},
1263};
1264
1265static const char * const adc_mux_text[] = {
1266	"MSM_DMIC", "SWR_MIC", "ANC_FB_TUNE1"
1267};
1268
1269static SOC_ENUM_SINGLE_DECL(tx_dec0_enum, CDC_TX_INP_MUX_ADC_MUX0_CFG1,
1270		   0, adc_mux_text);
1271static SOC_ENUM_SINGLE_DECL(tx_dec1_enum, CDC_TX_INP_MUX_ADC_MUX1_CFG1,
1272		   0, adc_mux_text);
1273static SOC_ENUM_SINGLE_DECL(tx_dec2_enum, CDC_TX_INP_MUX_ADC_MUX2_CFG1,
1274		   0, adc_mux_text);
1275static SOC_ENUM_SINGLE_DECL(tx_dec3_enum, CDC_TX_INP_MUX_ADC_MUX3_CFG1,
1276		   0, adc_mux_text);
1277static SOC_ENUM_SINGLE_DECL(tx_dec4_enum, CDC_TX_INP_MUX_ADC_MUX4_CFG1,
1278		   0, adc_mux_text);
1279static SOC_ENUM_SINGLE_DECL(tx_dec5_enum, CDC_TX_INP_MUX_ADC_MUX5_CFG1,
1280		   0, adc_mux_text);
1281static SOC_ENUM_SINGLE_DECL(tx_dec6_enum, CDC_TX_INP_MUX_ADC_MUX6_CFG1,
1282		   0, adc_mux_text);
1283static SOC_ENUM_SINGLE_DECL(tx_dec7_enum, CDC_TX_INP_MUX_ADC_MUX7_CFG1,
1284		   0, adc_mux_text);
1285
1286static const struct snd_kcontrol_new tx_dec0_mux = SOC_DAPM_ENUM("tx_dec0", tx_dec0_enum);
1287static const struct snd_kcontrol_new tx_dec1_mux = SOC_DAPM_ENUM("tx_dec1", tx_dec1_enum);
1288static const struct snd_kcontrol_new tx_dec2_mux = SOC_DAPM_ENUM("tx_dec2", tx_dec2_enum);
1289static const struct snd_kcontrol_new tx_dec3_mux = SOC_DAPM_ENUM("tx_dec3", tx_dec3_enum);
1290static const struct snd_kcontrol_new tx_dec4_mux = SOC_DAPM_ENUM("tx_dec4", tx_dec4_enum);
1291static const struct snd_kcontrol_new tx_dec5_mux = SOC_DAPM_ENUM("tx_dec5", tx_dec5_enum);
1292static const struct snd_kcontrol_new tx_dec6_mux = SOC_DAPM_ENUM("tx_dec6", tx_dec6_enum);
1293static const struct snd_kcontrol_new tx_dec7_mux = SOC_DAPM_ENUM("tx_dec7", tx_dec7_enum);
1294
1295static const char * const dmic_mux_text[] = {
1296	"ZERO", "DMIC0", "DMIC1", "DMIC2", "DMIC3",
1297	"DMIC4", "DMIC5", "DMIC6", "DMIC7"
1298};
1299
1300static SOC_ENUM_SINGLE_DECL(tx_dmic0_enum, CDC_TX_INP_MUX_ADC_MUX0_CFG0,
1301			4, dmic_mux_text);
1302
1303static SOC_ENUM_SINGLE_DECL(tx_dmic1_enum, CDC_TX_INP_MUX_ADC_MUX1_CFG0,
1304			4, dmic_mux_text);
1305
1306static SOC_ENUM_SINGLE_DECL(tx_dmic2_enum, CDC_TX_INP_MUX_ADC_MUX2_CFG0,
1307			4, dmic_mux_text);
1308
1309static SOC_ENUM_SINGLE_DECL(tx_dmic3_enum, CDC_TX_INP_MUX_ADC_MUX3_CFG0,
1310			4, dmic_mux_text);
1311
1312static SOC_ENUM_SINGLE_DECL(tx_dmic4_enum, CDC_TX_INP_MUX_ADC_MUX4_CFG0,
1313			4, dmic_mux_text);
1314
1315static SOC_ENUM_SINGLE_DECL(tx_dmic5_enum, CDC_TX_INP_MUX_ADC_MUX5_CFG0,
1316			4, dmic_mux_text);
1317
1318static SOC_ENUM_SINGLE_DECL(tx_dmic6_enum, CDC_TX_INP_MUX_ADC_MUX6_CFG0,
1319			4, dmic_mux_text);
1320
1321static SOC_ENUM_SINGLE_DECL(tx_dmic7_enum, CDC_TX_INP_MUX_ADC_MUX7_CFG0,
1322			4, dmic_mux_text);
1323
1324static const struct snd_kcontrol_new tx_dmic0_mux = SOC_DAPM_ENUM_EXT("tx_dmic0", tx_dmic0_enum,
1325			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1326static const struct snd_kcontrol_new tx_dmic1_mux = SOC_DAPM_ENUM_EXT("tx_dmic1", tx_dmic1_enum,
1327			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1328static const struct snd_kcontrol_new tx_dmic2_mux = SOC_DAPM_ENUM_EXT("tx_dmic2", tx_dmic2_enum,
1329			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1330static const struct snd_kcontrol_new tx_dmic3_mux = SOC_DAPM_ENUM_EXT("tx_dmic3", tx_dmic3_enum,
1331			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1332static const struct snd_kcontrol_new tx_dmic4_mux = SOC_DAPM_ENUM_EXT("tx_dmic4", tx_dmic4_enum,
1333			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1334static const struct snd_kcontrol_new tx_dmic5_mux = SOC_DAPM_ENUM_EXT("tx_dmic5", tx_dmic5_enum,
1335			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1336static const struct snd_kcontrol_new tx_dmic6_mux = SOC_DAPM_ENUM_EXT("tx_dmic6", tx_dmic6_enum,
1337			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1338static const struct snd_kcontrol_new tx_dmic7_mux = SOC_DAPM_ENUM_EXT("tx_dmic7", tx_dmic7_enum,
1339			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1340
1341static const char * const dec_mode_mux_text[] = {
1342	"ADC_DEFAULT", "ADC_LOW_PWR", "ADC_HIGH_PERF",
1343};
1344
1345static const struct soc_enum dec_mode_mux_enum[] = {
1346	SOC_ENUM_SINGLE(SND_SOC_NOPM, 0, ARRAY_SIZE(dec_mode_mux_text),
1347			dec_mode_mux_text),
1348	SOC_ENUM_SINGLE(SND_SOC_NOPM, 1, ARRAY_SIZE(dec_mode_mux_text),
1349			dec_mode_mux_text),
1350	SOC_ENUM_SINGLE(SND_SOC_NOPM, 2,  ARRAY_SIZE(dec_mode_mux_text),
1351			dec_mode_mux_text),
1352	SOC_ENUM_SINGLE(SND_SOC_NOPM, 3, ARRAY_SIZE(dec_mode_mux_text),
1353			dec_mode_mux_text),
1354	SOC_ENUM_SINGLE(SND_SOC_NOPM, 4, ARRAY_SIZE(dec_mode_mux_text),
1355			dec_mode_mux_text),
1356	SOC_ENUM_SINGLE(SND_SOC_NOPM, 5, ARRAY_SIZE(dec_mode_mux_text),
1357			dec_mode_mux_text),
1358	SOC_ENUM_SINGLE(SND_SOC_NOPM, 6, ARRAY_SIZE(dec_mode_mux_text),
1359			dec_mode_mux_text),
1360	SOC_ENUM_SINGLE(SND_SOC_NOPM, 7, ARRAY_SIZE(dec_mode_mux_text),
1361			dec_mode_mux_text),
1362};
1363
1364static const struct snd_kcontrol_new tx_aif1_cap_mixer[] = {
1365	SOC_SINGLE_EXT("DEC0", SND_SOC_NOPM, TX_MACRO_DEC0, 1, 0,
1366			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1367	SOC_SINGLE_EXT("DEC1", SND_SOC_NOPM, TX_MACRO_DEC1, 1, 0,
1368			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1369	SOC_SINGLE_EXT("DEC2", SND_SOC_NOPM, TX_MACRO_DEC2, 1, 0,
1370			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1371	SOC_SINGLE_EXT("DEC3", SND_SOC_NOPM, TX_MACRO_DEC3, 1, 0,
1372			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1373	SOC_SINGLE_EXT("DEC4", SND_SOC_NOPM, TX_MACRO_DEC4, 1, 0,
1374			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1375	SOC_SINGLE_EXT("DEC5", SND_SOC_NOPM, TX_MACRO_DEC5, 1, 0,
1376			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1377	SOC_SINGLE_EXT("DEC6", SND_SOC_NOPM, TX_MACRO_DEC6, 1, 0,
1378			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1379	SOC_SINGLE_EXT("DEC7", SND_SOC_NOPM, TX_MACRO_DEC7, 1, 0,
1380			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1381};
1382
1383static const struct snd_kcontrol_new tx_aif2_cap_mixer[] = {
1384	SOC_SINGLE_EXT("DEC0", SND_SOC_NOPM, TX_MACRO_DEC0, 1, 0,
1385			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1386	SOC_SINGLE_EXT("DEC1", SND_SOC_NOPM, TX_MACRO_DEC1, 1, 0,
1387			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1388	SOC_SINGLE_EXT("DEC2", SND_SOC_NOPM, TX_MACRO_DEC2, 1, 0,
1389			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1390	SOC_SINGLE_EXT("DEC3", SND_SOC_NOPM, TX_MACRO_DEC3, 1, 0,
1391			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1392	SOC_SINGLE_EXT("DEC4", SND_SOC_NOPM, TX_MACRO_DEC4, 1, 0,
1393			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1394	SOC_SINGLE_EXT("DEC5", SND_SOC_NOPM, TX_MACRO_DEC5, 1, 0,
1395			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1396	SOC_SINGLE_EXT("DEC6", SND_SOC_NOPM, TX_MACRO_DEC6, 1, 0,
1397			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1398	SOC_SINGLE_EXT("DEC7", SND_SOC_NOPM, TX_MACRO_DEC7, 1, 0,
1399			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1400};
1401
1402static const struct snd_kcontrol_new tx_aif3_cap_mixer[] = {
1403	SOC_SINGLE_EXT("DEC0", SND_SOC_NOPM, TX_MACRO_DEC0, 1, 0,
1404			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1405	SOC_SINGLE_EXT("DEC1", SND_SOC_NOPM, TX_MACRO_DEC1, 1, 0,
1406			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1407	SOC_SINGLE_EXT("DEC2", SND_SOC_NOPM, TX_MACRO_DEC2, 1, 0,
1408			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1409	SOC_SINGLE_EXT("DEC3", SND_SOC_NOPM, TX_MACRO_DEC3, 1, 0,
1410			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1411	SOC_SINGLE_EXT("DEC4", SND_SOC_NOPM, TX_MACRO_DEC4, 1, 0,
1412			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1413	SOC_SINGLE_EXT("DEC5", SND_SOC_NOPM, TX_MACRO_DEC5, 1, 0,
1414			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1415	SOC_SINGLE_EXT("DEC6", SND_SOC_NOPM, TX_MACRO_DEC6, 1, 0,
1416			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1417	SOC_SINGLE_EXT("DEC7", SND_SOC_NOPM, TX_MACRO_DEC7, 1, 0,
1418			tx_macro_tx_mixer_get, tx_macro_tx_mixer_put),
1419};
1420
1421static const struct snd_soc_dapm_widget tx_macro_dapm_widgets[] = {
1422	SND_SOC_DAPM_AIF_OUT("TX_AIF1 CAP", "TX_AIF1 Capture", 0,
1423		SND_SOC_NOPM, TX_MACRO_AIF1_CAP, 0),
1424
1425	SND_SOC_DAPM_AIF_OUT("TX_AIF2 CAP", "TX_AIF2 Capture", 0,
1426		SND_SOC_NOPM, TX_MACRO_AIF2_CAP, 0),
1427
1428	SND_SOC_DAPM_AIF_OUT("TX_AIF3 CAP", "TX_AIF3 Capture", 0,
1429		SND_SOC_NOPM, TX_MACRO_AIF3_CAP, 0),
1430
1431	SND_SOC_DAPM_MIXER("TX_AIF1_CAP Mixer", SND_SOC_NOPM, TX_MACRO_AIF1_CAP, 0,
1432		tx_aif1_cap_mixer, ARRAY_SIZE(tx_aif1_cap_mixer)),
1433
1434	SND_SOC_DAPM_MIXER("TX_AIF2_CAP Mixer", SND_SOC_NOPM, TX_MACRO_AIF2_CAP, 0,
1435		tx_aif2_cap_mixer, ARRAY_SIZE(tx_aif2_cap_mixer)),
1436
1437	SND_SOC_DAPM_MIXER("TX_AIF3_CAP Mixer", SND_SOC_NOPM, TX_MACRO_AIF3_CAP, 0,
1438		tx_aif3_cap_mixer, ARRAY_SIZE(tx_aif3_cap_mixer)),
1439
1440	SND_SOC_DAPM_MUX("TX DMIC MUX0", SND_SOC_NOPM, 4, 0, &tx_dmic0_mux),
1441	SND_SOC_DAPM_MUX("TX DMIC MUX1", SND_SOC_NOPM, 4, 0, &tx_dmic1_mux),
1442	SND_SOC_DAPM_MUX("TX DMIC MUX2", SND_SOC_NOPM, 4, 0, &tx_dmic2_mux),
1443	SND_SOC_DAPM_MUX("TX DMIC MUX3", SND_SOC_NOPM, 4, 0, &tx_dmic3_mux),
1444	SND_SOC_DAPM_MUX("TX DMIC MUX4", SND_SOC_NOPM, 4, 0, &tx_dmic4_mux),
1445	SND_SOC_DAPM_MUX("TX DMIC MUX5", SND_SOC_NOPM, 4, 0, &tx_dmic5_mux),
1446	SND_SOC_DAPM_MUX("TX DMIC MUX6", SND_SOC_NOPM, 4, 0, &tx_dmic6_mux),
1447	SND_SOC_DAPM_MUX("TX DMIC MUX7", SND_SOC_NOPM, 4, 0, &tx_dmic7_mux),
1448
1449	SND_SOC_DAPM_INPUT("TX DMIC0"),
1450	SND_SOC_DAPM_INPUT("TX DMIC1"),
1451	SND_SOC_DAPM_INPUT("TX DMIC2"),
1452	SND_SOC_DAPM_INPUT("TX DMIC3"),
1453	SND_SOC_DAPM_INPUT("TX DMIC4"),
1454	SND_SOC_DAPM_INPUT("TX DMIC5"),
1455	SND_SOC_DAPM_INPUT("TX DMIC6"),
1456	SND_SOC_DAPM_INPUT("TX DMIC7"),
1457
1458	SND_SOC_DAPM_MUX_E("TX DEC0 MUX", SND_SOC_NOPM,
1459			   TX_MACRO_DEC0, 0,
1460			   &tx_dec0_mux, tx_macro_enable_dec,
1461			   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU |
1462			   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD),
1463
1464	SND_SOC_DAPM_MUX_E("TX DEC1 MUX", SND_SOC_NOPM,
1465			   TX_MACRO_DEC1, 0,
1466			   &tx_dec1_mux, tx_macro_enable_dec,
1467			   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU |
1468			   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD),
1469
1470	SND_SOC_DAPM_MUX_E("TX DEC2 MUX", SND_SOC_NOPM,
1471			   TX_MACRO_DEC2, 0,
1472			   &tx_dec2_mux, tx_macro_enable_dec,
1473			   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU |
1474			   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD),
1475
1476	SND_SOC_DAPM_MUX_E("TX DEC3 MUX", SND_SOC_NOPM,
1477			   TX_MACRO_DEC3, 0,
1478			   &tx_dec3_mux, tx_macro_enable_dec,
1479			   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU |
1480			   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD),
1481
1482	SND_SOC_DAPM_MUX_E("TX DEC4 MUX", SND_SOC_NOPM,
1483			   TX_MACRO_DEC4, 0,
1484			   &tx_dec4_mux, tx_macro_enable_dec,
1485			   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU |
1486			   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD),
1487
1488	SND_SOC_DAPM_MUX_E("TX DEC5 MUX", SND_SOC_NOPM,
1489			   TX_MACRO_DEC5, 0,
1490			   &tx_dec5_mux, tx_macro_enable_dec,
1491			   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU |
1492			   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD),
1493
1494	SND_SOC_DAPM_MUX_E("TX DEC6 MUX", SND_SOC_NOPM,
1495			   TX_MACRO_DEC6, 0,
1496			   &tx_dec6_mux, tx_macro_enable_dec,
1497			   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU |
1498			   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD),
1499
1500	SND_SOC_DAPM_MUX_E("TX DEC7 MUX", SND_SOC_NOPM,
1501			   TX_MACRO_DEC7, 0,
1502			   &tx_dec7_mux, tx_macro_enable_dec,
1503			   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU |
1504			   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD),
1505
1506	SND_SOC_DAPM_SUPPLY_S("TX_MCLK", 0, SND_SOC_NOPM, 0, 0,
1507	tx_macro_mclk_event, SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
1508
1509	SND_SOC_DAPM_SUPPLY_S("TX_SWR_CLK", 0, SND_SOC_NOPM, 0, 0, NULL, 0),
1510
1511	SND_SOC_DAPM_SUPPLY_S("VA_SWR_CLK", 0, SND_SOC_NOPM, 0, 0,
1512			NULL, 0),
1513};
1514
1515static const struct snd_soc_dapm_route tx_audio_map[] = {
1516	{"TX_AIF1 CAP", NULL, "TX_MCLK"},
1517	{"TX_AIF2 CAP", NULL, "TX_MCLK"},
1518	{"TX_AIF3 CAP", NULL, "TX_MCLK"},
1519
1520	{"TX_AIF1 CAP", NULL, "TX_AIF1_CAP Mixer"},
1521	{"TX_AIF2 CAP", NULL, "TX_AIF2_CAP Mixer"},
1522	{"TX_AIF3 CAP", NULL, "TX_AIF3_CAP Mixer"},
1523
1524	{"TX_AIF1_CAP Mixer", "DEC0", "TX DEC0 MUX"},
1525	{"TX_AIF1_CAP Mixer", "DEC1", "TX DEC1 MUX"},
1526	{"TX_AIF1_CAP Mixer", "DEC2", "TX DEC2 MUX"},
1527	{"TX_AIF1_CAP Mixer", "DEC3", "TX DEC3 MUX"},
1528	{"TX_AIF1_CAP Mixer", "DEC4", "TX DEC4 MUX"},
1529	{"TX_AIF1_CAP Mixer", "DEC5", "TX DEC5 MUX"},
1530	{"TX_AIF1_CAP Mixer", "DEC6", "TX DEC6 MUX"},
1531	{"TX_AIF1_CAP Mixer", "DEC7", "TX DEC7 MUX"},
1532
1533	{"TX_AIF2_CAP Mixer", "DEC0", "TX DEC0 MUX"},
1534	{"TX_AIF2_CAP Mixer", "DEC1", "TX DEC1 MUX"},
1535	{"TX_AIF2_CAP Mixer", "DEC2", "TX DEC2 MUX"},
1536	{"TX_AIF2_CAP Mixer", "DEC3", "TX DEC3 MUX"},
1537	{"TX_AIF2_CAP Mixer", "DEC4", "TX DEC4 MUX"},
1538	{"TX_AIF2_CAP Mixer", "DEC5", "TX DEC5 MUX"},
1539	{"TX_AIF2_CAP Mixer", "DEC6", "TX DEC6 MUX"},
1540	{"TX_AIF2_CAP Mixer", "DEC7", "TX DEC7 MUX"},
1541
1542	{"TX_AIF3_CAP Mixer", "DEC0", "TX DEC0 MUX"},
1543	{"TX_AIF3_CAP Mixer", "DEC1", "TX DEC1 MUX"},
1544	{"TX_AIF3_CAP Mixer", "DEC2", "TX DEC2 MUX"},
1545	{"TX_AIF3_CAP Mixer", "DEC3", "TX DEC3 MUX"},
1546	{"TX_AIF3_CAP Mixer", "DEC4", "TX DEC4 MUX"},
1547	{"TX_AIF3_CAP Mixer", "DEC5", "TX DEC5 MUX"},
1548	{"TX_AIF3_CAP Mixer", "DEC6", "TX DEC6 MUX"},
1549	{"TX_AIF3_CAP Mixer", "DEC7", "TX DEC7 MUX"},
1550
1551	{"TX DEC0 MUX", NULL, "TX_MCLK"},
1552	{"TX DEC1 MUX", NULL, "TX_MCLK"},
1553	{"TX DEC2 MUX", NULL, "TX_MCLK"},
1554	{"TX DEC3 MUX", NULL, "TX_MCLK"},
1555	{"TX DEC4 MUX", NULL, "TX_MCLK"},
1556	{"TX DEC5 MUX", NULL, "TX_MCLK"},
1557	{"TX DEC6 MUX", NULL, "TX_MCLK"},
1558	{"TX DEC7 MUX", NULL, "TX_MCLK"},
1559
1560	{"TX DEC0 MUX", "MSM_DMIC", "TX DMIC MUX0"},
1561	{"TX DMIC MUX0", "DMIC0", "TX DMIC0"},
1562	{"TX DMIC MUX0", "DMIC1", "TX DMIC1"},
1563	{"TX DMIC MUX0", "DMIC2", "TX DMIC2"},
1564	{"TX DMIC MUX0", "DMIC3", "TX DMIC3"},
1565	{"TX DMIC MUX0", "DMIC4", "TX DMIC4"},
1566	{"TX DMIC MUX0", "DMIC5", "TX DMIC5"},
1567	{"TX DMIC MUX0", "DMIC6", "TX DMIC6"},
1568	{"TX DMIC MUX0", "DMIC7", "TX DMIC7"},
1569
1570	{"TX DEC1 MUX", "MSM_DMIC", "TX DMIC MUX1"},
1571	{"TX DMIC MUX1", "DMIC0", "TX DMIC0"},
1572	{"TX DMIC MUX1", "DMIC1", "TX DMIC1"},
1573	{"TX DMIC MUX1", "DMIC2", "TX DMIC2"},
1574	{"TX DMIC MUX1", "DMIC3", "TX DMIC3"},
1575	{"TX DMIC MUX1", "DMIC4", "TX DMIC4"},
1576	{"TX DMIC MUX1", "DMIC5", "TX DMIC5"},
1577	{"TX DMIC MUX1", "DMIC6", "TX DMIC6"},
1578	{"TX DMIC MUX1", "DMIC7", "TX DMIC7"},
1579
1580	{"TX DEC2 MUX", "MSM_DMIC", "TX DMIC MUX2"},
1581	{"TX DMIC MUX2", "DMIC0", "TX DMIC0"},
1582	{"TX DMIC MUX2", "DMIC1", "TX DMIC1"},
1583	{"TX DMIC MUX2", "DMIC2", "TX DMIC2"},
1584	{"TX DMIC MUX2", "DMIC3", "TX DMIC3"},
1585	{"TX DMIC MUX2", "DMIC4", "TX DMIC4"},
1586	{"TX DMIC MUX2", "DMIC5", "TX DMIC5"},
1587	{"TX DMIC MUX2", "DMIC6", "TX DMIC6"},
1588	{"TX DMIC MUX2", "DMIC7", "TX DMIC7"},
1589
1590	{"TX DEC3 MUX", "MSM_DMIC", "TX DMIC MUX3"},
1591	{"TX DMIC MUX3", "DMIC0", "TX DMIC0"},
1592	{"TX DMIC MUX3", "DMIC1", "TX DMIC1"},
1593	{"TX DMIC MUX3", "DMIC2", "TX DMIC2"},
1594	{"TX DMIC MUX3", "DMIC3", "TX DMIC3"},
1595	{"TX DMIC MUX3", "DMIC4", "TX DMIC4"},
1596	{"TX DMIC MUX3", "DMIC5", "TX DMIC5"},
1597	{"TX DMIC MUX3", "DMIC6", "TX DMIC6"},
1598	{"TX DMIC MUX3", "DMIC7", "TX DMIC7"},
1599
1600	{"TX DEC4 MUX", "MSM_DMIC", "TX DMIC MUX4"},
1601	{"TX DMIC MUX4", "DMIC0", "TX DMIC0"},
1602	{"TX DMIC MUX4", "DMIC1", "TX DMIC1"},
1603	{"TX DMIC MUX4", "DMIC2", "TX DMIC2"},
1604	{"TX DMIC MUX4", "DMIC3", "TX DMIC3"},
1605	{"TX DMIC MUX4", "DMIC4", "TX DMIC4"},
1606	{"TX DMIC MUX4", "DMIC5", "TX DMIC5"},
1607	{"TX DMIC MUX4", "DMIC6", "TX DMIC6"},
1608	{"TX DMIC MUX4", "DMIC7", "TX DMIC7"},
1609
1610	{"TX DEC5 MUX", "MSM_DMIC", "TX DMIC MUX5"},
1611	{"TX DMIC MUX5", "DMIC0", "TX DMIC0"},
1612	{"TX DMIC MUX5", "DMIC1", "TX DMIC1"},
1613	{"TX DMIC MUX5", "DMIC2", "TX DMIC2"},
1614	{"TX DMIC MUX5", "DMIC3", "TX DMIC3"},
1615	{"TX DMIC MUX5", "DMIC4", "TX DMIC4"},
1616	{"TX DMIC MUX5", "DMIC5", "TX DMIC5"},
1617	{"TX DMIC MUX5", "DMIC6", "TX DMIC6"},
1618	{"TX DMIC MUX5", "DMIC7", "TX DMIC7"},
1619
1620	{"TX DEC6 MUX", "MSM_DMIC", "TX DMIC MUX6"},
1621	{"TX DMIC MUX6", "DMIC0", "TX DMIC0"},
1622	{"TX DMIC MUX6", "DMIC1", "TX DMIC1"},
1623	{"TX DMIC MUX6", "DMIC2", "TX DMIC2"},
1624	{"TX DMIC MUX6", "DMIC3", "TX DMIC3"},
1625	{"TX DMIC MUX6", "DMIC4", "TX DMIC4"},
1626	{"TX DMIC MUX6", "DMIC5", "TX DMIC5"},
1627	{"TX DMIC MUX6", "DMIC6", "TX DMIC6"},
1628	{"TX DMIC MUX6", "DMIC7", "TX DMIC7"},
1629
1630	{"TX DEC7 MUX", "MSM_DMIC", "TX DMIC MUX7"},
1631	{"TX DMIC MUX7", "DMIC0", "TX DMIC0"},
1632	{"TX DMIC MUX7", "DMIC1", "TX DMIC1"},
1633	{"TX DMIC MUX7", "DMIC2", "TX DMIC2"},
1634	{"TX DMIC MUX7", "DMIC3", "TX DMIC3"},
1635	{"TX DMIC MUX7", "DMIC4", "TX DMIC4"},
1636	{"TX DMIC MUX7", "DMIC5", "TX DMIC5"},
1637	{"TX DMIC MUX7", "DMIC6", "TX DMIC6"},
1638	{"TX DMIC MUX7", "DMIC7", "TX DMIC7"},
1639};
1640
1641/* Controls and routes specific to LPASS <= v9.0.0 */
1642static const char * const smic_mux_text_v9[] = {
1643	"ZERO", "ADC0", "ADC1", "ADC2", "ADC3", "SWR_DMIC0",
1644	"SWR_DMIC1", "SWR_DMIC2", "SWR_DMIC3", "SWR_DMIC4",
1645	"SWR_DMIC5", "SWR_DMIC6", "SWR_DMIC7"
1646};
1647
1648static SOC_ENUM_SINGLE_DECL(tx_smic0_enum_v9, CDC_TX_INP_MUX_ADC_MUX0_CFG0,
1649			0, smic_mux_text_v9);
1650
1651static SOC_ENUM_SINGLE_DECL(tx_smic1_enum_v9, CDC_TX_INP_MUX_ADC_MUX1_CFG0,
1652			0, smic_mux_text_v9);
1653
1654static SOC_ENUM_SINGLE_DECL(tx_smic2_enum_v9, CDC_TX_INP_MUX_ADC_MUX2_CFG0,
1655			0, smic_mux_text_v9);
1656
1657static SOC_ENUM_SINGLE_DECL(tx_smic3_enum_v9, CDC_TX_INP_MUX_ADC_MUX3_CFG0,
1658			0, smic_mux_text_v9);
1659
1660static SOC_ENUM_SINGLE_DECL(tx_smic4_enum_v9, CDC_TX_INP_MUX_ADC_MUX4_CFG0,
1661			0, smic_mux_text_v9);
1662
1663static SOC_ENUM_SINGLE_DECL(tx_smic5_enum_v9, CDC_TX_INP_MUX_ADC_MUX5_CFG0,
1664			0, smic_mux_text_v9);
1665
1666static SOC_ENUM_SINGLE_DECL(tx_smic6_enum_v9, CDC_TX_INP_MUX_ADC_MUX6_CFG0,
1667			0, smic_mux_text_v9);
1668
1669static SOC_ENUM_SINGLE_DECL(tx_smic7_enum_v9, CDC_TX_INP_MUX_ADC_MUX7_CFG0,
1670			0, smic_mux_text_v9);
1671
1672static const struct snd_kcontrol_new tx_smic0_mux_v9 = SOC_DAPM_ENUM_EXT("tx_smic0", tx_smic0_enum_v9,
1673			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1674static const struct snd_kcontrol_new tx_smic1_mux_v9 = SOC_DAPM_ENUM_EXT("tx_smic1", tx_smic1_enum_v9,
1675			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1676static const struct snd_kcontrol_new tx_smic2_mux_v9 = SOC_DAPM_ENUM_EXT("tx_smic2", tx_smic2_enum_v9,
1677			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1678static const struct snd_kcontrol_new tx_smic3_mux_v9 = SOC_DAPM_ENUM_EXT("tx_smic3", tx_smic3_enum_v9,
1679			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1680static const struct snd_kcontrol_new tx_smic4_mux_v9 = SOC_DAPM_ENUM_EXT("tx_smic4", tx_smic4_enum_v9,
1681			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1682static const struct snd_kcontrol_new tx_smic5_mux_v9 = SOC_DAPM_ENUM_EXT("tx_smic5", tx_smic5_enum_v9,
1683			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1684static const struct snd_kcontrol_new tx_smic6_mux_v9 = SOC_DAPM_ENUM_EXT("tx_smic6", tx_smic6_enum_v9,
1685			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1686static const struct snd_kcontrol_new tx_smic7_mux_v9 = SOC_DAPM_ENUM_EXT("tx_smic7", tx_smic7_enum_v9,
1687			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1688
1689static const struct snd_soc_dapm_widget tx_macro_dapm_widgets_v9[] = {
1690	SND_SOC_DAPM_MUX("TX SMIC MUX0", SND_SOC_NOPM, 0, 0, &tx_smic0_mux_v9),
1691	SND_SOC_DAPM_MUX("TX SMIC MUX1", SND_SOC_NOPM, 0, 0, &tx_smic1_mux_v9),
1692	SND_SOC_DAPM_MUX("TX SMIC MUX2", SND_SOC_NOPM, 0, 0, &tx_smic2_mux_v9),
1693	SND_SOC_DAPM_MUX("TX SMIC MUX3", SND_SOC_NOPM, 0, 0, &tx_smic3_mux_v9),
1694	SND_SOC_DAPM_MUX("TX SMIC MUX4", SND_SOC_NOPM, 0, 0, &tx_smic4_mux_v9),
1695	SND_SOC_DAPM_MUX("TX SMIC MUX5", SND_SOC_NOPM, 0, 0, &tx_smic5_mux_v9),
1696	SND_SOC_DAPM_MUX("TX SMIC MUX6", SND_SOC_NOPM, 0, 0, &tx_smic6_mux_v9),
1697	SND_SOC_DAPM_MUX("TX SMIC MUX7", SND_SOC_NOPM, 0, 0, &tx_smic7_mux_v9),
1698
1699	SND_SOC_DAPM_INPUT("TX SWR_ADC0"),
1700	SND_SOC_DAPM_INPUT("TX SWR_ADC1"),
1701	SND_SOC_DAPM_INPUT("TX SWR_ADC2"),
1702	SND_SOC_DAPM_INPUT("TX SWR_ADC3"),
1703	SND_SOC_DAPM_INPUT("TX SWR_DMIC0"),
1704	SND_SOC_DAPM_INPUT("TX SWR_DMIC1"),
1705	SND_SOC_DAPM_INPUT("TX SWR_DMIC2"),
1706	SND_SOC_DAPM_INPUT("TX SWR_DMIC3"),
1707	SND_SOC_DAPM_INPUT("TX SWR_DMIC4"),
1708	SND_SOC_DAPM_INPUT("TX SWR_DMIC5"),
1709	SND_SOC_DAPM_INPUT("TX SWR_DMIC6"),
1710	SND_SOC_DAPM_INPUT("TX SWR_DMIC7"),
1711};
1712
1713static const struct snd_soc_dapm_route tx_audio_map_v9[] = {
1714	{"TX DEC0 MUX", "SWR_MIC", "TX SMIC MUX0"},
1715	{"TX SMIC MUX0", NULL, "TX_SWR_CLK"},
1716	{"TX SMIC MUX0", "ADC0", "TX SWR_ADC0"},
1717	{"TX SMIC MUX0", "ADC1", "TX SWR_ADC1"},
1718	{"TX SMIC MUX0", "ADC2", "TX SWR_ADC2"},
1719	{"TX SMIC MUX0", "ADC3", "TX SWR_ADC3"},
1720	{"TX SMIC MUX0", "SWR_DMIC0", "TX SWR_DMIC0"},
1721	{"TX SMIC MUX0", "SWR_DMIC1", "TX SWR_DMIC1"},
1722	{"TX SMIC MUX0", "SWR_DMIC2", "TX SWR_DMIC2"},
1723	{"TX SMIC MUX0", "SWR_DMIC3", "TX SWR_DMIC3"},
1724	{"TX SMIC MUX0", "SWR_DMIC4", "TX SWR_DMIC4"},
1725	{"TX SMIC MUX0", "SWR_DMIC5", "TX SWR_DMIC5"},
1726	{"TX SMIC MUX0", "SWR_DMIC6", "TX SWR_DMIC6"},
1727	{"TX SMIC MUX0", "SWR_DMIC7", "TX SWR_DMIC7"},
1728
1729	{"TX DEC1 MUX", "SWR_MIC", "TX SMIC MUX1"},
1730	{"TX SMIC MUX1", NULL, "TX_SWR_CLK"},
1731	{"TX SMIC MUX1", "ADC0", "TX SWR_ADC0"},
1732	{"TX SMIC MUX1", "ADC1", "TX SWR_ADC1"},
1733	{"TX SMIC MUX1", "ADC2", "TX SWR_ADC2"},
1734	{"TX SMIC MUX1", "ADC3", "TX SWR_ADC3"},
1735	{"TX SMIC MUX1", "SWR_DMIC0", "TX SWR_DMIC0"},
1736	{"TX SMIC MUX1", "SWR_DMIC1", "TX SWR_DMIC1"},
1737	{"TX SMIC MUX1", "SWR_DMIC2", "TX SWR_DMIC2"},
1738	{"TX SMIC MUX1", "SWR_DMIC3", "TX SWR_DMIC3"},
1739	{"TX SMIC MUX1", "SWR_DMIC4", "TX SWR_DMIC4"},
1740	{"TX SMIC MUX1", "SWR_DMIC5", "TX SWR_DMIC5"},
1741	{"TX SMIC MUX1", "SWR_DMIC6", "TX SWR_DMIC6"},
1742	{"TX SMIC MUX1", "SWR_DMIC7", "TX SWR_DMIC7"},
1743
1744	{"TX DEC2 MUX", "SWR_MIC", "TX SMIC MUX2"},
1745	{"TX SMIC MUX2", NULL, "TX_SWR_CLK"},
1746	{"TX SMIC MUX2", "ADC0", "TX SWR_ADC0"},
1747	{"TX SMIC MUX2", "ADC1", "TX SWR_ADC1"},
1748	{"TX SMIC MUX2", "ADC2", "TX SWR_ADC2"},
1749	{"TX SMIC MUX2", "ADC3", "TX SWR_ADC3"},
1750	{"TX SMIC MUX2", "SWR_DMIC0", "TX SWR_DMIC0"},
1751	{"TX SMIC MUX2", "SWR_DMIC1", "TX SWR_DMIC1"},
1752	{"TX SMIC MUX2", "SWR_DMIC2", "TX SWR_DMIC2"},
1753	{"TX SMIC MUX2", "SWR_DMIC3", "TX SWR_DMIC3"},
1754	{"TX SMIC MUX2", "SWR_DMIC4", "TX SWR_DMIC4"},
1755	{"TX SMIC MUX2", "SWR_DMIC5", "TX SWR_DMIC5"},
1756	{"TX SMIC MUX2", "SWR_DMIC6", "TX SWR_DMIC6"},
1757	{"TX SMIC MUX2", "SWR_DMIC7", "TX SWR_DMIC7"},
1758
1759	{"TX DEC3 MUX", "SWR_MIC", "TX SMIC MUX3"},
1760	{"TX SMIC MUX3", NULL, "TX_SWR_CLK"},
1761	{"TX SMIC MUX3", "ADC0", "TX SWR_ADC0"},
1762	{"TX SMIC MUX3", "ADC1", "TX SWR_ADC1"},
1763	{"TX SMIC MUX3", "ADC2", "TX SWR_ADC2"},
1764	{"TX SMIC MUX3", "ADC3", "TX SWR_ADC3"},
1765	{"TX SMIC MUX3", "SWR_DMIC0", "TX SWR_DMIC0"},
1766	{"TX SMIC MUX3", "SWR_DMIC1", "TX SWR_DMIC1"},
1767	{"TX SMIC MUX3", "SWR_DMIC2", "TX SWR_DMIC2"},
1768	{"TX SMIC MUX3", "SWR_DMIC3", "TX SWR_DMIC3"},
1769	{"TX SMIC MUX3", "SWR_DMIC4", "TX SWR_DMIC4"},
1770	{"TX SMIC MUX3", "SWR_DMIC5", "TX SWR_DMIC5"},
1771	{"TX SMIC MUX3", "SWR_DMIC6", "TX SWR_DMIC6"},
1772	{"TX SMIC MUX3", "SWR_DMIC7", "TX SWR_DMIC7"},
1773
1774	{"TX DEC4 MUX", "SWR_MIC", "TX SMIC MUX4"},
1775	{"TX SMIC MUX4", NULL, "TX_SWR_CLK"},
1776	{"TX SMIC MUX4", "ADC0", "TX SWR_ADC0"},
1777	{"TX SMIC MUX4", "ADC1", "TX SWR_ADC1"},
1778	{"TX SMIC MUX4", "ADC2", "TX SWR_ADC2"},
1779	{"TX SMIC MUX4", "ADC3", "TX SWR_ADC3"},
1780	{"TX SMIC MUX4", "SWR_DMIC0", "TX SWR_DMIC0"},
1781	{"TX SMIC MUX4", "SWR_DMIC1", "TX SWR_DMIC1"},
1782	{"TX SMIC MUX4", "SWR_DMIC2", "TX SWR_DMIC2"},
1783	{"TX SMIC MUX4", "SWR_DMIC3", "TX SWR_DMIC3"},
1784	{"TX SMIC MUX4", "SWR_DMIC4", "TX SWR_DMIC4"},
1785	{"TX SMIC MUX4", "SWR_DMIC5", "TX SWR_DMIC5"},
1786	{"TX SMIC MUX4", "SWR_DMIC6", "TX SWR_DMIC6"},
1787	{"TX SMIC MUX4", "SWR_DMIC7", "TX SWR_DMIC7"},
1788
1789	{"TX DEC5 MUX", "SWR_MIC", "TX SMIC MUX5"},
1790	{"TX SMIC MUX5", NULL, "TX_SWR_CLK"},
1791	{"TX SMIC MUX5", "ADC0", "TX SWR_ADC0"},
1792	{"TX SMIC MUX5", "ADC1", "TX SWR_ADC1"},
1793	{"TX SMIC MUX5", "ADC2", "TX SWR_ADC2"},
1794	{"TX SMIC MUX5", "ADC3", "TX SWR_ADC3"},
1795	{"TX SMIC MUX5", "SWR_DMIC0", "TX SWR_DMIC0"},
1796	{"TX SMIC MUX5", "SWR_DMIC1", "TX SWR_DMIC1"},
1797	{"TX SMIC MUX5", "SWR_DMIC2", "TX SWR_DMIC2"},
1798	{"TX SMIC MUX5", "SWR_DMIC3", "TX SWR_DMIC3"},
1799	{"TX SMIC MUX5", "SWR_DMIC4", "TX SWR_DMIC4"},
1800	{"TX SMIC MUX5", "SWR_DMIC5", "TX SWR_DMIC5"},
1801	{"TX SMIC MUX5", "SWR_DMIC6", "TX SWR_DMIC6"},
1802	{"TX SMIC MUX5", "SWR_DMIC7", "TX SWR_DMIC7"},
1803
1804	{"TX DEC6 MUX", "SWR_MIC", "TX SMIC MUX6"},
1805	{"TX SMIC MUX6", NULL, "TX_SWR_CLK"},
1806	{"TX SMIC MUX6", "ADC0", "TX SWR_ADC0"},
1807	{"TX SMIC MUX6", "ADC1", "TX SWR_ADC1"},
1808	{"TX SMIC MUX6", "ADC2", "TX SWR_ADC2"},
1809	{"TX SMIC MUX6", "ADC3", "TX SWR_ADC3"},
1810	{"TX SMIC MUX6", "SWR_DMIC0", "TX SWR_DMIC0"},
1811	{"TX SMIC MUX6", "SWR_DMIC1", "TX SWR_DMIC1"},
1812	{"TX SMIC MUX6", "SWR_DMIC2", "TX SWR_DMIC2"},
1813	{"TX SMIC MUX6", "SWR_DMIC3", "TX SWR_DMIC3"},
1814	{"TX SMIC MUX6", "SWR_DMIC4", "TX SWR_DMIC4"},
1815	{"TX SMIC MUX6", "SWR_DMIC5", "TX SWR_DMIC5"},
1816	{"TX SMIC MUX6", "SWR_DMIC6", "TX SWR_DMIC6"},
1817	{"TX SMIC MUX6", "SWR_DMIC7", "TX SWR_DMIC7"},
1818
1819	{"TX DEC7 MUX", "SWR_MIC", "TX SMIC MUX7"},
1820	{"TX SMIC MUX7", NULL, "TX_SWR_CLK"},
1821	{"TX SMIC MUX7", "ADC0", "TX SWR_ADC0"},
1822	{"TX SMIC MUX7", "ADC1", "TX SWR_ADC1"},
1823	{"TX SMIC MUX7", "ADC2", "TX SWR_ADC2"},
1824	{"TX SMIC MUX7", "ADC3", "TX SWR_ADC3"},
1825	{"TX SMIC MUX7", "SWR_DMIC0", "TX SWR_DMIC0"},
1826	{"TX SMIC MUX7", "SWR_DMIC1", "TX SWR_DMIC1"},
1827	{"TX SMIC MUX7", "SWR_DMIC2", "TX SWR_DMIC2"},
1828	{"TX SMIC MUX7", "SWR_DMIC3", "TX SWR_DMIC3"},
1829	{"TX SMIC MUX7", "SWR_DMIC4", "TX SWR_DMIC4"},
1830	{"TX SMIC MUX7", "SWR_DMIC5", "TX SWR_DMIC5"},
1831	{"TX SMIC MUX7", "SWR_DMIC6", "TX SWR_DMIC6"},
1832	{"TX SMIC MUX7", "SWR_DMIC7", "TX SWR_DMIC7"},
1833};
1834
1835/* Controls and routes specific to LPASS >= v9.2.0 */
1836static const char * const smic_mux_text_v9_2[] = {
1837	"ZERO", "SWR_MIC0", "SWR_MIC1", "SWR_MIC2", "SWR_MIC3",
1838	"SWR_MIC4", "SWR_MIC5", "SWR_MIC6", "SWR_MIC7",
1839	"SWR_MIC8", "SWR_MIC9", "SWR_MIC10", "SWR_MIC11"
1840};
1841
1842static SOC_ENUM_SINGLE_DECL(tx_smic0_enum_v9_2, CDC_TX_INP_MUX_ADC_MUX0_CFG0,
1843			0, smic_mux_text_v9_2);
1844
1845static SOC_ENUM_SINGLE_DECL(tx_smic1_enum_v9_2, CDC_TX_INP_MUX_ADC_MUX1_CFG0,
1846			0, smic_mux_text_v9_2);
1847
1848static SOC_ENUM_SINGLE_DECL(tx_smic2_enum_v9_2, CDC_TX_INP_MUX_ADC_MUX2_CFG0,
1849			0, smic_mux_text_v9_2);
1850
1851static SOC_ENUM_SINGLE_DECL(tx_smic3_enum_v9_2, CDC_TX_INP_MUX_ADC_MUX3_CFG0,
1852			0, smic_mux_text_v9_2);
1853
1854static SOC_ENUM_SINGLE_DECL(tx_smic4_enum_v9_2, CDC_TX_INP_MUX_ADC_MUX4_CFG0,
1855			0, smic_mux_text_v9_2);
1856
1857static SOC_ENUM_SINGLE_DECL(tx_smic5_enum_v9_2, CDC_TX_INP_MUX_ADC_MUX5_CFG0,
1858			0, smic_mux_text_v9_2);
1859
1860static SOC_ENUM_SINGLE_DECL(tx_smic6_enum_v9_2, CDC_TX_INP_MUX_ADC_MUX6_CFG0,
1861			0, smic_mux_text_v9_2);
1862
1863static SOC_ENUM_SINGLE_DECL(tx_smic7_enum_v9_2, CDC_TX_INP_MUX_ADC_MUX7_CFG0,
1864			0, smic_mux_text_v9_2);
1865
1866static const struct snd_kcontrol_new tx_smic0_mux_v9_2 = SOC_DAPM_ENUM_EXT("tx_smic0", tx_smic0_enum_v9_2,
1867			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1868static const struct snd_kcontrol_new tx_smic1_mux_v9_2 = SOC_DAPM_ENUM_EXT("tx_smic1", tx_smic1_enum_v9_2,
1869			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1870static const struct snd_kcontrol_new tx_smic2_mux_v9_2 = SOC_DAPM_ENUM_EXT("tx_smic2", tx_smic2_enum_v9_2,
1871			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1872static const struct snd_kcontrol_new tx_smic3_mux_v9_2 = SOC_DAPM_ENUM_EXT("tx_smic3", tx_smic3_enum_v9_2,
1873			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1874static const struct snd_kcontrol_new tx_smic4_mux_v9_2 = SOC_DAPM_ENUM_EXT("tx_smic4", tx_smic4_enum_v9_2,
1875			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1876static const struct snd_kcontrol_new tx_smic5_mux_v9_2 = SOC_DAPM_ENUM_EXT("tx_smic5", tx_smic5_enum_v9_2,
1877			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1878static const struct snd_kcontrol_new tx_smic6_mux_v9_2 = SOC_DAPM_ENUM_EXT("tx_smic6", tx_smic6_enum_v9_2,
1879			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1880static const struct snd_kcontrol_new tx_smic7_mux_v9_2 = SOC_DAPM_ENUM_EXT("tx_smic7", tx_smic7_enum_v9_2,
1881			snd_soc_dapm_get_enum_double, tx_macro_put_dec_enum);
1882
1883static const struct snd_soc_dapm_widget tx_macro_dapm_widgets_v9_2[] = {
1884	SND_SOC_DAPM_MUX("TX SMIC MUX0", SND_SOC_NOPM, 0, 0, &tx_smic0_mux_v9_2),
1885	SND_SOC_DAPM_MUX("TX SMIC MUX1", SND_SOC_NOPM, 0, 0, &tx_smic1_mux_v9_2),
1886	SND_SOC_DAPM_MUX("TX SMIC MUX2", SND_SOC_NOPM, 0, 0, &tx_smic2_mux_v9_2),
1887	SND_SOC_DAPM_MUX("TX SMIC MUX3", SND_SOC_NOPM, 0, 0, &tx_smic3_mux_v9_2),
1888	SND_SOC_DAPM_MUX("TX SMIC MUX4", SND_SOC_NOPM, 0, 0, &tx_smic4_mux_v9_2),
1889	SND_SOC_DAPM_MUX("TX SMIC MUX5", SND_SOC_NOPM, 0, 0, &tx_smic5_mux_v9_2),
1890	SND_SOC_DAPM_MUX("TX SMIC MUX6", SND_SOC_NOPM, 0, 0, &tx_smic6_mux_v9_2),
1891	SND_SOC_DAPM_MUX("TX SMIC MUX7", SND_SOC_NOPM, 0, 0, &tx_smic7_mux_v9_2),
1892
1893	SND_SOC_DAPM_INPUT("TX SWR_INPUT0"),
1894	SND_SOC_DAPM_INPUT("TX SWR_INPUT1"),
1895	SND_SOC_DAPM_INPUT("TX SWR_INPUT2"),
1896	SND_SOC_DAPM_INPUT("TX SWR_INPUT3"),
1897	SND_SOC_DAPM_INPUT("TX SWR_INPUT4"),
1898	SND_SOC_DAPM_INPUT("TX SWR_INPUT5"),
1899	SND_SOC_DAPM_INPUT("TX SWR_INPUT6"),
1900	SND_SOC_DAPM_INPUT("TX SWR_INPUT7"),
1901	SND_SOC_DAPM_INPUT("TX SWR_INPUT8"),
1902	SND_SOC_DAPM_INPUT("TX SWR_INPUT9"),
1903	SND_SOC_DAPM_INPUT("TX SWR_INPUT10"),
1904	SND_SOC_DAPM_INPUT("TX SWR_INPUT11"),
1905};
1906
1907static const struct snd_soc_dapm_route tx_audio_map_v9_2[] = {
1908	{"TX DEC0 MUX", "SWR_MIC", "TX SMIC MUX0"},
1909	{"TX SMIC MUX0", NULL, "TX_SWR_CLK"},
1910	{"TX SMIC MUX0", "SWR_MIC0", "TX SWR_INPUT0"},
1911	{"TX SMIC MUX0", "SWR_MIC1", "TX SWR_INPUT1"},
1912	{"TX SMIC MUX0", "SWR_MIC2", "TX SWR_INPUT2"},
1913	{"TX SMIC MUX0", "SWR_MIC3", "TX SWR_INPUT3"},
1914	{"TX SMIC MUX0", "SWR_MIC4", "TX SWR_INPUT4"},
1915	{"TX SMIC MUX0", "SWR_MIC5", "TX SWR_INPUT5"},
1916	{"TX SMIC MUX0", "SWR_MIC6", "TX SWR_INPUT6"},
1917	{"TX SMIC MUX0", "SWR_MIC7", "TX SWR_INPUT7"},
1918	{"TX SMIC MUX0", "SWR_MIC8", "TX SWR_INPUT8"},
1919	{"TX SMIC MUX0", "SWR_MIC9", "TX SWR_INPUT9"},
1920	{"TX SMIC MUX0", "SWR_MIC10", "TX SWR_INPUT11"},
1921	{"TX SMIC MUX0", "SWR_MIC11", "TX SWR_INPUT10"},
1922
1923	{"TX DEC1 MUX", "SWR_MIC", "TX SMIC MUX1"},
1924	{"TX SMIC MUX1", NULL, "TX_SWR_CLK"},
1925	{"TX SMIC MUX1", "SWR_MIC0", "TX SWR_INPUT0"},
1926	{"TX SMIC MUX1", "SWR_MIC1", "TX SWR_INPUT1"},
1927	{"TX SMIC MUX1", "SWR_MIC2", "TX SWR_INPUT2"},
1928	{"TX SMIC MUX1", "SWR_MIC3", "TX SWR_INPUT3"},
1929	{"TX SMIC MUX1", "SWR_MIC4", "TX SWR_INPUT4"},
1930	{"TX SMIC MUX1", "SWR_MIC5", "TX SWR_INPUT5"},
1931	{"TX SMIC MUX1", "SWR_MIC6", "TX SWR_INPUT6"},
1932	{"TX SMIC MUX1", "SWR_MIC7", "TX SWR_INPUT7"},
1933	{"TX SMIC MUX1", "SWR_MIC8", "TX SWR_INPUT8"},
1934	{"TX SMIC MUX1", "SWR_MIC9", "TX SWR_INPUT9"},
1935	{"TX SMIC MUX1", "SWR_MIC10", "TX SWR_INPUT10"},
1936	{"TX SMIC MUX1", "SWR_MIC11", "TX SWR_INPUT11"},
1937
1938	{"TX DEC2 MUX", "SWR_MIC", "TX SMIC MUX2"},
1939	{"TX SMIC MUX2", NULL, "TX_SWR_CLK"},
1940	{"TX SMIC MUX2", "SWR_MIC0", "TX SWR_INPUT0"},
1941	{"TX SMIC MUX2", "SWR_MIC1", "TX SWR_INPUT1"},
1942	{"TX SMIC MUX2", "SWR_MIC2", "TX SWR_INPUT2"},
1943	{"TX SMIC MUX2", "SWR_MIC3", "TX SWR_INPUT3"},
1944	{"TX SMIC MUX2", "SWR_MIC4", "TX SWR_INPUT4"},
1945	{"TX SMIC MUX2", "SWR_MIC5", "TX SWR_INPUT5"},
1946	{"TX SMIC MUX2", "SWR_MIC6", "TX SWR_INPUT6"},
1947	{"TX SMIC MUX2", "SWR_MIC7", "TX SWR_INPUT7"},
1948	{"TX SMIC MUX2", "SWR_MIC8", "TX SWR_INPUT8"},
1949	{"TX SMIC MUX2", "SWR_MIC9", "TX SWR_INPUT9"},
1950	{"TX SMIC MUX2", "SWR_MIC10", "TX SWR_INPUT10"},
1951	{"TX SMIC MUX2", "SWR_MIC11", "TX SWR_INPUT11"},
1952
1953	{"TX DEC3 MUX", "SWR_MIC", "TX SMIC MUX3"},
1954	{"TX SMIC MUX3", NULL, "TX_SWR_CLK"},
1955	{"TX SMIC MUX3", "SWR_MIC0", "TX SWR_INPUT0"},
1956	{"TX SMIC MUX3", "SWR_MIC1", "TX SWR_INPUT1"},
1957	{"TX SMIC MUX3", "SWR_MIC2", "TX SWR_INPUT2"},
1958	{"TX SMIC MUX3", "SWR_MIC3", "TX SWR_INPUT3"},
1959	{"TX SMIC MUX3", "SWR_MIC4", "TX SWR_INPUT4"},
1960	{"TX SMIC MUX3", "SWR_MIC5", "TX SWR_INPUT5"},
1961	{"TX SMIC MUX3", "SWR_MIC6", "TX SWR_INPUT6"},
1962	{"TX SMIC MUX3", "SWR_MIC7", "TX SWR_INPUT7"},
1963	{"TX SMIC MUX3", "SWR_MIC8", "TX SWR_INPUT8"},
1964	{"TX SMIC MUX3", "SWR_MIC9", "TX SWR_INPUT9"},
1965	{"TX SMIC MUX3", "SWR_MIC10", "TX SWR_INPUT10"},
1966	{"TX SMIC MUX3", "SWR_MIC11", "TX SWR_INPUT11"},
1967
1968	{"TX DEC4 MUX", "SWR_MIC", "TX SMIC MUX4"},
1969	{"TX SMIC MUX4", NULL, "TX_SWR_CLK"},
1970	{"TX SMIC MUX4", "SWR_MIC0", "TX SWR_INPUT0"},
1971	{"TX SMIC MUX4", "SWR_MIC1", "TX SWR_INPUT1"},
1972	{"TX SMIC MUX4", "SWR_MIC2", "TX SWR_INPUT2"},
1973	{"TX SMIC MUX4", "SWR_MIC3", "TX SWR_INPUT3"},
1974	{"TX SMIC MUX4", "SWR_MIC4", "TX SWR_INPUT4"},
1975	{"TX SMIC MUX4", "SWR_MIC5", "TX SWR_INPUT5"},
1976	{"TX SMIC MUX4", "SWR_MIC6", "TX SWR_INPUT6"},
1977	{"TX SMIC MUX4", "SWR_MIC7", "TX SWR_INPUT7"},
1978	{"TX SMIC MUX4", "SWR_MIC8", "TX SWR_INPUT8"},
1979	{"TX SMIC MUX4", "SWR_MIC9", "TX SWR_INPUT9"},
1980	{"TX SMIC MUX4", "SWR_MIC10", "TX SWR_INPUT10"},
1981	{"TX SMIC MUX4", "SWR_MIC11", "TX SWR_INPUT11"},
1982
1983	{"TX DEC5 MUX", "SWR_MIC", "TX SMIC MUX5"},
1984	{"TX SMIC MUX5", NULL, "TX_SWR_CLK"},
1985	{"TX SMIC MUX5", "SWR_MIC0", "TX SWR_INPUT0"},
1986	{"TX SMIC MUX5", "SWR_MIC1", "TX SWR_INPUT1"},
1987	{"TX SMIC MUX5", "SWR_MIC2", "TX SWR_INPUT2"},
1988	{"TX SMIC MUX5", "SWR_MIC3", "TX SWR_INPUT3"},
1989	{"TX SMIC MUX5", "SWR_MIC4", "TX SWR_INPUT4"},
1990	{"TX SMIC MUX5", "SWR_MIC5", "TX SWR_INPUT5"},
1991	{"TX SMIC MUX5", "SWR_MIC6", "TX SWR_INPUT6"},
1992	{"TX SMIC MUX5", "SWR_MIC7", "TX SWR_INPUT7"},
1993	{"TX SMIC MUX5", "SWR_MIC8", "TX SWR_INPUT8"},
1994	{"TX SMIC MUX5", "SWR_MIC9", "TX SWR_INPUT9"},
1995	{"TX SMIC MUX5", "SWR_MIC10", "TX SWR_INPUT10"},
1996	{"TX SMIC MUX5", "SWR_MIC11", "TX SWR_INPUT11"},
1997
1998	{"TX DEC6 MUX", "SWR_MIC", "TX SMIC MUX6"},
1999	{"TX SMIC MUX6", NULL, "TX_SWR_CLK"},
2000	{"TX SMIC MUX6", "SWR_MIC0", "TX SWR_INPUT0"},
2001	{"TX SMIC MUX6", "SWR_MIC1", "TX SWR_INPUT1"},
2002	{"TX SMIC MUX6", "SWR_MIC2", "TX SWR_INPUT2"},
2003	{"TX SMIC MUX6", "SWR_MIC3", "TX SWR_INPUT3"},
2004	{"TX SMIC MUX6", "SWR_MIC4", "TX SWR_INPUT4"},
2005	{"TX SMIC MUX6", "SWR_MIC5", "TX SWR_INPUT5"},
2006	{"TX SMIC MUX6", "SWR_MIC6", "TX SWR_INPUT6"},
2007	{"TX SMIC MUX6", "SWR_MIC7", "TX SWR_INPUT7"},
2008	{"TX SMIC MUX6", "SWR_MIC8", "TX SWR_INPUT8"},
2009	{"TX SMIC MUX6", "SWR_MIC9", "TX SWR_INPUT9"},
2010	{"TX SMIC MUX6", "SWR_MIC10", "TX SWR_INPUT10"},
2011	{"TX SMIC MUX6", "SWR_MIC11", "TX SWR_INPUT11"},
2012
2013	{"TX DEC7 MUX", "SWR_MIC", "TX SMIC MUX7"},
2014	{"TX SMIC MUX7", NULL, "TX_SWR_CLK"},
2015	{"TX SMIC MUX7", "SWR_MIC0", "TX SWR_INPUT0"},
2016	{"TX SMIC MUX7", "SWR_MIC1", "TX SWR_INPUT1"},
2017	{"TX SMIC MUX7", "SWR_MIC2", "TX SWR_INPUT2"},
2018	{"TX SMIC MUX7", "SWR_MIC3", "TX SWR_INPUT3"},
2019	{"TX SMIC MUX7", "SWR_MIC4", "TX SWR_INPUT4"},
2020	{"TX SMIC MUX7", "SWR_MIC5", "TX SWR_INPUT5"},
2021	{"TX SMIC MUX7", "SWR_MIC6", "TX SWR_INPUT6"},
2022	{"TX SMIC MUX7", "SWR_MIC7", "TX SWR_INPUT7"},
2023	{"TX SMIC MUX7", "SWR_MIC8", "TX SWR_INPUT8"},
2024	{"TX SMIC MUX7", "SWR_MIC9", "TX SWR_INPUT9"},
2025	{"TX SMIC MUX7", "SWR_MIC10", "TX SWR_INPUT10"},
2026	{"TX SMIC MUX7", "SWR_MIC11", "TX SWR_INPUT11"},
2027};
2028
2029static const struct snd_kcontrol_new tx_macro_snd_controls[] = {
2030	SOC_SINGLE_S8_TLV("TX_DEC0 Volume",
2031			  CDC_TX0_TX_VOL_CTL,
2032			  -84, 40, digital_gain),
2033	SOC_SINGLE_S8_TLV("TX_DEC1 Volume",
2034			  CDC_TX1_TX_VOL_CTL,
2035			  -84, 40, digital_gain),
2036	SOC_SINGLE_S8_TLV("TX_DEC2 Volume",
2037			  CDC_TX2_TX_VOL_CTL,
2038			  -84, 40, digital_gain),
2039	SOC_SINGLE_S8_TLV("TX_DEC3 Volume",
2040			  CDC_TX3_TX_VOL_CTL,
2041			  -84, 40, digital_gain),
2042	SOC_SINGLE_S8_TLV("TX_DEC4 Volume",
2043			  CDC_TX4_TX_VOL_CTL,
2044			  -84, 40, digital_gain),
2045	SOC_SINGLE_S8_TLV("TX_DEC5 Volume",
2046			  CDC_TX5_TX_VOL_CTL,
2047			  -84, 40, digital_gain),
2048	SOC_SINGLE_S8_TLV("TX_DEC6 Volume",
2049			  CDC_TX6_TX_VOL_CTL,
2050			  -84, 40, digital_gain),
2051	SOC_SINGLE_S8_TLV("TX_DEC7 Volume",
2052			  CDC_TX7_TX_VOL_CTL,
2053			  -84, 40, digital_gain),
2054
2055	SOC_ENUM_EXT("DEC0 MODE", dec_mode_mux_enum[0],
2056			tx_macro_dec_mode_get, tx_macro_dec_mode_put),
2057
2058	SOC_ENUM_EXT("DEC1 MODE", dec_mode_mux_enum[1],
2059			tx_macro_dec_mode_get, tx_macro_dec_mode_put),
2060
2061	SOC_ENUM_EXT("DEC2 MODE", dec_mode_mux_enum[2],
2062			tx_macro_dec_mode_get, tx_macro_dec_mode_put),
2063
2064	SOC_ENUM_EXT("DEC3 MODE", dec_mode_mux_enum[3],
2065			tx_macro_dec_mode_get, tx_macro_dec_mode_put),
2066
2067	SOC_ENUM_EXT("DEC4 MODE", dec_mode_mux_enum[4],
2068			tx_macro_dec_mode_get, tx_macro_dec_mode_put),
2069
2070	SOC_ENUM_EXT("DEC5 MODE", dec_mode_mux_enum[5],
2071			tx_macro_dec_mode_get, tx_macro_dec_mode_put),
2072
2073	SOC_ENUM_EXT("DEC6 MODE", dec_mode_mux_enum[6],
2074			tx_macro_dec_mode_get, tx_macro_dec_mode_put),
2075
2076	SOC_ENUM_EXT("DEC7 MODE", dec_mode_mux_enum[7],
2077			tx_macro_dec_mode_get, tx_macro_dec_mode_put),
2078
2079	SOC_SINGLE_EXT("DEC0_BCS Switch", SND_SOC_NOPM, 0, 1, 0,
2080		       tx_macro_get_bcs, tx_macro_set_bcs),
2081};
2082
2083static int tx_macro_component_extend(struct snd_soc_component *comp)
2084{
2085	struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(comp);
2086	struct tx_macro *tx = snd_soc_component_get_drvdata(comp);
2087	int ret;
2088
2089	if (tx->data->extra_widgets_num) {
2090		ret = snd_soc_dapm_new_controls(dapm, tx->data->extra_widgets,
2091						tx->data->extra_widgets_num);
2092		if (ret) {
2093			dev_err(tx->dev, "failed to add extra widgets: %d\n", ret);
2094			return ret;
2095		}
2096	}
2097
2098	if (tx->data->extra_routes_num) {
2099		ret = snd_soc_dapm_add_routes(dapm, tx->data->extra_routes,
2100					      tx->data->extra_routes_num);
2101		if (ret) {
2102			dev_err(tx->dev, "failed to add extra routes: %d\n", ret);
2103			return ret;
2104		}
2105	}
2106
2107	return 0;
2108}
2109
2110static int tx_macro_component_probe(struct snd_soc_component *comp)
2111{
2112	struct tx_macro *tx = snd_soc_component_get_drvdata(comp);
2113	int i, ret;
2114
2115	ret = tx_macro_component_extend(comp);
2116	if (ret)
2117		return ret;
2118
2119	snd_soc_component_init_regmap(comp, tx->regmap);
2120
2121	for (i = 0; i < NUM_DECIMATORS; i++) {
2122		tx->tx_hpf_work[i].tx = tx;
2123		tx->tx_hpf_work[i].decimator = i;
2124		INIT_DELAYED_WORK(&tx->tx_hpf_work[i].dwork,
2125			tx_macro_tx_hpf_corner_freq_callback);
2126	}
2127
2128	for (i = 0; i < NUM_DECIMATORS; i++) {
2129		tx->tx_mute_dwork[i].tx = tx;
2130		tx->tx_mute_dwork[i].decimator = i;
2131		INIT_DELAYED_WORK(&tx->tx_mute_dwork[i].dwork,
2132			  tx_macro_mute_update_callback);
2133	}
2134	tx->component = comp;
2135
2136	snd_soc_component_update_bits(comp, CDC_TX0_TX_PATH_SEC7, 0x3F,
2137				      0x0A);
2138	/* Enable swr mic0 and mic1 clock */
2139	snd_soc_component_write(comp, CDC_TX_TOP_CSR_SWR_AMIC0_CTL,
2140				CDC_TX_SWR_MIC_CLK_DEFAULT);
2141	snd_soc_component_write(comp, CDC_TX_TOP_CSR_SWR_AMIC1_CTL,
2142				CDC_TX_SWR_MIC_CLK_DEFAULT);
2143
2144	return 0;
2145}
2146
2147static int swclk_gate_enable(struct clk_hw *hw)
2148{
2149	struct tx_macro *tx = to_tx_macro(hw);
2150	struct regmap *regmap = tx->regmap;
2151	int ret;
2152
2153	ret = clk_prepare_enable(tx->mclk);
2154	if (ret) {
2155		dev_err(tx->dev, "failed to enable mclk\n");
2156		return ret;
2157	}
2158
2159	tx_macro_mclk_enable(tx, true);
2160
2161	regmap_update_bits(regmap, CDC_TX_CLK_RST_CTRL_SWR_CONTROL,
2162			   CDC_TX_SWR_CLK_EN_MASK,
2163			   CDC_TX_SWR_CLK_ENABLE);
2164	return 0;
2165}
2166
2167static void swclk_gate_disable(struct clk_hw *hw)
2168{
2169	struct tx_macro *tx = to_tx_macro(hw);
2170	struct regmap *regmap = tx->regmap;
2171
2172	regmap_update_bits(regmap, CDC_TX_CLK_RST_CTRL_SWR_CONTROL,
2173			   CDC_TX_SWR_CLK_EN_MASK, 0x0);
2174
2175	tx_macro_mclk_enable(tx, false);
2176	clk_disable_unprepare(tx->mclk);
2177}
2178
2179static int swclk_gate_is_enabled(struct clk_hw *hw)
2180{
2181	struct tx_macro *tx = to_tx_macro(hw);
2182	int ret, val;
2183
2184	regmap_read(tx->regmap, CDC_TX_CLK_RST_CTRL_SWR_CONTROL, &val);
2185	ret = val & BIT(0);
2186
2187	return ret;
2188}
2189
2190static unsigned long swclk_recalc_rate(struct clk_hw *hw,
2191				       unsigned long parent_rate)
2192{
2193	return parent_rate / 2;
2194}
2195
2196static const struct clk_ops swclk_gate_ops = {
2197	.prepare = swclk_gate_enable,
2198	.unprepare = swclk_gate_disable,
2199	.is_enabled = swclk_gate_is_enabled,
2200	.recalc_rate = swclk_recalc_rate,
2201
2202};
2203
2204static int tx_macro_register_mclk_output(struct tx_macro *tx)
2205{
2206	struct device *dev = tx->dev;
2207	const char *parent_clk_name = NULL;
2208	const char *clk_name = "lpass-tx-mclk";
2209	struct clk_hw *hw;
2210	struct clk_init_data init;
2211	int ret;
2212
2213	if (tx->npl)
2214		parent_clk_name = __clk_get_name(tx->npl);
2215	else
2216		parent_clk_name = __clk_get_name(tx->mclk);
2217
2218	init.name = clk_name;
2219	init.ops = &swclk_gate_ops;
2220	init.flags = 0;
2221	init.parent_names = &parent_clk_name;
2222	init.num_parents = 1;
2223	tx->hw.init = &init;
2224	hw = &tx->hw;
2225	ret = devm_clk_hw_register(dev, hw);
2226	if (ret)
2227		return ret;
2228
2229	return devm_of_clk_add_hw_provider(dev, of_clk_hw_simple_get, hw);
2230}
2231
2232static const struct snd_soc_component_driver tx_macro_component_drv = {
2233	.name = "RX-MACRO",
2234	.probe = tx_macro_component_probe,
2235	.controls = tx_macro_snd_controls,
2236	.num_controls = ARRAY_SIZE(tx_macro_snd_controls),
2237	.dapm_widgets = tx_macro_dapm_widgets,
2238	.num_dapm_widgets = ARRAY_SIZE(tx_macro_dapm_widgets),
2239	.dapm_routes = tx_audio_map,
2240	.num_dapm_routes = ARRAY_SIZE(tx_audio_map),
2241};
2242
2243static int tx_macro_probe(struct platform_device *pdev)
2244{
2245	struct device *dev = &pdev->dev;
2246	struct device_node *np = dev->of_node;
2247	struct tx_macro *tx;
2248	void __iomem *base;
2249	int ret, reg;
2250
2251	tx = devm_kzalloc(dev, sizeof(*tx), GFP_KERNEL);
2252	if (!tx)
2253		return -ENOMEM;
2254
2255	tx->data = device_get_match_data(dev);
2256
2257	tx->macro = devm_clk_get_optional(dev, "macro");
2258	if (IS_ERR(tx->macro))
2259		return dev_err_probe(dev, PTR_ERR(tx->macro), "unable to get macro clock\n");
2260
2261	tx->dcodec = devm_clk_get_optional(dev, "dcodec");
2262	if (IS_ERR(tx->dcodec))
2263		return dev_err_probe(dev, PTR_ERR(tx->dcodec), "unable to get dcodec clock\n");
2264
2265	tx->mclk = devm_clk_get(dev, "mclk");
2266	if (IS_ERR(tx->mclk))
2267		return dev_err_probe(dev, PTR_ERR(tx->mclk), "unable to get mclk clock\n");
2268
2269	if (tx->data->flags & LPASS_MACRO_FLAG_HAS_NPL_CLOCK) {
2270		tx->npl = devm_clk_get(dev, "npl");
2271		if (IS_ERR(tx->npl))
2272			return dev_err_probe(dev, PTR_ERR(tx->npl), "unable to get npl clock\n");
2273	}
2274
2275	tx->fsgen = devm_clk_get(dev, "fsgen");
2276	if (IS_ERR(tx->fsgen))
2277		return dev_err_probe(dev, PTR_ERR(tx->fsgen), "unable to get fsgen clock\n");
2278
2279	tx->pds = lpass_macro_pds_init(dev);
2280	if (IS_ERR(tx->pds))
2281		return PTR_ERR(tx->pds);
2282
2283	base = devm_platform_ioremap_resource(pdev, 0);
2284	if (IS_ERR(base)) {
2285		ret = PTR_ERR(base);
2286		goto err;
2287	}
2288
2289	/* Update defaults for lpass sc7280 */
2290	if (of_device_is_compatible(np, "qcom,sc7280-lpass-tx-macro")) {
2291		for (reg = 0; reg < ARRAY_SIZE(tx_defaults); reg++) {
2292			switch (tx_defaults[reg].reg) {
2293			case CDC_TX_TOP_CSR_SWR_AMIC0_CTL:
2294			case CDC_TX_TOP_CSR_SWR_AMIC1_CTL:
2295				tx_defaults[reg].def = 0x0E;
2296				break;
2297			default:
2298				break;
2299			}
2300		}
2301	}
2302
2303	tx->regmap = devm_regmap_init_mmio(dev, base, &tx_regmap_config);
2304	if (IS_ERR(tx->regmap)) {
2305		ret = PTR_ERR(tx->regmap);
2306		goto err;
2307	}
2308
2309	dev_set_drvdata(dev, tx);
2310
2311	tx->dev = dev;
2312
2313	/* Set active_decimator default value */
2314	tx->active_decimator[TX_MACRO_AIF1_CAP] = -1;
2315	tx->active_decimator[TX_MACRO_AIF2_CAP] = -1;
2316	tx->active_decimator[TX_MACRO_AIF3_CAP] = -1;
2317
2318	/* set MCLK and NPL rates */
2319	clk_set_rate(tx->mclk, MCLK_FREQ);
2320	clk_set_rate(tx->npl, MCLK_FREQ);
2321
2322	ret = clk_prepare_enable(tx->macro);
2323	if (ret)
2324		goto err;
2325
2326	ret = clk_prepare_enable(tx->dcodec);
2327	if (ret)
2328		goto err_dcodec;
2329
2330	ret = clk_prepare_enable(tx->mclk);
2331	if (ret)
2332		goto err_mclk;
2333
2334	ret = clk_prepare_enable(tx->npl);
2335	if (ret)
2336		goto err_npl;
2337
2338	ret = clk_prepare_enable(tx->fsgen);
2339	if (ret)
2340		goto err_fsgen;
2341
2342
2343	/* reset soundwire block */
2344	if (tx->data->flags & LPASS_MACRO_FLAG_RESET_SWR)
2345		regmap_update_bits(tx->regmap, CDC_TX_CLK_RST_CTRL_SWR_CONTROL,
2346				   CDC_TX_SWR_RESET_MASK, CDC_TX_SWR_RESET_ENABLE);
2347
2348	regmap_update_bits(tx->regmap, CDC_TX_CLK_RST_CTRL_SWR_CONTROL,
2349			   CDC_TX_SWR_CLK_EN_MASK,
2350			   CDC_TX_SWR_CLK_ENABLE);
2351
2352	if (tx->data->flags & LPASS_MACRO_FLAG_RESET_SWR)
2353		regmap_update_bits(tx->regmap, CDC_TX_CLK_RST_CTRL_SWR_CONTROL,
2354				   CDC_TX_SWR_RESET_MASK, 0x0);
2355
2356	ret = devm_snd_soc_register_component(dev, &tx_macro_component_drv,
2357					      tx_macro_dai,
2358					      ARRAY_SIZE(tx_macro_dai));
2359	if (ret)
2360		goto err_clkout;
2361
2362	pm_runtime_set_autosuspend_delay(dev, 3000);
2363	pm_runtime_use_autosuspend(dev);
2364	pm_runtime_mark_last_busy(dev);
2365	pm_runtime_set_active(dev);
2366	pm_runtime_enable(dev);
2367
2368	ret = tx_macro_register_mclk_output(tx);
2369	if (ret)
2370		goto err_clkout;
2371
2372	return 0;
2373
2374err_clkout:
2375	clk_disable_unprepare(tx->fsgen);
2376err_fsgen:
2377	clk_disable_unprepare(tx->npl);
2378err_npl:
2379	clk_disable_unprepare(tx->mclk);
2380err_mclk:
2381	clk_disable_unprepare(tx->dcodec);
2382err_dcodec:
2383	clk_disable_unprepare(tx->macro);
2384err:
2385	lpass_macro_pds_exit(tx->pds);
2386
2387	return ret;
2388}
2389
2390static void tx_macro_remove(struct platform_device *pdev)
2391{
2392	struct tx_macro *tx = dev_get_drvdata(&pdev->dev);
2393
2394	clk_disable_unprepare(tx->macro);
2395	clk_disable_unprepare(tx->dcodec);
2396	clk_disable_unprepare(tx->mclk);
2397	clk_disable_unprepare(tx->npl);
2398	clk_disable_unprepare(tx->fsgen);
2399
2400	lpass_macro_pds_exit(tx->pds);
2401}
2402
2403static int __maybe_unused tx_macro_runtime_suspend(struct device *dev)
2404{
2405	struct tx_macro *tx = dev_get_drvdata(dev);
2406
2407	regcache_cache_only(tx->regmap, true);
2408	regcache_mark_dirty(tx->regmap);
2409
2410	clk_disable_unprepare(tx->fsgen);
2411	clk_disable_unprepare(tx->npl);
2412	clk_disable_unprepare(tx->mclk);
2413
2414	return 0;
2415}
2416
2417static int __maybe_unused tx_macro_runtime_resume(struct device *dev)
2418{
2419	struct tx_macro *tx = dev_get_drvdata(dev);
2420	int ret;
2421
2422	ret = clk_prepare_enable(tx->mclk);
2423	if (ret) {
2424		dev_err(dev, "unable to prepare mclk\n");
2425		return ret;
2426	}
2427
2428	ret = clk_prepare_enable(tx->npl);
2429	if (ret) {
2430		dev_err(dev, "unable to prepare npl\n");
2431		goto err_npl;
2432	}
2433
2434	ret = clk_prepare_enable(tx->fsgen);
2435	if (ret) {
2436		dev_err(dev, "unable to prepare fsgen\n");
2437		goto err_fsgen;
2438	}
2439
2440	regcache_cache_only(tx->regmap, false);
2441	regcache_sync(tx->regmap);
2442
2443	return 0;
2444err_fsgen:
2445	clk_disable_unprepare(tx->npl);
2446err_npl:
2447	clk_disable_unprepare(tx->mclk);
2448
2449	return ret;
2450}
2451
2452static const struct dev_pm_ops tx_macro_pm_ops = {
2453	SET_RUNTIME_PM_OPS(tx_macro_runtime_suspend, tx_macro_runtime_resume, NULL)
2454};
2455
2456static const struct tx_macro_data lpass_ver_9 = {
2457	.flags			= LPASS_MACRO_FLAG_HAS_NPL_CLOCK |
2458				  LPASS_MACRO_FLAG_RESET_SWR,
2459	.ver			= LPASS_VER_9_0_0,
2460	.extra_widgets		= tx_macro_dapm_widgets_v9,
2461	.extra_widgets_num	= ARRAY_SIZE(tx_macro_dapm_widgets_v9),
2462	.extra_routes		= tx_audio_map_v9,
2463	.extra_routes_num	= ARRAY_SIZE(tx_audio_map_v9),
2464};
2465
2466static const struct tx_macro_data lpass_ver_9_2 = {
2467	.flags			= LPASS_MACRO_FLAG_HAS_NPL_CLOCK |
2468				  LPASS_MACRO_FLAG_RESET_SWR,
2469	.ver			= LPASS_VER_9_2_0,
2470	.extra_widgets		= tx_macro_dapm_widgets_v9_2,
2471	.extra_widgets_num	= ARRAY_SIZE(tx_macro_dapm_widgets_v9_2),
2472	.extra_routes		= tx_audio_map_v9_2,
2473	.extra_routes_num	= ARRAY_SIZE(tx_audio_map_v9_2),
2474};
2475
2476static const struct tx_macro_data lpass_ver_10_sm6115 = {
2477	.flags			= LPASS_MACRO_FLAG_HAS_NPL_CLOCK,
2478	.ver			= LPASS_VER_10_0_0,
2479	.extra_widgets		= tx_macro_dapm_widgets_v9_2,
2480	.extra_widgets_num	= ARRAY_SIZE(tx_macro_dapm_widgets_v9_2),
2481	.extra_routes		= tx_audio_map_v9_2,
2482	.extra_routes_num	= ARRAY_SIZE(tx_audio_map_v9_2),
2483};
2484
2485static const struct tx_macro_data lpass_ver_11 = {
2486	.flags			= LPASS_MACRO_FLAG_RESET_SWR,
2487	.ver			= LPASS_VER_11_0_0,
2488	.extra_widgets		= tx_macro_dapm_widgets_v9_2,
2489	.extra_widgets_num	= ARRAY_SIZE(tx_macro_dapm_widgets_v9_2),
2490	.extra_routes		= tx_audio_map_v9_2,
2491	.extra_routes_num	= ARRAY_SIZE(tx_audio_map_v9_2),
2492};
2493
2494static const struct of_device_id tx_macro_dt_match[] = {
2495	{
2496		/*
2497		 * The block is actually LPASS v9.4, but keep LPASS v9 match
2498		 * data and audio widgets, due to compatibility reasons.
2499		 * Microphones are working on SC7280 fine, so apparently the fix
2500		 * is not necessary.
2501		 */
2502		.compatible = "qcom,sc7280-lpass-tx-macro",
2503		.data = &lpass_ver_9,
2504	}, {
2505		.compatible = "qcom,sm6115-lpass-tx-macro",
2506		.data = &lpass_ver_10_sm6115,
2507	}, {
2508		.compatible = "qcom,sm8250-lpass-tx-macro",
2509		.data = &lpass_ver_9,
2510	}, {
2511		.compatible = "qcom,sm8450-lpass-tx-macro",
2512		.data = &lpass_ver_9_2,
2513	}, {
2514		.compatible = "qcom,sm8550-lpass-tx-macro",
2515		.data = &lpass_ver_11,
2516	}, {
2517		.compatible = "qcom,sc8280xp-lpass-tx-macro",
2518		/*
2519		 * The block is actually LPASS v9.3, but keep LPASS v9 match
2520		 * data and audio widgets, due to compatibility reasons.
2521		 * Microphones are working on SC8280xp fine, so apparently the
2522		 * fix is not necessary.
2523		 */
2524		.data = &lpass_ver_9,
2525	},
2526	{ }
2527};
2528MODULE_DEVICE_TABLE(of, tx_macro_dt_match);
2529static struct platform_driver tx_macro_driver = {
2530	.driver = {
2531		.name = "tx_macro",
2532		.of_match_table = tx_macro_dt_match,
2533		.suppress_bind_attrs = true,
2534		.pm = &tx_macro_pm_ops,
2535	},
2536	.probe = tx_macro_probe,
2537	.remove_new = tx_macro_remove,
2538};
2539
2540module_platform_driver(tx_macro_driver);
2541
2542MODULE_DESCRIPTION("TX macro driver");
2543MODULE_LICENSE("GPL");
2544