xref: /openbmc/linux/sound/soc/codecs/cs47l90.c (revision c900529f3d9161bfde5cca0754f83b4d3c3e0220)
1472e5df0SCharles Keepax // SPDX-License-Identifier: GPL-2.0-only
2f1572a44SRichard Fitzgerald //
3f1572a44SRichard Fitzgerald // ALSA SoC Audio driver for CS47L90 codec
4f1572a44SRichard Fitzgerald //
5f1572a44SRichard Fitzgerald // Copyright (C) 2015-2019 Cirrus Logic, Inc. and
6f1572a44SRichard Fitzgerald //                         Cirrus Logic International Semiconductor Ltd.
7f1572a44SRichard Fitzgerald //
8f1572a44SRichard Fitzgerald 
9f1572a44SRichard Fitzgerald #include <linux/module.h>
10f1572a44SRichard Fitzgerald #include <linux/moduleparam.h>
11f1572a44SRichard Fitzgerald #include <linux/device.h>
12f1572a44SRichard Fitzgerald #include <linux/delay.h>
13f1572a44SRichard Fitzgerald #include <linux/init.h>
14f1572a44SRichard Fitzgerald #include <linux/pm.h>
15f1572a44SRichard Fitzgerald #include <linux/pm_runtime.h>
16f1572a44SRichard Fitzgerald #include <linux/regmap.h>
17f1572a44SRichard Fitzgerald #include <sound/core.h>
18f1572a44SRichard Fitzgerald #include <sound/pcm.h>
19f1572a44SRichard Fitzgerald #include <sound/pcm_params.h>
20f1572a44SRichard Fitzgerald #include <sound/soc.h>
21f1572a44SRichard Fitzgerald #include <sound/tlv.h>
22f1572a44SRichard Fitzgerald 
23f1572a44SRichard Fitzgerald #include <linux/irqchip/irq-madera.h>
24f1572a44SRichard Fitzgerald #include <linux/mfd/madera/core.h>
25f1572a44SRichard Fitzgerald #include <linux/mfd/madera/registers.h>
26f1572a44SRichard Fitzgerald 
27f1572a44SRichard Fitzgerald #include "madera.h"
28f1572a44SRichard Fitzgerald #include "wm_adsp.h"
29f1572a44SRichard Fitzgerald 
30f1572a44SRichard Fitzgerald #define DRV_NAME "cs47l90-codec"
31f1572a44SRichard Fitzgerald 
32f1572a44SRichard Fitzgerald #define CS47L90_NUM_ADSP	7
33f1572a44SRichard Fitzgerald #define CS47L90_MONO_OUTPUTS	3
34f1572a44SRichard Fitzgerald 
35f1572a44SRichard Fitzgerald struct cs47l90 {
36f1572a44SRichard Fitzgerald 	struct madera_priv core;
37f1572a44SRichard Fitzgerald 	struct madera_fll fll[3];
38f1572a44SRichard Fitzgerald };
39f1572a44SRichard Fitzgerald 
405beb8eeaSSimon Trimmer static const struct cs_dsp_region cs47l90_dsp1_regions[] = {
41f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_PM, .base = 0x080000 },
42f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_ZM, .base = 0x0e0000 },
43f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_XM, .base = 0x0a0000 },
44f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_YM, .base = 0x0c0000 },
45f1572a44SRichard Fitzgerald };
46f1572a44SRichard Fitzgerald 
475beb8eeaSSimon Trimmer static const struct cs_dsp_region cs47l90_dsp2_regions[] = {
48f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_PM, .base = 0x100000 },
49f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_ZM, .base = 0x160000 },
50f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_XM, .base = 0x120000 },
51f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_YM, .base = 0x140000 },
52f1572a44SRichard Fitzgerald };
53f1572a44SRichard Fitzgerald 
545beb8eeaSSimon Trimmer static const struct cs_dsp_region cs47l90_dsp3_regions[] = {
55f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_PM, .base = 0x180000 },
56f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_ZM, .base = 0x1e0000 },
57f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_XM, .base = 0x1a0000 },
58f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_YM, .base = 0x1c0000 },
59f1572a44SRichard Fitzgerald };
60f1572a44SRichard Fitzgerald 
615beb8eeaSSimon Trimmer static const struct cs_dsp_region cs47l90_dsp4_regions[] = {
62f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_PM, .base = 0x200000 },
63f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_ZM, .base = 0x260000 },
64f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_XM, .base = 0x220000 },
65f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_YM, .base = 0x240000 },
66f1572a44SRichard Fitzgerald };
67f1572a44SRichard Fitzgerald 
685beb8eeaSSimon Trimmer static const struct cs_dsp_region cs47l90_dsp5_regions[] = {
69f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_PM, .base = 0x280000 },
70f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_ZM, .base = 0x2e0000 },
71f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_XM, .base = 0x2a0000 },
72f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_YM, .base = 0x2c0000 },
73f1572a44SRichard Fitzgerald };
74f1572a44SRichard Fitzgerald 
755beb8eeaSSimon Trimmer static const struct cs_dsp_region cs47l90_dsp6_regions[] = {
76f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_PM, .base = 0x300000 },
77f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_ZM, .base = 0x360000 },
78f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_XM, .base = 0x320000 },
79f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_YM, .base = 0x340000 },
80f1572a44SRichard Fitzgerald };
81f1572a44SRichard Fitzgerald 
825beb8eeaSSimon Trimmer static const struct cs_dsp_region cs47l90_dsp7_regions[] = {
83f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_PM, .base = 0x380000 },
84f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_ZM, .base = 0x3e0000 },
85f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_XM, .base = 0x3a0000 },
86f1572a44SRichard Fitzgerald 	{ .type = WMFW_ADSP2_YM, .base = 0x3c0000 },
87f1572a44SRichard Fitzgerald };
88f1572a44SRichard Fitzgerald 
895beb8eeaSSimon Trimmer static const struct cs_dsp_region *cs47l90_dsp_regions[] = {
90f1572a44SRichard Fitzgerald 	cs47l90_dsp1_regions,
91f1572a44SRichard Fitzgerald 	cs47l90_dsp2_regions,
92f1572a44SRichard Fitzgerald 	cs47l90_dsp3_regions,
93f1572a44SRichard Fitzgerald 	cs47l90_dsp4_regions,
94f1572a44SRichard Fitzgerald 	cs47l90_dsp5_regions,
95f1572a44SRichard Fitzgerald 	cs47l90_dsp6_regions,
96f1572a44SRichard Fitzgerald 	cs47l90_dsp7_regions,
97f1572a44SRichard Fitzgerald };
98f1572a44SRichard Fitzgerald 
99f1572a44SRichard Fitzgerald static const int cs47l90_dsp_control_bases[] = {
100f1572a44SRichard Fitzgerald 	MADERA_DSP1_CONFIG_1,
101f1572a44SRichard Fitzgerald 	MADERA_DSP2_CONFIG_1,
102f1572a44SRichard Fitzgerald 	MADERA_DSP3_CONFIG_1,
103f1572a44SRichard Fitzgerald 	MADERA_DSP4_CONFIG_1,
104f1572a44SRichard Fitzgerald 	MADERA_DSP5_CONFIG_1,
105f1572a44SRichard Fitzgerald 	MADERA_DSP6_CONFIG_1,
106f1572a44SRichard Fitzgerald 	MADERA_DSP7_CONFIG_1,
107f1572a44SRichard Fitzgerald };
108f1572a44SRichard Fitzgerald 
cs47l90_adsp_power_ev(struct snd_soc_dapm_widget * w,struct snd_kcontrol * kcontrol,int event)109f1572a44SRichard Fitzgerald static int cs47l90_adsp_power_ev(struct snd_soc_dapm_widget *w,
110f1572a44SRichard Fitzgerald 				 struct snd_kcontrol *kcontrol,
111f1572a44SRichard Fitzgerald 				 int event)
112f1572a44SRichard Fitzgerald {
113f1572a44SRichard Fitzgerald 	struct snd_soc_component *component =
114f1572a44SRichard Fitzgerald 		snd_soc_dapm_to_component(w->dapm);
115f1572a44SRichard Fitzgerald 	struct cs47l90 *cs47l90 = snd_soc_component_get_drvdata(component);
116f1572a44SRichard Fitzgerald 	struct madera_priv *priv = &cs47l90->core;
117f1572a44SRichard Fitzgerald 	struct madera *madera = priv->madera;
118f1572a44SRichard Fitzgerald 	unsigned int freq;
119f1572a44SRichard Fitzgerald 	int ret;
120f1572a44SRichard Fitzgerald 
121f1572a44SRichard Fitzgerald 	ret = regmap_read(madera->regmap, MADERA_DSP_CLOCK_2, &freq);
122f1572a44SRichard Fitzgerald 	if (ret != 0) {
123f1572a44SRichard Fitzgerald 		dev_err(madera->dev,
124f1572a44SRichard Fitzgerald 			"Failed to read MADERA_DSP_CLOCK_2: %d\n", ret);
125f1572a44SRichard Fitzgerald 		return ret;
126f1572a44SRichard Fitzgerald 	}
127f1572a44SRichard Fitzgerald 
128f1572a44SRichard Fitzgerald 	switch (event) {
129f1572a44SRichard Fitzgerald 	case SND_SOC_DAPM_PRE_PMU:
130f1572a44SRichard Fitzgerald 		ret = madera_set_adsp_clk(&cs47l90->core, w->shift, freq);
131f1572a44SRichard Fitzgerald 		if (ret)
132f1572a44SRichard Fitzgerald 			return ret;
133f1572a44SRichard Fitzgerald 		break;
134f1572a44SRichard Fitzgerald 	default:
135f1572a44SRichard Fitzgerald 		break;
136f1572a44SRichard Fitzgerald 	}
137f1572a44SRichard Fitzgerald 
138f1572a44SRichard Fitzgerald 	return wm_adsp_early_event(w, kcontrol, event);
139f1572a44SRichard Fitzgerald }
140f1572a44SRichard Fitzgerald 
141f1572a44SRichard Fitzgerald #define CS47L90_NG_SRC(name, base) \
142f1572a44SRichard Fitzgerald 	SOC_SINGLE(name " NG HPOUT1L Switch",  base,  0, 1, 0), \
143f1572a44SRichard Fitzgerald 	SOC_SINGLE(name " NG HPOUT1R Switch",  base,  1, 1, 0), \
144f1572a44SRichard Fitzgerald 	SOC_SINGLE(name " NG HPOUT2L Switch",  base,  2, 1, 0), \
145f1572a44SRichard Fitzgerald 	SOC_SINGLE(name " NG HPOUT2R Switch",  base,  3, 1, 0), \
146f1572a44SRichard Fitzgerald 	SOC_SINGLE(name " NG HPOUT3L Switch",  base,  4, 1, 0), \
147f1572a44SRichard Fitzgerald 	SOC_SINGLE(name " NG HPOUT3R Switch",  base,  5, 1, 0), \
148f1572a44SRichard Fitzgerald 	SOC_SINGLE(name " NG SPKDAT1L Switch", base,  8, 1, 0), \
149f1572a44SRichard Fitzgerald 	SOC_SINGLE(name " NG SPKDAT1R Switch", base,  9, 1, 0)
150f1572a44SRichard Fitzgerald 
151f1572a44SRichard Fitzgerald #define CS47L90_RXANC_INPUT_ROUTES(widget, name) \
152f1572a44SRichard Fitzgerald 	{ widget, NULL, name " NG Mux" }, \
153f1572a44SRichard Fitzgerald 	{ name " NG Internal", NULL, "RXANC NG Clock" }, \
154f1572a44SRichard Fitzgerald 	{ name " NG Internal", NULL, name " Channel" }, \
155f1572a44SRichard Fitzgerald 	{ name " NG External", NULL, "RXANC NG External Clock" }, \
156f1572a44SRichard Fitzgerald 	{ name " NG External", NULL, name " Channel" }, \
157f1572a44SRichard Fitzgerald 	{ name " NG Mux", "None", name " Channel" }, \
158f1572a44SRichard Fitzgerald 	{ name " NG Mux", "Internal", name " NG Internal" }, \
159f1572a44SRichard Fitzgerald 	{ name " NG Mux", "External", name " NG External" }, \
160f1572a44SRichard Fitzgerald 	{ name " Channel", "Left", name " Left Input" }, \
161f1572a44SRichard Fitzgerald 	{ name " Channel", "Combine", name " Left Input" }, \
162f1572a44SRichard Fitzgerald 	{ name " Channel", "Right", name " Right Input" }, \
163f1572a44SRichard Fitzgerald 	{ name " Channel", "Combine", name " Right Input" }, \
164f1572a44SRichard Fitzgerald 	{ name " Left Input", "IN1", "IN1L" }, \
165f1572a44SRichard Fitzgerald 	{ name " Right Input", "IN1", "IN1R" }, \
166f1572a44SRichard Fitzgerald 	{ name " Left Input", "IN2", "IN2L" }, \
167f1572a44SRichard Fitzgerald 	{ name " Right Input", "IN2", "IN2R" }, \
168f1572a44SRichard Fitzgerald 	{ name " Left Input", "IN3", "IN3L" }, \
169f1572a44SRichard Fitzgerald 	{ name " Right Input", "IN3", "IN3R" }, \
170f1572a44SRichard Fitzgerald 	{ name " Left Input", "IN4", "IN4L" }, \
171f1572a44SRichard Fitzgerald 	{ name " Right Input", "IN4", "IN4R" }, \
172f1572a44SRichard Fitzgerald 	{ name " Left Input", "IN5", "IN5L" }, \
173f1572a44SRichard Fitzgerald 	{ name " Right Input", "IN5", "IN5R" }
174f1572a44SRichard Fitzgerald 
175f1572a44SRichard Fitzgerald #define CS47L90_RXANC_OUTPUT_ROUTES(widget, name) \
176f1572a44SRichard Fitzgerald 	{ widget, NULL, name " ANC Source" }, \
177f1572a44SRichard Fitzgerald 	{ name " ANC Source", "RXANCL", "RXANCL" }, \
178f1572a44SRichard Fitzgerald 	{ name " ANC Source", "RXANCR", "RXANCR" }
179f1572a44SRichard Fitzgerald 
180f1572a44SRichard Fitzgerald static const struct snd_kcontrol_new cs47l90_snd_controls[] = {
181f1572a44SRichard Fitzgerald SOC_ENUM("IN1 OSR", madera_in_dmic_osr[0]),
182f1572a44SRichard Fitzgerald SOC_ENUM("IN2 OSR", madera_in_dmic_osr[1]),
183f1572a44SRichard Fitzgerald SOC_ENUM("IN3 OSR", madera_in_dmic_osr[2]),
184f1572a44SRichard Fitzgerald SOC_ENUM("IN4 OSR", madera_in_dmic_osr[3]),
185f1572a44SRichard Fitzgerald SOC_ENUM("IN5 OSR", madera_in_dmic_osr[4]),
186f1572a44SRichard Fitzgerald 
187f1572a44SRichard Fitzgerald SOC_SINGLE_RANGE_TLV("IN1L Volume", MADERA_IN1L_CONTROL,
188f1572a44SRichard Fitzgerald 		     MADERA_IN1L_PGA_VOL_SHIFT, 0x40, 0x5f, 0, madera_ana_tlv),
189f1572a44SRichard Fitzgerald SOC_SINGLE_RANGE_TLV("IN1R Volume", MADERA_IN1R_CONTROL,
190f1572a44SRichard Fitzgerald 		     MADERA_IN1R_PGA_VOL_SHIFT, 0x40, 0x5f, 0, madera_ana_tlv),
191f1572a44SRichard Fitzgerald SOC_SINGLE_RANGE_TLV("IN2L Volume", MADERA_IN2L_CONTROL,
192f1572a44SRichard Fitzgerald 		     MADERA_IN2L_PGA_VOL_SHIFT, 0x40, 0x5f, 0, madera_ana_tlv),
193f1572a44SRichard Fitzgerald SOC_SINGLE_RANGE_TLV("IN2R Volume", MADERA_IN2R_CONTROL,
194f1572a44SRichard Fitzgerald 		     MADERA_IN2R_PGA_VOL_SHIFT, 0x40, 0x5f, 0, madera_ana_tlv),
195f1572a44SRichard Fitzgerald 
196f1572a44SRichard Fitzgerald SOC_ENUM("IN HPF Cutoff Frequency", madera_in_hpf_cut_enum),
197f1572a44SRichard Fitzgerald 
198f1572a44SRichard Fitzgerald SOC_SINGLE_EXT("IN1L LP Switch", MADERA_ADC_DIGITAL_VOLUME_1L,
199f1572a44SRichard Fitzgerald 	       MADERA_IN1L_LP_MODE_SHIFT, 1, 0,
200f1572a44SRichard Fitzgerald 	       snd_soc_get_volsw, madera_lp_mode_put),
201f1572a44SRichard Fitzgerald SOC_SINGLE_EXT("IN1R LP Switch", MADERA_ADC_DIGITAL_VOLUME_1R,
202f1572a44SRichard Fitzgerald 	       MADERA_IN1R_LP_MODE_SHIFT, 1, 0,
203f1572a44SRichard Fitzgerald 	       snd_soc_get_volsw, madera_lp_mode_put),
204f1572a44SRichard Fitzgerald SOC_SINGLE_EXT("IN2L LP Switch", MADERA_ADC_DIGITAL_VOLUME_2L,
205f1572a44SRichard Fitzgerald 	       MADERA_IN2L_LP_MODE_SHIFT, 1, 0,
206f1572a44SRichard Fitzgerald 	       snd_soc_get_volsw, madera_lp_mode_put),
207f1572a44SRichard Fitzgerald SOC_SINGLE_EXT("IN2R LP Switch", MADERA_ADC_DIGITAL_VOLUME_2R,
208f1572a44SRichard Fitzgerald 	       MADERA_IN2R_LP_MODE_SHIFT, 1, 0,
209f1572a44SRichard Fitzgerald 	       snd_soc_get_volsw, madera_lp_mode_put),
210f1572a44SRichard Fitzgerald 
211f1572a44SRichard Fitzgerald SOC_SINGLE("IN1L HPF Switch", MADERA_IN1L_CONTROL,
212f1572a44SRichard Fitzgerald 	   MADERA_IN1L_HPF_SHIFT, 1, 0),
213f1572a44SRichard Fitzgerald SOC_SINGLE("IN1R HPF Switch", MADERA_IN1R_CONTROL,
214f1572a44SRichard Fitzgerald 	   MADERA_IN1R_HPF_SHIFT, 1, 0),
215f1572a44SRichard Fitzgerald SOC_SINGLE("IN2L HPF Switch", MADERA_IN2L_CONTROL,
216f1572a44SRichard Fitzgerald 	   MADERA_IN2L_HPF_SHIFT, 1, 0),
217f1572a44SRichard Fitzgerald SOC_SINGLE("IN2R HPF Switch", MADERA_IN2R_CONTROL,
218f1572a44SRichard Fitzgerald 	   MADERA_IN2R_HPF_SHIFT, 1, 0),
219f1572a44SRichard Fitzgerald SOC_SINGLE("IN3L HPF Switch", MADERA_IN3L_CONTROL,
220f1572a44SRichard Fitzgerald 	   MADERA_IN3L_HPF_SHIFT, 1, 0),
221f1572a44SRichard Fitzgerald SOC_SINGLE("IN3R HPF Switch", MADERA_IN3R_CONTROL,
222f1572a44SRichard Fitzgerald 	   MADERA_IN3R_HPF_SHIFT, 1, 0),
223f1572a44SRichard Fitzgerald SOC_SINGLE("IN4L HPF Switch", MADERA_IN4L_CONTROL,
224f1572a44SRichard Fitzgerald 	   MADERA_IN4L_HPF_SHIFT, 1, 0),
225f1572a44SRichard Fitzgerald SOC_SINGLE("IN4R HPF Switch", MADERA_IN4R_CONTROL,
226f1572a44SRichard Fitzgerald 	   MADERA_IN4R_HPF_SHIFT, 1, 0),
227f1572a44SRichard Fitzgerald SOC_SINGLE("IN5L HPF Switch", MADERA_IN5L_CONTROL,
228f1572a44SRichard Fitzgerald 	   MADERA_IN5L_HPF_SHIFT, 1, 0),
229f1572a44SRichard Fitzgerald SOC_SINGLE("IN5R HPF Switch", MADERA_IN5R_CONTROL,
230f1572a44SRichard Fitzgerald 	   MADERA_IN5R_HPF_SHIFT, 1, 0),
231f1572a44SRichard Fitzgerald 
232f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("IN1L Digital Volume", MADERA_ADC_DIGITAL_VOLUME_1L,
233f1572a44SRichard Fitzgerald 	       MADERA_IN1L_DIG_VOL_SHIFT, 0xbf, 0, madera_digital_tlv),
234f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("IN1R Digital Volume", MADERA_ADC_DIGITAL_VOLUME_1R,
235f1572a44SRichard Fitzgerald 	       MADERA_IN1R_DIG_VOL_SHIFT, 0xbf, 0, madera_digital_tlv),
236f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("IN2L Digital Volume", MADERA_ADC_DIGITAL_VOLUME_2L,
237f1572a44SRichard Fitzgerald 	       MADERA_IN2L_DIG_VOL_SHIFT, 0xbf, 0, madera_digital_tlv),
238f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("IN2R Digital Volume", MADERA_ADC_DIGITAL_VOLUME_2R,
239f1572a44SRichard Fitzgerald 	       MADERA_IN2R_DIG_VOL_SHIFT, 0xbf, 0, madera_digital_tlv),
240f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("IN3L Digital Volume", MADERA_ADC_DIGITAL_VOLUME_3L,
241f1572a44SRichard Fitzgerald 	       MADERA_IN3L_DIG_VOL_SHIFT, 0xbf, 0, madera_digital_tlv),
242f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("IN3R Digital Volume", MADERA_ADC_DIGITAL_VOLUME_3R,
243f1572a44SRichard Fitzgerald 	       MADERA_IN3R_DIG_VOL_SHIFT, 0xbf, 0, madera_digital_tlv),
244f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("IN4L Digital Volume", MADERA_ADC_DIGITAL_VOLUME_4L,
245f1572a44SRichard Fitzgerald 	       MADERA_IN4L_DIG_VOL_SHIFT, 0xbf, 0, madera_digital_tlv),
246f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("IN4R Digital Volume", MADERA_ADC_DIGITAL_VOLUME_4R,
247f1572a44SRichard Fitzgerald 	       MADERA_IN4R_DIG_VOL_SHIFT, 0xbf, 0, madera_digital_tlv),
248f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("IN5L Digital Volume", MADERA_ADC_DIGITAL_VOLUME_5L,
249f1572a44SRichard Fitzgerald 	       MADERA_IN5L_DIG_VOL_SHIFT, 0xbf, 0, madera_digital_tlv),
250f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("IN5R Digital Volume", MADERA_ADC_DIGITAL_VOLUME_5R,
251f1572a44SRichard Fitzgerald 	       MADERA_IN5R_DIG_VOL_SHIFT, 0xbf, 0, madera_digital_tlv),
252f1572a44SRichard Fitzgerald 
253f1572a44SRichard Fitzgerald SOC_ENUM("Input Ramp Up", madera_in_vi_ramp),
254f1572a44SRichard Fitzgerald SOC_ENUM("Input Ramp Down", madera_in_vd_ramp),
255f1572a44SRichard Fitzgerald 
256f1572a44SRichard Fitzgerald SND_SOC_BYTES("RXANC Coefficients", MADERA_ANC_COEFF_START,
257f1572a44SRichard Fitzgerald 	      MADERA_ANC_COEFF_END - MADERA_ANC_COEFF_START + 1),
258f1572a44SRichard Fitzgerald SND_SOC_BYTES("RXANCL Config", MADERA_FCL_FILTER_CONTROL, 1),
259f1572a44SRichard Fitzgerald SND_SOC_BYTES("RXANCL Coefficients", MADERA_FCL_COEFF_START,
260f1572a44SRichard Fitzgerald 	      MADERA_FCL_COEFF_END - MADERA_FCL_COEFF_START + 1),
261f1572a44SRichard Fitzgerald SND_SOC_BYTES("RXANCR Config", MADERA_FCR_FILTER_CONTROL, 1),
262f1572a44SRichard Fitzgerald SND_SOC_BYTES("RXANCR Coefficients", MADERA_FCR_COEFF_START,
263f1572a44SRichard Fitzgerald 	      MADERA_FCR_COEFF_END - MADERA_FCR_COEFF_START + 1),
264f1572a44SRichard Fitzgerald 
265f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("EQ1", MADERA_EQ1MIX_INPUT_1_SOURCE),
266f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("EQ2", MADERA_EQ2MIX_INPUT_1_SOURCE),
267f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("EQ3", MADERA_EQ3MIX_INPUT_1_SOURCE),
268f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("EQ4", MADERA_EQ4MIX_INPUT_1_SOURCE),
269f1572a44SRichard Fitzgerald 
270f1572a44SRichard Fitzgerald MADERA_EQ_CONTROL("EQ1 Coefficients", MADERA_EQ1_2),
271f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ1 B1 Volume", MADERA_EQ1_1, MADERA_EQ1_B1_GAIN_SHIFT,
272f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
273f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ1 B2 Volume", MADERA_EQ1_1, MADERA_EQ1_B2_GAIN_SHIFT,
274f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
275f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ1 B3 Volume", MADERA_EQ1_1, MADERA_EQ1_B3_GAIN_SHIFT,
276f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
277f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ1 B4 Volume", MADERA_EQ1_2, MADERA_EQ1_B4_GAIN_SHIFT,
278f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
279f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ1 B5 Volume", MADERA_EQ1_2, MADERA_EQ1_B5_GAIN_SHIFT,
280f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
281f1572a44SRichard Fitzgerald 
282f1572a44SRichard Fitzgerald MADERA_EQ_CONTROL("EQ2 Coefficients", MADERA_EQ2_2),
283f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ2 B1 Volume", MADERA_EQ2_1, MADERA_EQ2_B1_GAIN_SHIFT,
284f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
285f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ2 B2 Volume", MADERA_EQ2_1, MADERA_EQ2_B2_GAIN_SHIFT,
286f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
287f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ2 B3 Volume", MADERA_EQ2_1, MADERA_EQ2_B3_GAIN_SHIFT,
288f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
289f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ2 B4 Volume", MADERA_EQ2_2, MADERA_EQ2_B4_GAIN_SHIFT,
290f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
291f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ2 B5 Volume", MADERA_EQ2_2, MADERA_EQ2_B5_GAIN_SHIFT,
292f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
293f1572a44SRichard Fitzgerald 
294f1572a44SRichard Fitzgerald MADERA_EQ_CONTROL("EQ3 Coefficients", MADERA_EQ3_2),
295f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ3 B1 Volume", MADERA_EQ3_1, MADERA_EQ3_B1_GAIN_SHIFT,
296f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
297f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ3 B2 Volume", MADERA_EQ3_1, MADERA_EQ3_B2_GAIN_SHIFT,
298f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
299f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ3 B3 Volume", MADERA_EQ3_1, MADERA_EQ3_B3_GAIN_SHIFT,
300f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
301f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ3 B4 Volume", MADERA_EQ3_2, MADERA_EQ3_B4_GAIN_SHIFT,
302f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
303f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ3 B5 Volume", MADERA_EQ3_2, MADERA_EQ3_B5_GAIN_SHIFT,
304f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
305f1572a44SRichard Fitzgerald 
306f1572a44SRichard Fitzgerald MADERA_EQ_CONTROL("EQ4 Coefficients", MADERA_EQ4_2),
307f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ4 B1 Volume", MADERA_EQ4_1, MADERA_EQ4_B1_GAIN_SHIFT,
308f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
309f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ4 B2 Volume", MADERA_EQ4_1, MADERA_EQ4_B2_GAIN_SHIFT,
310f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
311f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ4 B3 Volume", MADERA_EQ4_1, MADERA_EQ4_B3_GAIN_SHIFT,
312f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
313f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ4 B4 Volume", MADERA_EQ4_2, MADERA_EQ4_B4_GAIN_SHIFT,
314f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
315f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("EQ4 B5 Volume", MADERA_EQ4_2, MADERA_EQ4_B5_GAIN_SHIFT,
316f1572a44SRichard Fitzgerald 	       24, 0, madera_eq_tlv),
317f1572a44SRichard Fitzgerald 
318f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DRC1L", MADERA_DRC1LMIX_INPUT_1_SOURCE),
319f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DRC1R", MADERA_DRC1RMIX_INPUT_1_SOURCE),
320f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DRC2L", MADERA_DRC2LMIX_INPUT_1_SOURCE),
321f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DRC2R", MADERA_DRC2RMIX_INPUT_1_SOURCE),
322f1572a44SRichard Fitzgerald 
323f1572a44SRichard Fitzgerald SND_SOC_BYTES_MASK("DRC1", MADERA_DRC1_CTRL1, 5,
324f1572a44SRichard Fitzgerald 		   MADERA_DRC1R_ENA | MADERA_DRC1L_ENA),
325f1572a44SRichard Fitzgerald SND_SOC_BYTES_MASK("DRC2", MADERA_DRC2_CTRL1, 5,
326f1572a44SRichard Fitzgerald 		   MADERA_DRC2R_ENA | MADERA_DRC2L_ENA),
327f1572a44SRichard Fitzgerald 
328f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("LHPF1", MADERA_HPLP1MIX_INPUT_1_SOURCE),
329f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("LHPF2", MADERA_HPLP2MIX_INPUT_1_SOURCE),
330f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("LHPF3", MADERA_HPLP3MIX_INPUT_1_SOURCE),
331f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("LHPF4", MADERA_HPLP4MIX_INPUT_1_SOURCE),
332f1572a44SRichard Fitzgerald 
333f1572a44SRichard Fitzgerald MADERA_LHPF_CONTROL("LHPF1 Coefficients", MADERA_HPLPF1_2),
334f1572a44SRichard Fitzgerald MADERA_LHPF_CONTROL("LHPF2 Coefficients", MADERA_HPLPF2_2),
335f1572a44SRichard Fitzgerald MADERA_LHPF_CONTROL("LHPF3 Coefficients", MADERA_HPLPF3_2),
336f1572a44SRichard Fitzgerald MADERA_LHPF_CONTROL("LHPF4 Coefficients", MADERA_HPLPF4_2),
337f1572a44SRichard Fitzgerald 
338f1572a44SRichard Fitzgerald SOC_ENUM("LHPF1 Mode", madera_lhpf1_mode),
339f1572a44SRichard Fitzgerald SOC_ENUM("LHPF2 Mode", madera_lhpf2_mode),
340f1572a44SRichard Fitzgerald SOC_ENUM("LHPF3 Mode", madera_lhpf3_mode),
341f1572a44SRichard Fitzgerald SOC_ENUM("LHPF4 Mode", madera_lhpf4_mode),
342f1572a44SRichard Fitzgerald 
343f1572a44SRichard Fitzgerald MADERA_RATE_ENUM("ISRC1 FSL", madera_isrc_fsl[0]),
344f1572a44SRichard Fitzgerald MADERA_RATE_ENUM("ISRC2 FSL", madera_isrc_fsl[1]),
345f1572a44SRichard Fitzgerald MADERA_RATE_ENUM("ISRC3 FSL", madera_isrc_fsl[2]),
346f1572a44SRichard Fitzgerald MADERA_RATE_ENUM("ISRC4 FSL", madera_isrc_fsl[3]),
347f1572a44SRichard Fitzgerald MADERA_RATE_ENUM("ISRC1 FSH", madera_isrc_fsh[0]),
348f1572a44SRichard Fitzgerald MADERA_RATE_ENUM("ISRC2 FSH", madera_isrc_fsh[1]),
349f1572a44SRichard Fitzgerald MADERA_RATE_ENUM("ISRC3 FSH", madera_isrc_fsh[2]),
350f1572a44SRichard Fitzgerald MADERA_RATE_ENUM("ISRC4 FSH", madera_isrc_fsh[3]),
351f1572a44SRichard Fitzgerald MADERA_RATE_ENUM("ASRC1 Rate 1", madera_asrc1_rate[0]),
352f1572a44SRichard Fitzgerald MADERA_RATE_ENUM("ASRC1 Rate 2", madera_asrc1_rate[1]),
353f1572a44SRichard Fitzgerald MADERA_RATE_ENUM("ASRC2 Rate 1", madera_asrc2_rate[0]),
354f1572a44SRichard Fitzgerald MADERA_RATE_ENUM("ASRC2 Rate 2", madera_asrc2_rate[1]),
355f1572a44SRichard Fitzgerald 
356f1572a44SRichard Fitzgerald WM_ADSP2_PRELOAD_SWITCH("DSP1", 1),
357f1572a44SRichard Fitzgerald WM_ADSP2_PRELOAD_SWITCH("DSP2", 2),
358f1572a44SRichard Fitzgerald WM_ADSP2_PRELOAD_SWITCH("DSP3", 3),
359f1572a44SRichard Fitzgerald WM_ADSP2_PRELOAD_SWITCH("DSP4", 4),
360f1572a44SRichard Fitzgerald WM_ADSP2_PRELOAD_SWITCH("DSP5", 5),
361f1572a44SRichard Fitzgerald WM_ADSP2_PRELOAD_SWITCH("DSP6", 6),
362f1572a44SRichard Fitzgerald WM_ADSP2_PRELOAD_SWITCH("DSP7", 7),
363f1572a44SRichard Fitzgerald 
364f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DSP1L", MADERA_DSP1LMIX_INPUT_1_SOURCE),
365f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DSP1R", MADERA_DSP1RMIX_INPUT_1_SOURCE),
366f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DSP2L", MADERA_DSP2LMIX_INPUT_1_SOURCE),
367f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DSP2R", MADERA_DSP2RMIX_INPUT_1_SOURCE),
368f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DSP3L", MADERA_DSP3LMIX_INPUT_1_SOURCE),
369f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DSP3R", MADERA_DSP3RMIX_INPUT_1_SOURCE),
370f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DSP4L", MADERA_DSP4LMIX_INPUT_1_SOURCE),
371f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DSP4R", MADERA_DSP4RMIX_INPUT_1_SOURCE),
372f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DSP5L", MADERA_DSP5LMIX_INPUT_1_SOURCE),
373f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DSP5R", MADERA_DSP5RMIX_INPUT_1_SOURCE),
374f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DSP6L", MADERA_DSP6LMIX_INPUT_1_SOURCE),
375f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DSP6R", MADERA_DSP6RMIX_INPUT_1_SOURCE),
376f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DSP7L", MADERA_DSP7LMIX_INPUT_1_SOURCE),
377f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("DSP7R", MADERA_DSP7RMIX_INPUT_1_SOURCE),
378f1572a44SRichard Fitzgerald 
379f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("Noise Generator Volume", MADERA_COMFORT_NOISE_GENERATOR,
380f1572a44SRichard Fitzgerald 	       MADERA_NOISE_GEN_GAIN_SHIFT, 0x16, 0, madera_noise_tlv),
381f1572a44SRichard Fitzgerald 
382f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("HPOUT1L", MADERA_OUT1LMIX_INPUT_1_SOURCE),
383f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("HPOUT1R", MADERA_OUT1RMIX_INPUT_1_SOURCE),
384f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("HPOUT2L", MADERA_OUT2LMIX_INPUT_1_SOURCE),
385f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("HPOUT2R", MADERA_OUT2RMIX_INPUT_1_SOURCE),
386f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("HPOUT3L", MADERA_OUT3LMIX_INPUT_1_SOURCE),
387f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("HPOUT3R", MADERA_OUT3RMIX_INPUT_1_SOURCE),
388f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("SPKDAT1L", MADERA_OUT5LMIX_INPUT_1_SOURCE),
389f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("SPKDAT1R", MADERA_OUT5RMIX_INPUT_1_SOURCE),
390f1572a44SRichard Fitzgerald 
391f1572a44SRichard Fitzgerald SOC_SINGLE("HPOUT1 SC Protect Switch", MADERA_HP1_SHORT_CIRCUIT_CTRL,
392f1572a44SRichard Fitzgerald 	   MADERA_HP1_SC_ENA_SHIFT, 1, 0),
393f1572a44SRichard Fitzgerald SOC_SINGLE("HPOUT2 SC Protect Switch", MADERA_HP2_SHORT_CIRCUIT_CTRL,
394f1572a44SRichard Fitzgerald 	   MADERA_HP2_SC_ENA_SHIFT, 1, 0),
395f1572a44SRichard Fitzgerald SOC_SINGLE("HPOUT3 SC Protect Switch", MADERA_HP3_SHORT_CIRCUIT_CTRL,
396f1572a44SRichard Fitzgerald 	   MADERA_HP3_SC_ENA_SHIFT, 1, 0),
397f1572a44SRichard Fitzgerald 
398f1572a44SRichard Fitzgerald SOC_SINGLE("SPKDAT1 High Performance Switch", MADERA_OUTPUT_PATH_CONFIG_5L,
399f1572a44SRichard Fitzgerald 	   MADERA_OUT5_OSR_SHIFT, 1, 0),
400f1572a44SRichard Fitzgerald 
401f1572a44SRichard Fitzgerald SOC_DOUBLE_R("HPOUT1 Digital Switch", MADERA_DAC_DIGITAL_VOLUME_1L,
402f1572a44SRichard Fitzgerald 	     MADERA_DAC_DIGITAL_VOLUME_1R, MADERA_OUT1L_MUTE_SHIFT, 1, 1),
403f1572a44SRichard Fitzgerald SOC_DOUBLE_R("HPOUT2 Digital Switch", MADERA_DAC_DIGITAL_VOLUME_2L,
404f1572a44SRichard Fitzgerald 	     MADERA_DAC_DIGITAL_VOLUME_2R, MADERA_OUT2L_MUTE_SHIFT, 1, 1),
405f1572a44SRichard Fitzgerald SOC_DOUBLE_R("HPOUT3 Digital Switch", MADERA_DAC_DIGITAL_VOLUME_3L,
406f1572a44SRichard Fitzgerald 	     MADERA_DAC_DIGITAL_VOLUME_3R, MADERA_OUT3L_MUTE_SHIFT, 1, 1),
407f1572a44SRichard Fitzgerald SOC_DOUBLE_R("SPKDAT1 Digital Switch", MADERA_DAC_DIGITAL_VOLUME_5L,
408f1572a44SRichard Fitzgerald 	     MADERA_DAC_DIGITAL_VOLUME_5R, MADERA_OUT5L_MUTE_SHIFT, 1, 1),
409f1572a44SRichard Fitzgerald 
410f1572a44SRichard Fitzgerald SOC_DOUBLE_R_TLV("HPOUT1 Digital Volume", MADERA_DAC_DIGITAL_VOLUME_1L,
411f1572a44SRichard Fitzgerald 		 MADERA_DAC_DIGITAL_VOLUME_1R, MADERA_OUT1L_VOL_SHIFT,
412f1572a44SRichard Fitzgerald 		 0xbf, 0, madera_digital_tlv),
413f1572a44SRichard Fitzgerald SOC_DOUBLE_R_TLV("HPOUT2 Digital Volume", MADERA_DAC_DIGITAL_VOLUME_2L,
414f1572a44SRichard Fitzgerald 		 MADERA_DAC_DIGITAL_VOLUME_2R, MADERA_OUT2L_VOL_SHIFT,
415f1572a44SRichard Fitzgerald 		 0xbf, 0, madera_digital_tlv),
416f1572a44SRichard Fitzgerald SOC_DOUBLE_R_TLV("HPOUT3 Digital Volume", MADERA_DAC_DIGITAL_VOLUME_3L,
417f1572a44SRichard Fitzgerald 		 MADERA_DAC_DIGITAL_VOLUME_3R, MADERA_OUT3L_VOL_SHIFT,
418f1572a44SRichard Fitzgerald 		 0xbf, 0, madera_digital_tlv),
419f1572a44SRichard Fitzgerald SOC_DOUBLE_R_TLV("SPKDAT1 Digital Volume", MADERA_DAC_DIGITAL_VOLUME_5L,
420f1572a44SRichard Fitzgerald 		 MADERA_DAC_DIGITAL_VOLUME_5R, MADERA_OUT5L_VOL_SHIFT,
421f1572a44SRichard Fitzgerald 		 0xbf, 0, madera_digital_tlv),
422f1572a44SRichard Fitzgerald 
423f1572a44SRichard Fitzgerald SOC_DOUBLE("SPKDAT1 Switch", MADERA_PDM_SPK1_CTRL_1, MADERA_SPK1L_MUTE_SHIFT,
424f1572a44SRichard Fitzgerald 	   MADERA_SPK1R_MUTE_SHIFT, 1, 1),
425f1572a44SRichard Fitzgerald 
426f1572a44SRichard Fitzgerald SOC_ENUM("Output Ramp Up", madera_out_vi_ramp),
427f1572a44SRichard Fitzgerald SOC_ENUM("Output Ramp Down", madera_out_vd_ramp),
428f1572a44SRichard Fitzgerald 
429f1572a44SRichard Fitzgerald SOC_SINGLE("Noise Gate Switch", MADERA_NOISE_GATE_CONTROL,
430f1572a44SRichard Fitzgerald 	   MADERA_NGATE_ENA_SHIFT, 1, 0),
431f1572a44SRichard Fitzgerald SOC_SINGLE_TLV("Noise Gate Threshold Volume", MADERA_NOISE_GATE_CONTROL,
432f1572a44SRichard Fitzgerald 	       MADERA_NGATE_THR_SHIFT, 7, 1, madera_ng_tlv),
433f1572a44SRichard Fitzgerald SOC_ENUM("Noise Gate Hold", madera_ng_hold),
434f1572a44SRichard Fitzgerald 
435f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC1RX Width", madera_dfc_width[0],
436f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
437f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC1RX Type", madera_dfc_type[0],
438f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
439f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC1TX Width", madera_dfc_width[1],
440f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
441f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC1TX Type", madera_dfc_type[1],
442f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
443f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC2RX Width", madera_dfc_width[2],
444f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
445f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC2RX Type", madera_dfc_type[2],
446f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
447f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC2TX Width", madera_dfc_width[3],
448f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
449f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC2TX Type", madera_dfc_type[3],
450f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
451f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC3RX Width", madera_dfc_width[4],
452f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
453f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC3RX Type", madera_dfc_type[4],
454f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
455f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC3TX Width", madera_dfc_width[5],
456f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
457f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC3TX Type", madera_dfc_type[5],
458f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
459f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC4RX Width", madera_dfc_width[6],
460f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
461f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC4RX Type", madera_dfc_type[6],
462f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
463f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC4TX Width", madera_dfc_width[7],
464f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
465f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC4TX Type", madera_dfc_type[7],
466f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
467f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC5RX Width", madera_dfc_width[8],
468f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
469f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC5RX Type", madera_dfc_type[8],
470f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
471f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC5TX Width", madera_dfc_width[9],
472f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
473f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC5TX Type", madera_dfc_type[9],
474f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
475f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC6RX Width", madera_dfc_width[10],
476f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
477f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC6RX Type", madera_dfc_type[10],
478f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
479f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC6TX Width", madera_dfc_width[11],
480f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
481f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC6TX Type", madera_dfc_type[11],
482f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
483f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC7RX Width", madera_dfc_width[12],
484f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
485f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC7RX Type", madera_dfc_type[12],
486f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
487f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC7TX Width", madera_dfc_width[13],
488f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
489f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC7TX Type", madera_dfc_type[13],
490f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
491f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC8RX Width", madera_dfc_width[14],
492f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
493f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC8RX Type", madera_dfc_type[14],
494f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
495f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC8TX Width", madera_dfc_width[15],
496f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
497f1572a44SRichard Fitzgerald SOC_ENUM_EXT("DFC8TX Type", madera_dfc_type[15],
498f1572a44SRichard Fitzgerald 	     snd_soc_get_enum_double, madera_dfc_put),
499f1572a44SRichard Fitzgerald 
500f1572a44SRichard Fitzgerald CS47L90_NG_SRC("HPOUT1L", MADERA_NOISE_GATE_SELECT_1L),
501f1572a44SRichard Fitzgerald CS47L90_NG_SRC("HPOUT1R", MADERA_NOISE_GATE_SELECT_1R),
502f1572a44SRichard Fitzgerald CS47L90_NG_SRC("HPOUT2L", MADERA_NOISE_GATE_SELECT_2L),
503f1572a44SRichard Fitzgerald CS47L90_NG_SRC("HPOUT2R", MADERA_NOISE_GATE_SELECT_2R),
504f1572a44SRichard Fitzgerald CS47L90_NG_SRC("HPOUT3L", MADERA_NOISE_GATE_SELECT_3L),
505f1572a44SRichard Fitzgerald CS47L90_NG_SRC("HPOUT3R", MADERA_NOISE_GATE_SELECT_3R),
506f1572a44SRichard Fitzgerald CS47L90_NG_SRC("SPKDAT1L", MADERA_NOISE_GATE_SELECT_5L),
507f1572a44SRichard Fitzgerald CS47L90_NG_SRC("SPKDAT1R", MADERA_NOISE_GATE_SELECT_5R),
508f1572a44SRichard Fitzgerald 
509f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF1TX1", MADERA_AIF1TX1MIX_INPUT_1_SOURCE),
510f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF1TX2", MADERA_AIF1TX2MIX_INPUT_1_SOURCE),
511f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF1TX3", MADERA_AIF1TX3MIX_INPUT_1_SOURCE),
512f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF1TX4", MADERA_AIF1TX4MIX_INPUT_1_SOURCE),
513f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF1TX5", MADERA_AIF1TX5MIX_INPUT_1_SOURCE),
514f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF1TX6", MADERA_AIF1TX6MIX_INPUT_1_SOURCE),
515f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF1TX7", MADERA_AIF1TX7MIX_INPUT_1_SOURCE),
516f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF1TX8", MADERA_AIF1TX8MIX_INPUT_1_SOURCE),
517f1572a44SRichard Fitzgerald 
518f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF2TX1", MADERA_AIF2TX1MIX_INPUT_1_SOURCE),
519f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF2TX2", MADERA_AIF2TX2MIX_INPUT_1_SOURCE),
520f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF2TX3", MADERA_AIF2TX3MIX_INPUT_1_SOURCE),
521f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF2TX4", MADERA_AIF2TX4MIX_INPUT_1_SOURCE),
522f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF2TX5", MADERA_AIF2TX5MIX_INPUT_1_SOURCE),
523f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF2TX6", MADERA_AIF2TX6MIX_INPUT_1_SOURCE),
524f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF2TX7", MADERA_AIF2TX7MIX_INPUT_1_SOURCE),
525f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF2TX8", MADERA_AIF2TX8MIX_INPUT_1_SOURCE),
526f1572a44SRichard Fitzgerald 
527f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF3TX1", MADERA_AIF3TX1MIX_INPUT_1_SOURCE),
528f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF3TX2", MADERA_AIF3TX2MIX_INPUT_1_SOURCE),
529f1572a44SRichard Fitzgerald 
530f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF4TX1", MADERA_AIF4TX1MIX_INPUT_1_SOURCE),
531f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("AIF4TX2", MADERA_AIF4TX2MIX_INPUT_1_SOURCE),
532f1572a44SRichard Fitzgerald 
533f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("SLIMTX1", MADERA_SLIMTX1MIX_INPUT_1_SOURCE),
534f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("SLIMTX2", MADERA_SLIMTX2MIX_INPUT_1_SOURCE),
535f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("SLIMTX3", MADERA_SLIMTX3MIX_INPUT_1_SOURCE),
536f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("SLIMTX4", MADERA_SLIMTX4MIX_INPUT_1_SOURCE),
537f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("SLIMTX5", MADERA_SLIMTX5MIX_INPUT_1_SOURCE),
538f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("SLIMTX6", MADERA_SLIMTX6MIX_INPUT_1_SOURCE),
539f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("SLIMTX7", MADERA_SLIMTX7MIX_INPUT_1_SOURCE),
540f1572a44SRichard Fitzgerald MADERA_MIXER_CONTROLS("SLIMTX8", MADERA_SLIMTX8MIX_INPUT_1_SOURCE),
541f1572a44SRichard Fitzgerald 
542f1572a44SRichard Fitzgerald MADERA_GAINMUX_CONTROLS("SPDIF1TX1", MADERA_SPDIF1TX1MIX_INPUT_1_SOURCE),
543f1572a44SRichard Fitzgerald MADERA_GAINMUX_CONTROLS("SPDIF1TX2", MADERA_SPDIF1TX2MIX_INPUT_1_SOURCE),
544f1572a44SRichard Fitzgerald 
545f1572a44SRichard Fitzgerald WM_ADSP_FW_CONTROL("DSP1", 0),
546f1572a44SRichard Fitzgerald WM_ADSP_FW_CONTROL("DSP2", 1),
547f1572a44SRichard Fitzgerald WM_ADSP_FW_CONTROL("DSP3", 2),
548f1572a44SRichard Fitzgerald WM_ADSP_FW_CONTROL("DSP4", 3),
549f1572a44SRichard Fitzgerald WM_ADSP_FW_CONTROL("DSP5", 4),
550f1572a44SRichard Fitzgerald WM_ADSP_FW_CONTROL("DSP6", 5),
551f1572a44SRichard Fitzgerald WM_ADSP_FW_CONTROL("DSP7", 6),
552f1572a44SRichard Fitzgerald };
553f1572a44SRichard Fitzgerald 
554f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(EQ1, MADERA_EQ1MIX_INPUT_1_SOURCE);
555f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(EQ2, MADERA_EQ2MIX_INPUT_1_SOURCE);
556f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(EQ3, MADERA_EQ3MIX_INPUT_1_SOURCE);
557f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(EQ4, MADERA_EQ4MIX_INPUT_1_SOURCE);
558f1572a44SRichard Fitzgerald 
559f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DRC1L, MADERA_DRC1LMIX_INPUT_1_SOURCE);
560f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DRC1R, MADERA_DRC1RMIX_INPUT_1_SOURCE);
561f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DRC2L, MADERA_DRC2LMIX_INPUT_1_SOURCE);
562f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DRC2R, MADERA_DRC2RMIX_INPUT_1_SOURCE);
563f1572a44SRichard Fitzgerald 
564f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(LHPF1, MADERA_HPLP1MIX_INPUT_1_SOURCE);
565f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(LHPF2, MADERA_HPLP2MIX_INPUT_1_SOURCE);
566f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(LHPF3, MADERA_HPLP3MIX_INPUT_1_SOURCE);
567f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(LHPF4, MADERA_HPLP4MIX_INPUT_1_SOURCE);
568f1572a44SRichard Fitzgerald 
569f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DSP1L, MADERA_DSP1LMIX_INPUT_1_SOURCE);
570f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DSP1R, MADERA_DSP1RMIX_INPUT_1_SOURCE);
571f1572a44SRichard Fitzgerald MADERA_DSP_AUX_ENUMS(DSP1, MADERA_DSP1AUX1MIX_INPUT_1_SOURCE);
572f1572a44SRichard Fitzgerald 
573f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DSP2L, MADERA_DSP2LMIX_INPUT_1_SOURCE);
574f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DSP2R, MADERA_DSP2RMIX_INPUT_1_SOURCE);
575f1572a44SRichard Fitzgerald MADERA_DSP_AUX_ENUMS(DSP2, MADERA_DSP2AUX1MIX_INPUT_1_SOURCE);
576f1572a44SRichard Fitzgerald 
577f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DSP3L, MADERA_DSP3LMIX_INPUT_1_SOURCE);
578f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DSP3R, MADERA_DSP3RMIX_INPUT_1_SOURCE);
579f1572a44SRichard Fitzgerald MADERA_DSP_AUX_ENUMS(DSP3, MADERA_DSP3AUX1MIX_INPUT_1_SOURCE);
580f1572a44SRichard Fitzgerald 
581f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DSP4L, MADERA_DSP4LMIX_INPUT_1_SOURCE);
582f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DSP4R, MADERA_DSP4RMIX_INPUT_1_SOURCE);
583f1572a44SRichard Fitzgerald MADERA_DSP_AUX_ENUMS(DSP4, MADERA_DSP4AUX1MIX_INPUT_1_SOURCE);
584f1572a44SRichard Fitzgerald 
585f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DSP5L, MADERA_DSP5LMIX_INPUT_1_SOURCE);
586f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DSP5R, MADERA_DSP5RMIX_INPUT_1_SOURCE);
587f1572a44SRichard Fitzgerald MADERA_DSP_AUX_ENUMS(DSP5, MADERA_DSP5AUX1MIX_INPUT_1_SOURCE);
588f1572a44SRichard Fitzgerald 
589f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DSP6L, MADERA_DSP6LMIX_INPUT_1_SOURCE);
590f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DSP6R, MADERA_DSP6RMIX_INPUT_1_SOURCE);
591f1572a44SRichard Fitzgerald MADERA_DSP_AUX_ENUMS(DSP6, MADERA_DSP6AUX1MIX_INPUT_1_SOURCE);
592f1572a44SRichard Fitzgerald 
593f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DSP7L, MADERA_DSP7LMIX_INPUT_1_SOURCE);
594f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(DSP7R, MADERA_DSP7RMIX_INPUT_1_SOURCE);
595f1572a44SRichard Fitzgerald MADERA_DSP_AUX_ENUMS(DSP7, MADERA_DSP7AUX1MIX_INPUT_1_SOURCE);
596f1572a44SRichard Fitzgerald 
597f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(PWM1, MADERA_PWM1MIX_INPUT_1_SOURCE);
598f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(PWM2, MADERA_PWM2MIX_INPUT_1_SOURCE);
599f1572a44SRichard Fitzgerald 
600f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(OUT1L, MADERA_OUT1LMIX_INPUT_1_SOURCE);
601f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(OUT1R, MADERA_OUT1RMIX_INPUT_1_SOURCE);
602f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(OUT2L, MADERA_OUT2LMIX_INPUT_1_SOURCE);
603f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(OUT2R, MADERA_OUT2RMIX_INPUT_1_SOURCE);
604f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(OUT3L, MADERA_OUT3LMIX_INPUT_1_SOURCE);
605f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(OUT3R, MADERA_OUT3RMIX_INPUT_1_SOURCE);
606f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(SPKDAT1L, MADERA_OUT5LMIX_INPUT_1_SOURCE);
607f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(SPKDAT1R, MADERA_OUT5RMIX_INPUT_1_SOURCE);
608f1572a44SRichard Fitzgerald 
609f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF1TX1, MADERA_AIF1TX1MIX_INPUT_1_SOURCE);
610f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF1TX2, MADERA_AIF1TX2MIX_INPUT_1_SOURCE);
611f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF1TX3, MADERA_AIF1TX3MIX_INPUT_1_SOURCE);
612f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF1TX4, MADERA_AIF1TX4MIX_INPUT_1_SOURCE);
613f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF1TX5, MADERA_AIF1TX5MIX_INPUT_1_SOURCE);
614f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF1TX6, MADERA_AIF1TX6MIX_INPUT_1_SOURCE);
615f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF1TX7, MADERA_AIF1TX7MIX_INPUT_1_SOURCE);
616f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF1TX8, MADERA_AIF1TX8MIX_INPUT_1_SOURCE);
617f1572a44SRichard Fitzgerald 
618f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF2TX1, MADERA_AIF2TX1MIX_INPUT_1_SOURCE);
619f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF2TX2, MADERA_AIF2TX2MIX_INPUT_1_SOURCE);
620f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF2TX3, MADERA_AIF2TX3MIX_INPUT_1_SOURCE);
621f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF2TX4, MADERA_AIF2TX4MIX_INPUT_1_SOURCE);
622f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF2TX5, MADERA_AIF2TX5MIX_INPUT_1_SOURCE);
623f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF2TX6, MADERA_AIF2TX6MIX_INPUT_1_SOURCE);
624f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF2TX7, MADERA_AIF2TX7MIX_INPUT_1_SOURCE);
625f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF2TX8, MADERA_AIF2TX8MIX_INPUT_1_SOURCE);
626f1572a44SRichard Fitzgerald 
627f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF3TX1, MADERA_AIF3TX1MIX_INPUT_1_SOURCE);
628f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF3TX2, MADERA_AIF3TX2MIX_INPUT_1_SOURCE);
629f1572a44SRichard Fitzgerald 
630f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF4TX1, MADERA_AIF4TX1MIX_INPUT_1_SOURCE);
631f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(AIF4TX2, MADERA_AIF4TX2MIX_INPUT_1_SOURCE);
632f1572a44SRichard Fitzgerald 
633f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(SLIMTX1, MADERA_SLIMTX1MIX_INPUT_1_SOURCE);
634f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(SLIMTX2, MADERA_SLIMTX2MIX_INPUT_1_SOURCE);
635f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(SLIMTX3, MADERA_SLIMTX3MIX_INPUT_1_SOURCE);
636f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(SLIMTX4, MADERA_SLIMTX4MIX_INPUT_1_SOURCE);
637f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(SLIMTX5, MADERA_SLIMTX5MIX_INPUT_1_SOURCE);
638f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(SLIMTX6, MADERA_SLIMTX6MIX_INPUT_1_SOURCE);
639f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(SLIMTX7, MADERA_SLIMTX7MIX_INPUT_1_SOURCE);
640f1572a44SRichard Fitzgerald MADERA_MIXER_ENUMS(SLIMTX8, MADERA_SLIMTX8MIX_INPUT_1_SOURCE);
641f1572a44SRichard Fitzgerald 
642f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(SPD1TX1, MADERA_SPDIF1TX1MIX_INPUT_1_SOURCE);
643f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(SPD1TX2, MADERA_SPDIF1TX2MIX_INPUT_1_SOURCE);
644f1572a44SRichard Fitzgerald 
645f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ASRC1IN1L, MADERA_ASRC1_1LMIX_INPUT_1_SOURCE);
646f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ASRC1IN1R, MADERA_ASRC1_1RMIX_INPUT_1_SOURCE);
647f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ASRC1IN2L, MADERA_ASRC1_2LMIX_INPUT_1_SOURCE);
648f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ASRC1IN2R, MADERA_ASRC1_2RMIX_INPUT_1_SOURCE);
649f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ASRC2IN1L, MADERA_ASRC2_1LMIX_INPUT_1_SOURCE);
650f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ASRC2IN1R, MADERA_ASRC2_1RMIX_INPUT_1_SOURCE);
651f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ASRC2IN2L, MADERA_ASRC2_2LMIX_INPUT_1_SOURCE);
652f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ASRC2IN2R, MADERA_ASRC2_2RMIX_INPUT_1_SOURCE);
653f1572a44SRichard Fitzgerald 
654f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC1INT1, MADERA_ISRC1INT1MIX_INPUT_1_SOURCE);
655f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC1INT2, MADERA_ISRC1INT2MIX_INPUT_1_SOURCE);
656f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC1INT3, MADERA_ISRC1INT3MIX_INPUT_1_SOURCE);
657f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC1INT4, MADERA_ISRC1INT4MIX_INPUT_1_SOURCE);
658f1572a44SRichard Fitzgerald 
659f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC1DEC1, MADERA_ISRC1DEC1MIX_INPUT_1_SOURCE);
660f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC1DEC2, MADERA_ISRC1DEC2MIX_INPUT_1_SOURCE);
661f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC1DEC3, MADERA_ISRC1DEC3MIX_INPUT_1_SOURCE);
662f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC1DEC4, MADERA_ISRC1DEC4MIX_INPUT_1_SOURCE);
663f1572a44SRichard Fitzgerald 
664f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC2INT1, MADERA_ISRC2INT1MIX_INPUT_1_SOURCE);
665f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC2INT2, MADERA_ISRC2INT2MIX_INPUT_1_SOURCE);
666f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC2INT3, MADERA_ISRC2INT3MIX_INPUT_1_SOURCE);
667f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC2INT4, MADERA_ISRC2INT4MIX_INPUT_1_SOURCE);
668f1572a44SRichard Fitzgerald 
669f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC2DEC1, MADERA_ISRC2DEC1MIX_INPUT_1_SOURCE);
670f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC2DEC2, MADERA_ISRC2DEC2MIX_INPUT_1_SOURCE);
671f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC2DEC3, MADERA_ISRC2DEC3MIX_INPUT_1_SOURCE);
672f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC2DEC4, MADERA_ISRC2DEC4MIX_INPUT_1_SOURCE);
673f1572a44SRichard Fitzgerald 
674f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC3INT1, MADERA_ISRC3INT1MIX_INPUT_1_SOURCE);
675f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC3INT2, MADERA_ISRC3INT2MIX_INPUT_1_SOURCE);
676f1572a44SRichard Fitzgerald 
677f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC3DEC1, MADERA_ISRC3DEC1MIX_INPUT_1_SOURCE);
678f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC3DEC2, MADERA_ISRC3DEC2MIX_INPUT_1_SOURCE);
679f1572a44SRichard Fitzgerald 
680f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC4INT1, MADERA_ISRC4INT1MIX_INPUT_1_SOURCE);
681f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC4INT2, MADERA_ISRC4INT2MIX_INPUT_1_SOURCE);
682f1572a44SRichard Fitzgerald 
683f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC4DEC1, MADERA_ISRC4DEC1MIX_INPUT_1_SOURCE);
684f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(ISRC4DEC2, MADERA_ISRC4DEC2MIX_INPUT_1_SOURCE);
685f1572a44SRichard Fitzgerald 
686f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(DFC1, MADERA_DFC1MIX_INPUT_1_SOURCE);
687f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(DFC2, MADERA_DFC2MIX_INPUT_1_SOURCE);
688f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(DFC3, MADERA_DFC3MIX_INPUT_1_SOURCE);
689f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(DFC4, MADERA_DFC4MIX_INPUT_1_SOURCE);
690f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(DFC5, MADERA_DFC5MIX_INPUT_1_SOURCE);
691f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(DFC6, MADERA_DFC6MIX_INPUT_1_SOURCE);
692f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(DFC7, MADERA_DFC7MIX_INPUT_1_SOURCE);
693f1572a44SRichard Fitzgerald MADERA_MUX_ENUMS(DFC8, MADERA_DFC8MIX_INPUT_1_SOURCE);
694f1572a44SRichard Fitzgerald 
695f1572a44SRichard Fitzgerald static const char * const cs47l90_aec_loopback_texts[] = {
696f1572a44SRichard Fitzgerald 	"HPOUT1L", "HPOUT1R", "HPOUT2L", "HPOUT2R", "HPOUT3L", "HPOUT3R",
697f1572a44SRichard Fitzgerald 	"SPKDAT1L", "SPKDAT1R",
698f1572a44SRichard Fitzgerald };
699f1572a44SRichard Fitzgerald 
700f1572a44SRichard Fitzgerald static const unsigned int cs47l90_aec_loopback_values[] = {
701f1572a44SRichard Fitzgerald 	0, 1, 2, 3, 4, 5, 8, 9,
702f1572a44SRichard Fitzgerald };
703f1572a44SRichard Fitzgerald 
704f1572a44SRichard Fitzgerald static const struct soc_enum cs47l90_aec1_loopback =
705f1572a44SRichard Fitzgerald 	SOC_VALUE_ENUM_SINGLE(MADERA_DAC_AEC_CONTROL_1,
706f1572a44SRichard Fitzgerald 			      MADERA_AEC1_LOOPBACK_SRC_SHIFT, 0xf,
707f1572a44SRichard Fitzgerald 			      ARRAY_SIZE(cs47l90_aec_loopback_texts),
708f1572a44SRichard Fitzgerald 			      cs47l90_aec_loopback_texts,
709f1572a44SRichard Fitzgerald 			      cs47l90_aec_loopback_values);
710f1572a44SRichard Fitzgerald 
711f1572a44SRichard Fitzgerald static const struct soc_enum cs47l90_aec2_loopback =
712f1572a44SRichard Fitzgerald 	SOC_VALUE_ENUM_SINGLE(MADERA_DAC_AEC_CONTROL_2,
713f1572a44SRichard Fitzgerald 			      MADERA_AEC2_LOOPBACK_SRC_SHIFT, 0xf,
714f1572a44SRichard Fitzgerald 			      ARRAY_SIZE(cs47l90_aec_loopback_texts),
715f1572a44SRichard Fitzgerald 			      cs47l90_aec_loopback_texts,
716f1572a44SRichard Fitzgerald 			      cs47l90_aec_loopback_values);
717f1572a44SRichard Fitzgerald 
718f1572a44SRichard Fitzgerald static const struct snd_kcontrol_new cs47l90_aec_loopback_mux[] = {
719f1572a44SRichard Fitzgerald 	SOC_DAPM_ENUM("AEC1 Loopback", cs47l90_aec1_loopback),
720f1572a44SRichard Fitzgerald 	SOC_DAPM_ENUM("AEC2 Loopback", cs47l90_aec2_loopback),
721f1572a44SRichard Fitzgerald };
722f1572a44SRichard Fitzgerald 
723f1572a44SRichard Fitzgerald static const struct snd_kcontrol_new cs47l90_anc_input_mux[] = {
724f1572a44SRichard Fitzgerald 	SOC_DAPM_ENUM("RXANCL Input", madera_anc_input_src[0]),
725f1572a44SRichard Fitzgerald 	SOC_DAPM_ENUM("RXANCL Channel", madera_anc_input_src[1]),
726f1572a44SRichard Fitzgerald 	SOC_DAPM_ENUM("RXANCR Input", madera_anc_input_src[2]),
727f1572a44SRichard Fitzgerald 	SOC_DAPM_ENUM("RXANCR Channel", madera_anc_input_src[3]),
728f1572a44SRichard Fitzgerald };
729f1572a44SRichard Fitzgerald 
730f1572a44SRichard Fitzgerald static const struct snd_kcontrol_new cs47l90_anc_ng_mux =
731f1572a44SRichard Fitzgerald 	SOC_DAPM_ENUM("RXANC NG Source", madera_anc_ng_enum);
732f1572a44SRichard Fitzgerald 
733f1572a44SRichard Fitzgerald static const struct snd_kcontrol_new cs47l90_output_anc_src[] = {
734f1572a44SRichard Fitzgerald 	SOC_DAPM_ENUM("HPOUT1L ANC Source", madera_output_anc_src[0]),
735f1572a44SRichard Fitzgerald 	SOC_DAPM_ENUM("HPOUT1R ANC Source", madera_output_anc_src[1]),
736f1572a44SRichard Fitzgerald 	SOC_DAPM_ENUM("HPOUT2L ANC Source", madera_output_anc_src[2]),
737f1572a44SRichard Fitzgerald 	SOC_DAPM_ENUM("HPOUT2R ANC Source", madera_output_anc_src[3]),
738f1572a44SRichard Fitzgerald 	SOC_DAPM_ENUM("HPOUT3L ANC Source", madera_output_anc_src[4]),
739f1572a44SRichard Fitzgerald 	SOC_DAPM_ENUM("HPOUT3R ANC Source", madera_output_anc_src[0]),
740f1572a44SRichard Fitzgerald 	SOC_DAPM_ENUM("SPKDAT1L ANC Source", madera_output_anc_src[8]),
741f1572a44SRichard Fitzgerald 	SOC_DAPM_ENUM("SPKDAT1R ANC Source", madera_output_anc_src[9]),
742f1572a44SRichard Fitzgerald };
743f1572a44SRichard Fitzgerald 
744f1572a44SRichard Fitzgerald static const struct snd_soc_dapm_widget cs47l90_dapm_widgets[] = {
745f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("SYSCLK", MADERA_SYSTEM_CLOCK_1, MADERA_SYSCLK_ENA_SHIFT,
746f1572a44SRichard Fitzgerald 		    0, madera_sysclk_ev,
7471094af11SCharles Keepax 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU |
7481094af11SCharles Keepax 		    SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD),
749f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("ASYNCCLK", MADERA_ASYNC_CLOCK_1,
7501094af11SCharles Keepax 		    MADERA_ASYNC_CLK_ENA_SHIFT, 0, madera_clk_ev,
7511094af11SCharles Keepax 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
752f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("OPCLK", MADERA_OUTPUT_SYSTEM_CLOCK,
753f1572a44SRichard Fitzgerald 		    MADERA_OPCLK_ENA_SHIFT, 0, NULL, 0),
754f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("ASYNCOPCLK", MADERA_OUTPUT_ASYNC_CLOCK,
755f1572a44SRichard Fitzgerald 		    MADERA_OPCLK_ASYNC_ENA_SHIFT, 0, NULL, 0),
7561094af11SCharles Keepax SND_SOC_DAPM_SUPPLY("DSPCLK", MADERA_DSP_CLOCK_1, MADERA_DSP_CLK_ENA_SHIFT,
7571094af11SCharles Keepax 		    0, madera_clk_ev,
7581094af11SCharles Keepax 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
759f1572a44SRichard Fitzgerald 
760f1572a44SRichard Fitzgerald SND_SOC_DAPM_REGULATOR_SUPPLY("DBVDD2", 0, 0),
761f1572a44SRichard Fitzgerald SND_SOC_DAPM_REGULATOR_SUPPLY("DBVDD3", 0, 0),
762f1572a44SRichard Fitzgerald SND_SOC_DAPM_REGULATOR_SUPPLY("DBVDD4", 0, 0),
763f1572a44SRichard Fitzgerald SND_SOC_DAPM_REGULATOR_SUPPLY("CPVDD1", 20, 0),
764f1572a44SRichard Fitzgerald SND_SOC_DAPM_REGULATOR_SUPPLY("CPVDD2", 20, 0),
765f1572a44SRichard Fitzgerald SND_SOC_DAPM_REGULATOR_SUPPLY("MICVDD", 0, SND_SOC_DAPM_REGULATOR_BYPASS),
766f1572a44SRichard Fitzgerald 
767f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("MICBIAS1", MADERA_MIC_BIAS_CTRL_1,
768f1572a44SRichard Fitzgerald 		    MADERA_MICB1_ENA_SHIFT, 0, NULL, 0),
769f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("MICBIAS2", MADERA_MIC_BIAS_CTRL_2,
770f1572a44SRichard Fitzgerald 		    MADERA_MICB1_ENA_SHIFT, 0, NULL, 0),
771f1572a44SRichard Fitzgerald 
772f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("MICBIAS1A", MADERA_MIC_BIAS_CTRL_5,
773f1572a44SRichard Fitzgerald 		    MADERA_MICB1A_ENA_SHIFT, 0, NULL, 0),
774f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("MICBIAS1B", MADERA_MIC_BIAS_CTRL_5,
775f1572a44SRichard Fitzgerald 		    MADERA_MICB1B_ENA_SHIFT, 0, NULL, 0),
776f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("MICBIAS1C", MADERA_MIC_BIAS_CTRL_5,
777f1572a44SRichard Fitzgerald 		    MADERA_MICB1C_ENA_SHIFT, 0, NULL, 0),
778f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("MICBIAS1D", MADERA_MIC_BIAS_CTRL_5,
779f1572a44SRichard Fitzgerald 		    MADERA_MICB1D_ENA_SHIFT, 0, NULL, 0),
780f1572a44SRichard Fitzgerald 
781f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("MICBIAS2A", MADERA_MIC_BIAS_CTRL_6,
782f1572a44SRichard Fitzgerald 		    MADERA_MICB2A_ENA_SHIFT, 0, NULL, 0),
783f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("MICBIAS2B", MADERA_MIC_BIAS_CTRL_6,
784f1572a44SRichard Fitzgerald 		    MADERA_MICB2B_ENA_SHIFT, 0, NULL, 0),
785f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("MICBIAS2C", MADERA_MIC_BIAS_CTRL_6,
786f1572a44SRichard Fitzgerald 		    MADERA_MICB2C_ENA_SHIFT, 0, NULL, 0),
787f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("MICBIAS2D", MADERA_MIC_BIAS_CTRL_6,
788f1572a44SRichard Fitzgerald 		    MADERA_MICB2D_ENA_SHIFT, 0, NULL, 0),
789f1572a44SRichard Fitzgerald 
790f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("FXCLK", SND_SOC_NOPM,
791f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_FX, 0,
792f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
793f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
794f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("ASRC1CLK", SND_SOC_NOPM,
795f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_ASRC1, 0,
796f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
797f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
798f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("ASRC2CLK", SND_SOC_NOPM,
799f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_ASRC2, 0,
800f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
801f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
802f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("ISRC1CLK", SND_SOC_NOPM,
803f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_ISRC1, 0,
804f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
805f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
806f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("ISRC2CLK", SND_SOC_NOPM,
807f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_ISRC2, 0,
808f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
809f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
810f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("ISRC3CLK", SND_SOC_NOPM,
811f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_ISRC3, 0,
812f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
813f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
814f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("ISRC4CLK", SND_SOC_NOPM,
815f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_ISRC4, 0,
816f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
817f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
818f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("OUTCLK", SND_SOC_NOPM,
819f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_OUT, 0,
820f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
821f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
822f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("SPDCLK", SND_SOC_NOPM,
823f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_SPD, 0,
824f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
825f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
826f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("DSP1CLK", SND_SOC_NOPM,
827f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_DSP1, 0,
828f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
829f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
830f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("DSP2CLK", SND_SOC_NOPM,
831f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_DSP2, 0,
832f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
833f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
834f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("DSP3CLK", SND_SOC_NOPM,
835f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_DSP3, 0,
836f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
837f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
838f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("DSP4CLK", SND_SOC_NOPM,
839f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_DSP4, 0,
840f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
841f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
842f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("DSP5CLK", SND_SOC_NOPM,
843f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_DSP5, 0,
844f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
845f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
846f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("DSP6CLK", SND_SOC_NOPM,
847f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_DSP6, 0,
848f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
849f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
850f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("DSP7CLK", SND_SOC_NOPM,
851f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_DSP7, 0,
852f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
853f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
854f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("AIF1TXCLK", SND_SOC_NOPM,
855f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_AIF1, 0,
856f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
857f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
858f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("AIF2TXCLK", SND_SOC_NOPM,
859f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_AIF2, 0,
860f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
861f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
862f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("AIF3TXCLK", SND_SOC_NOPM,
863f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_AIF3, 0,
864f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
865f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
866f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("AIF4TXCLK", SND_SOC_NOPM,
867f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_AIF4, 0,
868f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
869f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
870f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("SLIMBUSCLK", SND_SOC_NOPM,
871f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_SLIMBUS, 0,
872f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
873f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
874f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("PWMCLK", SND_SOC_NOPM,
875f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_PWM, 0,
876f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
877f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
878f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("DFCCLK", SND_SOC_NOPM,
879f1572a44SRichard Fitzgerald 		    MADERA_DOM_GRP_DFC, 0,
880f1572a44SRichard Fitzgerald 		    madera_domain_clk_ev,
881f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
882f1572a44SRichard Fitzgerald 
883f1572a44SRichard Fitzgerald SND_SOC_DAPM_SIGGEN("TONE"),
884f1572a44SRichard Fitzgerald SND_SOC_DAPM_SIGGEN("NOISE"),
885f1572a44SRichard Fitzgerald 
886f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("IN1ALN"),
887f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("IN1ALP"),
888f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("IN1BLN"),
889f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("IN1BLP"),
890f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("IN1ARN"),
891f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("IN1ARP"),
892f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("IN1BRN"),
893f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("IN1BRP"),
894f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("IN2ALN"),
895f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("IN2ALP"),
896f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("IN2BLN"),
897f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("IN2BLP"),
898f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("IN2RN"),
899f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("IN2RP"),
900f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("DMICCLK3"),
901f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("DMICDAT3"),
902f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("DMICCLK4"),
903f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("DMICDAT4"),
904f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("DMICCLK5"),
905f1572a44SRichard Fitzgerald SND_SOC_DAPM_INPUT("DMICDAT5"),
906f1572a44SRichard Fitzgerald 
907f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("IN1L Analog Mux", SND_SOC_NOPM, 0, 0, &madera_inmux[0]),
908f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("IN1R Analog Mux", SND_SOC_NOPM, 0, 0, &madera_inmux[1]),
909f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("IN2L Analog Mux", SND_SOC_NOPM, 0, 0, &madera_inmux[2]),
910f1572a44SRichard Fitzgerald 
911f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("IN1L Mode", SND_SOC_NOPM, 0, 0, &madera_inmode[0]),
912f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("IN1R Mode", SND_SOC_NOPM, 0, 0, &madera_inmode[0]),
913f1572a44SRichard Fitzgerald 
914f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("IN2L Mode", SND_SOC_NOPM, 0, 0, &madera_inmode[1]),
915f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("IN2R Mode", SND_SOC_NOPM, 0, 0, &madera_inmode[1]),
916f1572a44SRichard Fitzgerald 
917f1572a44SRichard Fitzgerald SND_SOC_DAPM_OUTPUT("DRC1 Signal Activity"),
918f1572a44SRichard Fitzgerald SND_SOC_DAPM_OUTPUT("DRC2 Signal Activity"),
919f1572a44SRichard Fitzgerald 
920f1572a44SRichard Fitzgerald SND_SOC_DAPM_OUTPUT("DSP Trigger Out"),
921f1572a44SRichard Fitzgerald 
922f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("PWM1 Driver", MADERA_PWM_DRIVE_1, MADERA_PWM1_ENA_SHIFT,
923f1572a44SRichard Fitzgerald 		 0, NULL, 0),
924f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("PWM2 Driver", MADERA_PWM_DRIVE_1, MADERA_PWM2_ENA_SHIFT,
925f1572a44SRichard Fitzgerald 		 0, NULL, 0),
926f1572a44SRichard Fitzgerald 
927f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("RXANC NG External Clock", SND_SOC_NOPM,
928f1572a44SRichard Fitzgerald 		    MADERA_EXT_NG_SEL_SET_SHIFT, 0, madera_anc_ev,
929f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_PRE_PMD),
930f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("RXANCL NG External", SND_SOC_NOPM, 0, 0, NULL, 0),
931f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("RXANCR NG External", SND_SOC_NOPM, 0, 0, NULL, 0),
932f1572a44SRichard Fitzgerald 
933f1572a44SRichard Fitzgerald SND_SOC_DAPM_SUPPLY("RXANC NG Clock", SND_SOC_NOPM,
934f1572a44SRichard Fitzgerald 		    MADERA_CLK_NG_ENA_SET_SHIFT, 0, madera_anc_ev,
935f1572a44SRichard Fitzgerald 		    SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_PRE_PMD),
936f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("RXANCL NG Internal", SND_SOC_NOPM, 0, 0, NULL, 0),
937f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("RXANCR NG Internal", SND_SOC_NOPM, 0, 0, NULL, 0),
938f1572a44SRichard Fitzgerald 
939f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("RXANCL Left Input", SND_SOC_NOPM, 0, 0,
940f1572a44SRichard Fitzgerald 		 &cs47l90_anc_input_mux[0]),
941f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("RXANCL Right Input", SND_SOC_NOPM, 0, 0,
942f1572a44SRichard Fitzgerald 		 &cs47l90_anc_input_mux[0]),
943f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("RXANCL Channel", SND_SOC_NOPM, 0, 0,
944f1572a44SRichard Fitzgerald 		 &cs47l90_anc_input_mux[1]),
945f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("RXANCL NG Mux", SND_SOC_NOPM, 0, 0, &cs47l90_anc_ng_mux),
946f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("RXANCR Left Input", SND_SOC_NOPM, 0, 0,
947f1572a44SRichard Fitzgerald 		 &cs47l90_anc_input_mux[2]),
948f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("RXANCR Right Input", SND_SOC_NOPM, 0, 0,
949f1572a44SRichard Fitzgerald 		 &cs47l90_anc_input_mux[2]),
950f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("RXANCR Channel", SND_SOC_NOPM, 0, 0,
951f1572a44SRichard Fitzgerald 		 &cs47l90_anc_input_mux[3]),
952f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("RXANCR NG Mux", SND_SOC_NOPM, 0, 0, &cs47l90_anc_ng_mux),
953f1572a44SRichard Fitzgerald 
954f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("RXANCL", SND_SOC_NOPM, MADERA_CLK_L_ENA_SET_SHIFT,
955f1572a44SRichard Fitzgerald 		   0, NULL, 0, madera_anc_ev,
956f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_PRE_PMD),
957f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("RXANCR", SND_SOC_NOPM, MADERA_CLK_R_ENA_SET_SHIFT,
958f1572a44SRichard Fitzgerald 		   0, NULL, 0, madera_anc_ev,
959f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_PRE_PMD),
960f1572a44SRichard Fitzgerald 
961f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("HPOUT1L ANC Source", SND_SOC_NOPM, 0, 0,
962f1572a44SRichard Fitzgerald 		 &cs47l90_output_anc_src[0]),
963f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("HPOUT1R ANC Source", SND_SOC_NOPM, 0, 0,
964f1572a44SRichard Fitzgerald 		 &cs47l90_output_anc_src[1]),
965f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("HPOUT2L ANC Source", SND_SOC_NOPM, 0, 0,
966f1572a44SRichard Fitzgerald 		 &cs47l90_output_anc_src[2]),
967f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("HPOUT2R ANC Source", SND_SOC_NOPM, 0, 0,
968f1572a44SRichard Fitzgerald 		 &cs47l90_output_anc_src[3]),
969f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("HPOUT3L ANC Source", SND_SOC_NOPM, 0, 0,
970f1572a44SRichard Fitzgerald 		 &cs47l90_output_anc_src[4]),
971f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("HPOUT3R ANC Source", SND_SOC_NOPM, 0, 0,
972f1572a44SRichard Fitzgerald 		 &cs47l90_output_anc_src[5]),
973f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("SPKDAT1L ANC Source", SND_SOC_NOPM, 0, 0,
974f1572a44SRichard Fitzgerald 		 &cs47l90_output_anc_src[6]),
975f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("SPKDAT1R ANC Source", SND_SOC_NOPM, 0, 0,
976f1572a44SRichard Fitzgerald 		 &cs47l90_output_anc_src[7]),
977f1572a44SRichard Fitzgerald 
978f1572a44SRichard Fitzgerald SND_SOC_DAPM_AIF_OUT("AIF1TX1", NULL, 0,
979f1572a44SRichard Fitzgerald 		     MADERA_AIF1_TX_ENABLES, MADERA_AIF1TX1_ENA_SHIFT, 0),
9803570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("AIF1TX2", NULL, 1,
981f1572a44SRichard Fitzgerald 		     MADERA_AIF1_TX_ENABLES, MADERA_AIF1TX2_ENA_SHIFT, 0),
9823570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("AIF1TX3", NULL, 2,
983f1572a44SRichard Fitzgerald 		     MADERA_AIF1_TX_ENABLES, MADERA_AIF1TX3_ENA_SHIFT, 0),
9843570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("AIF1TX4", NULL, 3,
985f1572a44SRichard Fitzgerald 		     MADERA_AIF1_TX_ENABLES, MADERA_AIF1TX4_ENA_SHIFT, 0),
9863570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("AIF1TX5", NULL, 4,
987f1572a44SRichard Fitzgerald 		     MADERA_AIF1_TX_ENABLES, MADERA_AIF1TX5_ENA_SHIFT, 0),
9883570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("AIF1TX6", NULL, 5,
989f1572a44SRichard Fitzgerald 		     MADERA_AIF1_TX_ENABLES, MADERA_AIF1TX6_ENA_SHIFT, 0),
9903570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("AIF1TX7", NULL, 6,
991f1572a44SRichard Fitzgerald 		     MADERA_AIF1_TX_ENABLES, MADERA_AIF1TX7_ENA_SHIFT, 0),
9923570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("AIF1TX8", NULL, 7,
993f1572a44SRichard Fitzgerald 		     MADERA_AIF1_TX_ENABLES, MADERA_AIF1TX8_ENA_SHIFT, 0),
994f1572a44SRichard Fitzgerald 
995f1572a44SRichard Fitzgerald SND_SOC_DAPM_AIF_OUT("AIF2TX1", NULL, 0,
996f1572a44SRichard Fitzgerald 		     MADERA_AIF2_TX_ENABLES, MADERA_AIF2TX1_ENA_SHIFT, 0),
9973570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("AIF2TX2", NULL, 1,
998f1572a44SRichard Fitzgerald 		     MADERA_AIF2_TX_ENABLES, MADERA_AIF2TX2_ENA_SHIFT, 0),
9993570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("AIF2TX3", NULL, 2,
1000f1572a44SRichard Fitzgerald 		     MADERA_AIF2_TX_ENABLES, MADERA_AIF2TX3_ENA_SHIFT, 0),
10013570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("AIF2TX4", NULL, 3,
1002f1572a44SRichard Fitzgerald 		     MADERA_AIF2_TX_ENABLES, MADERA_AIF2TX4_ENA_SHIFT, 0),
10033570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("AIF2TX5", NULL, 4,
1004f1572a44SRichard Fitzgerald 		     MADERA_AIF2_TX_ENABLES, MADERA_AIF2TX5_ENA_SHIFT, 0),
10053570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("AIF2TX6", NULL, 5,
1006f1572a44SRichard Fitzgerald 		     MADERA_AIF2_TX_ENABLES, MADERA_AIF2TX6_ENA_SHIFT, 0),
10073570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("AIF2TX7", NULL, 6,
1008f1572a44SRichard Fitzgerald 		     MADERA_AIF2_TX_ENABLES, MADERA_AIF2TX7_ENA_SHIFT, 0),
10093570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("AIF2TX8", NULL, 7,
1010f1572a44SRichard Fitzgerald 		     MADERA_AIF2_TX_ENABLES, MADERA_AIF2TX8_ENA_SHIFT, 0),
1011f1572a44SRichard Fitzgerald 
1012f1572a44SRichard Fitzgerald SND_SOC_DAPM_AIF_OUT("SLIMTX1", NULL, 0,
1013f1572a44SRichard Fitzgerald 		     MADERA_SLIMBUS_TX_CHANNEL_ENABLE,
1014f1572a44SRichard Fitzgerald 		     MADERA_SLIMTX1_ENA_SHIFT, 0),
10153570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("SLIMTX2", NULL, 1,
1016f1572a44SRichard Fitzgerald 		     MADERA_SLIMBUS_TX_CHANNEL_ENABLE,
1017f1572a44SRichard Fitzgerald 		     MADERA_SLIMTX2_ENA_SHIFT, 0),
10183570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("SLIMTX3", NULL, 2,
1019f1572a44SRichard Fitzgerald 		     MADERA_SLIMBUS_TX_CHANNEL_ENABLE,
1020f1572a44SRichard Fitzgerald 		     MADERA_SLIMTX3_ENA_SHIFT, 0),
10213570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("SLIMTX4", NULL, 3,
1022f1572a44SRichard Fitzgerald 		     MADERA_SLIMBUS_TX_CHANNEL_ENABLE,
1023f1572a44SRichard Fitzgerald 		     MADERA_SLIMTX4_ENA_SHIFT, 0),
10243570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("SLIMTX5", NULL, 4,
1025f1572a44SRichard Fitzgerald 		     MADERA_SLIMBUS_TX_CHANNEL_ENABLE,
1026f1572a44SRichard Fitzgerald 		     MADERA_SLIMTX5_ENA_SHIFT, 0),
10273570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("SLIMTX6", NULL, 5,
1028f1572a44SRichard Fitzgerald 		     MADERA_SLIMBUS_TX_CHANNEL_ENABLE,
1029f1572a44SRichard Fitzgerald 		     MADERA_SLIMTX6_ENA_SHIFT, 0),
10303570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("SLIMTX7", NULL, 6,
1031f1572a44SRichard Fitzgerald 		     MADERA_SLIMBUS_TX_CHANNEL_ENABLE,
1032f1572a44SRichard Fitzgerald 		     MADERA_SLIMTX7_ENA_SHIFT, 0),
10333570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("SLIMTX8", NULL, 7,
1034f1572a44SRichard Fitzgerald 		     MADERA_SLIMBUS_TX_CHANNEL_ENABLE,
1035f1572a44SRichard Fitzgerald 		     MADERA_SLIMTX8_ENA_SHIFT, 0),
1036f1572a44SRichard Fitzgerald 
1037f1572a44SRichard Fitzgerald SND_SOC_DAPM_AIF_OUT("AIF3TX1", NULL, 0,
1038f1572a44SRichard Fitzgerald 		     MADERA_AIF3_TX_ENABLES, MADERA_AIF3TX1_ENA_SHIFT, 0),
10393570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("AIF3TX2", NULL, 1,
1040f1572a44SRichard Fitzgerald 		     MADERA_AIF3_TX_ENABLES, MADERA_AIF3TX2_ENA_SHIFT, 0),
1041f1572a44SRichard Fitzgerald 
1042f1572a44SRichard Fitzgerald SND_SOC_DAPM_AIF_OUT("AIF4TX1", NULL, 0,
1043f1572a44SRichard Fitzgerald 		     MADERA_AIF4_TX_ENABLES, MADERA_AIF4TX1_ENA_SHIFT, 0),
10443570922cSCharles Keepax SND_SOC_DAPM_AIF_OUT("AIF4TX2", NULL, 1,
1045f1572a44SRichard Fitzgerald 		     MADERA_AIF4_TX_ENABLES, MADERA_AIF4TX2_ENA_SHIFT, 0),
1046f1572a44SRichard Fitzgerald 
1047f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("OUT1L", SND_SOC_NOPM,
1048f1572a44SRichard Fitzgerald 		   MADERA_OUT1L_ENA_SHIFT, 0, NULL, 0, madera_hp_ev,
1049f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD |
1050f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1051f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("OUT1R", SND_SOC_NOPM,
1052f1572a44SRichard Fitzgerald 		   MADERA_OUT1R_ENA_SHIFT, 0, NULL, 0, madera_hp_ev,
1053f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD |
1054f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1055f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("OUT2L", SND_SOC_NOPM,
1056f1572a44SRichard Fitzgerald 		   MADERA_OUT2L_ENA_SHIFT, 0, NULL, 0, madera_hp_ev,
1057f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD |
1058f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1059f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("OUT2R", SND_SOC_NOPM,
1060f1572a44SRichard Fitzgerald 		   MADERA_OUT2R_ENA_SHIFT, 0, NULL, 0, madera_hp_ev,
1061f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD |
1062f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1063f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("OUT3L", SND_SOC_NOPM,
1064f1572a44SRichard Fitzgerald 		   MADERA_OUT3L_ENA_SHIFT, 0, NULL, 0, madera_hp_ev,
1065f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD |
1066f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1067f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("OUT3R", SND_SOC_NOPM,
1068f1572a44SRichard Fitzgerald 		   MADERA_OUT3R_ENA_SHIFT, 0, NULL, 0, madera_hp_ev,
1069f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD |
1070f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1071f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("OUT5L", MADERA_OUTPUT_ENABLES_1,
1072f1572a44SRichard Fitzgerald 		   MADERA_OUT5L_ENA_SHIFT, 0, NULL, 0, madera_out_ev,
1073f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMU),
1074f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("OUT5R", MADERA_OUTPUT_ENABLES_1,
1075f1572a44SRichard Fitzgerald 		   MADERA_OUT5R_ENA_SHIFT, 0, NULL, 0, madera_out_ev,
1076f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMU),
1077f1572a44SRichard Fitzgerald 
1078f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("SPD1TX1", MADERA_SPD1_TX_CONTROL,
1079f1572a44SRichard Fitzgerald 		 MADERA_SPD1_VAL1_SHIFT, 0, NULL, 0),
1080f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("SPD1TX2", MADERA_SPD1_TX_CONTROL,
1081f1572a44SRichard Fitzgerald 		 MADERA_SPD1_VAL2_SHIFT, 0, NULL, 0),
1082f1572a44SRichard Fitzgerald SND_SOC_DAPM_OUT_DRV("SPD1", MADERA_SPD1_TX_CONTROL,
1083f1572a44SRichard Fitzgerald 		     MADERA_SPD1_ENA_SHIFT, 0, NULL, 0),
1084f1572a44SRichard Fitzgerald 
1085f1572a44SRichard Fitzgerald /*
1086f1572a44SRichard Fitzgerald  * mux_in widgets : arranged in the order of sources
1087f1572a44SRichard Fitzgerald  * specified in MADERA_MIXER_INPUT_ROUTES
1088f1572a44SRichard Fitzgerald  */
1089f1572a44SRichard Fitzgerald 
1090f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("Noise Generator", MADERA_COMFORT_NOISE_GENERATOR,
1091f1572a44SRichard Fitzgerald 		 MADERA_NOISE_GEN_ENA_SHIFT, 0, NULL, 0),
1092f1572a44SRichard Fitzgerald 
1093f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("Tone Generator 1", MADERA_TONE_GENERATOR_1,
1094f1572a44SRichard Fitzgerald 		 MADERA_TONE1_ENA_SHIFT, 0, NULL, 0),
1095f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("Tone Generator 2", MADERA_TONE_GENERATOR_1,
1096f1572a44SRichard Fitzgerald 		 MADERA_TONE2_ENA_SHIFT, 0, NULL, 0),
1097f1572a44SRichard Fitzgerald 
1098f1572a44SRichard Fitzgerald SND_SOC_DAPM_SIGGEN("HAPTICS"),
1099f1572a44SRichard Fitzgerald 
1100f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("AEC1 Loopback", MADERA_DAC_AEC_CONTROL_1,
1101f1572a44SRichard Fitzgerald 		 MADERA_AEC1_LOOPBACK_ENA_SHIFT, 0,
1102f1572a44SRichard Fitzgerald 		 &cs47l90_aec_loopback_mux[0]),
1103f1572a44SRichard Fitzgerald SND_SOC_DAPM_MUX("AEC2 Loopback", MADERA_DAC_AEC_CONTROL_2,
1104f1572a44SRichard Fitzgerald 		 MADERA_AEC2_LOOPBACK_ENA_SHIFT, 0,
1105f1572a44SRichard Fitzgerald 		 &cs47l90_aec_loopback_mux[1]),
1106f1572a44SRichard Fitzgerald 
1107f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("IN1L", MADERA_INPUT_ENABLES, MADERA_IN1L_ENA_SHIFT,
1108f1572a44SRichard Fitzgerald 		   0, NULL, 0, madera_in_ev,
1109f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD |
1110f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1111f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("IN1R", MADERA_INPUT_ENABLES, MADERA_IN1R_ENA_SHIFT,
1112f1572a44SRichard Fitzgerald 		   0, NULL, 0, madera_in_ev,
1113f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD |
1114f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1115f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("IN2L", MADERA_INPUT_ENABLES, MADERA_IN2L_ENA_SHIFT,
1116f1572a44SRichard Fitzgerald 		   0, NULL, 0, madera_in_ev,
1117f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD |
1118f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1119f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("IN2R", MADERA_INPUT_ENABLES, MADERA_IN2R_ENA_SHIFT,
1120f1572a44SRichard Fitzgerald 		   0, NULL, 0, madera_in_ev,
1121f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD |
1122f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1123f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("IN3L", MADERA_INPUT_ENABLES, MADERA_IN3L_ENA_SHIFT,
1124f1572a44SRichard Fitzgerald 		   0, NULL, 0, madera_in_ev,
1125f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD |
1126f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1127f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("IN3R", MADERA_INPUT_ENABLES, MADERA_IN3R_ENA_SHIFT,
1128f1572a44SRichard Fitzgerald 		   0, NULL, 0, madera_in_ev,
1129f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD |
1130f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1131f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("IN4L", MADERA_INPUT_ENABLES, MADERA_IN4L_ENA_SHIFT,
1132f1572a44SRichard Fitzgerald 		   0, NULL, 0, madera_in_ev,
1133f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD |
1134f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1135f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("IN4R", MADERA_INPUT_ENABLES, MADERA_IN4R_ENA_SHIFT,
1136f1572a44SRichard Fitzgerald 		   0, NULL, 0, madera_in_ev,
1137f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD |
1138f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1139f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("IN5L", MADERA_INPUT_ENABLES, MADERA_IN5L_ENA_SHIFT,
1140f1572a44SRichard Fitzgerald 		   0, NULL, 0, madera_in_ev,
1141f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD |
1142f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1143f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA_E("IN5R", MADERA_INPUT_ENABLES, MADERA_IN5R_ENA_SHIFT,
1144f1572a44SRichard Fitzgerald 		   0, NULL, 0, madera_in_ev,
1145f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD |
1146f1572a44SRichard Fitzgerald 		   SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU),
1147f1572a44SRichard Fitzgerald 
1148f1572a44SRichard Fitzgerald SND_SOC_DAPM_AIF_IN("AIF1RX1", NULL, 0,
1149f1572a44SRichard Fitzgerald 		    MADERA_AIF1_RX_ENABLES, MADERA_AIF1RX1_ENA_SHIFT, 0),
11503570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("AIF1RX2", NULL, 1,
1151f1572a44SRichard Fitzgerald 		    MADERA_AIF1_RX_ENABLES, MADERA_AIF1RX2_ENA_SHIFT, 0),
11523570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("AIF1RX3", NULL, 2,
1153f1572a44SRichard Fitzgerald 		    MADERA_AIF1_RX_ENABLES, MADERA_AIF1RX3_ENA_SHIFT, 0),
11543570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("AIF1RX4", NULL, 3,
1155f1572a44SRichard Fitzgerald 		    MADERA_AIF1_RX_ENABLES, MADERA_AIF1RX4_ENA_SHIFT, 0),
11563570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("AIF1RX5", NULL, 4,
1157f1572a44SRichard Fitzgerald 		    MADERA_AIF1_RX_ENABLES, MADERA_AIF1RX5_ENA_SHIFT, 0),
11583570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("AIF1RX6", NULL, 5,
1159f1572a44SRichard Fitzgerald 		    MADERA_AIF1_RX_ENABLES, MADERA_AIF1RX6_ENA_SHIFT, 0),
11603570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("AIF1RX7", NULL, 6,
1161f1572a44SRichard Fitzgerald 		    MADERA_AIF1_RX_ENABLES, MADERA_AIF1RX7_ENA_SHIFT, 0),
11623570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("AIF1RX8", NULL, 7,
1163f1572a44SRichard Fitzgerald 		    MADERA_AIF1_RX_ENABLES, MADERA_AIF1RX8_ENA_SHIFT, 0),
1164f1572a44SRichard Fitzgerald 
1165f1572a44SRichard Fitzgerald SND_SOC_DAPM_AIF_IN("AIF2RX1", NULL, 0,
1166f1572a44SRichard Fitzgerald 		    MADERA_AIF2_RX_ENABLES, MADERA_AIF2RX1_ENA_SHIFT, 0),
11673570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("AIF2RX2", NULL, 1,
1168f1572a44SRichard Fitzgerald 		    MADERA_AIF2_RX_ENABLES, MADERA_AIF2RX2_ENA_SHIFT, 0),
11693570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("AIF2RX3", NULL, 2,
1170f1572a44SRichard Fitzgerald 		    MADERA_AIF2_RX_ENABLES, MADERA_AIF2RX3_ENA_SHIFT, 0),
11713570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("AIF2RX4", NULL, 3,
1172f1572a44SRichard Fitzgerald 		    MADERA_AIF2_RX_ENABLES, MADERA_AIF2RX4_ENA_SHIFT, 0),
11733570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("AIF2RX5", NULL, 4,
1174f1572a44SRichard Fitzgerald 		    MADERA_AIF2_RX_ENABLES, MADERA_AIF2RX5_ENA_SHIFT, 0),
11753570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("AIF2RX6", NULL, 5,
1176f1572a44SRichard Fitzgerald 		    MADERA_AIF2_RX_ENABLES, MADERA_AIF2RX6_ENA_SHIFT, 0),
11773570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("AIF2RX7", NULL, 6,
1178f1572a44SRichard Fitzgerald 		    MADERA_AIF2_RX_ENABLES, MADERA_AIF2RX7_ENA_SHIFT, 0),
11793570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("AIF2RX8", NULL, 7,
1180f1572a44SRichard Fitzgerald 		    MADERA_AIF2_RX_ENABLES, MADERA_AIF2RX8_ENA_SHIFT, 0),
1181f1572a44SRichard Fitzgerald 
1182f1572a44SRichard Fitzgerald SND_SOC_DAPM_AIF_IN("AIF3RX1", NULL, 0,
1183f1572a44SRichard Fitzgerald 		    MADERA_AIF3_RX_ENABLES, MADERA_AIF3RX1_ENA_SHIFT, 0),
11843570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("AIF3RX2", NULL, 1,
1185f1572a44SRichard Fitzgerald 		    MADERA_AIF3_RX_ENABLES, MADERA_AIF3RX2_ENA_SHIFT, 0),
1186f1572a44SRichard Fitzgerald 
1187f1572a44SRichard Fitzgerald SND_SOC_DAPM_AIF_IN("AIF4RX1", NULL, 0,
1188f1572a44SRichard Fitzgerald 		    MADERA_AIF4_RX_ENABLES, MADERA_AIF4RX1_ENA_SHIFT, 0),
11893570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("AIF4RX2", NULL, 1,
1190f1572a44SRichard Fitzgerald 		    MADERA_AIF4_RX_ENABLES, MADERA_AIF4RX2_ENA_SHIFT, 0),
1191f1572a44SRichard Fitzgerald 
1192f1572a44SRichard Fitzgerald SND_SOC_DAPM_AIF_IN("SLIMRX1", NULL, 0, MADERA_SLIMBUS_RX_CHANNEL_ENABLE,
1193f1572a44SRichard Fitzgerald 		    MADERA_SLIMRX1_ENA_SHIFT, 0),
11943570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("SLIMRX2", NULL, 1, MADERA_SLIMBUS_RX_CHANNEL_ENABLE,
1195f1572a44SRichard Fitzgerald 		    MADERA_SLIMRX2_ENA_SHIFT, 0),
11963570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("SLIMRX3", NULL, 2, MADERA_SLIMBUS_RX_CHANNEL_ENABLE,
1197f1572a44SRichard Fitzgerald 		    MADERA_SLIMRX3_ENA_SHIFT, 0),
11983570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("SLIMRX4", NULL, 3, MADERA_SLIMBUS_RX_CHANNEL_ENABLE,
1199f1572a44SRichard Fitzgerald 		    MADERA_SLIMRX4_ENA_SHIFT, 0),
12003570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("SLIMRX5", NULL, 4, MADERA_SLIMBUS_RX_CHANNEL_ENABLE,
1201f1572a44SRichard Fitzgerald 		    MADERA_SLIMRX5_ENA_SHIFT, 0),
12023570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("SLIMRX6", NULL, 5, MADERA_SLIMBUS_RX_CHANNEL_ENABLE,
1203f1572a44SRichard Fitzgerald 		    MADERA_SLIMRX6_ENA_SHIFT, 0),
12043570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("SLIMRX7", NULL, 6, MADERA_SLIMBUS_RX_CHANNEL_ENABLE,
1205f1572a44SRichard Fitzgerald 		    MADERA_SLIMRX7_ENA_SHIFT, 0),
12063570922cSCharles Keepax SND_SOC_DAPM_AIF_IN("SLIMRX8", NULL, 7, MADERA_SLIMBUS_RX_CHANNEL_ENABLE,
1207f1572a44SRichard Fitzgerald 		    MADERA_SLIMRX8_ENA_SHIFT, 0),
1208f1572a44SRichard Fitzgerald 
1209f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("EQ1", MADERA_EQ1_1, MADERA_EQ1_ENA_SHIFT, 0, NULL, 0),
1210f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("EQ2", MADERA_EQ2_1, MADERA_EQ2_ENA_SHIFT, 0, NULL, 0),
1211f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("EQ3", MADERA_EQ3_1, MADERA_EQ3_ENA_SHIFT, 0, NULL, 0),
1212f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("EQ4", MADERA_EQ4_1, MADERA_EQ4_ENA_SHIFT, 0, NULL, 0),
1213f1572a44SRichard Fitzgerald 
1214f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("DRC1L", MADERA_DRC1_CTRL1, MADERA_DRC1L_ENA_SHIFT, 0,
1215f1572a44SRichard Fitzgerald 		 NULL, 0),
1216f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("DRC1R", MADERA_DRC1_CTRL1, MADERA_DRC1R_ENA_SHIFT, 0,
1217f1572a44SRichard Fitzgerald 		 NULL, 0),
1218f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("DRC2L", MADERA_DRC2_CTRL1, MADERA_DRC2L_ENA_SHIFT, 0,
1219f1572a44SRichard Fitzgerald 		 NULL, 0),
1220f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("DRC2R", MADERA_DRC2_CTRL1, MADERA_DRC2R_ENA_SHIFT, 0,
1221f1572a44SRichard Fitzgerald 		 NULL, 0),
1222f1572a44SRichard Fitzgerald 
1223f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("LHPF1", MADERA_HPLPF1_1, MADERA_LHPF1_ENA_SHIFT, 0,
1224f1572a44SRichard Fitzgerald 		 NULL, 0),
1225f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("LHPF2", MADERA_HPLPF2_1, MADERA_LHPF2_ENA_SHIFT, 0,
1226f1572a44SRichard Fitzgerald 		 NULL, 0),
1227f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("LHPF3", MADERA_HPLPF3_1, MADERA_LHPF3_ENA_SHIFT, 0,
1228f1572a44SRichard Fitzgerald 		 NULL, 0),
1229f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("LHPF4", MADERA_HPLPF4_1, MADERA_LHPF4_ENA_SHIFT, 0,
1230f1572a44SRichard Fitzgerald 		 NULL, 0),
1231f1572a44SRichard Fitzgerald 
1232f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ASRC1IN1L", MADERA_ASRC1_ENABLE,
1233f1572a44SRichard Fitzgerald 		 MADERA_ASRC1_IN1L_ENA_SHIFT, 0, NULL, 0),
1234f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ASRC1IN1R", MADERA_ASRC1_ENABLE,
1235f1572a44SRichard Fitzgerald 		 MADERA_ASRC1_IN1R_ENA_SHIFT, 0, NULL, 0),
1236f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ASRC1IN2L", MADERA_ASRC1_ENABLE,
1237f1572a44SRichard Fitzgerald 		 MADERA_ASRC1_IN2L_ENA_SHIFT, 0, NULL, 0),
1238f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ASRC1IN2R", MADERA_ASRC1_ENABLE,
1239f1572a44SRichard Fitzgerald 		 MADERA_ASRC1_IN2R_ENA_SHIFT, 0, NULL, 0),
1240f1572a44SRichard Fitzgerald 
1241f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ASRC2IN1L", MADERA_ASRC2_ENABLE,
1242f1572a44SRichard Fitzgerald 		 MADERA_ASRC2_IN1L_ENA_SHIFT, 0, NULL, 0),
1243f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ASRC2IN1R", MADERA_ASRC2_ENABLE,
1244f1572a44SRichard Fitzgerald 		 MADERA_ASRC2_IN1R_ENA_SHIFT, 0, NULL, 0),
1245f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ASRC2IN2L", MADERA_ASRC2_ENABLE,
1246f1572a44SRichard Fitzgerald 		 MADERA_ASRC2_IN2L_ENA_SHIFT, 0, NULL, 0),
1247f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ASRC2IN2R", MADERA_ASRC2_ENABLE,
1248f1572a44SRichard Fitzgerald 		 MADERA_ASRC2_IN2R_ENA_SHIFT, 0, NULL, 0),
1249f1572a44SRichard Fitzgerald 
1250f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC1DEC1", MADERA_ISRC_1_CTRL_3,
1251f1572a44SRichard Fitzgerald 		 MADERA_ISRC1_DEC1_ENA_SHIFT, 0, NULL, 0),
1252f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC1DEC2", MADERA_ISRC_1_CTRL_3,
1253f1572a44SRichard Fitzgerald 		 MADERA_ISRC1_DEC2_ENA_SHIFT, 0, NULL, 0),
1254f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC1DEC3", MADERA_ISRC_1_CTRL_3,
1255f1572a44SRichard Fitzgerald 		 MADERA_ISRC1_DEC3_ENA_SHIFT, 0, NULL, 0),
1256f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC1DEC4", MADERA_ISRC_1_CTRL_3,
1257f1572a44SRichard Fitzgerald 		 MADERA_ISRC1_DEC4_ENA_SHIFT, 0, NULL, 0),
1258f1572a44SRichard Fitzgerald 
1259f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC1INT1", MADERA_ISRC_1_CTRL_3,
1260f1572a44SRichard Fitzgerald 		 MADERA_ISRC1_INT1_ENA_SHIFT, 0, NULL, 0),
1261f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC1INT2", MADERA_ISRC_1_CTRL_3,
1262f1572a44SRichard Fitzgerald 		 MADERA_ISRC1_INT2_ENA_SHIFT, 0, NULL, 0),
1263f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC1INT3", MADERA_ISRC_1_CTRL_3,
1264f1572a44SRichard Fitzgerald 		 MADERA_ISRC1_INT3_ENA_SHIFT, 0, NULL, 0),
1265f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC1INT4", MADERA_ISRC_1_CTRL_3,
1266f1572a44SRichard Fitzgerald 		 MADERA_ISRC1_INT4_ENA_SHIFT, 0, NULL, 0),
1267f1572a44SRichard Fitzgerald 
1268f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC2DEC1", MADERA_ISRC_2_CTRL_3,
1269f1572a44SRichard Fitzgerald 		 MADERA_ISRC2_DEC1_ENA_SHIFT, 0, NULL, 0),
1270f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC2DEC2", MADERA_ISRC_2_CTRL_3,
1271f1572a44SRichard Fitzgerald 		 MADERA_ISRC2_DEC2_ENA_SHIFT, 0, NULL, 0),
1272f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC2DEC3", MADERA_ISRC_2_CTRL_3,
1273f1572a44SRichard Fitzgerald 		 MADERA_ISRC2_DEC3_ENA_SHIFT, 0, NULL, 0),
1274f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC2DEC4", MADERA_ISRC_2_CTRL_3,
1275f1572a44SRichard Fitzgerald 		 MADERA_ISRC2_DEC4_ENA_SHIFT, 0, NULL, 0),
1276f1572a44SRichard Fitzgerald 
1277f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC2INT1", MADERA_ISRC_2_CTRL_3,
1278f1572a44SRichard Fitzgerald 		 MADERA_ISRC2_INT1_ENA_SHIFT, 0, NULL, 0),
1279f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC2INT2", MADERA_ISRC_2_CTRL_3,
1280f1572a44SRichard Fitzgerald 		 MADERA_ISRC2_INT2_ENA_SHIFT, 0, NULL, 0),
1281f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC2INT3", MADERA_ISRC_2_CTRL_3,
1282f1572a44SRichard Fitzgerald 		 MADERA_ISRC2_INT3_ENA_SHIFT, 0, NULL, 0),
1283f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC2INT4", MADERA_ISRC_2_CTRL_3,
1284f1572a44SRichard Fitzgerald 		 MADERA_ISRC2_INT4_ENA_SHIFT, 0, NULL, 0),
1285f1572a44SRichard Fitzgerald 
1286f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC3DEC1", MADERA_ISRC_3_CTRL_3,
1287f1572a44SRichard Fitzgerald 		 MADERA_ISRC3_DEC1_ENA_SHIFT, 0, NULL, 0),
1288f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC3DEC2", MADERA_ISRC_3_CTRL_3,
1289f1572a44SRichard Fitzgerald 		 MADERA_ISRC3_DEC2_ENA_SHIFT, 0, NULL, 0),
1290f1572a44SRichard Fitzgerald 
1291f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC3INT1", MADERA_ISRC_3_CTRL_3,
1292f1572a44SRichard Fitzgerald 		 MADERA_ISRC3_INT1_ENA_SHIFT, 0, NULL, 0),
1293f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC3INT2", MADERA_ISRC_3_CTRL_3,
1294f1572a44SRichard Fitzgerald 		 MADERA_ISRC3_INT2_ENA_SHIFT, 0, NULL, 0),
1295f1572a44SRichard Fitzgerald 
1296f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC4DEC1", MADERA_ISRC_4_CTRL_3,
1297f1572a44SRichard Fitzgerald 		 MADERA_ISRC4_DEC1_ENA_SHIFT, 0, NULL, 0),
1298f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC4DEC2", MADERA_ISRC_4_CTRL_3,
1299f1572a44SRichard Fitzgerald 		 MADERA_ISRC4_DEC2_ENA_SHIFT, 0, NULL, 0),
1300f1572a44SRichard Fitzgerald 
1301f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC4INT1", MADERA_ISRC_4_CTRL_3,
1302f1572a44SRichard Fitzgerald 		 MADERA_ISRC4_INT1_ENA_SHIFT, 0, NULL, 0),
1303f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("ISRC4INT2", MADERA_ISRC_4_CTRL_3,
1304f1572a44SRichard Fitzgerald 		 MADERA_ISRC4_INT2_ENA_SHIFT, 0, NULL, 0),
1305f1572a44SRichard Fitzgerald 
1306f1572a44SRichard Fitzgerald WM_ADSP2("DSP1", 0, cs47l90_adsp_power_ev),
1307f1572a44SRichard Fitzgerald WM_ADSP2("DSP2", 1, cs47l90_adsp_power_ev),
1308f1572a44SRichard Fitzgerald WM_ADSP2("DSP3", 2, cs47l90_adsp_power_ev),
1309f1572a44SRichard Fitzgerald WM_ADSP2("DSP4", 3, cs47l90_adsp_power_ev),
1310f1572a44SRichard Fitzgerald WM_ADSP2("DSP5", 4, cs47l90_adsp_power_ev),
1311f1572a44SRichard Fitzgerald WM_ADSP2("DSP6", 5, cs47l90_adsp_power_ev),
1312f1572a44SRichard Fitzgerald WM_ADSP2("DSP7", 6, cs47l90_adsp_power_ev),
1313f1572a44SRichard Fitzgerald 
1314f1572a44SRichard Fitzgerald /* end of ordered widget list */
1315f1572a44SRichard Fitzgerald 
1316f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("DFC1", MADERA_DFC1_CTRL, MADERA_DFC1_ENA_SHIFT, 0, NULL, 0),
1317f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("DFC2", MADERA_DFC2_CTRL, MADERA_DFC1_ENA_SHIFT, 0, NULL, 0),
1318f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("DFC3", MADERA_DFC3_CTRL, MADERA_DFC1_ENA_SHIFT, 0, NULL, 0),
1319f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("DFC4", MADERA_DFC4_CTRL, MADERA_DFC1_ENA_SHIFT, 0, NULL, 0),
1320f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("DFC5", MADERA_DFC5_CTRL, MADERA_DFC1_ENA_SHIFT, 0, NULL, 0),
1321f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("DFC6", MADERA_DFC6_CTRL, MADERA_DFC1_ENA_SHIFT, 0, NULL, 0),
1322f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("DFC7", MADERA_DFC7_CTRL, MADERA_DFC1_ENA_SHIFT, 0, NULL, 0),
1323f1572a44SRichard Fitzgerald SND_SOC_DAPM_PGA("DFC8", MADERA_DFC8_CTRL, MADERA_DFC1_ENA_SHIFT, 0, NULL, 0),
1324f1572a44SRichard Fitzgerald 
1325f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(EQ1, "EQ1"),
1326f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(EQ2, "EQ2"),
1327f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(EQ3, "EQ3"),
1328f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(EQ4, "EQ4"),
1329f1572a44SRichard Fitzgerald 
1330f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(DRC1L, "DRC1L"),
1331f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(DRC1R, "DRC1R"),
1332f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(DRC2L, "DRC2L"),
1333f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(DRC2R, "DRC2R"),
1334f1572a44SRichard Fitzgerald 
1335f1572a44SRichard Fitzgerald SND_SOC_DAPM_SWITCH("DRC1 Activity Output", SND_SOC_NOPM, 0, 0,
1336f1572a44SRichard Fitzgerald 		    &madera_drc_activity_output_mux[0]),
1337f1572a44SRichard Fitzgerald SND_SOC_DAPM_SWITCH("DRC2 Activity Output", SND_SOC_NOPM, 0, 0,
1338f1572a44SRichard Fitzgerald 		    &madera_drc_activity_output_mux[1]),
1339f1572a44SRichard Fitzgerald 
1340f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(LHPF1, "LHPF1"),
1341f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(LHPF2, "LHPF2"),
1342f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(LHPF3, "LHPF3"),
1343f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(LHPF4, "LHPF4"),
1344f1572a44SRichard Fitzgerald 
1345f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(PWM1, "PWM1"),
1346f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(PWM2, "PWM2"),
1347f1572a44SRichard Fitzgerald 
1348f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(OUT1L, "HPOUT1L"),
1349f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(OUT1R, "HPOUT1R"),
1350f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(OUT2L, "HPOUT2L"),
1351f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(OUT2R, "HPOUT2R"),
1352f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(OUT3L, "HPOUT3L"),
1353f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(OUT3R, "HPOUT3R"),
1354f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(SPKDAT1L, "SPKDAT1L"),
1355f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(SPKDAT1R, "SPKDAT1R"),
1356f1572a44SRichard Fitzgerald 
1357f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF1TX1, "AIF1TX1"),
1358f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF1TX2, "AIF1TX2"),
1359f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF1TX3, "AIF1TX3"),
1360f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF1TX4, "AIF1TX4"),
1361f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF1TX5, "AIF1TX5"),
1362f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF1TX6, "AIF1TX6"),
1363f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF1TX7, "AIF1TX7"),
1364f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF1TX8, "AIF1TX8"),
1365f1572a44SRichard Fitzgerald 
1366f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF2TX1, "AIF2TX1"),
1367f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF2TX2, "AIF2TX2"),
1368f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF2TX3, "AIF2TX3"),
1369f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF2TX4, "AIF2TX4"),
1370f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF2TX5, "AIF2TX5"),
1371f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF2TX6, "AIF2TX6"),
1372f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF2TX7, "AIF2TX7"),
1373f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF2TX8, "AIF2TX8"),
1374f1572a44SRichard Fitzgerald 
1375f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF3TX1, "AIF3TX1"),
1376f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF3TX2, "AIF3TX2"),
1377f1572a44SRichard Fitzgerald 
1378f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF4TX1, "AIF4TX1"),
1379f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(AIF4TX2, "AIF4TX2"),
1380f1572a44SRichard Fitzgerald 
1381f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(SLIMTX1, "SLIMTX1"),
1382f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(SLIMTX2, "SLIMTX2"),
1383f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(SLIMTX3, "SLIMTX3"),
1384f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(SLIMTX4, "SLIMTX4"),
1385f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(SLIMTX5, "SLIMTX5"),
1386f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(SLIMTX6, "SLIMTX6"),
1387f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(SLIMTX7, "SLIMTX7"),
1388f1572a44SRichard Fitzgerald MADERA_MIXER_WIDGETS(SLIMTX8, "SLIMTX8"),
1389f1572a44SRichard Fitzgerald 
1390f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(SPD1TX1, "SPDIF1TX1"),
1391f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(SPD1TX2, "SPDIF1TX2"),
1392f1572a44SRichard Fitzgerald 
1393f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ASRC1IN1L, "ASRC1IN1L"),
1394f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ASRC1IN1R, "ASRC1IN1R"),
1395f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ASRC1IN2L, "ASRC1IN2L"),
1396f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ASRC1IN2R, "ASRC1IN2R"),
1397f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ASRC2IN1L, "ASRC2IN1L"),
1398f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ASRC2IN1R, "ASRC2IN1R"),
1399f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ASRC2IN2L, "ASRC2IN2L"),
1400f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ASRC2IN2R, "ASRC2IN2R"),
1401f1572a44SRichard Fitzgerald 
1402f1572a44SRichard Fitzgerald MADERA_DSP_WIDGETS(DSP1, "DSP1"),
1403f1572a44SRichard Fitzgerald MADERA_DSP_WIDGETS(DSP2, "DSP2"),
1404f1572a44SRichard Fitzgerald MADERA_DSP_WIDGETS(DSP3, "DSP3"),
1405f1572a44SRichard Fitzgerald MADERA_DSP_WIDGETS(DSP4, "DSP4"),
1406f1572a44SRichard Fitzgerald MADERA_DSP_WIDGETS(DSP5, "DSP5"),
1407f1572a44SRichard Fitzgerald MADERA_DSP_WIDGETS(DSP6, "DSP6"),
1408f1572a44SRichard Fitzgerald MADERA_DSP_WIDGETS(DSP7, "DSP7"),
1409f1572a44SRichard Fitzgerald 
1410f1572a44SRichard Fitzgerald SND_SOC_DAPM_SWITCH("DSP1 Trigger Output", SND_SOC_NOPM, 0, 0,
1411f1572a44SRichard Fitzgerald 		    &madera_dsp_trigger_output_mux[0]),
1412f1572a44SRichard Fitzgerald SND_SOC_DAPM_SWITCH("DSP2 Trigger Output", SND_SOC_NOPM, 0, 0,
1413f1572a44SRichard Fitzgerald 		    &madera_dsp_trigger_output_mux[1]),
1414f1572a44SRichard Fitzgerald SND_SOC_DAPM_SWITCH("DSP3 Trigger Output", SND_SOC_NOPM, 0, 0,
1415f1572a44SRichard Fitzgerald 		    &madera_dsp_trigger_output_mux[2]),
1416f1572a44SRichard Fitzgerald SND_SOC_DAPM_SWITCH("DSP4 Trigger Output", SND_SOC_NOPM, 0, 0,
1417f1572a44SRichard Fitzgerald 		    &madera_dsp_trigger_output_mux[3]),
1418f1572a44SRichard Fitzgerald SND_SOC_DAPM_SWITCH("DSP5 Trigger Output", SND_SOC_NOPM, 0, 0,
1419f1572a44SRichard Fitzgerald 		    &madera_dsp_trigger_output_mux[4]),
1420f1572a44SRichard Fitzgerald SND_SOC_DAPM_SWITCH("DSP6 Trigger Output", SND_SOC_NOPM, 0, 0,
1421f1572a44SRichard Fitzgerald 		    &madera_dsp_trigger_output_mux[5]),
1422f1572a44SRichard Fitzgerald SND_SOC_DAPM_SWITCH("DSP7 Trigger Output", SND_SOC_NOPM, 0, 0,
1423f1572a44SRichard Fitzgerald 		    &madera_dsp_trigger_output_mux[6]),
1424f1572a44SRichard Fitzgerald 
1425f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC1DEC1, "ISRC1DEC1"),
1426f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC1DEC2, "ISRC1DEC2"),
1427f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC1DEC3, "ISRC1DEC3"),
1428f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC1DEC4, "ISRC1DEC4"),
1429f1572a44SRichard Fitzgerald 
1430f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC1INT1, "ISRC1INT1"),
1431f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC1INT2, "ISRC1INT2"),
1432f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC1INT3, "ISRC1INT3"),
1433f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC1INT4, "ISRC1INT4"),
1434f1572a44SRichard Fitzgerald 
1435f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC2DEC1, "ISRC2DEC1"),
1436f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC2DEC2, "ISRC2DEC2"),
1437f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC2DEC3, "ISRC2DEC3"),
1438f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC2DEC4, "ISRC2DEC4"),
1439f1572a44SRichard Fitzgerald 
1440f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC2INT1, "ISRC2INT1"),
1441f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC2INT2, "ISRC2INT2"),
1442f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC2INT3, "ISRC2INT3"),
1443f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC2INT4, "ISRC2INT4"),
1444f1572a44SRichard Fitzgerald 
1445f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC3DEC1, "ISRC3DEC1"),
1446f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC3DEC2, "ISRC3DEC2"),
1447f1572a44SRichard Fitzgerald 
1448f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC3INT1, "ISRC3INT1"),
1449f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC3INT2, "ISRC3INT2"),
1450f1572a44SRichard Fitzgerald 
1451f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC4DEC1, "ISRC4DEC1"),
1452f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC4DEC2, "ISRC4DEC2"),
1453f1572a44SRichard Fitzgerald 
1454f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC4INT1, "ISRC4INT1"),
1455f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(ISRC4INT2, "ISRC4INT2"),
1456f1572a44SRichard Fitzgerald 
1457f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(DFC1, "DFC1"),
1458f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(DFC2, "DFC2"),
1459f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(DFC3, "DFC3"),
1460f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(DFC4, "DFC4"),
1461f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(DFC5, "DFC5"),
1462f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(DFC6, "DFC6"),
1463f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(DFC7, "DFC7"),
1464f1572a44SRichard Fitzgerald MADERA_MUX_WIDGETS(DFC8, "DFC8"),
1465f1572a44SRichard Fitzgerald 
1466f1572a44SRichard Fitzgerald SND_SOC_DAPM_OUTPUT("HPOUT1L"),
1467f1572a44SRichard Fitzgerald SND_SOC_DAPM_OUTPUT("HPOUT1R"),
1468f1572a44SRichard Fitzgerald SND_SOC_DAPM_OUTPUT("HPOUT2L"),
1469f1572a44SRichard Fitzgerald SND_SOC_DAPM_OUTPUT("HPOUT2R"),
1470f1572a44SRichard Fitzgerald SND_SOC_DAPM_OUTPUT("HPOUT3L"),
1471f1572a44SRichard Fitzgerald SND_SOC_DAPM_OUTPUT("HPOUT3R"),
1472f1572a44SRichard Fitzgerald SND_SOC_DAPM_OUTPUT("SPKDAT1L"),
1473f1572a44SRichard Fitzgerald SND_SOC_DAPM_OUTPUT("SPKDAT1R"),
1474f1572a44SRichard Fitzgerald SND_SOC_DAPM_OUTPUT("SPDIF1"),
1475f1572a44SRichard Fitzgerald 
1476f1572a44SRichard Fitzgerald SND_SOC_DAPM_OUTPUT("MICSUPP"),
1477f1572a44SRichard Fitzgerald };
1478f1572a44SRichard Fitzgerald 
1479f1572a44SRichard Fitzgerald #define MADERA_MIXER_INPUT_ROUTES(name)	\
1480f1572a44SRichard Fitzgerald 	{ name, "Noise Generator", "Noise Generator" }, \
1481f1572a44SRichard Fitzgerald 	{ name, "Tone Generator 1", "Tone Generator 1" }, \
1482f1572a44SRichard Fitzgerald 	{ name, "Tone Generator 2", "Tone Generator 2" }, \
1483f1572a44SRichard Fitzgerald 	{ name, "Haptics", "HAPTICS" }, \
1484f1572a44SRichard Fitzgerald 	{ name, "AEC1", "AEC1 Loopback" }, \
1485f1572a44SRichard Fitzgerald 	{ name, "AEC2", "AEC2 Loopback" }, \
1486f1572a44SRichard Fitzgerald 	{ name, "IN1L", "IN1L" }, \
1487f1572a44SRichard Fitzgerald 	{ name, "IN1R", "IN1R" }, \
1488f1572a44SRichard Fitzgerald 	{ name, "IN2L", "IN2L" }, \
1489f1572a44SRichard Fitzgerald 	{ name, "IN2R", "IN2R" }, \
1490f1572a44SRichard Fitzgerald 	{ name, "IN3L", "IN3L" }, \
1491f1572a44SRichard Fitzgerald 	{ name, "IN3R", "IN3R" }, \
1492f1572a44SRichard Fitzgerald 	{ name, "IN4L", "IN4L" }, \
1493f1572a44SRichard Fitzgerald 	{ name, "IN4R", "IN4R" }, \
1494f1572a44SRichard Fitzgerald 	{ name, "IN5L", "IN5L" }, \
1495f1572a44SRichard Fitzgerald 	{ name, "IN5R", "IN5R" }, \
1496f1572a44SRichard Fitzgerald 	{ name, "AIF1RX1", "AIF1RX1" }, \
1497f1572a44SRichard Fitzgerald 	{ name, "AIF1RX2", "AIF1RX2" }, \
1498f1572a44SRichard Fitzgerald 	{ name, "AIF1RX3", "AIF1RX3" }, \
1499f1572a44SRichard Fitzgerald 	{ name, "AIF1RX4", "AIF1RX4" }, \
1500f1572a44SRichard Fitzgerald 	{ name, "AIF1RX5", "AIF1RX5" }, \
1501f1572a44SRichard Fitzgerald 	{ name, "AIF1RX6", "AIF1RX6" }, \
1502f1572a44SRichard Fitzgerald 	{ name, "AIF1RX7", "AIF1RX7" }, \
1503f1572a44SRichard Fitzgerald 	{ name, "AIF1RX8", "AIF1RX8" }, \
1504f1572a44SRichard Fitzgerald 	{ name, "AIF2RX1", "AIF2RX1" }, \
1505f1572a44SRichard Fitzgerald 	{ name, "AIF2RX2", "AIF2RX2" }, \
1506f1572a44SRichard Fitzgerald 	{ name, "AIF2RX3", "AIF2RX3" }, \
1507f1572a44SRichard Fitzgerald 	{ name, "AIF2RX4", "AIF2RX4" }, \
1508f1572a44SRichard Fitzgerald 	{ name, "AIF2RX5", "AIF2RX5" }, \
1509f1572a44SRichard Fitzgerald 	{ name, "AIF2RX6", "AIF2RX6" }, \
1510f1572a44SRichard Fitzgerald 	{ name, "AIF2RX7", "AIF2RX7" }, \
1511f1572a44SRichard Fitzgerald 	{ name, "AIF2RX8", "AIF2RX8" }, \
1512f1572a44SRichard Fitzgerald 	{ name, "AIF3RX1", "AIF3RX1" }, \
1513f1572a44SRichard Fitzgerald 	{ name, "AIF3RX2", "AIF3RX2" }, \
1514f1572a44SRichard Fitzgerald 	{ name, "AIF4RX1", "AIF4RX1" }, \
1515f1572a44SRichard Fitzgerald 	{ name, "AIF4RX2", "AIF4RX2" }, \
1516f1572a44SRichard Fitzgerald 	{ name, "SLIMRX1", "SLIMRX1" }, \
1517f1572a44SRichard Fitzgerald 	{ name, "SLIMRX2", "SLIMRX2" }, \
1518f1572a44SRichard Fitzgerald 	{ name, "SLIMRX3", "SLIMRX3" }, \
1519f1572a44SRichard Fitzgerald 	{ name, "SLIMRX4", "SLIMRX4" }, \
1520f1572a44SRichard Fitzgerald 	{ name, "SLIMRX5", "SLIMRX5" }, \
1521f1572a44SRichard Fitzgerald 	{ name, "SLIMRX6", "SLIMRX6" }, \
1522f1572a44SRichard Fitzgerald 	{ name, "SLIMRX7", "SLIMRX7" }, \
1523f1572a44SRichard Fitzgerald 	{ name, "SLIMRX8", "SLIMRX8" }, \
1524f1572a44SRichard Fitzgerald 	{ name, "EQ1", "EQ1" }, \
1525f1572a44SRichard Fitzgerald 	{ name, "EQ2", "EQ2" }, \
1526f1572a44SRichard Fitzgerald 	{ name, "EQ3", "EQ3" }, \
1527f1572a44SRichard Fitzgerald 	{ name, "EQ4", "EQ4" }, \
1528f1572a44SRichard Fitzgerald 	{ name, "DRC1L", "DRC1L" }, \
1529f1572a44SRichard Fitzgerald 	{ name, "DRC1R", "DRC1R" }, \
1530f1572a44SRichard Fitzgerald 	{ name, "DRC2L", "DRC2L" }, \
1531f1572a44SRichard Fitzgerald 	{ name, "DRC2R", "DRC2R" }, \
1532f1572a44SRichard Fitzgerald 	{ name, "LHPF1", "LHPF1" }, \
1533f1572a44SRichard Fitzgerald 	{ name, "LHPF2", "LHPF2" }, \
1534f1572a44SRichard Fitzgerald 	{ name, "LHPF3", "LHPF3" }, \
1535f1572a44SRichard Fitzgerald 	{ name, "LHPF4", "LHPF4" }, \
1536f1572a44SRichard Fitzgerald 	{ name, "ASRC1IN1L", "ASRC1IN1L" }, \
1537f1572a44SRichard Fitzgerald 	{ name, "ASRC1IN1R", "ASRC1IN1R" }, \
1538f1572a44SRichard Fitzgerald 	{ name, "ASRC1IN2L", "ASRC1IN2L" }, \
1539f1572a44SRichard Fitzgerald 	{ name, "ASRC1IN2R", "ASRC1IN2R" }, \
1540f1572a44SRichard Fitzgerald 	{ name, "ASRC2IN1L", "ASRC2IN1L" }, \
1541f1572a44SRichard Fitzgerald 	{ name, "ASRC2IN1R", "ASRC2IN1R" }, \
1542f1572a44SRichard Fitzgerald 	{ name, "ASRC2IN2L", "ASRC2IN2L" }, \
1543f1572a44SRichard Fitzgerald 	{ name, "ASRC2IN2R", "ASRC2IN2R" }, \
1544f1572a44SRichard Fitzgerald 	{ name, "ISRC1DEC1", "ISRC1DEC1" }, \
1545f1572a44SRichard Fitzgerald 	{ name, "ISRC1DEC2", "ISRC1DEC2" }, \
1546f1572a44SRichard Fitzgerald 	{ name, "ISRC1DEC3", "ISRC1DEC3" }, \
1547f1572a44SRichard Fitzgerald 	{ name, "ISRC1DEC4", "ISRC1DEC4" }, \
1548f1572a44SRichard Fitzgerald 	{ name, "ISRC1INT1", "ISRC1INT1" }, \
1549f1572a44SRichard Fitzgerald 	{ name, "ISRC1INT2", "ISRC1INT2" }, \
1550f1572a44SRichard Fitzgerald 	{ name, "ISRC1INT3", "ISRC1INT3" }, \
1551f1572a44SRichard Fitzgerald 	{ name, "ISRC1INT4", "ISRC1INT4" }, \
1552f1572a44SRichard Fitzgerald 	{ name, "ISRC2DEC1", "ISRC2DEC1" }, \
1553f1572a44SRichard Fitzgerald 	{ name, "ISRC2DEC2", "ISRC2DEC2" }, \
1554f1572a44SRichard Fitzgerald 	{ name, "ISRC2DEC3", "ISRC2DEC3" }, \
1555f1572a44SRichard Fitzgerald 	{ name, "ISRC2DEC4", "ISRC2DEC4" }, \
1556f1572a44SRichard Fitzgerald 	{ name, "ISRC2INT1", "ISRC2INT1" }, \
1557f1572a44SRichard Fitzgerald 	{ name, "ISRC2INT2", "ISRC2INT2" }, \
1558f1572a44SRichard Fitzgerald 	{ name, "ISRC2INT3", "ISRC2INT3" }, \
1559f1572a44SRichard Fitzgerald 	{ name, "ISRC2INT4", "ISRC2INT4" }, \
1560f1572a44SRichard Fitzgerald 	{ name, "ISRC3DEC1", "ISRC3DEC1" }, \
1561f1572a44SRichard Fitzgerald 	{ name, "ISRC3DEC2", "ISRC3DEC2" }, \
1562f1572a44SRichard Fitzgerald 	{ name, "ISRC3INT1", "ISRC3INT1" }, \
1563f1572a44SRichard Fitzgerald 	{ name, "ISRC3INT2", "ISRC3INT2" }, \
1564f1572a44SRichard Fitzgerald 	{ name, "ISRC4DEC1", "ISRC4DEC1" }, \
1565f1572a44SRichard Fitzgerald 	{ name, "ISRC4DEC2", "ISRC4DEC2" }, \
1566f1572a44SRichard Fitzgerald 	{ name, "ISRC4INT1", "ISRC4INT1" }, \
1567f1572a44SRichard Fitzgerald 	{ name, "ISRC4INT2", "ISRC4INT2" }, \
1568f1572a44SRichard Fitzgerald 	{ name, "DSP1.1", "DSP1" }, \
1569f1572a44SRichard Fitzgerald 	{ name, "DSP1.2", "DSP1" }, \
1570f1572a44SRichard Fitzgerald 	{ name, "DSP1.3", "DSP1" }, \
1571f1572a44SRichard Fitzgerald 	{ name, "DSP1.4", "DSP1" }, \
1572f1572a44SRichard Fitzgerald 	{ name, "DSP1.5", "DSP1" }, \
1573f1572a44SRichard Fitzgerald 	{ name, "DSP1.6", "DSP1" }, \
1574f1572a44SRichard Fitzgerald 	{ name, "DSP2.1", "DSP2" }, \
1575f1572a44SRichard Fitzgerald 	{ name, "DSP2.2", "DSP2" }, \
1576f1572a44SRichard Fitzgerald 	{ name, "DSP2.3", "DSP2" }, \
1577f1572a44SRichard Fitzgerald 	{ name, "DSP2.4", "DSP2" }, \
1578f1572a44SRichard Fitzgerald 	{ name, "DSP2.5", "DSP2" }, \
1579f1572a44SRichard Fitzgerald 	{ name, "DSP2.6", "DSP2" }, \
1580f1572a44SRichard Fitzgerald 	{ name, "DSP3.1", "DSP3" }, \
1581f1572a44SRichard Fitzgerald 	{ name, "DSP3.2", "DSP3" }, \
1582f1572a44SRichard Fitzgerald 	{ name, "DSP3.3", "DSP3" }, \
1583f1572a44SRichard Fitzgerald 	{ name, "DSP3.4", "DSP3" }, \
1584f1572a44SRichard Fitzgerald 	{ name, "DSP3.5", "DSP3" }, \
1585f1572a44SRichard Fitzgerald 	{ name, "DSP3.6", "DSP3" }, \
1586f1572a44SRichard Fitzgerald 	{ name, "DSP4.1", "DSP4" }, \
1587f1572a44SRichard Fitzgerald 	{ name, "DSP4.2", "DSP4" }, \
1588f1572a44SRichard Fitzgerald 	{ name, "DSP4.3", "DSP4" }, \
1589f1572a44SRichard Fitzgerald 	{ name, "DSP4.4", "DSP4" }, \
1590f1572a44SRichard Fitzgerald 	{ name, "DSP4.5", "DSP4" }, \
1591f1572a44SRichard Fitzgerald 	{ name, "DSP4.6", "DSP4" }, \
1592f1572a44SRichard Fitzgerald 	{ name, "DSP5.1", "DSP5" }, \
1593f1572a44SRichard Fitzgerald 	{ name, "DSP5.2", "DSP5" }, \
1594f1572a44SRichard Fitzgerald 	{ name, "DSP5.3", "DSP5" }, \
1595f1572a44SRichard Fitzgerald 	{ name, "DSP5.4", "DSP5" }, \
1596f1572a44SRichard Fitzgerald 	{ name, "DSP5.5", "DSP5" }, \
1597f1572a44SRichard Fitzgerald 	{ name, "DSP5.6", "DSP5" }, \
1598f1572a44SRichard Fitzgerald 	{ name, "DSP6.1", "DSP6" }, \
1599f1572a44SRichard Fitzgerald 	{ name, "DSP6.2", "DSP6" }, \
1600f1572a44SRichard Fitzgerald 	{ name, "DSP6.3", "DSP6" }, \
1601f1572a44SRichard Fitzgerald 	{ name, "DSP6.4", "DSP6" }, \
1602f1572a44SRichard Fitzgerald 	{ name, "DSP6.5", "DSP6" }, \
1603f1572a44SRichard Fitzgerald 	{ name, "DSP6.6", "DSP6" }, \
1604f1572a44SRichard Fitzgerald 	{ name, "DSP7.1", "DSP7" }, \
1605f1572a44SRichard Fitzgerald 	{ name, "DSP7.2", "DSP7" }, \
1606f1572a44SRichard Fitzgerald 	{ name, "DSP7.3", "DSP7" }, \
1607f1572a44SRichard Fitzgerald 	{ name, "DSP7.4", "DSP7" }, \
1608f1572a44SRichard Fitzgerald 	{ name, "DSP7.5", "DSP7" }, \
1609f1572a44SRichard Fitzgerald 	{ name, "DSP7.6", "DSP7" }, \
1610f1572a44SRichard Fitzgerald 	{ name, "DFC1", "DFC1" }, \
1611f1572a44SRichard Fitzgerald 	{ name, "DFC2", "DFC2" }, \
1612f1572a44SRichard Fitzgerald 	{ name, "DFC3", "DFC3" }, \
1613f1572a44SRichard Fitzgerald 	{ name, "DFC4", "DFC4" }, \
1614f1572a44SRichard Fitzgerald 	{ name, "DFC5", "DFC5" }, \
1615f1572a44SRichard Fitzgerald 	{ name, "DFC6", "DFC6" }, \
1616f1572a44SRichard Fitzgerald 	{ name, "DFC7", "DFC7" }, \
1617f1572a44SRichard Fitzgerald 	{ name, "DFC8", "DFC8" }
1618f1572a44SRichard Fitzgerald 
1619f1572a44SRichard Fitzgerald static const struct snd_soc_dapm_route cs47l90_dapm_routes[] = {
1620f1572a44SRichard Fitzgerald 	/* Internal clock domains */
1621f1572a44SRichard Fitzgerald 	{ "EQ1", NULL, "FXCLK" },
1622f1572a44SRichard Fitzgerald 	{ "EQ2", NULL, "FXCLK" },
1623f1572a44SRichard Fitzgerald 	{ "EQ3", NULL, "FXCLK" },
1624f1572a44SRichard Fitzgerald 	{ "EQ4", NULL, "FXCLK" },
1625f1572a44SRichard Fitzgerald 	{ "DRC1L", NULL, "FXCLK" },
1626f1572a44SRichard Fitzgerald 	{ "DRC1R", NULL, "FXCLK" },
1627f1572a44SRichard Fitzgerald 	{ "DRC2L", NULL, "FXCLK" },
1628f1572a44SRichard Fitzgerald 	{ "DRC2R", NULL, "FXCLK" },
1629f1572a44SRichard Fitzgerald 	{ "LHPF1", NULL, "FXCLK" },
1630f1572a44SRichard Fitzgerald 	{ "LHPF2", NULL, "FXCLK" },
1631f1572a44SRichard Fitzgerald 	{ "LHPF3", NULL, "FXCLK" },
1632f1572a44SRichard Fitzgerald 	{ "LHPF4", NULL, "FXCLK" },
1633f1572a44SRichard Fitzgerald 	{ "PWM1 Mixer", NULL, "PWMCLK" },
1634f1572a44SRichard Fitzgerald 	{ "PWM2 Mixer", NULL, "PWMCLK" },
1635f1572a44SRichard Fitzgerald 	{ "OUT1L", NULL, "OUTCLK" },
1636f1572a44SRichard Fitzgerald 	{ "OUT1R", NULL, "OUTCLK" },
1637f1572a44SRichard Fitzgerald 	{ "OUT2L", NULL, "OUTCLK" },
1638f1572a44SRichard Fitzgerald 	{ "OUT2R", NULL, "OUTCLK" },
1639f1572a44SRichard Fitzgerald 	{ "OUT3L", NULL, "OUTCLK" },
1640f1572a44SRichard Fitzgerald 	{ "OUT3R", NULL, "OUTCLK" },
1641f1572a44SRichard Fitzgerald 	{ "OUT5L", NULL, "OUTCLK" },
1642f1572a44SRichard Fitzgerald 	{ "OUT5R", NULL, "OUTCLK" },
1643f1572a44SRichard Fitzgerald 	{ "AIF1TX1", NULL, "AIF1TXCLK" },
1644f1572a44SRichard Fitzgerald 	{ "AIF1TX2", NULL, "AIF1TXCLK" },
1645f1572a44SRichard Fitzgerald 	{ "AIF1TX3", NULL, "AIF1TXCLK" },
1646f1572a44SRichard Fitzgerald 	{ "AIF1TX4", NULL, "AIF1TXCLK" },
1647f1572a44SRichard Fitzgerald 	{ "AIF1TX5", NULL, "AIF1TXCLK" },
1648f1572a44SRichard Fitzgerald 	{ "AIF1TX6", NULL, "AIF1TXCLK" },
1649f1572a44SRichard Fitzgerald 	{ "AIF1TX7", NULL, "AIF1TXCLK" },
1650f1572a44SRichard Fitzgerald 	{ "AIF1TX8", NULL, "AIF1TXCLK" },
1651f1572a44SRichard Fitzgerald 	{ "AIF2TX1", NULL, "AIF2TXCLK" },
1652f1572a44SRichard Fitzgerald 	{ "AIF2TX2", NULL, "AIF2TXCLK" },
1653f1572a44SRichard Fitzgerald 	{ "AIF2TX3", NULL, "AIF2TXCLK" },
1654f1572a44SRichard Fitzgerald 	{ "AIF2TX4", NULL, "AIF2TXCLK" },
1655f1572a44SRichard Fitzgerald 	{ "AIF2TX5", NULL, "AIF2TXCLK" },
1656f1572a44SRichard Fitzgerald 	{ "AIF2TX6", NULL, "AIF2TXCLK" },
1657f1572a44SRichard Fitzgerald 	{ "AIF2TX7", NULL, "AIF2TXCLK" },
1658f1572a44SRichard Fitzgerald 	{ "AIF2TX8", NULL, "AIF2TXCLK" },
1659f1572a44SRichard Fitzgerald 	{ "AIF3TX1", NULL, "AIF3TXCLK" },
1660f1572a44SRichard Fitzgerald 	{ "AIF3TX2", NULL, "AIF3TXCLK" },
1661f1572a44SRichard Fitzgerald 	{ "AIF4TX1", NULL, "AIF4TXCLK" },
1662f1572a44SRichard Fitzgerald 	{ "AIF4TX2", NULL, "AIF4TXCLK" },
1663f1572a44SRichard Fitzgerald 	{ "SLIMTX1", NULL, "SLIMBUSCLK" },
1664f1572a44SRichard Fitzgerald 	{ "SLIMTX2", NULL, "SLIMBUSCLK" },
1665f1572a44SRichard Fitzgerald 	{ "SLIMTX3", NULL, "SLIMBUSCLK" },
1666f1572a44SRichard Fitzgerald 	{ "SLIMTX4", NULL, "SLIMBUSCLK" },
1667f1572a44SRichard Fitzgerald 	{ "SLIMTX5", NULL, "SLIMBUSCLK" },
1668f1572a44SRichard Fitzgerald 	{ "SLIMTX6", NULL, "SLIMBUSCLK" },
1669f1572a44SRichard Fitzgerald 	{ "SLIMTX7", NULL, "SLIMBUSCLK" },
1670f1572a44SRichard Fitzgerald 	{ "SLIMTX8", NULL, "SLIMBUSCLK" },
1671f1572a44SRichard Fitzgerald 	{ "SPD1TX1", NULL, "SPDCLK" },
1672f1572a44SRichard Fitzgerald 	{ "SPD1TX2", NULL, "SPDCLK" },
1673f1572a44SRichard Fitzgerald 	{ "DSP1", NULL, "DSP1CLK" },
1674f1572a44SRichard Fitzgerald 	{ "DSP2", NULL, "DSP2CLK" },
1675f1572a44SRichard Fitzgerald 	{ "DSP3", NULL, "DSP3CLK" },
1676f1572a44SRichard Fitzgerald 	{ "DSP4", NULL, "DSP4CLK" },
1677f1572a44SRichard Fitzgerald 	{ "DSP5", NULL, "DSP5CLK" },
1678f1572a44SRichard Fitzgerald 	{ "DSP6", NULL, "DSP6CLK" },
1679f1572a44SRichard Fitzgerald 	{ "DSP7", NULL, "DSP7CLK" },
1680f1572a44SRichard Fitzgerald 	{ "ISRC1DEC1", NULL, "ISRC1CLK" },
1681f1572a44SRichard Fitzgerald 	{ "ISRC1DEC2", NULL, "ISRC1CLK" },
1682f1572a44SRichard Fitzgerald 	{ "ISRC1DEC3", NULL, "ISRC1CLK" },
1683f1572a44SRichard Fitzgerald 	{ "ISRC1DEC4", NULL, "ISRC1CLK" },
1684f1572a44SRichard Fitzgerald 	{ "ISRC1INT1", NULL, "ISRC1CLK" },
1685f1572a44SRichard Fitzgerald 	{ "ISRC1INT2", NULL, "ISRC1CLK" },
1686f1572a44SRichard Fitzgerald 	{ "ISRC1INT3", NULL, "ISRC1CLK" },
1687f1572a44SRichard Fitzgerald 	{ "ISRC1INT4", NULL, "ISRC1CLK" },
1688f1572a44SRichard Fitzgerald 	{ "ISRC2DEC1", NULL, "ISRC2CLK" },
1689f1572a44SRichard Fitzgerald 	{ "ISRC2DEC2", NULL, "ISRC2CLK" },
1690f1572a44SRichard Fitzgerald 	{ "ISRC2DEC3", NULL, "ISRC2CLK" },
1691f1572a44SRichard Fitzgerald 	{ "ISRC2DEC4", NULL, "ISRC2CLK" },
1692f1572a44SRichard Fitzgerald 	{ "ISRC2INT1", NULL, "ISRC2CLK" },
1693f1572a44SRichard Fitzgerald 	{ "ISRC2INT2", NULL, "ISRC2CLK" },
1694f1572a44SRichard Fitzgerald 	{ "ISRC2INT3", NULL, "ISRC2CLK" },
1695f1572a44SRichard Fitzgerald 	{ "ISRC2INT4", NULL, "ISRC2CLK" },
1696f1572a44SRichard Fitzgerald 	{ "ISRC3DEC1", NULL, "ISRC3CLK" },
1697f1572a44SRichard Fitzgerald 	{ "ISRC3DEC2", NULL, "ISRC3CLK" },
1698f1572a44SRichard Fitzgerald 	{ "ISRC3INT1", NULL, "ISRC3CLK" },
1699f1572a44SRichard Fitzgerald 	{ "ISRC3INT2", NULL, "ISRC3CLK" },
1700f1572a44SRichard Fitzgerald 	{ "ISRC4DEC1", NULL, "ISRC4CLK" },
1701f1572a44SRichard Fitzgerald 	{ "ISRC4DEC2", NULL, "ISRC4CLK" },
1702f1572a44SRichard Fitzgerald 	{ "ISRC4INT1", NULL, "ISRC4CLK" },
1703f1572a44SRichard Fitzgerald 	{ "ISRC4INT2", NULL, "ISRC4CLK" },
1704f1572a44SRichard Fitzgerald 	{ "ASRC1IN1L", NULL, "ASRC1CLK" },
1705f1572a44SRichard Fitzgerald 	{ "ASRC1IN1R", NULL, "ASRC1CLK" },
1706f1572a44SRichard Fitzgerald 	{ "ASRC1IN2L", NULL, "ASRC1CLK" },
1707f1572a44SRichard Fitzgerald 	{ "ASRC1IN2R", NULL, "ASRC1CLK" },
1708f1572a44SRichard Fitzgerald 	{ "ASRC2IN1L", NULL, "ASRC2CLK" },
1709f1572a44SRichard Fitzgerald 	{ "ASRC2IN1R", NULL, "ASRC2CLK" },
1710f1572a44SRichard Fitzgerald 	{ "ASRC2IN2L", NULL, "ASRC2CLK" },
1711f1572a44SRichard Fitzgerald 	{ "ASRC2IN2R", NULL, "ASRC2CLK" },
1712f1572a44SRichard Fitzgerald 	{ "DFC1", NULL, "DFCCLK" },
1713f1572a44SRichard Fitzgerald 	{ "DFC2", NULL, "DFCCLK" },
1714f1572a44SRichard Fitzgerald 	{ "DFC3", NULL, "DFCCLK" },
1715f1572a44SRichard Fitzgerald 	{ "DFC4", NULL, "DFCCLK" },
1716f1572a44SRichard Fitzgerald 	{ "DFC5", NULL, "DFCCLK" },
1717f1572a44SRichard Fitzgerald 	{ "DFC6", NULL, "DFCCLK" },
1718f1572a44SRichard Fitzgerald 	{ "DFC7", NULL, "DFCCLK" },
1719f1572a44SRichard Fitzgerald 	{ "DFC8", NULL, "DFCCLK" },
1720f1572a44SRichard Fitzgerald 
1721f1572a44SRichard Fitzgerald 	{ "AIF2 Capture", NULL, "DBVDD2" },
1722f1572a44SRichard Fitzgerald 	{ "AIF2 Playback", NULL, "DBVDD2" },
1723f1572a44SRichard Fitzgerald 
1724f1572a44SRichard Fitzgerald 	{ "AIF3 Capture", NULL, "DBVDD3" },
1725f1572a44SRichard Fitzgerald 	{ "AIF3 Playback", NULL, "DBVDD3" },
1726f1572a44SRichard Fitzgerald 
1727f1572a44SRichard Fitzgerald 	{ "AIF4 Capture", NULL, "DBVDD3" },
1728f1572a44SRichard Fitzgerald 	{ "AIF4 Playback", NULL, "DBVDD3" },
1729f1572a44SRichard Fitzgerald 
1730f1572a44SRichard Fitzgerald 	{ "OUT1L", NULL, "CPVDD1" },
1731f1572a44SRichard Fitzgerald 	{ "OUT1L", NULL, "CPVDD2" },
1732f1572a44SRichard Fitzgerald 	{ "OUT1R", NULL, "CPVDD1" },
1733f1572a44SRichard Fitzgerald 	{ "OUT1R", NULL, "CPVDD2" },
1734f1572a44SRichard Fitzgerald 	{ "OUT2L", NULL, "CPVDD1" },
1735f1572a44SRichard Fitzgerald 	{ "OUT2L", NULL, "CPVDD2" },
1736f1572a44SRichard Fitzgerald 	{ "OUT2R", NULL, "CPVDD1" },
1737f1572a44SRichard Fitzgerald 	{ "OUT2R", NULL, "CPVDD2" },
1738f1572a44SRichard Fitzgerald 	{ "OUT3L", NULL, "CPVDD1" },
1739f1572a44SRichard Fitzgerald 	{ "OUT3L", NULL, "CPVDD2" },
1740f1572a44SRichard Fitzgerald 	{ "OUT3R", NULL, "CPVDD1" },
1741f1572a44SRichard Fitzgerald 	{ "OUT3R", NULL, "CPVDD2" },
1742f1572a44SRichard Fitzgerald 
1743f1572a44SRichard Fitzgerald 	{ "OUT1L", NULL, "SYSCLK" },
1744f1572a44SRichard Fitzgerald 	{ "OUT1R", NULL, "SYSCLK" },
1745f1572a44SRichard Fitzgerald 	{ "OUT2L", NULL, "SYSCLK" },
1746f1572a44SRichard Fitzgerald 	{ "OUT2R", NULL, "SYSCLK" },
1747f1572a44SRichard Fitzgerald 	{ "OUT3L", NULL, "SYSCLK" },
1748f1572a44SRichard Fitzgerald 	{ "OUT3R", NULL, "SYSCLK" },
1749f1572a44SRichard Fitzgerald 	{ "OUT5L", NULL, "SYSCLK" },
1750f1572a44SRichard Fitzgerald 	{ "OUT5R", NULL, "SYSCLK" },
1751f1572a44SRichard Fitzgerald 
1752f1572a44SRichard Fitzgerald 	{ "SPD1", NULL, "SYSCLK" },
1753f1572a44SRichard Fitzgerald 	{ "SPD1", NULL, "SPD1TX1" },
1754f1572a44SRichard Fitzgerald 	{ "SPD1", NULL, "SPD1TX2" },
1755f1572a44SRichard Fitzgerald 
1756f1572a44SRichard Fitzgerald 	{ "IN1L", NULL, "SYSCLK" },
1757f1572a44SRichard Fitzgerald 	{ "IN1R", NULL, "SYSCLK" },
1758f1572a44SRichard Fitzgerald 	{ "IN2L", NULL, "SYSCLK" },
1759f1572a44SRichard Fitzgerald 	{ "IN2R", NULL, "SYSCLK" },
1760f1572a44SRichard Fitzgerald 	{ "IN3L", NULL, "SYSCLK" },
1761f1572a44SRichard Fitzgerald 	{ "IN3R", NULL, "SYSCLK" },
1762f1572a44SRichard Fitzgerald 	{ "IN4L", NULL, "SYSCLK" },
1763f1572a44SRichard Fitzgerald 	{ "IN4R", NULL, "SYSCLK" },
1764f1572a44SRichard Fitzgerald 	{ "IN5L", NULL, "SYSCLK" },
1765f1572a44SRichard Fitzgerald 	{ "IN5R", NULL, "SYSCLK" },
1766f1572a44SRichard Fitzgerald 
1767f1572a44SRichard Fitzgerald 	{ "IN3L", NULL, "DBVDD4" },
1768f1572a44SRichard Fitzgerald 	{ "IN3R", NULL, "DBVDD4" },
1769f1572a44SRichard Fitzgerald 	{ "IN4L", NULL, "DBVDD4" },
1770f1572a44SRichard Fitzgerald 	{ "IN4R", NULL, "DBVDD4" },
1771f1572a44SRichard Fitzgerald 	{ "IN5L", NULL, "DBVDD4" },
1772f1572a44SRichard Fitzgerald 	{ "IN5R", NULL, "DBVDD4" },
1773f1572a44SRichard Fitzgerald 
1774f1572a44SRichard Fitzgerald 	{ "ASRC1IN1L", NULL, "SYSCLK" },
1775f1572a44SRichard Fitzgerald 	{ "ASRC1IN1R", NULL, "SYSCLK" },
1776f1572a44SRichard Fitzgerald 	{ "ASRC1IN2L", NULL, "SYSCLK" },
1777f1572a44SRichard Fitzgerald 	{ "ASRC1IN2R", NULL, "SYSCLK" },
1778f1572a44SRichard Fitzgerald 	{ "ASRC2IN1L", NULL, "SYSCLK" },
1779f1572a44SRichard Fitzgerald 	{ "ASRC2IN1R", NULL, "SYSCLK" },
1780f1572a44SRichard Fitzgerald 	{ "ASRC2IN2L", NULL, "SYSCLK" },
1781f1572a44SRichard Fitzgerald 	{ "ASRC2IN2R", NULL, "SYSCLK" },
1782f1572a44SRichard Fitzgerald 
1783f1572a44SRichard Fitzgerald 	{ "ASRC1IN1L", NULL, "ASYNCCLK" },
1784f1572a44SRichard Fitzgerald 	{ "ASRC1IN1R", NULL, "ASYNCCLK" },
1785f1572a44SRichard Fitzgerald 	{ "ASRC1IN2L", NULL, "ASYNCCLK" },
1786f1572a44SRichard Fitzgerald 	{ "ASRC1IN2R", NULL, "ASYNCCLK" },
1787f1572a44SRichard Fitzgerald 	{ "ASRC2IN1L", NULL, "ASYNCCLK" },
1788f1572a44SRichard Fitzgerald 	{ "ASRC2IN1R", NULL, "ASYNCCLK" },
1789f1572a44SRichard Fitzgerald 	{ "ASRC2IN2L", NULL, "ASYNCCLK" },
1790f1572a44SRichard Fitzgerald 	{ "ASRC2IN2R", NULL, "ASYNCCLK" },
1791f1572a44SRichard Fitzgerald 
1792f1572a44SRichard Fitzgerald 	{ "MICBIAS1", NULL, "MICVDD" },
1793f1572a44SRichard Fitzgerald 	{ "MICBIAS2", NULL, "MICVDD" },
1794f1572a44SRichard Fitzgerald 
1795f1572a44SRichard Fitzgerald 	{ "MICBIAS1A", NULL, "MICBIAS1" },
1796f1572a44SRichard Fitzgerald 	{ "MICBIAS1B", NULL, "MICBIAS1" },
1797f1572a44SRichard Fitzgerald 	{ "MICBIAS1C", NULL, "MICBIAS1" },
1798f1572a44SRichard Fitzgerald 	{ "MICBIAS1D", NULL, "MICBIAS1" },
1799f1572a44SRichard Fitzgerald 
1800f1572a44SRichard Fitzgerald 	{ "MICBIAS2A", NULL, "MICBIAS2" },
1801f1572a44SRichard Fitzgerald 	{ "MICBIAS2B", NULL, "MICBIAS2" },
1802f1572a44SRichard Fitzgerald 	{ "MICBIAS2C", NULL, "MICBIAS2" },
1803f1572a44SRichard Fitzgerald 	{ "MICBIAS2D", NULL, "MICBIAS2" },
1804f1572a44SRichard Fitzgerald 
1805f1572a44SRichard Fitzgerald 	{ "Noise Generator", NULL, "SYSCLK" },
1806f1572a44SRichard Fitzgerald 	{ "Tone Generator 1", NULL, "SYSCLK" },
1807f1572a44SRichard Fitzgerald 	{ "Tone Generator 2", NULL, "SYSCLK" },
1808f1572a44SRichard Fitzgerald 
1809f1572a44SRichard Fitzgerald 	{ "Noise Generator", NULL, "NOISE" },
1810f1572a44SRichard Fitzgerald 	{ "Tone Generator 1", NULL, "TONE" },
1811f1572a44SRichard Fitzgerald 	{ "Tone Generator 2", NULL, "TONE" },
1812f1572a44SRichard Fitzgerald 
1813f1572a44SRichard Fitzgerald 	{ "AIF1 Capture", NULL, "AIF1TX1" },
1814f1572a44SRichard Fitzgerald 	{ "AIF1 Capture", NULL, "AIF1TX2" },
1815f1572a44SRichard Fitzgerald 	{ "AIF1 Capture", NULL, "AIF1TX3" },
1816f1572a44SRichard Fitzgerald 	{ "AIF1 Capture", NULL, "AIF1TX4" },
1817f1572a44SRichard Fitzgerald 	{ "AIF1 Capture", NULL, "AIF1TX5" },
1818f1572a44SRichard Fitzgerald 	{ "AIF1 Capture", NULL, "AIF1TX6" },
1819f1572a44SRichard Fitzgerald 	{ "AIF1 Capture", NULL, "AIF1TX7" },
1820f1572a44SRichard Fitzgerald 	{ "AIF1 Capture", NULL, "AIF1TX8" },
1821f1572a44SRichard Fitzgerald 
1822f1572a44SRichard Fitzgerald 	{ "AIF1RX1", NULL, "AIF1 Playback" },
1823f1572a44SRichard Fitzgerald 	{ "AIF1RX2", NULL, "AIF1 Playback" },
1824f1572a44SRichard Fitzgerald 	{ "AIF1RX3", NULL, "AIF1 Playback" },
1825f1572a44SRichard Fitzgerald 	{ "AIF1RX4", NULL, "AIF1 Playback" },
1826f1572a44SRichard Fitzgerald 	{ "AIF1RX5", NULL, "AIF1 Playback" },
1827f1572a44SRichard Fitzgerald 	{ "AIF1RX6", NULL, "AIF1 Playback" },
1828f1572a44SRichard Fitzgerald 	{ "AIF1RX7", NULL, "AIF1 Playback" },
1829f1572a44SRichard Fitzgerald 	{ "AIF1RX8", NULL, "AIF1 Playback" },
1830f1572a44SRichard Fitzgerald 
1831f1572a44SRichard Fitzgerald 	{ "AIF2 Capture", NULL, "AIF2TX1" },
1832f1572a44SRichard Fitzgerald 	{ "AIF2 Capture", NULL, "AIF2TX2" },
1833f1572a44SRichard Fitzgerald 	{ "AIF2 Capture", NULL, "AIF2TX3" },
1834f1572a44SRichard Fitzgerald 	{ "AIF2 Capture", NULL, "AIF2TX4" },
1835f1572a44SRichard Fitzgerald 	{ "AIF2 Capture", NULL, "AIF2TX5" },
1836f1572a44SRichard Fitzgerald 	{ "AIF2 Capture", NULL, "AIF2TX6" },
1837f1572a44SRichard Fitzgerald 	{ "AIF2 Capture", NULL, "AIF2TX7" },
1838f1572a44SRichard Fitzgerald 	{ "AIF2 Capture", NULL, "AIF2TX8" },
1839f1572a44SRichard Fitzgerald 
1840f1572a44SRichard Fitzgerald 	{ "AIF2RX1", NULL, "AIF2 Playback" },
1841f1572a44SRichard Fitzgerald 	{ "AIF2RX2", NULL, "AIF2 Playback" },
1842f1572a44SRichard Fitzgerald 	{ "AIF2RX3", NULL, "AIF2 Playback" },
1843f1572a44SRichard Fitzgerald 	{ "AIF2RX4", NULL, "AIF2 Playback" },
1844f1572a44SRichard Fitzgerald 	{ "AIF2RX5", NULL, "AIF2 Playback" },
1845f1572a44SRichard Fitzgerald 	{ "AIF2RX6", NULL, "AIF2 Playback" },
1846f1572a44SRichard Fitzgerald 	{ "AIF2RX7", NULL, "AIF2 Playback" },
1847f1572a44SRichard Fitzgerald 	{ "AIF2RX8", NULL, "AIF2 Playback" },
1848f1572a44SRichard Fitzgerald 
1849f1572a44SRichard Fitzgerald 	{ "AIF3 Capture", NULL, "AIF3TX1" },
1850f1572a44SRichard Fitzgerald 	{ "AIF3 Capture", NULL, "AIF3TX2" },
1851f1572a44SRichard Fitzgerald 
1852f1572a44SRichard Fitzgerald 	{ "AIF3RX1", NULL, "AIF3 Playback" },
1853f1572a44SRichard Fitzgerald 	{ "AIF3RX2", NULL, "AIF3 Playback" },
1854f1572a44SRichard Fitzgerald 
1855f1572a44SRichard Fitzgerald 	{ "AIF4 Capture", NULL, "AIF4TX1" },
1856f1572a44SRichard Fitzgerald 	{ "AIF4 Capture", NULL, "AIF4TX2" },
1857f1572a44SRichard Fitzgerald 
1858f1572a44SRichard Fitzgerald 	{ "AIF4RX1", NULL, "AIF4 Playback" },
1859f1572a44SRichard Fitzgerald 	{ "AIF4RX2", NULL, "AIF4 Playback" },
1860f1572a44SRichard Fitzgerald 
1861f1572a44SRichard Fitzgerald 	{ "Slim1 Capture", NULL, "SLIMTX1" },
1862f1572a44SRichard Fitzgerald 	{ "Slim1 Capture", NULL, "SLIMTX2" },
1863f1572a44SRichard Fitzgerald 	{ "Slim1 Capture", NULL, "SLIMTX3" },
1864f1572a44SRichard Fitzgerald 	{ "Slim1 Capture", NULL, "SLIMTX4" },
1865f1572a44SRichard Fitzgerald 
1866f1572a44SRichard Fitzgerald 	{ "SLIMRX1", NULL, "Slim1 Playback" },
1867f1572a44SRichard Fitzgerald 	{ "SLIMRX2", NULL, "Slim1 Playback" },
1868f1572a44SRichard Fitzgerald 	{ "SLIMRX3", NULL, "Slim1 Playback" },
1869f1572a44SRichard Fitzgerald 	{ "SLIMRX4", NULL, "Slim1 Playback" },
1870f1572a44SRichard Fitzgerald 
1871f1572a44SRichard Fitzgerald 	{ "Slim2 Capture", NULL, "SLIMTX5" },
1872f1572a44SRichard Fitzgerald 	{ "Slim2 Capture", NULL, "SLIMTX6" },
1873f1572a44SRichard Fitzgerald 
1874f1572a44SRichard Fitzgerald 	{ "SLIMRX5", NULL, "Slim2 Playback" },
1875f1572a44SRichard Fitzgerald 	{ "SLIMRX6", NULL, "Slim2 Playback" },
1876f1572a44SRichard Fitzgerald 
1877f1572a44SRichard Fitzgerald 	{ "Slim3 Capture", NULL, "SLIMTX7" },
1878f1572a44SRichard Fitzgerald 	{ "Slim3 Capture", NULL, "SLIMTX8" },
1879f1572a44SRichard Fitzgerald 
1880f1572a44SRichard Fitzgerald 	{ "SLIMRX7", NULL, "Slim3 Playback" },
1881f1572a44SRichard Fitzgerald 	{ "SLIMRX8", NULL, "Slim3 Playback" },
1882f1572a44SRichard Fitzgerald 
1883f1572a44SRichard Fitzgerald 	{ "AIF1 Playback", NULL, "SYSCLK" },
1884f1572a44SRichard Fitzgerald 	{ "AIF2 Playback", NULL, "SYSCLK" },
1885f1572a44SRichard Fitzgerald 	{ "AIF3 Playback", NULL, "SYSCLK" },
1886f1572a44SRichard Fitzgerald 	{ "AIF4 Playback", NULL, "SYSCLK" },
1887f1572a44SRichard Fitzgerald 	{ "Slim1 Playback", NULL, "SYSCLK" },
1888f1572a44SRichard Fitzgerald 	{ "Slim2 Playback", NULL, "SYSCLK" },
1889f1572a44SRichard Fitzgerald 	{ "Slim3 Playback", NULL, "SYSCLK" },
1890f1572a44SRichard Fitzgerald 
1891f1572a44SRichard Fitzgerald 	{ "AIF1 Capture", NULL, "SYSCLK" },
1892f1572a44SRichard Fitzgerald 	{ "AIF2 Capture", NULL, "SYSCLK" },
1893f1572a44SRichard Fitzgerald 	{ "AIF3 Capture", NULL, "SYSCLK" },
1894f1572a44SRichard Fitzgerald 	{ "AIF4 Capture", NULL, "SYSCLK" },
1895f1572a44SRichard Fitzgerald 	{ "Slim1 Capture", NULL, "SYSCLK" },
1896f1572a44SRichard Fitzgerald 	{ "Slim2 Capture", NULL, "SYSCLK" },
1897f1572a44SRichard Fitzgerald 	{ "Slim3 Capture", NULL, "SYSCLK" },
1898f1572a44SRichard Fitzgerald 
1899f1572a44SRichard Fitzgerald 	{ "Voice Control DSP", NULL, "DSP6" },
1900f1572a44SRichard Fitzgerald 
1901f1572a44SRichard Fitzgerald 	{ "Audio Trace DSP", NULL, "DSP1" },
1902f1572a44SRichard Fitzgerald 
1903f1572a44SRichard Fitzgerald 	{ "IN1L Analog Mux", "A", "IN1ALN" },
1904f1572a44SRichard Fitzgerald 	{ "IN1L Analog Mux", "A", "IN1ALP" },
1905f1572a44SRichard Fitzgerald 	{ "IN1L Analog Mux", "B", "IN1BLN" },
1906f1572a44SRichard Fitzgerald 	{ "IN1L Analog Mux", "B", "IN1BLP" },
1907f1572a44SRichard Fitzgerald 	{ "IN1R Analog Mux", "A", "IN1ARN" },
1908f1572a44SRichard Fitzgerald 	{ "IN1R Analog Mux", "A", "IN1ARP" },
1909f1572a44SRichard Fitzgerald 	{ "IN1R Analog Mux", "B", "IN1BRN" },
1910f1572a44SRichard Fitzgerald 	{ "IN1R Analog Mux", "B", "IN1BRP" },
1911f1572a44SRichard Fitzgerald 
1912f1572a44SRichard Fitzgerald 	{ "IN1L Mode", "Analog", "IN1L Analog Mux" },
1913f1572a44SRichard Fitzgerald 	{ "IN1R Mode", "Analog", "IN1R Analog Mux" },
1914f1572a44SRichard Fitzgerald 
1915f1572a44SRichard Fitzgerald 	{ "IN1L Mode", "Digital", "IN1ARN" },
1916f1572a44SRichard Fitzgerald 	{ "IN1L Mode", "Digital", "IN1ARP" },
1917f1572a44SRichard Fitzgerald 	{ "IN1R Mode", "Digital", "IN1ARN" },
1918f1572a44SRichard Fitzgerald 	{ "IN1R Mode", "Digital", "IN1ARP" },
1919f1572a44SRichard Fitzgerald 
1920f1572a44SRichard Fitzgerald 	{ "IN1L", NULL, "IN1L Mode" },
1921f1572a44SRichard Fitzgerald 	{ "IN1R", NULL, "IN1R Mode" },
1922f1572a44SRichard Fitzgerald 
1923f1572a44SRichard Fitzgerald 	{ "IN2L Analog Mux", "A", "IN2ALN" },
1924f1572a44SRichard Fitzgerald 	{ "IN2L Analog Mux", "A", "IN2ALP" },
1925f1572a44SRichard Fitzgerald 	{ "IN2L Analog Mux", "B", "IN2BLN" },
1926f1572a44SRichard Fitzgerald 	{ "IN2L Analog Mux", "B", "IN2BLP" },
1927f1572a44SRichard Fitzgerald 
1928f1572a44SRichard Fitzgerald 	{ "IN2L Mode", "Analog", "IN2L Analog Mux" },
1929f1572a44SRichard Fitzgerald 	{ "IN2R Mode", "Analog", "IN2RN" },
1930f1572a44SRichard Fitzgerald 	{ "IN2R Mode", "Analog", "IN2RP" },
1931f1572a44SRichard Fitzgerald 
1932f1572a44SRichard Fitzgerald 	{ "IN2L Mode", "Digital", "IN2ALN" },
1933f1572a44SRichard Fitzgerald 	{ "IN2L Mode", "Digital", "IN2ALP" },
1934f1572a44SRichard Fitzgerald 	{ "IN2R Mode", "Digital", "IN2ALN" },
1935f1572a44SRichard Fitzgerald 	{ "IN2R Mode", "Digital", "IN2ALP" },
1936f1572a44SRichard Fitzgerald 
1937f1572a44SRichard Fitzgerald 	{ "IN2L", NULL, "IN2L Mode" },
1938f1572a44SRichard Fitzgerald 	{ "IN2R", NULL, "IN2R Mode" },
1939f1572a44SRichard Fitzgerald 
1940f1572a44SRichard Fitzgerald 	{ "IN3L", NULL, "DMICCLK3" },
1941ca34fa86SCharles Keepax 	{ "IN3L", NULL, "DMICDAT3" },
1942ca34fa86SCharles Keepax 	{ "IN3R", NULL, "DMICCLK3" },
1943f1572a44SRichard Fitzgerald 	{ "IN3R", NULL, "DMICDAT3" },
1944f1572a44SRichard Fitzgerald 
1945f1572a44SRichard Fitzgerald 	{ "IN4L", NULL, "DMICCLK4" },
1946ca34fa86SCharles Keepax 	{ "IN4L", NULL, "DMICDAT4" },
1947ca34fa86SCharles Keepax 	{ "IN4R", NULL, "DMICCLK4" },
1948f1572a44SRichard Fitzgerald 	{ "IN4R", NULL, "DMICDAT4" },
1949f1572a44SRichard Fitzgerald 
1950f1572a44SRichard Fitzgerald 	{ "IN5L", NULL, "DMICCLK5" },
1951ca34fa86SCharles Keepax 	{ "IN5L", NULL, "DMICDAT5" },
1952ca34fa86SCharles Keepax 	{ "IN5R", NULL, "DMICCLK5" },
1953f1572a44SRichard Fitzgerald 	{ "IN5R", NULL, "DMICDAT5" },
1954f1572a44SRichard Fitzgerald 
1955f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("OUT1L", "HPOUT1L"),
1956f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("OUT1R", "HPOUT1R"),
1957f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("OUT2L", "HPOUT2L"),
1958f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("OUT2R", "HPOUT2R"),
1959f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("OUT3L", "HPOUT3L"),
1960f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("OUT3R", "HPOUT3R"),
1961f1572a44SRichard Fitzgerald 
1962f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("OUT5L", "SPKDAT1L"),
1963f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("OUT5R", "SPKDAT1R"),
1964f1572a44SRichard Fitzgerald 
1965f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("PWM1 Driver", "PWM1"),
1966f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("PWM2 Driver", "PWM2"),
1967f1572a44SRichard Fitzgerald 
1968f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF1TX1", "AIF1TX1"),
1969f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF1TX2", "AIF1TX2"),
1970f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF1TX3", "AIF1TX3"),
1971f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF1TX4", "AIF1TX4"),
1972f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF1TX5", "AIF1TX5"),
1973f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF1TX6", "AIF1TX6"),
1974f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF1TX7", "AIF1TX7"),
1975f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF1TX8", "AIF1TX8"),
1976f1572a44SRichard Fitzgerald 
1977f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF2TX1", "AIF2TX1"),
1978f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF2TX2", "AIF2TX2"),
1979f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF2TX3", "AIF2TX3"),
1980f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF2TX4", "AIF2TX4"),
1981f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF2TX5", "AIF2TX5"),
1982f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF2TX6", "AIF2TX6"),
1983f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF2TX7", "AIF2TX7"),
1984f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF2TX8", "AIF2TX8"),
1985f1572a44SRichard Fitzgerald 
1986f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF3TX1", "AIF3TX1"),
1987f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF3TX2", "AIF3TX2"),
1988f1572a44SRichard Fitzgerald 
1989f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF4TX1", "AIF4TX1"),
1990f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("AIF4TX2", "AIF4TX2"),
1991f1572a44SRichard Fitzgerald 
1992f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("SLIMTX1", "SLIMTX1"),
1993f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("SLIMTX2", "SLIMTX2"),
1994f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("SLIMTX3", "SLIMTX3"),
1995f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("SLIMTX4", "SLIMTX4"),
1996f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("SLIMTX5", "SLIMTX5"),
1997f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("SLIMTX6", "SLIMTX6"),
1998f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("SLIMTX7", "SLIMTX7"),
1999f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("SLIMTX8", "SLIMTX8"),
2000f1572a44SRichard Fitzgerald 
2001f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("SPD1TX1", "SPDIF1TX1"),
2002f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("SPD1TX2", "SPDIF1TX2"),
2003f1572a44SRichard Fitzgerald 
2004f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("EQ1", "EQ1"),
2005f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("EQ2", "EQ2"),
2006f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("EQ3", "EQ3"),
2007f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("EQ4", "EQ4"),
2008f1572a44SRichard Fitzgerald 
2009f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("DRC1L", "DRC1L"),
2010f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("DRC1R", "DRC1R"),
2011f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("DRC2L", "DRC2L"),
2012f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("DRC2R", "DRC2R"),
2013f1572a44SRichard Fitzgerald 
2014f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("LHPF1", "LHPF1"),
2015f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("LHPF2", "LHPF2"),
2016f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("LHPF3", "LHPF3"),
2017f1572a44SRichard Fitzgerald 	MADERA_MIXER_ROUTES("LHPF4", "LHPF4"),
2018f1572a44SRichard Fitzgerald 
2019f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ASRC1IN1L", "ASRC1IN1L"),
2020f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ASRC1IN1R", "ASRC1IN1R"),
2021f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ASRC1IN2L", "ASRC1IN2L"),
2022f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ASRC1IN2R", "ASRC1IN2R"),
2023f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ASRC2IN1L", "ASRC2IN1L"),
2024f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ASRC2IN1R", "ASRC2IN1R"),
2025f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ASRC2IN2L", "ASRC2IN2L"),
2026f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ASRC2IN2R", "ASRC2IN2R"),
2027f1572a44SRichard Fitzgerald 
2028f1572a44SRichard Fitzgerald 	MADERA_DSP_ROUTES("DSP1"),
2029f1572a44SRichard Fitzgerald 	MADERA_DSP_ROUTES("DSP2"),
2030f1572a44SRichard Fitzgerald 	MADERA_DSP_ROUTES("DSP3"),
2031f1572a44SRichard Fitzgerald 	MADERA_DSP_ROUTES("DSP4"),
2032f1572a44SRichard Fitzgerald 	MADERA_DSP_ROUTES("DSP5"),
2033f1572a44SRichard Fitzgerald 	MADERA_DSP_ROUTES("DSP6"),
2034f1572a44SRichard Fitzgerald 	MADERA_DSP_ROUTES("DSP7"),
2035f1572a44SRichard Fitzgerald 
2036f1572a44SRichard Fitzgerald 	{ "DSP Trigger Out", NULL, "DSP1 Trigger Output" },
2037f1572a44SRichard Fitzgerald 	{ "DSP Trigger Out", NULL, "DSP2 Trigger Output" },
2038f1572a44SRichard Fitzgerald 	{ "DSP Trigger Out", NULL, "DSP3 Trigger Output" },
2039f1572a44SRichard Fitzgerald 	{ "DSP Trigger Out", NULL, "DSP4 Trigger Output" },
2040f1572a44SRichard Fitzgerald 	{ "DSP Trigger Out", NULL, "DSP5 Trigger Output" },
2041f1572a44SRichard Fitzgerald 	{ "DSP Trigger Out", NULL, "DSP6 Trigger Output" },
2042f1572a44SRichard Fitzgerald 	{ "DSP Trigger Out", NULL, "DSP7 Trigger Output" },
2043f1572a44SRichard Fitzgerald 
2044f1572a44SRichard Fitzgerald 	{ "DSP1 Trigger Output", "Switch", "DSP1" },
2045f1572a44SRichard Fitzgerald 	{ "DSP2 Trigger Output", "Switch", "DSP2" },
2046f1572a44SRichard Fitzgerald 	{ "DSP3 Trigger Output", "Switch", "DSP3" },
2047f1572a44SRichard Fitzgerald 	{ "DSP4 Trigger Output", "Switch", "DSP4" },
2048f1572a44SRichard Fitzgerald 	{ "DSP5 Trigger Output", "Switch", "DSP5" },
2049f1572a44SRichard Fitzgerald 	{ "DSP6 Trigger Output", "Switch", "DSP6" },
2050f1572a44SRichard Fitzgerald 	{ "DSP7 Trigger Output", "Switch", "DSP7" },
2051f1572a44SRichard Fitzgerald 
2052f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC1INT1", "ISRC1INT1"),
2053f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC1INT2", "ISRC1INT2"),
2054f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC1INT3", "ISRC1INT3"),
2055f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC1INT4", "ISRC1INT4"),
2056f1572a44SRichard Fitzgerald 
2057f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC1DEC1", "ISRC1DEC1"),
2058f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC1DEC2", "ISRC1DEC2"),
2059f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC1DEC3", "ISRC1DEC3"),
2060f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC1DEC4", "ISRC1DEC4"),
2061f1572a44SRichard Fitzgerald 
2062f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC2INT1", "ISRC2INT1"),
2063f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC2INT2", "ISRC2INT2"),
2064f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC2INT3", "ISRC2INT3"),
2065f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC2INT4", "ISRC2INT4"),
2066f1572a44SRichard Fitzgerald 
2067f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC2DEC1", "ISRC2DEC1"),
2068f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC2DEC2", "ISRC2DEC2"),
2069f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC2DEC3", "ISRC2DEC3"),
2070f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC2DEC4", "ISRC2DEC4"),
2071f1572a44SRichard Fitzgerald 
2072f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC3INT1", "ISRC3INT1"),
2073f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC3INT2", "ISRC3INT2"),
2074f1572a44SRichard Fitzgerald 
2075f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC3DEC1", "ISRC3DEC1"),
2076f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC3DEC2", "ISRC3DEC2"),
2077f1572a44SRichard Fitzgerald 
2078f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC4INT1", "ISRC4INT1"),
2079f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC4INT2", "ISRC4INT2"),
2080f1572a44SRichard Fitzgerald 
2081f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC4DEC1", "ISRC4DEC1"),
2082f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("ISRC4DEC2", "ISRC4DEC2"),
2083f1572a44SRichard Fitzgerald 
2084f1572a44SRichard Fitzgerald 	{ "AEC1 Loopback", "HPOUT1L", "OUT1L" },
2085f1572a44SRichard Fitzgerald 	{ "AEC1 Loopback", "HPOUT1R", "OUT1R" },
2086f1572a44SRichard Fitzgerald 	{ "AEC2 Loopback", "HPOUT1L", "OUT1L" },
2087f1572a44SRichard Fitzgerald 	{ "AEC2 Loopback", "HPOUT1R", "OUT1R" },
2088f1572a44SRichard Fitzgerald 	{ "HPOUT1L", NULL, "OUT1L" },
2089f1572a44SRichard Fitzgerald 	{ "HPOUT1R", NULL, "OUT1R" },
2090f1572a44SRichard Fitzgerald 
2091f1572a44SRichard Fitzgerald 	{ "AEC1 Loopback", "HPOUT2L", "OUT2L" },
2092f1572a44SRichard Fitzgerald 	{ "AEC1 Loopback", "HPOUT2R", "OUT2R" },
2093f1572a44SRichard Fitzgerald 	{ "AEC2 Loopback", "HPOUT2L", "OUT2L" },
2094f1572a44SRichard Fitzgerald 	{ "AEC2 Loopback", "HPOUT2R", "OUT2R" },
2095f1572a44SRichard Fitzgerald 	{ "HPOUT2L", NULL, "OUT2L" },
2096f1572a44SRichard Fitzgerald 	{ "HPOUT2R", NULL, "OUT2R" },
2097f1572a44SRichard Fitzgerald 
2098f1572a44SRichard Fitzgerald 	{ "AEC1 Loopback", "HPOUT3L", "OUT3L" },
2099f1572a44SRichard Fitzgerald 	{ "AEC1 Loopback", "HPOUT3R", "OUT3R" },
2100f1572a44SRichard Fitzgerald 	{ "AEC2 Loopback", "HPOUT3L", "OUT3L" },
2101f1572a44SRichard Fitzgerald 	{ "AEC2 Loopback", "HPOUT3R", "OUT3R" },
2102f1572a44SRichard Fitzgerald 	{ "HPOUT3L", NULL, "OUT3L" },
2103f1572a44SRichard Fitzgerald 	{ "HPOUT3R", NULL, "OUT3R" },
2104f1572a44SRichard Fitzgerald 
2105f1572a44SRichard Fitzgerald 	{ "AEC1 Loopback", "SPKDAT1L", "OUT5L" },
2106f1572a44SRichard Fitzgerald 	{ "AEC1 Loopback", "SPKDAT1R", "OUT5R" },
2107f1572a44SRichard Fitzgerald 	{ "AEC2 Loopback", "SPKDAT1L", "OUT5L" },
2108f1572a44SRichard Fitzgerald 	{ "AEC2 Loopback", "SPKDAT1R", "OUT5R" },
2109f1572a44SRichard Fitzgerald 	{ "SPKDAT1L", NULL, "OUT5L" },
2110f1572a44SRichard Fitzgerald 	{ "SPKDAT1R", NULL, "OUT5R" },
2111f1572a44SRichard Fitzgerald 
2112f1572a44SRichard Fitzgerald 	CS47L90_RXANC_INPUT_ROUTES("RXANCL", "RXANCL"),
2113f1572a44SRichard Fitzgerald 	CS47L90_RXANC_INPUT_ROUTES("RXANCR", "RXANCR"),
2114f1572a44SRichard Fitzgerald 
2115f1572a44SRichard Fitzgerald 	CS47L90_RXANC_OUTPUT_ROUTES("OUT1L", "HPOUT1L"),
2116f1572a44SRichard Fitzgerald 	CS47L90_RXANC_OUTPUT_ROUTES("OUT1R", "HPOUT1R"),
2117f1572a44SRichard Fitzgerald 	CS47L90_RXANC_OUTPUT_ROUTES("OUT2L", "HPOUT2L"),
2118f1572a44SRichard Fitzgerald 	CS47L90_RXANC_OUTPUT_ROUTES("OUT2R", "HPOUT2R"),
2119f1572a44SRichard Fitzgerald 	CS47L90_RXANC_OUTPUT_ROUTES("OUT3L", "HPOUT3L"),
2120f1572a44SRichard Fitzgerald 	CS47L90_RXANC_OUTPUT_ROUTES("OUT3R", "HPOUT3R"),
2121f1572a44SRichard Fitzgerald 	CS47L90_RXANC_OUTPUT_ROUTES("OUT5L", "SPKDAT1L"),
2122f1572a44SRichard Fitzgerald 	CS47L90_RXANC_OUTPUT_ROUTES("OUT5R", "SPKDAT1R"),
2123f1572a44SRichard Fitzgerald 
2124f1572a44SRichard Fitzgerald 	{ "SPDIF1", NULL, "SPD1" },
2125f1572a44SRichard Fitzgerald 
2126f1572a44SRichard Fitzgerald 	{ "MICSUPP", NULL, "SYSCLK" },
2127f1572a44SRichard Fitzgerald 
2128f1572a44SRichard Fitzgerald 	{ "DRC1 Signal Activity", NULL, "DRC1 Activity Output" },
2129f1572a44SRichard Fitzgerald 	{ "DRC2 Signal Activity", NULL, "DRC2 Activity Output" },
2130f1572a44SRichard Fitzgerald 	{ "DRC1 Activity Output", "Switch", "DRC1L" },
2131f1572a44SRichard Fitzgerald 	{ "DRC1 Activity Output", "Switch", "DRC1R" },
2132f1572a44SRichard Fitzgerald 	{ "DRC2 Activity Output", "Switch", "DRC2L" },
2133f1572a44SRichard Fitzgerald 	{ "DRC2 Activity Output", "Switch", "DRC2R" },
2134f1572a44SRichard Fitzgerald 
2135f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("DFC1", "DFC1"),
2136f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("DFC2", "DFC2"),
2137f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("DFC3", "DFC3"),
2138f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("DFC4", "DFC4"),
2139f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("DFC5", "DFC5"),
2140f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("DFC6", "DFC6"),
2141f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("DFC7", "DFC7"),
2142f1572a44SRichard Fitzgerald 	MADERA_MUX_ROUTES("DFC8", "DFC8"),
2143f1572a44SRichard Fitzgerald };
2144f1572a44SRichard Fitzgerald 
cs47l90_set_fll(struct snd_soc_component * component,int fll_id,int source,unsigned int fref,unsigned int fout)2145f1572a44SRichard Fitzgerald static int cs47l90_set_fll(struct snd_soc_component *component, int fll_id,
2146f1572a44SRichard Fitzgerald 			   int source, unsigned int fref, unsigned int fout)
2147f1572a44SRichard Fitzgerald {
2148f1572a44SRichard Fitzgerald 	struct cs47l90 *cs47l90 = snd_soc_component_get_drvdata(component);
2149f1572a44SRichard Fitzgerald 
2150f1572a44SRichard Fitzgerald 	switch (fll_id) {
2151f1572a44SRichard Fitzgerald 	case MADERA_FLL1_REFCLK:
2152f1572a44SRichard Fitzgerald 		return madera_set_fll_refclk(&cs47l90->fll[0], source, fref,
2153f1572a44SRichard Fitzgerald 					     fout);
2154f1572a44SRichard Fitzgerald 	case MADERA_FLL2_REFCLK:
2155f1572a44SRichard Fitzgerald 		return madera_set_fll_refclk(&cs47l90->fll[1], source, fref,
2156f1572a44SRichard Fitzgerald 					     fout);
2157f1572a44SRichard Fitzgerald 	case MADERA_FLLAO_REFCLK:
2158f1572a44SRichard Fitzgerald 		return madera_set_fll_ao_refclk(&cs47l90->fll[2], source, fref,
2159f1572a44SRichard Fitzgerald 						fout);
2160f1572a44SRichard Fitzgerald 	case MADERA_FLL1_SYNCCLK:
2161f1572a44SRichard Fitzgerald 		return madera_set_fll_syncclk(&cs47l90->fll[0], source, fref,
2162f1572a44SRichard Fitzgerald 					      fout);
2163f1572a44SRichard Fitzgerald 	case MADERA_FLL2_SYNCCLK:
2164f1572a44SRichard Fitzgerald 		return madera_set_fll_syncclk(&cs47l90->fll[1], source, fref,
2165f1572a44SRichard Fitzgerald 					      fout);
2166f1572a44SRichard Fitzgerald 	default:
2167f1572a44SRichard Fitzgerald 		return -EINVAL;
2168f1572a44SRichard Fitzgerald 	}
2169f1572a44SRichard Fitzgerald }
2170f1572a44SRichard Fitzgerald 
2171*e22a907dSKuninori Morimoto static const struct snd_soc_dai_ops cs47l90_dai_ops = {
2172*e22a907dSKuninori Morimoto 	.compress_new = snd_soc_new_compress,
2173*e22a907dSKuninori Morimoto };
2174*e22a907dSKuninori Morimoto 
2175f1572a44SRichard Fitzgerald static struct snd_soc_dai_driver cs47l90_dai[] = {
2176f1572a44SRichard Fitzgerald 	{
2177f1572a44SRichard Fitzgerald 		.name = "cs47l90-aif1",
2178f1572a44SRichard Fitzgerald 		.id = 1,
2179f1572a44SRichard Fitzgerald 		.base = MADERA_AIF1_BCLK_CTRL,
2180f1572a44SRichard Fitzgerald 		.playback = {
2181f1572a44SRichard Fitzgerald 			.stream_name = "AIF1 Playback",
2182f1572a44SRichard Fitzgerald 			.channels_min = 1,
2183f1572a44SRichard Fitzgerald 			.channels_max = 8,
2184f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2185f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2186f1572a44SRichard Fitzgerald 		},
2187f1572a44SRichard Fitzgerald 		.capture = {
2188f1572a44SRichard Fitzgerald 			.stream_name = "AIF1 Capture",
2189f1572a44SRichard Fitzgerald 			.channels_min = 1,
2190f1572a44SRichard Fitzgerald 			.channels_max = 8,
2191f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2192f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2193f1572a44SRichard Fitzgerald 		 },
2194f1572a44SRichard Fitzgerald 		.ops = &madera_dai_ops,
2195260b668cSKuninori Morimoto 		.symmetric_rate = 1,
2196260b668cSKuninori Morimoto 		.symmetric_sample_bits = 1,
2197f1572a44SRichard Fitzgerald 	},
2198f1572a44SRichard Fitzgerald 	{
2199f1572a44SRichard Fitzgerald 		.name = "cs47l90-aif2",
2200f1572a44SRichard Fitzgerald 		.id = 2,
2201f1572a44SRichard Fitzgerald 		.base = MADERA_AIF2_BCLK_CTRL,
2202f1572a44SRichard Fitzgerald 		.playback = {
2203f1572a44SRichard Fitzgerald 			.stream_name = "AIF2 Playback",
2204f1572a44SRichard Fitzgerald 			.channels_min = 1,
2205f1572a44SRichard Fitzgerald 			.channels_max = 8,
2206f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2207f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2208f1572a44SRichard Fitzgerald 		},
2209f1572a44SRichard Fitzgerald 		.capture = {
2210f1572a44SRichard Fitzgerald 			.stream_name = "AIF2 Capture",
2211f1572a44SRichard Fitzgerald 			.channels_min = 1,
2212f1572a44SRichard Fitzgerald 			.channels_max = 8,
2213f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2214f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2215f1572a44SRichard Fitzgerald 		 },
2216f1572a44SRichard Fitzgerald 		.ops = &madera_dai_ops,
2217260b668cSKuninori Morimoto 		.symmetric_rate = 1,
2218260b668cSKuninori Morimoto 		.symmetric_sample_bits = 1,
2219f1572a44SRichard Fitzgerald 	},
2220f1572a44SRichard Fitzgerald 	{
2221f1572a44SRichard Fitzgerald 		.name = "cs47l90-aif3",
2222f1572a44SRichard Fitzgerald 		.id = 3,
2223f1572a44SRichard Fitzgerald 		.base = MADERA_AIF3_BCLK_CTRL,
2224f1572a44SRichard Fitzgerald 		.playback = {
2225f1572a44SRichard Fitzgerald 			.stream_name = "AIF3 Playback",
2226f1572a44SRichard Fitzgerald 			.channels_min = 1,
2227f1572a44SRichard Fitzgerald 			.channels_max = 2,
2228f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2229f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2230f1572a44SRichard Fitzgerald 		},
2231f1572a44SRichard Fitzgerald 		.capture = {
2232f1572a44SRichard Fitzgerald 			.stream_name = "AIF3 Capture",
2233f1572a44SRichard Fitzgerald 			.channels_min = 1,
2234f1572a44SRichard Fitzgerald 			.channels_max = 2,
2235f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2236f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2237f1572a44SRichard Fitzgerald 		 },
2238f1572a44SRichard Fitzgerald 		.ops = &madera_dai_ops,
2239260b668cSKuninori Morimoto 		.symmetric_rate = 1,
2240260b668cSKuninori Morimoto 		.symmetric_sample_bits = 1,
2241f1572a44SRichard Fitzgerald 	},
2242f1572a44SRichard Fitzgerald 	{
2243f1572a44SRichard Fitzgerald 		.name = "cs47l90-aif4",
2244f1572a44SRichard Fitzgerald 		.id = 4,
2245f1572a44SRichard Fitzgerald 		.base = MADERA_AIF4_BCLK_CTRL,
2246f1572a44SRichard Fitzgerald 		.playback = {
2247f1572a44SRichard Fitzgerald 			.stream_name = "AIF4 Playback",
2248f1572a44SRichard Fitzgerald 			.channels_min = 1,
2249f1572a44SRichard Fitzgerald 			.channels_max = 2,
2250f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2251f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2252f1572a44SRichard Fitzgerald 		},
2253f1572a44SRichard Fitzgerald 		.capture = {
2254f1572a44SRichard Fitzgerald 			.stream_name = "AIF4 Capture",
2255f1572a44SRichard Fitzgerald 			.channels_min = 1,
2256f1572a44SRichard Fitzgerald 			.channels_max = 2,
2257f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2258f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2259f1572a44SRichard Fitzgerald 		 },
2260f1572a44SRichard Fitzgerald 		.ops = &madera_dai_ops,
2261260b668cSKuninori Morimoto 		.symmetric_rate = 1,
2262260b668cSKuninori Morimoto 		.symmetric_sample_bits = 1,
2263f1572a44SRichard Fitzgerald 	},
2264f1572a44SRichard Fitzgerald 	{
2265f1572a44SRichard Fitzgerald 		.name = "cs47l90-slim1",
2266f1572a44SRichard Fitzgerald 		.id = 5,
2267f1572a44SRichard Fitzgerald 		.playback = {
2268f1572a44SRichard Fitzgerald 			.stream_name = "Slim1 Playback",
2269f1572a44SRichard Fitzgerald 			.channels_min = 1,
2270f1572a44SRichard Fitzgerald 			.channels_max = 4,
2271f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2272f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2273f1572a44SRichard Fitzgerald 		},
2274f1572a44SRichard Fitzgerald 		.capture = {
2275f1572a44SRichard Fitzgerald 			.stream_name = "Slim1 Capture",
2276f1572a44SRichard Fitzgerald 			.channels_min = 1,
2277f1572a44SRichard Fitzgerald 			.channels_max = 4,
2278f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2279f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2280f1572a44SRichard Fitzgerald 		 },
2281f1572a44SRichard Fitzgerald 		.ops = &madera_simple_dai_ops,
2282f1572a44SRichard Fitzgerald 	},
2283f1572a44SRichard Fitzgerald 	{
2284f1572a44SRichard Fitzgerald 		.name = "cs47l90-slim2",
2285f1572a44SRichard Fitzgerald 		.id = 6,
2286f1572a44SRichard Fitzgerald 		.playback = {
2287f1572a44SRichard Fitzgerald 			.stream_name = "Slim2 Playback",
2288f1572a44SRichard Fitzgerald 			.channels_min = 1,
2289f1572a44SRichard Fitzgerald 			.channels_max = 2,
2290f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2291f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2292f1572a44SRichard Fitzgerald 		},
2293f1572a44SRichard Fitzgerald 		.capture = {
2294f1572a44SRichard Fitzgerald 			.stream_name = "Slim2 Capture",
2295f1572a44SRichard Fitzgerald 			.channels_min = 1,
2296f1572a44SRichard Fitzgerald 			.channels_max = 2,
2297f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2298f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2299f1572a44SRichard Fitzgerald 		 },
2300f1572a44SRichard Fitzgerald 		.ops = &madera_simple_dai_ops,
2301f1572a44SRichard Fitzgerald 	},
2302f1572a44SRichard Fitzgerald 	{
2303f1572a44SRichard Fitzgerald 		.name = "cs47l90-slim3",
2304f1572a44SRichard Fitzgerald 		.id = 7,
2305f1572a44SRichard Fitzgerald 		.playback = {
2306f1572a44SRichard Fitzgerald 			.stream_name = "Slim3 Playback",
2307f1572a44SRichard Fitzgerald 			.channels_min = 1,
2308f1572a44SRichard Fitzgerald 			.channels_max = 2,
2309f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2310f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2311f1572a44SRichard Fitzgerald 		},
2312f1572a44SRichard Fitzgerald 		.capture = {
2313f1572a44SRichard Fitzgerald 			.stream_name = "Slim3 Capture",
2314f1572a44SRichard Fitzgerald 			.channels_min = 1,
2315f1572a44SRichard Fitzgerald 			.channels_max = 2,
2316f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2317f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2318f1572a44SRichard Fitzgerald 		 },
2319f1572a44SRichard Fitzgerald 		.ops = &madera_simple_dai_ops,
2320f1572a44SRichard Fitzgerald 	},
2321f1572a44SRichard Fitzgerald 	{
2322f1572a44SRichard Fitzgerald 		.name = "cs47l90-cpu-voicectrl",
2323f1572a44SRichard Fitzgerald 		.capture = {
2324f1572a44SRichard Fitzgerald 			.stream_name = "Voice Control CPU",
2325f1572a44SRichard Fitzgerald 			.channels_min = 1,
2326f1572a44SRichard Fitzgerald 			.channels_max = 1,
2327f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2328f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2329f1572a44SRichard Fitzgerald 		},
2330*e22a907dSKuninori Morimoto 		.ops = &cs47l90_dai_ops,
2331f1572a44SRichard Fitzgerald 	},
2332f1572a44SRichard Fitzgerald 	{
2333f1572a44SRichard Fitzgerald 		.name = "cs47l90-dsp-voicectrl",
2334f1572a44SRichard Fitzgerald 		.capture = {
2335f1572a44SRichard Fitzgerald 			.stream_name = "Voice Control DSP",
2336f1572a44SRichard Fitzgerald 			.channels_min = 1,
2337f1572a44SRichard Fitzgerald 			.channels_max = 1,
2338f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2339f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2340f1572a44SRichard Fitzgerald 		},
2341f1572a44SRichard Fitzgerald 	},
2342f1572a44SRichard Fitzgerald 	{
2343f1572a44SRichard Fitzgerald 		.name = "cs47l90-cpu-trace",
2344f1572a44SRichard Fitzgerald 		.capture = {
2345f1572a44SRichard Fitzgerald 			.stream_name = "Audio Trace CPU",
2346f1572a44SRichard Fitzgerald 			.channels_min = 1,
2347f1572a44SRichard Fitzgerald 			.channels_max = 6,
2348f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2349f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2350f1572a44SRichard Fitzgerald 		},
2351*e22a907dSKuninori Morimoto 		.ops = &cs47l90_dai_ops,
2352f1572a44SRichard Fitzgerald 	},
2353f1572a44SRichard Fitzgerald 	{
2354f1572a44SRichard Fitzgerald 		.name = "cs47l90-dsp-trace",
2355f1572a44SRichard Fitzgerald 		.capture = {
2356f1572a44SRichard Fitzgerald 			.stream_name = "Audio Trace DSP",
2357f1572a44SRichard Fitzgerald 			.channels_min = 1,
2358f1572a44SRichard Fitzgerald 			.channels_max = 6,
2359f1572a44SRichard Fitzgerald 			.rates = MADERA_RATES,
2360f1572a44SRichard Fitzgerald 			.formats = MADERA_FORMATS,
2361f1572a44SRichard Fitzgerald 		},
2362f1572a44SRichard Fitzgerald 	},
2363f1572a44SRichard Fitzgerald };
2364f1572a44SRichard Fitzgerald 
cs47l90_open(struct snd_soc_component * component,struct snd_compr_stream * stream)23653a5ccf25SKuninori Morimoto static int cs47l90_open(struct snd_soc_component *component,
23663a5ccf25SKuninori Morimoto 			struct snd_compr_stream *stream)
2367f1572a44SRichard Fitzgerald {
2368f1572a44SRichard Fitzgerald 	struct snd_soc_pcm_runtime *rtd = stream->private_data;
2369f1572a44SRichard Fitzgerald 	struct cs47l90 *cs47l90 = snd_soc_component_get_drvdata(component);
2370f1572a44SRichard Fitzgerald 	struct madera_priv *priv = &cs47l90->core;
2371f1572a44SRichard Fitzgerald 	struct madera *madera = priv->madera;
2372f1572a44SRichard Fitzgerald 	int n_adsp;
2373f1572a44SRichard Fitzgerald 
2374b5cb8558SKuninori Morimoto 	if (strcmp(asoc_rtd_to_codec(rtd, 0)->name, "cs47l90-dsp-voicectrl") == 0) {
2375f1572a44SRichard Fitzgerald 		n_adsp = 5;
2376b5cb8558SKuninori Morimoto 	} else if (strcmp(asoc_rtd_to_codec(rtd, 0)->name, "cs47l90-dsp-trace") == 0) {
2377f1572a44SRichard Fitzgerald 		n_adsp = 0;
2378f1572a44SRichard Fitzgerald 	} else {
2379f1572a44SRichard Fitzgerald 		dev_err(madera->dev,
2380f1572a44SRichard Fitzgerald 			"No suitable compressed stream for DAI '%s'\n",
2381b5cb8558SKuninori Morimoto 			asoc_rtd_to_codec(rtd, 0)->name);
2382f1572a44SRichard Fitzgerald 		return -EINVAL;
2383f1572a44SRichard Fitzgerald 	}
2384f1572a44SRichard Fitzgerald 
2385f1572a44SRichard Fitzgerald 	return wm_adsp_compr_open(&priv->adsp[n_adsp], stream);
2386f1572a44SRichard Fitzgerald }
2387f1572a44SRichard Fitzgerald 
cs47l90_adsp2_irq(int irq,void * data)2388f1572a44SRichard Fitzgerald static irqreturn_t cs47l90_adsp2_irq(int irq, void *data)
2389f1572a44SRichard Fitzgerald {
2390f1572a44SRichard Fitzgerald 	struct cs47l90 *cs47l90 = data;
2391f1572a44SRichard Fitzgerald 	struct madera_priv *priv = &cs47l90->core;
2392f1572a44SRichard Fitzgerald 	struct madera *madera = priv->madera;
2393f1572a44SRichard Fitzgerald 	struct madera_voice_trigger_info trig_info;
2394f1572a44SRichard Fitzgerald 	int serviced = 0;
2395f1572a44SRichard Fitzgerald 	int i, ret;
2396f1572a44SRichard Fitzgerald 
2397f1572a44SRichard Fitzgerald 	for (i = 0; i < CS47L90_NUM_ADSP; ++i) {
2398f1572a44SRichard Fitzgerald 		ret = wm_adsp_compr_handle_irq(&priv->adsp[i]);
2399f1572a44SRichard Fitzgerald 		if (ret != -ENODEV)
2400f1572a44SRichard Fitzgerald 			serviced++;
2401f1572a44SRichard Fitzgerald 		if (ret == WM_ADSP_COMPR_VOICE_TRIGGER) {
2402f1572a44SRichard Fitzgerald 			trig_info.core_num = i + 1;
2403f1572a44SRichard Fitzgerald 			blocking_notifier_call_chain(&madera->notifier,
2404f1572a44SRichard Fitzgerald 						MADERA_NOTIFY_VOICE_TRIGGER,
2405f1572a44SRichard Fitzgerald 						&trig_info);
2406f1572a44SRichard Fitzgerald 		}
2407f1572a44SRichard Fitzgerald 	}
2408f1572a44SRichard Fitzgerald 
2409f1572a44SRichard Fitzgerald 	if (!serviced) {
2410f1572a44SRichard Fitzgerald 		dev_err(madera->dev, "Spurious compressed data IRQ\n");
2411f1572a44SRichard Fitzgerald 		return IRQ_NONE;
2412f1572a44SRichard Fitzgerald 	}
2413f1572a44SRichard Fitzgerald 
2414f1572a44SRichard Fitzgerald 	return IRQ_HANDLED;
2415f1572a44SRichard Fitzgerald }
2416f1572a44SRichard Fitzgerald 
cs47l90_component_probe(struct snd_soc_component * component)2417f1572a44SRichard Fitzgerald static int cs47l90_component_probe(struct snd_soc_component *component)
2418f1572a44SRichard Fitzgerald {
2419f1572a44SRichard Fitzgerald 	struct cs47l90 *cs47l90 = snd_soc_component_get_drvdata(component);
2420f1572a44SRichard Fitzgerald 	struct madera *madera = cs47l90->core.madera;
2421f1572a44SRichard Fitzgerald 	int ret, i;
2422f1572a44SRichard Fitzgerald 
2423f1572a44SRichard Fitzgerald 	snd_soc_component_init_regmap(component, madera->regmap);
2424f1572a44SRichard Fitzgerald 
2425f1572a44SRichard Fitzgerald 	mutex_lock(&madera->dapm_ptr_lock);
2426f1572a44SRichard Fitzgerald 	madera->dapm = snd_soc_component_get_dapm(component);
2427f1572a44SRichard Fitzgerald 	mutex_unlock(&madera->dapm_ptr_lock);
2428f1572a44SRichard Fitzgerald 
2429f1572a44SRichard Fitzgerald 	ret = madera_init_inputs(component);
2430f1572a44SRichard Fitzgerald 	if (ret)
2431f1572a44SRichard Fitzgerald 		return ret;
2432f1572a44SRichard Fitzgerald 
24338ab6ddc5SCharles Keepax 	ret = madera_init_outputs(component, NULL, CS47L90_MONO_OUTPUTS,
24348ab6ddc5SCharles Keepax 				  CS47L90_MONO_OUTPUTS);
2435f1572a44SRichard Fitzgerald 	if (ret)
2436f1572a44SRichard Fitzgerald 		return ret;
2437f1572a44SRichard Fitzgerald 
2438f1572a44SRichard Fitzgerald 	snd_soc_component_disable_pin(component, "HAPTICS");
2439f1572a44SRichard Fitzgerald 
2440f1572a44SRichard Fitzgerald 	ret = snd_soc_add_component_controls(component,
2441f1572a44SRichard Fitzgerald 					     madera_adsp_rate_controls,
2442f1572a44SRichard Fitzgerald 					     CS47L90_NUM_ADSP);
2443f1572a44SRichard Fitzgerald 	if (ret)
2444f1572a44SRichard Fitzgerald 		return ret;
2445f1572a44SRichard Fitzgerald 
2446f1572a44SRichard Fitzgerald 	for (i = 0; i < CS47L90_NUM_ADSP; i++)
2447f1572a44SRichard Fitzgerald 		wm_adsp2_component_probe(&cs47l90->core.adsp[i], component);
2448f1572a44SRichard Fitzgerald 
2449f1572a44SRichard Fitzgerald 	return 0;
2450f1572a44SRichard Fitzgerald }
2451f1572a44SRichard Fitzgerald 
cs47l90_component_remove(struct snd_soc_component * component)2452f1572a44SRichard Fitzgerald static void cs47l90_component_remove(struct snd_soc_component *component)
2453f1572a44SRichard Fitzgerald {
2454f1572a44SRichard Fitzgerald 	struct cs47l90 *cs47l90 = snd_soc_component_get_drvdata(component);
2455f1572a44SRichard Fitzgerald 	struct madera *madera = cs47l90->core.madera;
2456f1572a44SRichard Fitzgerald 	int i;
2457f1572a44SRichard Fitzgerald 
2458f1572a44SRichard Fitzgerald 	mutex_lock(&madera->dapm_ptr_lock);
2459f1572a44SRichard Fitzgerald 	madera->dapm = NULL;
2460f1572a44SRichard Fitzgerald 	mutex_unlock(&madera->dapm_ptr_lock);
2461f1572a44SRichard Fitzgerald 
2462f1572a44SRichard Fitzgerald 	for (i = 0; i < CS47L90_NUM_ADSP; i++)
2463f1572a44SRichard Fitzgerald 		wm_adsp2_component_remove(&cs47l90->core.adsp[i], component);
2464f1572a44SRichard Fitzgerald }
2465f1572a44SRichard Fitzgerald 
2466f1572a44SRichard Fitzgerald #define CS47L90_DIG_VU 0x0200
2467f1572a44SRichard Fitzgerald 
2468f1572a44SRichard Fitzgerald static unsigned int cs47l90_digital_vu[] = {
2469f1572a44SRichard Fitzgerald 	MADERA_DAC_DIGITAL_VOLUME_1L,
2470f1572a44SRichard Fitzgerald 	MADERA_DAC_DIGITAL_VOLUME_1R,
2471f1572a44SRichard Fitzgerald 	MADERA_DAC_DIGITAL_VOLUME_2L,
2472f1572a44SRichard Fitzgerald 	MADERA_DAC_DIGITAL_VOLUME_2R,
2473f1572a44SRichard Fitzgerald 	MADERA_DAC_DIGITAL_VOLUME_3L,
2474f1572a44SRichard Fitzgerald 	MADERA_DAC_DIGITAL_VOLUME_3R,
2475f1572a44SRichard Fitzgerald 	MADERA_DAC_DIGITAL_VOLUME_5L,
2476f1572a44SRichard Fitzgerald 	MADERA_DAC_DIGITAL_VOLUME_5R,
2477f1572a44SRichard Fitzgerald };
2478f1572a44SRichard Fitzgerald 
24793a5ccf25SKuninori Morimoto static const struct snd_compress_ops cs47l90_compress_ops = {
2480f1572a44SRichard Fitzgerald 	.open = &cs47l90_open,
2481f1572a44SRichard Fitzgerald 	.free = &wm_adsp_compr_free,
2482f1572a44SRichard Fitzgerald 	.set_params = &wm_adsp_compr_set_params,
2483f1572a44SRichard Fitzgerald 	.get_caps = &wm_adsp_compr_get_caps,
2484f1572a44SRichard Fitzgerald 	.trigger = &wm_adsp_compr_trigger,
2485f1572a44SRichard Fitzgerald 	.pointer = &wm_adsp_compr_pointer,
2486f1572a44SRichard Fitzgerald 	.copy = &wm_adsp_compr_copy,
2487f1572a44SRichard Fitzgerald };
2488f1572a44SRichard Fitzgerald 
2489f1572a44SRichard Fitzgerald static const struct snd_soc_component_driver soc_component_dev_cs47l90 = {
2490f1572a44SRichard Fitzgerald 	.probe			= &cs47l90_component_probe,
2491f1572a44SRichard Fitzgerald 	.remove			= &cs47l90_component_remove,
2492f1572a44SRichard Fitzgerald 	.set_sysclk		= &madera_set_sysclk,
2493f1572a44SRichard Fitzgerald 	.set_pll		= &cs47l90_set_fll,
2494f1572a44SRichard Fitzgerald 	.name			= DRV_NAME,
24953a5ccf25SKuninori Morimoto 	.compress_ops		= &cs47l90_compress_ops,
2496f1572a44SRichard Fitzgerald 	.controls		= cs47l90_snd_controls,
2497f1572a44SRichard Fitzgerald 	.num_controls		= ARRAY_SIZE(cs47l90_snd_controls),
2498f1572a44SRichard Fitzgerald 	.dapm_widgets		= cs47l90_dapm_widgets,
2499f1572a44SRichard Fitzgerald 	.num_dapm_widgets	= ARRAY_SIZE(cs47l90_dapm_widgets),
2500f1572a44SRichard Fitzgerald 	.dapm_routes		= cs47l90_dapm_routes,
2501f1572a44SRichard Fitzgerald 	.num_dapm_routes	= ARRAY_SIZE(cs47l90_dapm_routes),
2502f1572a44SRichard Fitzgerald 	.use_pmdown_time	= 1,
2503f1572a44SRichard Fitzgerald 	.endianness		= 1,
2504f1572a44SRichard Fitzgerald };
2505f1572a44SRichard Fitzgerald 
cs47l90_probe(struct platform_device * pdev)2506f1572a44SRichard Fitzgerald static int cs47l90_probe(struct platform_device *pdev)
2507f1572a44SRichard Fitzgerald {
2508f1572a44SRichard Fitzgerald 	struct madera *madera = dev_get_drvdata(pdev->dev.parent);
2509f1572a44SRichard Fitzgerald 	struct cs47l90 *cs47l90;
2510f1572a44SRichard Fitzgerald 	int i, ret;
2511f1572a44SRichard Fitzgerald 
2512f1572a44SRichard Fitzgerald 	BUILD_BUG_ON(ARRAY_SIZE(cs47l90_dai) > MADERA_MAX_DAI);
2513f1572a44SRichard Fitzgerald 
2514f1572a44SRichard Fitzgerald 	/* quick exit if Madera irqchip driver hasn't completed probe */
2515f1572a44SRichard Fitzgerald 	if (!madera->irq_dev) {
2516f1572a44SRichard Fitzgerald 		dev_dbg(&pdev->dev, "irqchip driver not ready\n");
2517f1572a44SRichard Fitzgerald 		return -EPROBE_DEFER;
2518f1572a44SRichard Fitzgerald 	}
2519f1572a44SRichard Fitzgerald 
2520f1572a44SRichard Fitzgerald 	cs47l90 = devm_kzalloc(&pdev->dev, sizeof(struct cs47l90),
2521f1572a44SRichard Fitzgerald 			       GFP_KERNEL);
2522f1572a44SRichard Fitzgerald 	if (!cs47l90)
2523f1572a44SRichard Fitzgerald 		return -ENOMEM;
2524f1572a44SRichard Fitzgerald 
2525f1572a44SRichard Fitzgerald 	platform_set_drvdata(pdev, cs47l90);
2526f1572a44SRichard Fitzgerald 
2527f1572a44SRichard Fitzgerald 	cs47l90->core.madera = madera;
2528f1572a44SRichard Fitzgerald 	cs47l90->core.dev = &pdev->dev;
2529f1572a44SRichard Fitzgerald 	cs47l90->core.num_inputs = 10;
2530f1572a44SRichard Fitzgerald 
2531f1572a44SRichard Fitzgerald 	ret = madera_core_init(&cs47l90->core);
2532f1572a44SRichard Fitzgerald 	if (ret)
2533f1572a44SRichard Fitzgerald 		return ret;
2534f1572a44SRichard Fitzgerald 
2535f1572a44SRichard Fitzgerald 	ret = madera_request_irq(madera, MADERA_IRQ_DSP_IRQ1,
2536f1572a44SRichard Fitzgerald 				 "ADSP2 Compressed IRQ", cs47l90_adsp2_irq,
2537f1572a44SRichard Fitzgerald 				 cs47l90);
2538f1572a44SRichard Fitzgerald 	if (ret != 0) {
2539f1572a44SRichard Fitzgerald 		dev_err(&pdev->dev, "Failed to request DSP IRQ: %d\n", ret);
2540f1572a44SRichard Fitzgerald 		goto error_core;
2541f1572a44SRichard Fitzgerald 	}
2542f1572a44SRichard Fitzgerald 
2543f1572a44SRichard Fitzgerald 	ret = madera_set_irq_wake(madera, MADERA_IRQ_DSP_IRQ1, 1);
2544f1572a44SRichard Fitzgerald 	if (ret)
2545f1572a44SRichard Fitzgerald 		dev_warn(&pdev->dev, "Failed to set DSP IRQ wake: %d\n", ret);
2546f1572a44SRichard Fitzgerald 
2547f1572a44SRichard Fitzgerald 	for (i = 0; i < CS47L90_NUM_ADSP; i++) {
2548f1572a44SRichard Fitzgerald 		cs47l90->core.adsp[i].part = "cs47l90";
2549e1468202SSimon Trimmer 		cs47l90->core.adsp[i].cs_dsp.num = i + 1;
2550e1468202SSimon Trimmer 		cs47l90->core.adsp[i].cs_dsp.type = WMFW_ADSP2;
2551e1468202SSimon Trimmer 		cs47l90->core.adsp[i].cs_dsp.rev = 2;
2552e1468202SSimon Trimmer 		cs47l90->core.adsp[i].cs_dsp.dev = madera->dev;
2553e1468202SSimon Trimmer 		cs47l90->core.adsp[i].cs_dsp.regmap = madera->regmap_32bit;
2554f1572a44SRichard Fitzgerald 
2555e1468202SSimon Trimmer 		cs47l90->core.adsp[i].cs_dsp.base = cs47l90_dsp_control_bases[i];
2556e1468202SSimon Trimmer 		cs47l90->core.adsp[i].cs_dsp.mem = cs47l90_dsp_regions[i];
2557e1468202SSimon Trimmer 		cs47l90->core.adsp[i].cs_dsp.num_mems =
2558f1572a44SRichard Fitzgerald 			ARRAY_SIZE(cs47l90_dsp1_regions);
2559f1572a44SRichard Fitzgerald 
2560e1468202SSimon Trimmer 		cs47l90->core.adsp[i].cs_dsp.lock_regions = CS_ADSP2_REGION_1_9;
2561f1572a44SRichard Fitzgerald 
2562f1572a44SRichard Fitzgerald 		ret = wm_adsp2_init(&cs47l90->core.adsp[i]);
2563f1572a44SRichard Fitzgerald 
2564f1572a44SRichard Fitzgerald 		if (ret == 0) {
2565f1572a44SRichard Fitzgerald 			ret = madera_init_bus_error_irq(&cs47l90->core, i,
256601ec57a4SCharles Keepax 							wm_adsp2_bus_error);
2567f1572a44SRichard Fitzgerald 			if (ret != 0)
2568f1572a44SRichard Fitzgerald 				wm_adsp2_remove(&cs47l90->core.adsp[i]);
2569f1572a44SRichard Fitzgerald 		}
2570f1572a44SRichard Fitzgerald 
2571f1572a44SRichard Fitzgerald 		if (ret) {
2572f1572a44SRichard Fitzgerald 			for (--i; i >= 0; --i) {
2573f1572a44SRichard Fitzgerald 				madera_free_bus_error_irq(&cs47l90->core, i);
2574f1572a44SRichard Fitzgerald 				wm_adsp2_remove(&cs47l90->core.adsp[i]);
2575f1572a44SRichard Fitzgerald 			}
2576f1572a44SRichard Fitzgerald 			goto error_dsp_irq;
2577f1572a44SRichard Fitzgerald 		}
2578f1572a44SRichard Fitzgerald 	}
2579f1572a44SRichard Fitzgerald 
2580f1572a44SRichard Fitzgerald 	madera_init_fll(madera, 1, MADERA_FLL1_CONTROL_1 - 1,
2581f1572a44SRichard Fitzgerald 			&cs47l90->fll[0]);
2582f1572a44SRichard Fitzgerald 	madera_init_fll(madera, 2, MADERA_FLL2_CONTROL_1 - 1,
2583f1572a44SRichard Fitzgerald 			&cs47l90->fll[1]);
2584f1572a44SRichard Fitzgerald 	madera_init_fll(madera, 4, MADERA_FLLAO_CONTROL_1 - 1,
2585f1572a44SRichard Fitzgerald 			&cs47l90->fll[2]);
2586f1572a44SRichard Fitzgerald 
2587f1572a44SRichard Fitzgerald 	for (i = 0; i < ARRAY_SIZE(cs47l90_dai); i++)
2588f1572a44SRichard Fitzgerald 		madera_init_dai(&cs47l90->core, i);
2589f1572a44SRichard Fitzgerald 
2590f1572a44SRichard Fitzgerald 	/* Latch volume update bits */
2591f1572a44SRichard Fitzgerald 	for (i = 0; i < ARRAY_SIZE(cs47l90_digital_vu); i++)
2592f1572a44SRichard Fitzgerald 		regmap_update_bits(madera->regmap, cs47l90_digital_vu[i],
2593f1572a44SRichard Fitzgerald 				   CS47L90_DIG_VU, CS47L90_DIG_VU);
2594f1572a44SRichard Fitzgerald 
2595f1572a44SRichard Fitzgerald 	pm_runtime_enable(&pdev->dev);
2596f1572a44SRichard Fitzgerald 	pm_runtime_idle(&pdev->dev);
2597f1572a44SRichard Fitzgerald 
2598f1572a44SRichard Fitzgerald 	ret = devm_snd_soc_register_component(&pdev->dev,
2599f1572a44SRichard Fitzgerald 					      &soc_component_dev_cs47l90,
2600f1572a44SRichard Fitzgerald 					      cs47l90_dai,
2601f1572a44SRichard Fitzgerald 					      ARRAY_SIZE(cs47l90_dai));
2602f1572a44SRichard Fitzgerald 	if (ret < 0) {
2603f1572a44SRichard Fitzgerald 		dev_err(&pdev->dev, "Failed to register component: %d\n", ret);
2604f1572a44SRichard Fitzgerald 		goto error_pm_runtime;
2605f1572a44SRichard Fitzgerald 	}
2606f1572a44SRichard Fitzgerald 
2607f1572a44SRichard Fitzgerald 	return ret;
2608f1572a44SRichard Fitzgerald 
2609f1572a44SRichard Fitzgerald error_pm_runtime:
2610f1572a44SRichard Fitzgerald 	pm_runtime_disable(&pdev->dev);
2611f1572a44SRichard Fitzgerald 
2612f1572a44SRichard Fitzgerald 	for (i = 0; i < CS47L90_NUM_ADSP; i++) {
2613f1572a44SRichard Fitzgerald 		madera_free_bus_error_irq(&cs47l90->core, i);
2614f1572a44SRichard Fitzgerald 		wm_adsp2_remove(&cs47l90->core.adsp[i]);
2615f1572a44SRichard Fitzgerald 	}
2616f1572a44SRichard Fitzgerald error_dsp_irq:
2617f1572a44SRichard Fitzgerald 	madera_set_irq_wake(madera, MADERA_IRQ_DSP_IRQ1, 0);
2618f1572a44SRichard Fitzgerald 	madera_free_irq(madera, MADERA_IRQ_DSP_IRQ1, cs47l90);
2619f1572a44SRichard Fitzgerald error_core:
2620f1572a44SRichard Fitzgerald 	madera_core_free(&cs47l90->core);
2621f1572a44SRichard Fitzgerald 
2622f1572a44SRichard Fitzgerald 	return ret;
2623f1572a44SRichard Fitzgerald }
2624f1572a44SRichard Fitzgerald 
cs47l90_remove(struct platform_device * pdev)2625acd39a37SUwe Kleine-König static void cs47l90_remove(struct platform_device *pdev)
2626f1572a44SRichard Fitzgerald {
2627f1572a44SRichard Fitzgerald 	struct cs47l90 *cs47l90 = platform_get_drvdata(pdev);
2628f1572a44SRichard Fitzgerald 	int i;
2629f1572a44SRichard Fitzgerald 
2630f1572a44SRichard Fitzgerald 	pm_runtime_disable(&pdev->dev);
2631f1572a44SRichard Fitzgerald 
2632f1572a44SRichard Fitzgerald 	for (i = 0; i < CS47L90_NUM_ADSP; i++) {
2633f1572a44SRichard Fitzgerald 		madera_free_bus_error_irq(&cs47l90->core, i);
2634f1572a44SRichard Fitzgerald 		wm_adsp2_remove(&cs47l90->core.adsp[i]);
2635f1572a44SRichard Fitzgerald 	}
2636f1572a44SRichard Fitzgerald 
2637f1572a44SRichard Fitzgerald 	madera_set_irq_wake(cs47l90->core.madera, MADERA_IRQ_DSP_IRQ1, 0);
2638f1572a44SRichard Fitzgerald 	madera_free_irq(cs47l90->core.madera, MADERA_IRQ_DSP_IRQ1, cs47l90);
2639f1572a44SRichard Fitzgerald 	madera_core_free(&cs47l90->core);
2640f1572a44SRichard Fitzgerald }
2641f1572a44SRichard Fitzgerald 
2642f1572a44SRichard Fitzgerald static struct platform_driver cs47l90_codec_driver = {
2643f1572a44SRichard Fitzgerald 	.driver = {
2644f1572a44SRichard Fitzgerald 		.name = "cs47l90-codec",
2645f1572a44SRichard Fitzgerald 	},
2646f1572a44SRichard Fitzgerald 	.probe = &cs47l90_probe,
2647acd39a37SUwe Kleine-König 	.remove_new = cs47l90_remove,
2648f1572a44SRichard Fitzgerald };
2649f1572a44SRichard Fitzgerald 
2650f1572a44SRichard Fitzgerald module_platform_driver(cs47l90_codec_driver);
2651f1572a44SRichard Fitzgerald 
2652f1572a44SRichard Fitzgerald MODULE_SOFTDEP("pre: madera irq-madera arizona-micsupp");
2653f1572a44SRichard Fitzgerald MODULE_DESCRIPTION("ASoC CS47L90 driver");
2654f1572a44SRichard Fitzgerald MODULE_AUTHOR("Nikesh Oswal <nikesh@opensource.cirrus.com>");
2655f1572a44SRichard Fitzgerald MODULE_LICENSE("GPL v2");
2656f1572a44SRichard Fitzgerald MODULE_ALIAS("platform:cs47l90-codec");
2657