GNU Linux-libre 5.10.219-gnu1
[releases.git] / drivers / mfd / wm5102-tables.c
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * wm5102-tables.c  --  WM5102 data tables
4  *
5  * Copyright 2012 Wolfson Microelectronics plc
6  *
7  * Author: Mark Brown <broonie@opensource.wolfsonmicro.com>
8  */
9
10 #include <linux/device.h>
11 #include <linux/module.h>
12
13 #include <linux/mfd/arizona/core.h>
14 #include <linux/mfd/arizona/registers.h>
15
16 #include "arizona.h"
17
18 #define WM5102_NUM_AOD_ISR 2
19 #define WM5102_NUM_ISR 5
20
21 static const struct reg_sequence wm5102_reva_patch[] = {
22         { 0x80, 0x0003 },
23         { 0x221, 0x0090 },
24         { 0x211, 0x0014 },
25         { 0x212, 0x0000 },
26         { 0x214, 0x000C },
27         { 0x171, 0x0002 },
28         { 0x171, 0x0000 },
29         { 0x461, 0x8000 },
30         { 0x463, 0x50F0 },
31         { 0x465, 0x4820 },
32         { 0x467, 0x4040 },
33         { 0x469, 0x3940 },
34         { 0x46B, 0x3310 },
35         { 0x46D, 0x2D80 },
36         { 0x46F, 0x2890 },
37         { 0x471, 0x1990 },
38         { 0x473, 0x1450 },
39         { 0x475, 0x1020 },
40         { 0x477, 0x0CD0 },
41         { 0x479, 0x0A30 },
42         { 0x47B, 0x0810 },
43         { 0x47D, 0x0510 },
44         { 0x4D1, 0x017F },
45         { 0x500, 0x000D },
46         { 0x507, 0x1820 },
47         { 0x508, 0x1820 },
48         { 0x540, 0x000D },
49         { 0x547, 0x1820 },
50         { 0x548, 0x1820 },
51         { 0x580, 0x000D },
52         { 0x587, 0x1820 },
53         { 0x588, 0x1820 },
54         { 0x80, 0x0000 },
55 };
56
57 static const struct reg_sequence wm5102_revb_patch[] = {
58         { 0x19, 0x0001 },
59         { 0x80, 0x0003 },
60         { 0x081, 0xE022 },
61         { 0x410, 0x6080 },
62         { 0x418, 0xa080 },
63         { 0x420, 0xa080 },
64         { 0x428, 0xe000 },
65         { 0x442, 0x3F0A },
66         { 0x443, 0xDC1F },
67         { 0x4B0, 0x0066 },
68         { 0x458, 0x000b },
69         { 0x212, 0x0000 },
70         { 0x171, 0x0000 },
71         { 0x35E, 0x000C },
72         { 0x2D4, 0x0000 },
73         { 0x4DC, 0x0900 },
74         { 0x80, 0x0000 },
75 };
76
77 /* We use a function so we can use ARRAY_SIZE() */
78 int wm5102_patch(struct arizona *arizona)
79 {
80         const struct reg_sequence *wm5102_patch;
81         int patch_size;
82
83         switch (arizona->rev) {
84         case 0:
85                 wm5102_patch = wm5102_reva_patch;
86                 patch_size = ARRAY_SIZE(wm5102_reva_patch);
87                 break;
88         default:
89                 wm5102_patch = wm5102_revb_patch;
90                 patch_size = ARRAY_SIZE(wm5102_revb_patch);
91         }
92
93         return regmap_multi_reg_write_bypassed(arizona->regmap,
94                                                wm5102_patch,
95                                                patch_size);
96 }
97
98 static const struct regmap_irq wm5102_aod_irqs[ARIZONA_NUM_IRQ] = {
99         [ARIZONA_IRQ_MICD_CLAMP_FALL] = {
100                 .mask = ARIZONA_MICD_CLAMP_FALL_EINT1
101         },
102         [ARIZONA_IRQ_MICD_CLAMP_RISE] = {
103                 .mask = ARIZONA_MICD_CLAMP_RISE_EINT1
104         },
105         [ARIZONA_IRQ_GP5_FALL] = { .mask = ARIZONA_GP5_FALL_EINT1 },
106         [ARIZONA_IRQ_GP5_RISE] = { .mask = ARIZONA_GP5_RISE_EINT1 },
107         [ARIZONA_IRQ_JD_FALL] = { .mask = ARIZONA_JD1_FALL_EINT1 },
108         [ARIZONA_IRQ_JD_RISE] = { .mask = ARIZONA_JD1_RISE_EINT1 },
109 };
110
111 const struct regmap_irq_chip wm5102_aod = {
112         .name = "wm5102 AOD",
113         .status_base = ARIZONA_AOD_IRQ1,
114         .mask_base = ARIZONA_AOD_IRQ_MASK_IRQ1,
115         .ack_base = ARIZONA_AOD_IRQ1,
116         .wake_base = ARIZONA_WAKE_CONTROL,
117         .wake_invert = 1,
118         .num_regs = 1,
119         .irqs = wm5102_aod_irqs,
120         .num_irqs = ARRAY_SIZE(wm5102_aod_irqs),
121 };
122
123 static const struct regmap_irq wm5102_irqs[ARIZONA_NUM_IRQ] = {
124         [ARIZONA_IRQ_GP4] = { .reg_offset = 0, .mask = ARIZONA_GP4_EINT1 },
125         [ARIZONA_IRQ_GP3] = { .reg_offset = 0, .mask = ARIZONA_GP3_EINT1 },
126         [ARIZONA_IRQ_GP2] = { .reg_offset = 0, .mask = ARIZONA_GP2_EINT1 },
127         [ARIZONA_IRQ_GP1] = { .reg_offset = 0, .mask = ARIZONA_GP1_EINT1 },
128
129         [ARIZONA_IRQ_DSP1_RAM_RDY] = {
130                 .reg_offset = 1, .mask = ARIZONA_DSP1_RAM_RDY_EINT1
131         },
132         [ARIZONA_IRQ_DSP_IRQ2] = {
133                 .reg_offset = 1, .mask = ARIZONA_DSP_IRQ2_EINT1
134         },
135         [ARIZONA_IRQ_DSP_IRQ1] = {
136                 .reg_offset = 1, .mask = ARIZONA_DSP_IRQ1_EINT1
137         },
138
139         [ARIZONA_IRQ_SPK_OVERHEAT_WARN] = {
140                 .reg_offset = 2, .mask = ARIZONA_SPK_OVERHEAT_WARN_EINT1
141         },
142         [ARIZONA_IRQ_SPK_OVERHEAT] = {
143                 .reg_offset = 2, .mask = ARIZONA_SPK_OVERHEAT_EINT1
144         },
145         [ARIZONA_IRQ_HPDET] = {
146                 .reg_offset = 2, .mask = ARIZONA_HPDET_EINT1
147         },
148         [ARIZONA_IRQ_MICDET] = {
149                 .reg_offset = 2, .mask = ARIZONA_MICDET_EINT1
150         },
151         [ARIZONA_IRQ_WSEQ_DONE] = {
152                 .reg_offset = 2, .mask = ARIZONA_WSEQ_DONE_EINT1
153         },
154         [ARIZONA_IRQ_DRC2_SIG_DET] = {
155                 .reg_offset = 2, .mask = ARIZONA_DRC2_SIG_DET_EINT1
156         },
157         [ARIZONA_IRQ_DRC1_SIG_DET] = {
158                 .reg_offset = 2, .mask = ARIZONA_DRC1_SIG_DET_EINT1
159         },
160         [ARIZONA_IRQ_ASRC2_LOCK] = {
161                 .reg_offset = 2, .mask = ARIZONA_ASRC2_LOCK_EINT1
162         },
163         [ARIZONA_IRQ_ASRC1_LOCK] = {
164                 .reg_offset = 2, .mask = ARIZONA_ASRC1_LOCK_EINT1
165         },
166         [ARIZONA_IRQ_UNDERCLOCKED] = {
167                 .reg_offset = 2, .mask = ARIZONA_UNDERCLOCKED_EINT1
168         },
169         [ARIZONA_IRQ_OVERCLOCKED] = {
170                 .reg_offset = 2, .mask = ARIZONA_OVERCLOCKED_EINT1
171         },
172         [ARIZONA_IRQ_FLL2_LOCK] = {
173                 .reg_offset = 2, .mask = ARIZONA_FLL2_LOCK_EINT1
174         },
175         [ARIZONA_IRQ_FLL1_LOCK] = {
176                 .reg_offset = 2, .mask = ARIZONA_FLL1_LOCK_EINT1
177         },
178         [ARIZONA_IRQ_CLKGEN_ERR] = {
179                 .reg_offset = 2, .mask = ARIZONA_CLKGEN_ERR_EINT1
180         },
181         [ARIZONA_IRQ_CLKGEN_ERR_ASYNC] = {
182                 .reg_offset = 2, .mask = ARIZONA_CLKGEN_ERR_ASYNC_EINT1
183         },
184
185         [ARIZONA_IRQ_ASRC_CFG_ERR] = {
186                 .reg_offset = 3, .mask = ARIZONA_ASRC_CFG_ERR_EINT1
187         },
188         [ARIZONA_IRQ_AIF3_ERR] = {
189                 .reg_offset = 3, .mask = ARIZONA_AIF3_ERR_EINT1
190         },
191         [ARIZONA_IRQ_AIF2_ERR] = {
192                 .reg_offset = 3, .mask = ARIZONA_AIF2_ERR_EINT1
193         },
194         [ARIZONA_IRQ_AIF1_ERR] = {
195                 .reg_offset = 3, .mask = ARIZONA_AIF1_ERR_EINT1
196         },
197         [ARIZONA_IRQ_CTRLIF_ERR] = {
198                 .reg_offset = 3, .mask = ARIZONA_CTRLIF_ERR_EINT1
199         },
200         [ARIZONA_IRQ_MIXER_DROPPED_SAMPLES] = {
201                 .reg_offset = 3, .mask = ARIZONA_MIXER_DROPPED_SAMPLE_EINT1
202         },
203         [ARIZONA_IRQ_ASYNC_CLK_ENA_LOW] = {
204                 .reg_offset = 3, .mask = ARIZONA_ASYNC_CLK_ENA_LOW_EINT1
205         },
206         [ARIZONA_IRQ_SYSCLK_ENA_LOW] = {
207                 .reg_offset = 3, .mask = ARIZONA_SYSCLK_ENA_LOW_EINT1
208         },
209         [ARIZONA_IRQ_ISRC1_CFG_ERR] = {
210                 .reg_offset = 3, .mask = ARIZONA_ISRC1_CFG_ERR_EINT1
211         },
212         [ARIZONA_IRQ_ISRC2_CFG_ERR] = {
213                 .reg_offset = 3, .mask = ARIZONA_ISRC2_CFG_ERR_EINT1
214         },
215
216         [ARIZONA_IRQ_BOOT_DONE] = {
217                 .reg_offset = 4, .mask = ARIZONA_BOOT_DONE_EINT1
218         },
219         [ARIZONA_IRQ_DCS_DAC_DONE] = {
220                 .reg_offset = 4, .mask = ARIZONA_DCS_DAC_DONE_EINT1
221         },
222         [ARIZONA_IRQ_DCS_HP_DONE] = {
223                 .reg_offset = 4, .mask = ARIZONA_DCS_HP_DONE_EINT1
224         },
225         [ARIZONA_IRQ_FLL2_CLOCK_OK] = {
226                 .reg_offset = 4, .mask = ARIZONA_FLL2_CLOCK_OK_EINT1
227         },
228         [ARIZONA_IRQ_FLL1_CLOCK_OK] = {
229                 .reg_offset = 4, .mask = ARIZONA_FLL1_CLOCK_OK_EINT1
230         },
231 };
232
233 const struct regmap_irq_chip wm5102_irq = {
234         .name = "wm5102 IRQ",
235         .status_base = ARIZONA_INTERRUPT_STATUS_1,
236         .mask_base = ARIZONA_INTERRUPT_STATUS_1_MASK,
237         .ack_base = ARIZONA_INTERRUPT_STATUS_1,
238         .num_regs = 5,
239         .irqs = wm5102_irqs,
240         .num_irqs = ARRAY_SIZE(wm5102_irqs),
241 };
242
243 static const struct reg_default wm5102_reg_default[] = {
244         { 0x00000008, 0x0019 },   /* R8     - Ctrl IF SPI CFG 1 */
245         { 0x00000009, 0x0001 },   /* R9     - Ctrl IF I2C1 CFG 1 */
246         { 0x00000020, 0x0000 },   /* R32    - Tone Generator 1 */
247         { 0x00000021, 0x1000 },   /* R33    - Tone Generator 2 */
248         { 0x00000022, 0x0000 },   /* R34    - Tone Generator 3 */
249         { 0x00000023, 0x1000 },   /* R35    - Tone Generator 4 */
250         { 0x00000024, 0x0000 },   /* R36    - Tone Generator 5 */
251         { 0x00000030, 0x0000 },   /* R48    - PWM Drive 1 */
252         { 0x00000031, 0x0100 },   /* R49    - PWM Drive 2 */
253         { 0x00000032, 0x0100 },   /* R50    - PWM Drive 3 */
254         { 0x00000040, 0x0000 },   /* R64    - Wake control */
255         { 0x00000041, 0x0000 },   /* R65    - Sequence control */
256         { 0x00000061, 0x01FF },   /* R97    - Sample Rate Sequence Select 1 */
257         { 0x00000062, 0x01FF },   /* R98    - Sample Rate Sequence Select 2 */
258         { 0x00000063, 0x01FF },   /* R99    - Sample Rate Sequence Select 3 */
259         { 0x00000064, 0x01FF },   /* R100   - Sample Rate Sequence Select 4 */
260         { 0x00000066, 0x01FF },   /* R102   - Always On Triggers Sequence Select 1 */
261         { 0x00000067, 0x01FF },   /* R103   - Always On Triggers Sequence Select 2 */
262         { 0x00000068, 0x01FF },   /* R104   - Always On Triggers Sequence Select 3 */
263         { 0x00000069, 0x01FF },   /* R105   - Always On Triggers Sequence Select 4 */
264         { 0x0000006A, 0x01FF },   /* R106   - Always On Triggers Sequence Select 5 */
265         { 0x0000006B, 0x01FF },   /* R107   - Always On Triggers Sequence Select 6 */
266         { 0x00000070, 0x0000 },   /* R112   - Comfort Noise Generator */
267         { 0x00000090, 0x0000 },   /* R144   - Haptics Control 1 */
268         { 0x00000091, 0x7FFF },   /* R145   - Haptics Control 2 */
269         { 0x00000092, 0x0000 },   /* R146   - Haptics phase 1 intensity */
270         { 0x00000093, 0x0000 },   /* R147   - Haptics phase 1 duration */
271         { 0x00000094, 0x0000 },   /* R148   - Haptics phase 2 intensity */
272         { 0x00000095, 0x0000 },   /* R149   - Haptics phase 2 duration */
273         { 0x00000096, 0x0000 },   /* R150   - Haptics phase 3 intensity */
274         { 0x00000097, 0x0000 },   /* R151   - Haptics phase 3 duration */
275         { 0x00000100, 0x0002 },   /* R256   - Clock 32k 1 */
276         { 0x00000101, 0x0304 },   /* R257   - System Clock 1 */
277         { 0x00000102, 0x0011 },   /* R258   - Sample rate 1 */
278         { 0x00000103, 0x0011 },   /* R259   - Sample rate 2 */
279         { 0x00000104, 0x0011 },   /* R260   - Sample rate 3 */
280         { 0x00000112, 0x0305 },   /* R274   - Async clock 1 */
281         { 0x00000113, 0x0011 },   /* R275   - Async sample rate 1 */
282         { 0x00000114, 0x0011 },   /* R276   - Async sample rate 2 */
283         { 0x00000149, 0x0000 },   /* R329   - Output system clock */
284         { 0x0000014A, 0x0000 },   /* R330   - Output async clock */
285         { 0x00000152, 0x0000 },   /* R338   - Rate Estimator 1 */
286         { 0x00000153, 0x0000 },   /* R339   - Rate Estimator 2 */
287         { 0x00000154, 0x0000 },   /* R340   - Rate Estimator 3 */
288         { 0x00000155, 0x0000 },   /* R341   - Rate Estimator 4 */
289         { 0x00000156, 0x0000 },   /* R342   - Rate Estimator 5 */
290         { 0x00000161, 0x0000 },   /* R353   - Dynamic Frequency Scaling 1 */
291         { 0x00000171, 0x0000 },   /* R369   - FLL1 Control 1 */
292         { 0x00000172, 0x0008 },   /* R370   - FLL1 Control 2 */
293         { 0x00000173, 0x0018 },   /* R371   - FLL1 Control 3 */
294         { 0x00000174, 0x007D },   /* R372   - FLL1 Control 4 */
295         { 0x00000175, 0x0004 },   /* R373   - FLL1 Control 5 */
296         { 0x00000176, 0x0000 },   /* R374   - FLL1 Control 6 */
297         { 0x00000179, 0x0000 },   /* R377   - FLL1 Control 7 */
298         { 0x00000181, 0x0000 },   /* R385   - FLL1 Synchroniser 1 */
299         { 0x00000182, 0x0000 },   /* R386   - FLL1 Synchroniser 2 */
300         { 0x00000183, 0x0000 },   /* R387   - FLL1 Synchroniser 3 */
301         { 0x00000184, 0x0000 },   /* R388   - FLL1 Synchroniser 4 */
302         { 0x00000185, 0x0000 },   /* R389   - FLL1 Synchroniser 5 */
303         { 0x00000186, 0x0000 },   /* R390   - FLL1 Synchroniser 6 */
304         { 0x00000187, 0x0001 },   /* R391   - FLL1 Synchroniser 7 */
305         { 0x00000189, 0x0000 },   /* R393   - FLL1 Spread Spectrum */
306         { 0x0000018A, 0x0004 },   /* R394   - FLL1 GPIO Clock */
307         { 0x00000191, 0x0000 },   /* R401   - FLL2 Control 1 */
308         { 0x00000192, 0x0008 },   /* R402   - FLL2 Control 2 */
309         { 0x00000193, 0x0018 },   /* R403   - FLL2 Control 3 */
310         { 0x00000194, 0x007D },   /* R404   - FLL2 Control 4 */
311         { 0x00000195, 0x0004 },   /* R405   - FLL2 Control 5 */
312         { 0x00000196, 0x0000 },   /* R406   - FLL2 Control 6 */
313         { 0x00000199, 0x0000 },   /* R409   - FLL2 Control 7 */
314         { 0x000001A1, 0x0000 },   /* R417   - FLL2 Synchroniser 1 */
315         { 0x000001A2, 0x0000 },   /* R418   - FLL2 Synchroniser 2 */
316         { 0x000001A3, 0x0000 },   /* R419   - FLL2 Synchroniser 3 */
317         { 0x000001A4, 0x0000 },   /* R420   - FLL2 Synchroniser 4 */
318         { 0x000001A5, 0x0000 },   /* R421   - FLL2 Synchroniser 5 */
319         { 0x000001A6, 0x0000 },   /* R422   - FLL2 Synchroniser 6 */
320         { 0x000001A7, 0x0001 },   /* R423   - FLL2 Synchroniser 7 */
321         { 0x000001A9, 0x0000 },   /* R425   - FLL2 Spread Spectrum */
322         { 0x000001AA, 0x0004 },   /* R426   - FLL2 GPIO Clock */
323         { 0x00000200, 0x0006 },   /* R512   - Mic Charge Pump 1 */
324         { 0x00000210, 0x00D4 },   /* R528   - LDO1 Control 1 */
325         { 0x00000212, 0x0000 },   /* R530   - LDO1 Control 2 */
326         { 0x00000213, 0x0344 },   /* R531   - LDO2 Control 1 */
327         { 0x00000218, 0x01A6 },   /* R536   - Mic Bias Ctrl 1 */
328         { 0x00000219, 0x01A6 },   /* R537   - Mic Bias Ctrl 2 */
329         { 0x0000021A, 0x01A6 },   /* R538   - Mic Bias Ctrl 3 */
330         { 0x00000293, 0x0000 },   /* R659   - Accessory Detect Mode 1 */
331         { 0x0000029B, 0x0020 },   /* R667   - Headphone Detect 1 */
332         { 0x000002A2, 0x0000 },   /* R674   - Micd clamp control */
333         { 0x000002A3, 0x1102 },   /* R675   - Mic Detect 1 */
334         { 0x000002A4, 0x009F },   /* R676   - Mic Detect 2 */
335         { 0x000002A6, 0x3737 },   /* R678   - Mic Detect Level 1 */
336         { 0x000002A7, 0x2C37 },   /* R679   - Mic Detect Level 2 */
337         { 0x000002A8, 0x1422 },   /* R680   - Mic Detect Level 3 */
338         { 0x000002A9, 0x030A },   /* R681   - Mic Detect Level 4 */
339         { 0x000002C3, 0x0000 },   /* R707   - Mic noise mix control 1 */
340         { 0x000002CB, 0x0000 },   /* R715   - Isolation control */
341         { 0x000002D3, 0x0000 },   /* R723   - Jack detect analogue */
342         { 0x00000300, 0x0000 },   /* R768   - Input Enables */
343         { 0x00000308, 0x0000 },   /* R776   - Input Rate */
344         { 0x00000309, 0x0022 },   /* R777   - Input Volume Ramp */
345         { 0x00000310, 0x2080 },   /* R784   - IN1L Control */
346         { 0x00000311, 0x0180 },   /* R785   - ADC Digital Volume 1L */
347         { 0x00000312, 0x0000 },   /* R786   - DMIC1L Control */
348         { 0x00000314, 0x0080 },   /* R788   - IN1R Control */
349         { 0x00000315, 0x0180 },   /* R789   - ADC Digital Volume 1R */
350         { 0x00000316, 0x0000 },   /* R790   - DMIC1R Control */
351         { 0x00000318, 0x2080 },   /* R792   - IN2L Control */
352         { 0x00000319, 0x0180 },   /* R793   - ADC Digital Volume 2L */
353         { 0x0000031A, 0x0000 },   /* R794   - DMIC2L Control */
354         { 0x0000031C, 0x0080 },   /* R796   - IN2R Control */
355         { 0x0000031D, 0x0180 },   /* R797   - ADC Digital Volume 2R */
356         { 0x0000031E, 0x0000 },   /* R798   - DMIC2R Control */
357         { 0x00000320, 0x2080 },   /* R800   - IN3L Control */
358         { 0x00000321, 0x0180 },   /* R801   - ADC Digital Volume 3L */
359         { 0x00000322, 0x0000 },   /* R802   - DMIC3L Control */
360         { 0x00000324, 0x0080 },   /* R804   - IN3R Control */
361         { 0x00000325, 0x0180 },   /* R805   - ADC Digital Volume 3R */
362         { 0x00000326, 0x0000 },   /* R806   - DMIC3R Control */
363         { 0x00000400, 0x0000 },   /* R1024  - Output Enables 1 */
364         { 0x00000408, 0x0000 },   /* R1032  - Output Rate 1 */
365         { 0x00000409, 0x0022 },   /* R1033  - Output Volume Ramp */
366         { 0x00000410, 0x6080 },   /* R1040  - Output Path Config 1L */
367         { 0x00000411, 0x0180 },   /* R1041  - DAC Digital Volume 1L */
368         { 0x00000412, 0x0081 },   /* R1042  - DAC Volume Limit 1L */
369         { 0x00000413, 0x0001 },   /* R1043  - Noise Gate Select 1L */
370         { 0x00000414, 0x0080 },   /* R1044  - Output Path Config 1R */
371         { 0x00000415, 0x0180 },   /* R1045  - DAC Digital Volume 1R */
372         { 0x00000416, 0x0081 },   /* R1046  - DAC Volume Limit 1R */
373         { 0x00000417, 0x0002 },   /* R1047  - Noise Gate Select 1R */
374         { 0x00000418, 0xA080 },   /* R1048  - Output Path Config 2L */
375         { 0x00000419, 0x0180 },   /* R1049  - DAC Digital Volume 2L */
376         { 0x0000041A, 0x0081 },   /* R1050  - DAC Volume Limit 2L */
377         { 0x0000041B, 0x0004 },   /* R1051  - Noise Gate Select 2L */
378         { 0x0000041C, 0x0080 },   /* R1052  - Output Path Config 2R */
379         { 0x0000041D, 0x0180 },   /* R1053  - DAC Digital Volume 2R */
380         { 0x0000041E, 0x0081 },   /* R1054  - DAC Volume Limit 2R */
381         { 0x0000041F, 0x0008 },   /* R1055  - Noise Gate Select 2R */
382         { 0x00000420, 0xA080 },   /* R1056  - Output Path Config 3L */
383         { 0x00000421, 0x0180 },   /* R1057  - DAC Digital Volume 3L */
384         { 0x00000422, 0x0081 },   /* R1058  - DAC Volume Limit 3L */
385         { 0x00000423, 0x0010 },   /* R1059  - Noise Gate Select 3L */
386         { 0x00000428, 0xE000 },   /* R1064  - Output Path Config 4L */
387         { 0x00000429, 0x0180 },   /* R1065  - DAC Digital Volume 4L */
388         { 0x0000042A, 0x0081 },   /* R1066  - Out Volume 4L */
389         { 0x0000042B, 0x0040 },   /* R1067  - Noise Gate Select 4L */
390         { 0x0000042D, 0x0180 },   /* R1069  - DAC Digital Volume 4R */
391         { 0x0000042E, 0x0081 },   /* R1070  - Out Volume 4R */
392         { 0x0000042F, 0x0080 },   /* R1071  - Noise Gate Select 4R */
393         { 0x00000430, 0x0000 },   /* R1072  - Output Path Config 5L */
394         { 0x00000431, 0x0180 },   /* R1073  - DAC Digital Volume 5L */
395         { 0x00000432, 0x0081 },   /* R1074  - DAC Volume Limit 5L */
396         { 0x00000433, 0x0100 },   /* R1075  - Noise Gate Select 5L */
397         { 0x00000435, 0x0180 },   /* R1077  - DAC Digital Volume 5R */
398         { 0x00000436, 0x0081 },   /* R1078  - DAC Volume Limit 5R */
399         { 0x00000437, 0x0200 },   /* R1079  - Noise Gate Select 5R */
400         { 0x00000440, 0x0FFF },   /* R1088  - DRE Enable */
401         { 0x00000442, 0x3F0A },   /* R1090  - DRE Control 2 */
402         { 0x00000443, 0xDC1F },   /* R1090  - DRE Control 3 */
403         { 0x00000450, 0x0000 },   /* R1104  - DAC AEC Control 1 */
404         { 0x00000458, 0x000B },   /* R1112  - Noise Gate Control */
405         { 0x00000490, 0x0069 },   /* R1168  - PDM SPK1 CTRL 1 */
406         { 0x00000491, 0x0000 },   /* R1169  - PDM SPK1 CTRL 2 */
407         { 0x00000500, 0x000C },   /* R1280  - AIF1 BCLK Ctrl */
408         { 0x00000501, 0x0008 },   /* R1281  - AIF1 Tx Pin Ctrl */
409         { 0x00000502, 0x0000 },   /* R1282  - AIF1 Rx Pin Ctrl */
410         { 0x00000503, 0x0000 },   /* R1283  - AIF1 Rate Ctrl */
411         { 0x00000504, 0x0000 },   /* R1284  - AIF1 Format */
412         { 0x00000505, 0x0040 },   /* R1285  - AIF1 Tx BCLK Rate */
413         { 0x00000506, 0x0040 },   /* R1286  - AIF1 Rx BCLK Rate */
414         { 0x00000507, 0x1818 },   /* R1287  - AIF1 Frame Ctrl 1 */
415         { 0x00000508, 0x1818 },   /* R1288  - AIF1 Frame Ctrl 2 */
416         { 0x00000509, 0x0000 },   /* R1289  - AIF1 Frame Ctrl 3 */
417         { 0x0000050A, 0x0001 },   /* R1290  - AIF1 Frame Ctrl 4 */
418         { 0x0000050B, 0x0002 },   /* R1291  - AIF1 Frame Ctrl 5 */
419         { 0x0000050C, 0x0003 },   /* R1292  - AIF1 Frame Ctrl 6 */
420         { 0x0000050D, 0x0004 },   /* R1293  - AIF1 Frame Ctrl 7 */
421         { 0x0000050E, 0x0005 },   /* R1294  - AIF1 Frame Ctrl 8 */
422         { 0x0000050F, 0x0006 },   /* R1295  - AIF1 Frame Ctrl 9 */
423         { 0x00000510, 0x0007 },   /* R1296  - AIF1 Frame Ctrl 10 */
424         { 0x00000511, 0x0000 },   /* R1297  - AIF1 Frame Ctrl 11 */
425         { 0x00000512, 0x0001 },   /* R1298  - AIF1 Frame Ctrl 12 */
426         { 0x00000513, 0x0002 },   /* R1299  - AIF1 Frame Ctrl 13 */
427         { 0x00000514, 0x0003 },   /* R1300  - AIF1 Frame Ctrl 14 */
428         { 0x00000515, 0x0004 },   /* R1301  - AIF1 Frame Ctrl 15 */
429         { 0x00000516, 0x0005 },   /* R1302  - AIF1 Frame Ctrl 16 */
430         { 0x00000517, 0x0006 },   /* R1303  - AIF1 Frame Ctrl 17 */
431         { 0x00000518, 0x0007 },   /* R1304  - AIF1 Frame Ctrl 18 */
432         { 0x00000519, 0x0000 },   /* R1305  - AIF1 Tx Enables */
433         { 0x0000051A, 0x0000 },   /* R1306  - AIF1 Rx Enables */
434         { 0x00000540, 0x000C },   /* R1344  - AIF2 BCLK Ctrl */
435         { 0x00000541, 0x0008 },   /* R1345  - AIF2 Tx Pin Ctrl */
436         { 0x00000542, 0x0000 },   /* R1346  - AIF2 Rx Pin Ctrl */
437         { 0x00000543, 0x0000 },   /* R1347  - AIF2 Rate Ctrl */
438         { 0x00000544, 0x0000 },   /* R1348  - AIF2 Format */
439         { 0x00000545, 0x0040 },   /* R1349  - AIF2 Tx BCLK Rate */
440         { 0x00000546, 0x0040 },   /* R1350  - AIF2 Rx BCLK Rate */
441         { 0x00000547, 0x1818 },   /* R1351  - AIF2 Frame Ctrl 1 */
442         { 0x00000548, 0x1818 },   /* R1352  - AIF2 Frame Ctrl 2 */
443         { 0x00000549, 0x0000 },   /* R1353  - AIF2 Frame Ctrl 3 */
444         { 0x0000054A, 0x0001 },   /* R1354  - AIF2 Frame Ctrl 4 */
445         { 0x00000551, 0x0000 },   /* R1361  - AIF2 Frame Ctrl 11 */
446         { 0x00000552, 0x0001 },   /* R1362  - AIF2 Frame Ctrl 12 */
447         { 0x00000559, 0x0000 },   /* R1369  - AIF2 Tx Enables */
448         { 0x0000055A, 0x0000 },   /* R1370  - AIF2 Rx Enables */
449         { 0x00000580, 0x000C },   /* R1408  - AIF3 BCLK Ctrl */
450         { 0x00000581, 0x0008 },   /* R1409  - AIF3 Tx Pin Ctrl */
451         { 0x00000582, 0x0000 },   /* R1410  - AIF3 Rx Pin Ctrl */
452         { 0x00000583, 0x0000 },   /* R1411  - AIF3 Rate Ctrl */
453         { 0x00000584, 0x0000 },   /* R1412  - AIF3 Format */
454         { 0x00000585, 0x0040 },   /* R1413  - AIF3 Tx BCLK Rate */
455         { 0x00000586, 0x0040 },   /* R1414  - AIF3 Rx BCLK Rate */
456         { 0x00000587, 0x1818 },   /* R1415  - AIF3 Frame Ctrl 1 */
457         { 0x00000588, 0x1818 },   /* R1416  - AIF3 Frame Ctrl 2 */
458         { 0x00000589, 0x0000 },   /* R1417  - AIF3 Frame Ctrl 3 */
459         { 0x0000058A, 0x0001 },   /* R1418  - AIF3 Frame Ctrl 4 */
460         { 0x00000591, 0x0000 },   /* R1425  - AIF3 Frame Ctrl 11 */
461         { 0x00000592, 0x0001 },   /* R1426  - AIF3 Frame Ctrl 12 */
462         { 0x00000599, 0x0000 },   /* R1433  - AIF3 Tx Enables */
463         { 0x0000059A, 0x0000 },   /* R1434  - AIF3 Rx Enables */
464         { 0x000005E3, 0x0004 },   /* R1507  - SLIMbus Framer Ref Gear */
465         { 0x000005E5, 0x0000 },   /* R1509  - SLIMbus Rates 1 */
466         { 0x000005E6, 0x0000 },   /* R1510  - SLIMbus Rates 2 */
467         { 0x000005E7, 0x0000 },   /* R1511  - SLIMbus Rates 3 */
468         { 0x000005E8, 0x0000 },   /* R1512  - SLIMbus Rates 4 */
469         { 0x000005E9, 0x0000 },   /* R1513  - SLIMbus Rates 5 */
470         { 0x000005EA, 0x0000 },   /* R1514  - SLIMbus Rates 6 */
471         { 0x000005EB, 0x0000 },   /* R1515  - SLIMbus Rates 7 */
472         { 0x000005EC, 0x0000 },   /* R1516  - SLIMbus Rates 8 */
473         { 0x000005F5, 0x0000 },   /* R1525  - SLIMbus RX Channel Enable */
474         { 0x000005F6, 0x0000 },   /* R1526  - SLIMbus TX Channel Enable */
475         { 0x00000640, 0x0000 },   /* R1600  - PWM1MIX Input 1 Source */
476         { 0x00000641, 0x0080 },   /* R1601  - PWM1MIX Input 1 Volume */
477         { 0x00000642, 0x0000 },   /* R1602  - PWM1MIX Input 2 Source */
478         { 0x00000643, 0x0080 },   /* R1603  - PWM1MIX Input 2 Volume */
479         { 0x00000644, 0x0000 },   /* R1604  - PWM1MIX Input 3 Source */
480         { 0x00000645, 0x0080 },   /* R1605  - PWM1MIX Input 3 Volume */
481         { 0x00000646, 0x0000 },   /* R1606  - PWM1MIX Input 4 Source */
482         { 0x00000647, 0x0080 },   /* R1607  - PWM1MIX Input 4 Volume */
483         { 0x00000648, 0x0000 },   /* R1608  - PWM2MIX Input 1 Source */
484         { 0x00000649, 0x0080 },   /* R1609  - PWM2MIX Input 1 Volume */
485         { 0x0000064A, 0x0000 },   /* R1610  - PWM2MIX Input 2 Source */
486         { 0x0000064B, 0x0080 },   /* R1611  - PWM2MIX Input 2 Volume */
487         { 0x0000064C, 0x0000 },   /* R1612  - PWM2MIX Input 3 Source */
488         { 0x0000064D, 0x0080 },   /* R1613  - PWM2MIX Input 3 Volume */
489         { 0x0000064E, 0x0000 },   /* R1614  - PWM2MIX Input 4 Source */
490         { 0x0000064F, 0x0080 },   /* R1615  - PWM2MIX Input 4 Volume */
491         { 0x00000660, 0x0000 },   /* R1632  - MICMIX Input 1 Source */
492         { 0x00000661, 0x0080 },   /* R1633  - MICMIX Input 1 Volume */
493         { 0x00000662, 0x0000 },   /* R1634  - MICMIX Input 2 Source */
494         { 0x00000663, 0x0080 },   /* R1635  - MICMIX Input 2 Volume */
495         { 0x00000664, 0x0000 },   /* R1636  - MICMIX Input 3 Source */
496         { 0x00000665, 0x0080 },   /* R1637  - MICMIX Input 3 Volume */
497         { 0x00000666, 0x0000 },   /* R1638  - MICMIX Input 4 Source */
498         { 0x00000667, 0x0080 },   /* R1639  - MICMIX Input 4 Volume */
499         { 0x00000668, 0x0000 },   /* R1640  - NOISEMIX Input 1 Source */
500         { 0x00000669, 0x0080 },   /* R1641  - NOISEMIX Input 1 Volume */
501         { 0x0000066A, 0x0000 },   /* R1642  - NOISEMIX Input 2 Source */
502         { 0x0000066B, 0x0080 },   /* R1643  - NOISEMIX Input 2 Volume */
503         { 0x0000066C, 0x0000 },   /* R1644  - NOISEMIX Input 3 Source */
504         { 0x0000066D, 0x0080 },   /* R1645  - NOISEMIX Input 3 Volume */
505         { 0x0000066E, 0x0000 },   /* R1646  - NOISEMIX Input 4 Source */
506         { 0x0000066F, 0x0080 },   /* R1647  - NOISEMIX Input 4 Volume */
507         { 0x00000680, 0x0000 },   /* R1664  - OUT1LMIX Input 1 Source */
508         { 0x00000681, 0x0080 },   /* R1665  - OUT1LMIX Input 1 Volume */
509         { 0x00000682, 0x0000 },   /* R1666  - OUT1LMIX Input 2 Source */
510         { 0x00000683, 0x0080 },   /* R1667  - OUT1LMIX Input 2 Volume */
511         { 0x00000684, 0x0000 },   /* R1668  - OUT1LMIX Input 3 Source */
512         { 0x00000685, 0x0080 },   /* R1669  - OUT1LMIX Input 3 Volume */
513         { 0x00000686, 0x0000 },   /* R1670  - OUT1LMIX Input 4 Source */
514         { 0x00000687, 0x0080 },   /* R1671  - OUT1LMIX Input 4 Volume */
515         { 0x00000688, 0x0000 },   /* R1672  - OUT1RMIX Input 1 Source */
516         { 0x00000689, 0x0080 },   /* R1673  - OUT1RMIX Input 1 Volume */
517         { 0x0000068A, 0x0000 },   /* R1674  - OUT1RMIX Input 2 Source */
518         { 0x0000068B, 0x0080 },   /* R1675  - OUT1RMIX Input 2 Volume */
519         { 0x0000068C, 0x0000 },   /* R1676  - OUT1RMIX Input 3 Source */
520         { 0x0000068D, 0x0080 },   /* R1677  - OUT1RMIX Input 3 Volume */
521         { 0x0000068E, 0x0000 },   /* R1678  - OUT1RMIX Input 4 Source */
522         { 0x0000068F, 0x0080 },   /* R1679  - OUT1RMIX Input 4 Volume */
523         { 0x00000690, 0x0000 },   /* R1680  - OUT2LMIX Input 1 Source */
524         { 0x00000691, 0x0080 },   /* R1681  - OUT2LMIX Input 1 Volume */
525         { 0x00000692, 0x0000 },   /* R1682  - OUT2LMIX Input 2 Source */
526         { 0x00000693, 0x0080 },   /* R1683  - OUT2LMIX Input 2 Volume */
527         { 0x00000694, 0x0000 },   /* R1684  - OUT2LMIX Input 3 Source */
528         { 0x00000695, 0x0080 },   /* R1685  - OUT2LMIX Input 3 Volume */
529         { 0x00000696, 0x0000 },   /* R1686  - OUT2LMIX Input 4 Source */
530         { 0x00000697, 0x0080 },   /* R1687  - OUT2LMIX Input 4 Volume */
531         { 0x00000698, 0x0000 },   /* R1688  - OUT2RMIX Input 1 Source */
532         { 0x00000699, 0x0080 },   /* R1689  - OUT2RMIX Input 1 Volume */
533         { 0x0000069A, 0x0000 },   /* R1690  - OUT2RMIX Input 2 Source */
534         { 0x0000069B, 0x0080 },   /* R1691  - OUT2RMIX Input 2 Volume */
535         { 0x0000069C, 0x0000 },   /* R1692  - OUT2RMIX Input 3 Source */
536         { 0x0000069D, 0x0080 },   /* R1693  - OUT2RMIX Input 3 Volume */
537         { 0x0000069E, 0x0000 },   /* R1694  - OUT2RMIX Input 4 Source */
538         { 0x0000069F, 0x0080 },   /* R1695  - OUT2RMIX Input 4 Volume */
539         { 0x000006A0, 0x0000 },   /* R1696  - OUT3LMIX Input 1 Source */
540         { 0x000006A1, 0x0080 },   /* R1697  - OUT3LMIX Input 1 Volume */
541         { 0x000006A2, 0x0000 },   /* R1698  - OUT3LMIX Input 2 Source */
542         { 0x000006A3, 0x0080 },   /* R1699  - OUT3LMIX Input 2 Volume */
543         { 0x000006A4, 0x0000 },   /* R1700  - OUT3LMIX Input 3 Source */
544         { 0x000006A5, 0x0080 },   /* R1701  - OUT3LMIX Input 3 Volume */
545         { 0x000006A6, 0x0000 },   /* R1702  - OUT3LMIX Input 4 Source */
546         { 0x000006A7, 0x0080 },   /* R1703  - OUT3LMIX Input 4 Volume */
547         { 0x000006B0, 0x0000 },   /* R1712  - OUT4LMIX Input 1 Source */
548         { 0x000006B1, 0x0080 },   /* R1713  - OUT4LMIX Input 1 Volume */
549         { 0x000006B2, 0x0000 },   /* R1714  - OUT4LMIX Input 2 Source */
550         { 0x000006B3, 0x0080 },   /* R1715  - OUT4LMIX Input 2 Volume */
551         { 0x000006B4, 0x0000 },   /* R1716  - OUT4LMIX Input 3 Source */
552         { 0x000006B5, 0x0080 },   /* R1717  - OUT4LMIX Input 3 Volume */
553         { 0x000006B6, 0x0000 },   /* R1718  - OUT4LMIX Input 4 Source */
554         { 0x000006B7, 0x0080 },   /* R1719  - OUT4LMIX Input 4 Volume */
555         { 0x000006B8, 0x0000 },   /* R1720  - OUT4RMIX Input 1 Source */
556         { 0x000006B9, 0x0080 },   /* R1721  - OUT4RMIX Input 1 Volume */
557         { 0x000006BA, 0x0000 },   /* R1722  - OUT4RMIX Input 2 Source */
558         { 0x000006BB, 0x0080 },   /* R1723  - OUT4RMIX Input 2 Volume */
559         { 0x000006BC, 0x0000 },   /* R1724  - OUT4RMIX Input 3 Source */
560         { 0x000006BD, 0x0080 },   /* R1725  - OUT4RMIX Input 3 Volume */
561         { 0x000006BE, 0x0000 },   /* R1726  - OUT4RMIX Input 4 Source */
562         { 0x000006BF, 0x0080 },   /* R1727  - OUT4RMIX Input 4 Volume */
563         { 0x000006C0, 0x0000 },   /* R1728  - OUT5LMIX Input 1 Source */
564         { 0x000006C1, 0x0080 },   /* R1729  - OUT5LMIX Input 1 Volume */
565         { 0x000006C2, 0x0000 },   /* R1730  - OUT5LMIX Input 2 Source */
566         { 0x000006C3, 0x0080 },   /* R1731  - OUT5LMIX Input 2 Volume */
567         { 0x000006C4, 0x0000 },   /* R1732  - OUT5LMIX Input 3 Source */
568         { 0x000006C5, 0x0080 },   /* R1733  - OUT5LMIX Input 3 Volume */
569         { 0x000006C6, 0x0000 },   /* R1734  - OUT5LMIX Input 4 Source */
570         { 0x000006C7, 0x0080 },   /* R1735  - OUT5LMIX Input 4 Volume */
571         { 0x000006C8, 0x0000 },   /* R1736  - OUT5RMIX Input 1 Source */
572         { 0x000006C9, 0x0080 },   /* R1737  - OUT5RMIX Input 1 Volume */
573         { 0x000006CA, 0x0000 },   /* R1738  - OUT5RMIX Input 2 Source */
574         { 0x000006CB, 0x0080 },   /* R1739  - OUT5RMIX Input 2 Volume */
575         { 0x000006CC, 0x0000 },   /* R1740  - OUT5RMIX Input 3 Source */
576         { 0x000006CD, 0x0080 },   /* R1741  - OUT5RMIX Input 3 Volume */
577         { 0x000006CE, 0x0000 },   /* R1742  - OUT5RMIX Input 4 Source */
578         { 0x000006CF, 0x0080 },   /* R1743  - OUT5RMIX Input 4 Volume */
579         { 0x00000700, 0x0000 },   /* R1792  - AIF1TX1MIX Input 1 Source */
580         { 0x00000701, 0x0080 },   /* R1793  - AIF1TX1MIX Input 1 Volume */
581         { 0x00000702, 0x0000 },   /* R1794  - AIF1TX1MIX Input 2 Source */
582         { 0x00000703, 0x0080 },   /* R1795  - AIF1TX1MIX Input 2 Volume */
583         { 0x00000704, 0x0000 },   /* R1796  - AIF1TX1MIX Input 3 Source */
584         { 0x00000705, 0x0080 },   /* R1797  - AIF1TX1MIX Input 3 Volume */
585         { 0x00000706, 0x0000 },   /* R1798  - AIF1TX1MIX Input 4 Source */
586         { 0x00000707, 0x0080 },   /* R1799  - AIF1TX1MIX Input 4 Volume */
587         { 0x00000708, 0x0000 },   /* R1800  - AIF1TX2MIX Input 1 Source */
588         { 0x00000709, 0x0080 },   /* R1801  - AIF1TX2MIX Input 1 Volume */
589         { 0x0000070A, 0x0000 },   /* R1802  - AIF1TX2MIX Input 2 Source */
590         { 0x0000070B, 0x0080 },   /* R1803  - AIF1TX2MIX Input 2 Volume */
591         { 0x0000070C, 0x0000 },   /* R1804  - AIF1TX2MIX Input 3 Source */
592         { 0x0000070D, 0x0080 },   /* R1805  - AIF1TX2MIX Input 3 Volume */
593         { 0x0000070E, 0x0000 },   /* R1806  - AIF1TX2MIX Input 4 Source */
594         { 0x0000070F, 0x0080 },   /* R1807  - AIF1TX2MIX Input 4 Volume */
595         { 0x00000710, 0x0000 },   /* R1808  - AIF1TX3MIX Input 1 Source */
596         { 0x00000711, 0x0080 },   /* R1809  - AIF1TX3MIX Input 1 Volume */
597         { 0x00000712, 0x0000 },   /* R1810  - AIF1TX3MIX Input 2 Source */
598         { 0x00000713, 0x0080 },   /* R1811  - AIF1TX3MIX Input 2 Volume */
599         { 0x00000714, 0x0000 },   /* R1812  - AIF1TX3MIX Input 3 Source */
600         { 0x00000715, 0x0080 },   /* R1813  - AIF1TX3MIX Input 3 Volume */
601         { 0x00000716, 0x0000 },   /* R1814  - AIF1TX3MIX Input 4 Source */
602         { 0x00000717, 0x0080 },   /* R1815  - AIF1TX3MIX Input 4 Volume */
603         { 0x00000718, 0x0000 },   /* R1816  - AIF1TX4MIX Input 1 Source */
604         { 0x00000719, 0x0080 },   /* R1817  - AIF1TX4MIX Input 1 Volume */
605         { 0x0000071A, 0x0000 },   /* R1818  - AIF1TX4MIX Input 2 Source */
606         { 0x0000071B, 0x0080 },   /* R1819  - AIF1TX4MIX Input 2 Volume */
607         { 0x0000071C, 0x0000 },   /* R1820  - AIF1TX4MIX Input 3 Source */
608         { 0x0000071D, 0x0080 },   /* R1821  - AIF1TX4MIX Input 3 Volume */
609         { 0x0000071E, 0x0000 },   /* R1822  - AIF1TX4MIX Input 4 Source */
610         { 0x0000071F, 0x0080 },   /* R1823  - AIF1TX4MIX Input 4 Volume */
611         { 0x00000720, 0x0000 },   /* R1824  - AIF1TX5MIX Input 1 Source */
612         { 0x00000721, 0x0080 },   /* R1825  - AIF1TX5MIX Input 1 Volume */
613         { 0x00000722, 0x0000 },   /* R1826  - AIF1TX5MIX Input 2 Source */
614         { 0x00000723, 0x0080 },   /* R1827  - AIF1TX5MIX Input 2 Volume */
615         { 0x00000724, 0x0000 },   /* R1828  - AIF1TX5MIX Input 3 Source */
616         { 0x00000725, 0x0080 },   /* R1829  - AIF1TX5MIX Input 3 Volume */
617         { 0x00000726, 0x0000 },   /* R1830  - AIF1TX5MIX Input 4 Source */
618         { 0x00000727, 0x0080 },   /* R1831  - AIF1TX5MIX Input 4 Volume */
619         { 0x00000728, 0x0000 },   /* R1832  - AIF1TX6MIX Input 1 Source */
620         { 0x00000729, 0x0080 },   /* R1833  - AIF1TX6MIX Input 1 Volume */
621         { 0x0000072A, 0x0000 },   /* R1834  - AIF1TX6MIX Input 2 Source */
622         { 0x0000072B, 0x0080 },   /* R1835  - AIF1TX6MIX Input 2 Volume */
623         { 0x0000072C, 0x0000 },   /* R1836  - AIF1TX6MIX Input 3 Source */
624         { 0x0000072D, 0x0080 },   /* R1837  - AIF1TX6MIX Input 3 Volume */
625         { 0x0000072E, 0x0000 },   /* R1838  - AIF1TX6MIX Input 4 Source */
626         { 0x0000072F, 0x0080 },   /* R1839  - AIF1TX6MIX Input 4 Volume */
627         { 0x00000730, 0x0000 },   /* R1840  - AIF1TX7MIX Input 1 Source */
628         { 0x00000731, 0x0080 },   /* R1841  - AIF1TX7MIX Input 1 Volume */
629         { 0x00000732, 0x0000 },   /* R1842  - AIF1TX7MIX Input 2 Source */
630         { 0x00000733, 0x0080 },   /* R1843  - AIF1TX7MIX Input 2 Volume */
631         { 0x00000734, 0x0000 },   /* R1844  - AIF1TX7MIX Input 3 Source */
632         { 0x00000735, 0x0080 },   /* R1845  - AIF1TX7MIX Input 3 Volume */
633         { 0x00000736, 0x0000 },   /* R1846  - AIF1TX7MIX Input 4 Source */
634         { 0x00000737, 0x0080 },   /* R1847  - AIF1TX7MIX Input 4 Volume */
635         { 0x00000738, 0x0000 },   /* R1848  - AIF1TX8MIX Input 1 Source */
636         { 0x00000739, 0x0080 },   /* R1849  - AIF1TX8MIX Input 1 Volume */
637         { 0x0000073A, 0x0000 },   /* R1850  - AIF1TX8MIX Input 2 Source */
638         { 0x0000073B, 0x0080 },   /* R1851  - AIF1TX8MIX Input 2 Volume */
639         { 0x0000073C, 0x0000 },   /* R1852  - AIF1TX8MIX Input 3 Source */
640         { 0x0000073D, 0x0080 },   /* R1853  - AIF1TX8MIX Input 3 Volume */
641         { 0x0000073E, 0x0000 },   /* R1854  - AIF1TX8MIX Input 4 Source */
642         { 0x0000073F, 0x0080 },   /* R1855  - AIF1TX8MIX Input 4 Volume */
643         { 0x00000740, 0x0000 },   /* R1856  - AIF2TX1MIX Input 1 Source */
644         { 0x00000741, 0x0080 },   /* R1857  - AIF2TX1MIX Input 1 Volume */
645         { 0x00000742, 0x0000 },   /* R1858  - AIF2TX1MIX Input 2 Source */
646         { 0x00000743, 0x0080 },   /* R1859  - AIF2TX1MIX Input 2 Volume */
647         { 0x00000744, 0x0000 },   /* R1860  - AIF2TX1MIX Input 3 Source */
648         { 0x00000745, 0x0080 },   /* R1861  - AIF2TX1MIX Input 3 Volume */
649         { 0x00000746, 0x0000 },   /* R1862  - AIF2TX1MIX Input 4 Source */
650         { 0x00000747, 0x0080 },   /* R1863  - AIF2TX1MIX Input 4 Volume */
651         { 0x00000748, 0x0000 },   /* R1864  - AIF2TX2MIX Input 1 Source */
652         { 0x00000749, 0x0080 },   /* R1865  - AIF2TX2MIX Input 1 Volume */
653         { 0x0000074A, 0x0000 },   /* R1866  - AIF2TX2MIX Input 2 Source */
654         { 0x0000074B, 0x0080 },   /* R1867  - AIF2TX2MIX Input 2 Volume */
655         { 0x0000074C, 0x0000 },   /* R1868  - AIF2TX2MIX Input 3 Source */
656         { 0x0000074D, 0x0080 },   /* R1869  - AIF2TX2MIX Input 3 Volume */
657         { 0x0000074E, 0x0000 },   /* R1870  - AIF2TX2MIX Input 4 Source */
658         { 0x0000074F, 0x0080 },   /* R1871  - AIF2TX2MIX Input 4 Volume */
659         { 0x00000780, 0x0000 },   /* R1920  - AIF3TX1MIX Input 1 Source */
660         { 0x00000781, 0x0080 },   /* R1921  - AIF3TX1MIX Input 1 Volume */
661         { 0x00000782, 0x0000 },   /* R1922  - AIF3TX1MIX Input 2 Source */
662         { 0x00000783, 0x0080 },   /* R1923  - AIF3TX1MIX Input 2 Volume */
663         { 0x00000784, 0x0000 },   /* R1924  - AIF3TX1MIX Input 3 Source */
664         { 0x00000785, 0x0080 },   /* R1925  - AIF3TX1MIX Input 3 Volume */
665         { 0x00000786, 0x0000 },   /* R1926  - AIF3TX1MIX Input 4 Source */
666         { 0x00000787, 0x0080 },   /* R1927  - AIF3TX1MIX Input 4 Volume */
667         { 0x00000788, 0x0000 },   /* R1928  - AIF3TX2MIX Input 1 Source */
668         { 0x00000789, 0x0080 },   /* R1929  - AIF3TX2MIX Input 1 Volume */
669         { 0x0000078A, 0x0000 },   /* R1930  - AIF3TX2MIX Input 2 Source */
670         { 0x0000078B, 0x0080 },   /* R1931  - AIF3TX2MIX Input 2 Volume */
671         { 0x0000078C, 0x0000 },   /* R1932  - AIF3TX2MIX Input 3 Source */
672         { 0x0000078D, 0x0080 },   /* R1933  - AIF3TX2MIX Input 3 Volume */
673         { 0x0000078E, 0x0000 },   /* R1934  - AIF3TX2MIX Input 4 Source */
674         { 0x0000078F, 0x0080 },   /* R1935  - AIF3TX2MIX Input 4 Volume */
675         { 0x000007C0, 0x0000 },   /* R1984  - SLIMTX1MIX Input 1 Source */
676         { 0x000007C1, 0x0080 },   /* R1985  - SLIMTX1MIX Input 1 Volume */
677         { 0x000007C2, 0x0000 },   /* R1986  - SLIMTX1MIX Input 2 Source */
678         { 0x000007C3, 0x0080 },   /* R1987  - SLIMTX1MIX Input 2 Volume */
679         { 0x000007C4, 0x0000 },   /* R1988  - SLIMTX1MIX Input 3 Source */
680         { 0x000007C5, 0x0080 },   /* R1989  - SLIMTX1MIX Input 3 Volume */
681         { 0x000007C6, 0x0000 },   /* R1990  - SLIMTX1MIX Input 4 Source */
682         { 0x000007C7, 0x0080 },   /* R1991  - SLIMTX1MIX Input 4 Volume */
683         { 0x000007C8, 0x0000 },   /* R1992  - SLIMTX2MIX Input 1 Source */
684         { 0x000007C9, 0x0080 },   /* R1993  - SLIMTX2MIX Input 1 Volume */
685         { 0x000007CA, 0x0000 },   /* R1994  - SLIMTX2MIX Input 2 Source */
686         { 0x000007CB, 0x0080 },   /* R1995  - SLIMTX2MIX Input 2 Volume */
687         { 0x000007CC, 0x0000 },   /* R1996  - SLIMTX2MIX Input 3 Source */
688         { 0x000007CD, 0x0080 },   /* R1997  - SLIMTX2MIX Input 3 Volume */
689         { 0x000007CE, 0x0000 },   /* R1998  - SLIMTX2MIX Input 4 Source */
690         { 0x000007CF, 0x0080 },   /* R1999  - SLIMTX2MIX Input 4 Volume */
691         { 0x000007D0, 0x0000 },   /* R2000  - SLIMTX3MIX Input 1 Source */
692         { 0x000007D1, 0x0080 },   /* R2001  - SLIMTX3MIX Input 1 Volume */
693         { 0x000007D2, 0x0000 },   /* R2002  - SLIMTX3MIX Input 2 Source */
694         { 0x000007D3, 0x0080 },   /* R2003  - SLIMTX3MIX Input 2 Volume */
695         { 0x000007D4, 0x0000 },   /* R2004  - SLIMTX3MIX Input 3 Source */
696         { 0x000007D5, 0x0080 },   /* R2005  - SLIMTX3MIX Input 3 Volume */
697         { 0x000007D6, 0x0000 },   /* R2006  - SLIMTX3MIX Input 4 Source */
698         { 0x000007D7, 0x0080 },   /* R2007  - SLIMTX3MIX Input 4 Volume */
699         { 0x000007D8, 0x0000 },   /* R2008  - SLIMTX4MIX Input 1 Source */
700         { 0x000007D9, 0x0080 },   /* R2009  - SLIMTX4MIX Input 1 Volume */
701         { 0x000007DA, 0x0000 },   /* R2010  - SLIMTX4MIX Input 2 Source */
702         { 0x000007DB, 0x0080 },   /* R2011  - SLIMTX4MIX Input 2 Volume */
703         { 0x000007DC, 0x0000 },   /* R2012  - SLIMTX4MIX Input 3 Source */
704         { 0x000007DD, 0x0080 },   /* R2013  - SLIMTX4MIX Input 3 Volume */
705         { 0x000007DE, 0x0000 },   /* R2014  - SLIMTX4MIX Input 4 Source */
706         { 0x000007DF, 0x0080 },   /* R2015  - SLIMTX4MIX Input 4 Volume */
707         { 0x000007E0, 0x0000 },   /* R2016  - SLIMTX5MIX Input 1 Source */
708         { 0x000007E1, 0x0080 },   /* R2017  - SLIMTX5MIX Input 1 Volume */
709         { 0x000007E2, 0x0000 },   /* R2018  - SLIMTX5MIX Input 2 Source */
710         { 0x000007E3, 0x0080 },   /* R2019  - SLIMTX5MIX Input 2 Volume */
711         { 0x000007E4, 0x0000 },   /* R2020  - SLIMTX5MIX Input 3 Source */
712         { 0x000007E5, 0x0080 },   /* R2021  - SLIMTX5MIX Input 3 Volume */
713         { 0x000007E6, 0x0000 },   /* R2022  - SLIMTX5MIX Input 4 Source */
714         { 0x000007E7, 0x0080 },   /* R2023  - SLIMTX5MIX Input 4 Volume */
715         { 0x000007E8, 0x0000 },   /* R2024  - SLIMTX6MIX Input 1 Source */
716         { 0x000007E9, 0x0080 },   /* R2025  - SLIMTX6MIX Input 1 Volume */
717         { 0x000007EA, 0x0000 },   /* R2026  - SLIMTX6MIX Input 2 Source */
718         { 0x000007EB, 0x0080 },   /* R2027  - SLIMTX6MIX Input 2 Volume */
719         { 0x000007EC, 0x0000 },   /* R2028  - SLIMTX6MIX Input 3 Source */
720         { 0x000007ED, 0x0080 },   /* R2029  - SLIMTX6MIX Input 3 Volume */
721         { 0x000007EE, 0x0000 },   /* R2030  - SLIMTX6MIX Input 4 Source */
722         { 0x000007EF, 0x0080 },   /* R2031  - SLIMTX6MIX Input 4 Volume */
723         { 0x000007F0, 0x0000 },   /* R2032  - SLIMTX7MIX Input 1 Source */
724         { 0x000007F1, 0x0080 },   /* R2033  - SLIMTX7MIX Input 1 Volume */
725         { 0x000007F2, 0x0000 },   /* R2034  - SLIMTX7MIX Input 2 Source */
726         { 0x000007F3, 0x0080 },   /* R2035  - SLIMTX7MIX Input 2 Volume */
727         { 0x000007F4, 0x0000 },   /* R2036  - SLIMTX7MIX Input 3 Source */
728         { 0x000007F5, 0x0080 },   /* R2037  - SLIMTX7MIX Input 3 Volume */
729         { 0x000007F6, 0x0000 },   /* R2038  - SLIMTX7MIX Input 4 Source */
730         { 0x000007F7, 0x0080 },   /* R2039  - SLIMTX7MIX Input 4 Volume */
731         { 0x000007F8, 0x0000 },   /* R2040  - SLIMTX8MIX Input 1 Source */
732         { 0x000007F9, 0x0080 },   /* R2041  - SLIMTX8MIX Input 1 Volume */
733         { 0x000007FA, 0x0000 },   /* R2042  - SLIMTX8MIX Input 2 Source */
734         { 0x000007FB, 0x0080 },   /* R2043  - SLIMTX8MIX Input 2 Volume */
735         { 0x000007FC, 0x0000 },   /* R2044  - SLIMTX8MIX Input 3 Source */
736         { 0x000007FD, 0x0080 },   /* R2045  - SLIMTX8MIX Input 3 Volume */
737         { 0x000007FE, 0x0000 },   /* R2046  - SLIMTX8MIX Input 4 Source */
738         { 0x000007FF, 0x0080 },   /* R2047  - SLIMTX8MIX Input 4 Volume */
739         { 0x00000880, 0x0000 },   /* R2176  - EQ1MIX Input 1 Source */
740         { 0x00000881, 0x0080 },   /* R2177  - EQ1MIX Input 1 Volume */
741         { 0x00000882, 0x0000 },   /* R2178  - EQ1MIX Input 2 Source */
742         { 0x00000883, 0x0080 },   /* R2179  - EQ1MIX Input 2 Volume */
743         { 0x00000884, 0x0000 },   /* R2180  - EQ1MIX Input 3 Source */
744         { 0x00000885, 0x0080 },   /* R2181  - EQ1MIX Input 3 Volume */
745         { 0x00000886, 0x0000 },   /* R2182  - EQ1MIX Input 4 Source */
746         { 0x00000887, 0x0080 },   /* R2183  - EQ1MIX Input 4 Volume */
747         { 0x00000888, 0x0000 },   /* R2184  - EQ2MIX Input 1 Source */
748         { 0x00000889, 0x0080 },   /* R2185  - EQ2MIX Input 1 Volume */
749         { 0x0000088A, 0x0000 },   /* R2186  - EQ2MIX Input 2 Source */
750         { 0x0000088B, 0x0080 },   /* R2187  - EQ2MIX Input 2 Volume */
751         { 0x0000088C, 0x0000 },   /* R2188  - EQ2MIX Input 3 Source */
752         { 0x0000088D, 0x0080 },   /* R2189  - EQ2MIX Input 3 Volume */
753         { 0x0000088E, 0x0000 },   /* R2190  - EQ2MIX Input 4 Source */
754         { 0x0000088F, 0x0080 },   /* R2191  - EQ2MIX Input 4 Volume */
755         { 0x00000890, 0x0000 },   /* R2192  - EQ3MIX Input 1 Source */
756         { 0x00000891, 0x0080 },   /* R2193  - EQ3MIX Input 1 Volume */
757         { 0x00000892, 0x0000 },   /* R2194  - EQ3MIX Input 2 Source */
758         { 0x00000893, 0x0080 },   /* R2195  - EQ3MIX Input 2 Volume */
759         { 0x00000894, 0x0000 },   /* R2196  - EQ3MIX Input 3 Source */
760         { 0x00000895, 0x0080 },   /* R2197  - EQ3MIX Input 3 Volume */
761         { 0x00000896, 0x0000 },   /* R2198  - EQ3MIX Input 4 Source */
762         { 0x00000897, 0x0080 },   /* R2199  - EQ3MIX Input 4 Volume */
763         { 0x00000898, 0x0000 },   /* R2200  - EQ4MIX Input 1 Source */
764         { 0x00000899, 0x0080 },   /* R2201  - EQ4MIX Input 1 Volume */
765         { 0x0000089A, 0x0000 },   /* R2202  - EQ4MIX Input 2 Source */
766         { 0x0000089B, 0x0080 },   /* R2203  - EQ4MIX Input 2 Volume */
767         { 0x0000089C, 0x0000 },   /* R2204  - EQ4MIX Input 3 Source */
768         { 0x0000089D, 0x0080 },   /* R2205  - EQ4MIX Input 3 Volume */
769         { 0x0000089E, 0x0000 },   /* R2206  - EQ4MIX Input 4 Source */
770         { 0x0000089F, 0x0080 },   /* R2207  - EQ4MIX Input 4 Volume */
771         { 0x000008C0, 0x0000 },   /* R2240  - DRC1LMIX Input 1 Source */
772         { 0x000008C1, 0x0080 },   /* R2241  - DRC1LMIX Input 1 Volume */
773         { 0x000008C2, 0x0000 },   /* R2242  - DRC1LMIX Input 2 Source */
774         { 0x000008C3, 0x0080 },   /* R2243  - DRC1LMIX Input 2 Volume */
775         { 0x000008C4, 0x0000 },   /* R2244  - DRC1LMIX Input 3 Source */
776         { 0x000008C5, 0x0080 },   /* R2245  - DRC1LMIX Input 3 Volume */
777         { 0x000008C6, 0x0000 },   /* R2246  - DRC1LMIX Input 4 Source */
778         { 0x000008C7, 0x0080 },   /* R2247  - DRC1LMIX Input 4 Volume */
779         { 0x000008C8, 0x0000 },   /* R2248  - DRC1RMIX Input 1 Source */
780         { 0x000008C9, 0x0080 },   /* R2249  - DRC1RMIX Input 1 Volume */
781         { 0x000008CA, 0x0000 },   /* R2250  - DRC1RMIX Input 2 Source */
782         { 0x000008CB, 0x0080 },   /* R2251  - DRC1RMIX Input 2 Volume */
783         { 0x000008CC, 0x0000 },   /* R2252  - DRC1RMIX Input 3 Source */
784         { 0x000008CD, 0x0080 },   /* R2253  - DRC1RMIX Input 3 Volume */
785         { 0x000008CE, 0x0000 },   /* R2254  - DRC1RMIX Input 4 Source */
786         { 0x000008CF, 0x0080 },   /* R2255  - DRC1RMIX Input 4 Volume */
787         { 0x00000900, 0x0000 },   /* R2304  - HPLP1MIX Input 1 Source */
788         { 0x00000901, 0x0080 },   /* R2305  - HPLP1MIX Input 1 Volume */
789         { 0x00000902, 0x0000 },   /* R2306  - HPLP1MIX Input 2 Source */
790         { 0x00000903, 0x0080 },   /* R2307  - HPLP1MIX Input 2 Volume */
791         { 0x00000904, 0x0000 },   /* R2308  - HPLP1MIX Input 3 Source */
792         { 0x00000905, 0x0080 },   /* R2309  - HPLP1MIX Input 3 Volume */
793         { 0x00000906, 0x0000 },   /* R2310  - HPLP1MIX Input 4 Source */
794         { 0x00000907, 0x0080 },   /* R2311  - HPLP1MIX Input 4 Volume */
795         { 0x00000908, 0x0000 },   /* R2312  - HPLP2MIX Input 1 Source */
796         { 0x00000909, 0x0080 },   /* R2313  - HPLP2MIX Input 1 Volume */
797         { 0x0000090A, 0x0000 },   /* R2314  - HPLP2MIX Input 2 Source */
798         { 0x0000090B, 0x0080 },   /* R2315  - HPLP2MIX Input 2 Volume */
799         { 0x0000090C, 0x0000 },   /* R2316  - HPLP2MIX Input 3 Source */
800         { 0x0000090D, 0x0080 },   /* R2317  - HPLP2MIX Input 3 Volume */
801         { 0x0000090E, 0x0000 },   /* R2318  - HPLP2MIX Input 4 Source */
802         { 0x0000090F, 0x0080 },   /* R2319  - HPLP2MIX Input 4 Volume */
803         { 0x00000910, 0x0000 },   /* R2320  - HPLP3MIX Input 1 Source */
804         { 0x00000911, 0x0080 },   /* R2321  - HPLP3MIX Input 1 Volume */
805         { 0x00000912, 0x0000 },   /* R2322  - HPLP3MIX Input 2 Source */
806         { 0x00000913, 0x0080 },   /* R2323  - HPLP3MIX Input 2 Volume */
807         { 0x00000914, 0x0000 },   /* R2324  - HPLP3MIX Input 3 Source */
808         { 0x00000915, 0x0080 },   /* R2325  - HPLP3MIX Input 3 Volume */
809         { 0x00000916, 0x0000 },   /* R2326  - HPLP3MIX Input 4 Source */
810         { 0x00000917, 0x0080 },   /* R2327  - HPLP3MIX Input 4 Volume */
811         { 0x00000918, 0x0000 },   /* R2328  - HPLP4MIX Input 1 Source */
812         { 0x00000919, 0x0080 },   /* R2329  - HPLP4MIX Input 1 Volume */
813         { 0x0000091A, 0x0000 },   /* R2330  - HPLP4MIX Input 2 Source */
814         { 0x0000091B, 0x0080 },   /* R2331  - HPLP4MIX Input 2 Volume */
815         { 0x0000091C, 0x0000 },   /* R2332  - HPLP4MIX Input 3 Source */
816         { 0x0000091D, 0x0080 },   /* R2333  - HPLP4MIX Input 3 Volume */
817         { 0x0000091E, 0x0000 },   /* R2334  - HPLP4MIX Input 4 Source */
818         { 0x0000091F, 0x0080 },   /* R2335  - HPLP4MIX Input 4 Volume */
819         { 0x00000940, 0x0000 },   /* R2368  - DSP1LMIX Input 1 Source */
820         { 0x00000941, 0x0080 },   /* R2369  - DSP1LMIX Input 1 Volume */
821         { 0x00000942, 0x0000 },   /* R2370  - DSP1LMIX Input 2 Source */
822         { 0x00000943, 0x0080 },   /* R2371  - DSP1LMIX Input 2 Volume */
823         { 0x00000944, 0x0000 },   /* R2372  - DSP1LMIX Input 3 Source */
824         { 0x00000945, 0x0080 },   /* R2373  - DSP1LMIX Input 3 Volume */
825         { 0x00000946, 0x0000 },   /* R2374  - DSP1LMIX Input 4 Source */
826         { 0x00000947, 0x0080 },   /* R2375  - DSP1LMIX Input 4 Volume */
827         { 0x00000948, 0x0000 },   /* R2376  - DSP1RMIX Input 1 Source */
828         { 0x00000949, 0x0080 },   /* R2377  - DSP1RMIX Input 1 Volume */
829         { 0x0000094A, 0x0000 },   /* R2378  - DSP1RMIX Input 2 Source */
830         { 0x0000094B, 0x0080 },   /* R2379  - DSP1RMIX Input 2 Volume */
831         { 0x0000094C, 0x0000 },   /* R2380  - DSP1RMIX Input 3 Source */
832         { 0x0000094D, 0x0080 },   /* R2381  - DSP1RMIX Input 3 Volume */
833         { 0x0000094E, 0x0000 },   /* R2382  - DSP1RMIX Input 4 Source */
834         { 0x0000094F, 0x0080 },   /* R2383  - DSP1RMIX Input 4 Volume */
835         { 0x00000950, 0x0000 },   /* R2384  - DSP1AUX1MIX Input 1 Source */
836         { 0x00000958, 0x0000 },   /* R2392  - DSP1AUX2MIX Input 1 Source */
837         { 0x00000960, 0x0000 },   /* R2400  - DSP1AUX3MIX Input 1 Source */
838         { 0x00000968, 0x0000 },   /* R2408  - DSP1AUX4MIX Input 1 Source */
839         { 0x00000970, 0x0000 },   /* R2416  - DSP1AUX5MIX Input 1 Source */
840         { 0x00000978, 0x0000 },   /* R2424  - DSP1AUX6MIX Input 1 Source */
841         { 0x00000A80, 0x0000 },   /* R2688  - ASRC1LMIX Input 1 Source */
842         { 0x00000A88, 0x0000 },   /* R2696  - ASRC1RMIX Input 1 Source */
843         { 0x00000A90, 0x0000 },   /* R2704  - ASRC2LMIX Input 1 Source */
844         { 0x00000A98, 0x0000 },   /* R2712  - ASRC2RMIX Input 1 Source */
845         { 0x00000B00, 0x0000 },   /* R2816  - ISRC1DEC1MIX Input 1 Source */
846         { 0x00000B08, 0x0000 },   /* R2824  - ISRC1DEC2MIX Input 1 Source */
847         { 0x00000B20, 0x0000 },   /* R2848  - ISRC1INT1MIX Input 1 Source */
848         { 0x00000B28, 0x0000 },   /* R2856  - ISRC1INT2MIX Input 1 Source */
849         { 0x00000B40, 0x0000 },   /* R2880  - ISRC2DEC1MIX Input 1 Source */
850         { 0x00000B48, 0x0000 },   /* R2888  - ISRC2DEC2MIX Input 1 Source */
851         { 0x00000B60, 0x0000 },   /* R2912  - ISRC2INT1MIX Input 1 Source */
852         { 0x00000B68, 0x0000 },   /* R2920  - ISRC2INT2MIX Input 1 Source */
853         { 0x00000C00, 0xA101 },   /* R3072  - GPIO1 CTRL */
854         { 0x00000C01, 0xA101 },   /* R3073  - GPIO2 CTRL */
855         { 0x00000C02, 0xA101 },   /* R3074  - GPIO3 CTRL */
856         { 0x00000C03, 0xA101 },   /* R3075  - GPIO4 CTRL */
857         { 0x00000C04, 0xA101 },   /* R3076  - GPIO5 CTRL */
858         { 0x00000C0F, 0x0400 },   /* R3087  - IRQ CTRL 1 */
859         { 0x00000C10, 0x1000 },   /* R3088  - GPIO Debounce Config */
860         { 0x00000C20, 0x8002 },   /* R3104  - Misc Pad Ctrl 1 */
861         { 0x00000C21, 0x0001 },   /* R3105  - Misc Pad Ctrl 2 */
862         { 0x00000C22, 0x0000 },   /* R3106  - Misc Pad Ctrl 3 */
863         { 0x00000C23, 0x0000 },   /* R3107  - Misc Pad Ctrl 4 */
864         { 0x00000C24, 0x0000 },   /* R3108  - Misc Pad Ctrl 5 */
865         { 0x00000C25, 0x0000 },   /* R3109  - Misc Pad Ctrl 6 */
866         { 0x00000D08, 0xFFFF },   /* R3336  - Interrupt Status 1 Mask */
867         { 0x00000D09, 0xFFFF },   /* R3337  - Interrupt Status 2 Mask */
868         { 0x00000D0A, 0xFFFF },   /* R3338  - Interrupt Status 3 Mask */
869         { 0x00000D0B, 0xFFFF },   /* R3339  - Interrupt Status 4 Mask */
870         { 0x00000D0C, 0xFEFF },   /* R3340  - Interrupt Status 5 Mask */
871         { 0x00000D0F, 0x0000 },   /* R3343  - Interrupt Control */
872         { 0x00000D18, 0xFFFF },   /* R3352  - IRQ2 Status 1 Mask */
873         { 0x00000D19, 0xFFFF },   /* R3353  - IRQ2 Status 2 Mask */
874         { 0x00000D1A, 0xFFFF },   /* R3354  - IRQ2 Status 3 Mask */
875         { 0x00000D1B, 0xFFFF },   /* R3355  - IRQ2 Status 4 Mask */
876         { 0x00000D1C, 0xFFFF },   /* R3356  - IRQ2 Status 5 Mask */
877         { 0x00000D1F, 0x0000 },   /* R3359  - IRQ2 Control */
878         { 0x00000D41, 0x0000 },   /* R3393  - ADSP2 IRQ0 */
879         { 0x00000D53, 0xFFFF },   /* R3411  - AOD IRQ Mask IRQ1 */
880         { 0x00000D54, 0xFFFF },   /* R3412  - AOD IRQ Mask IRQ2 */
881         { 0x00000D56, 0x0000 },   /* R3414  - Jack detect debounce */
882         { 0x00000E00, 0x0000 },   /* R3584  - FX_Ctrl1 */
883         { 0x00000E10, 0x6318 },   /* R3600  - EQ1_1 */
884         { 0x00000E11, 0x6300 },   /* R3601  - EQ1_2 */
885         { 0x00000E12, 0x0FC8 },   /* R3602  - EQ1_3 */
886         { 0x00000E13, 0x03FE },   /* R3603  - EQ1_4 */
887         { 0x00000E14, 0x00E0 },   /* R3604  - EQ1_5 */
888         { 0x00000E15, 0x1EC4 },   /* R3605  - EQ1_6 */
889         { 0x00000E16, 0xF136 },   /* R3606  - EQ1_7 */
890         { 0x00000E17, 0x0409 },   /* R3607  - EQ1_8 */
891         { 0x00000E18, 0x04CC },   /* R3608  - EQ1_9 */
892         { 0x00000E19, 0x1C9B },   /* R3609  - EQ1_10 */
893         { 0x00000E1A, 0xF337 },   /* R3610  - EQ1_11 */
894         { 0x00000E1B, 0x040B },   /* R3611  - EQ1_12 */
895         { 0x00000E1C, 0x0CBB },   /* R3612  - EQ1_13 */
896         { 0x00000E1D, 0x16F8 },   /* R3613  - EQ1_14 */
897         { 0x00000E1E, 0xF7D9 },   /* R3614  - EQ1_15 */
898         { 0x00000E1F, 0x040A },   /* R3615  - EQ1_16 */
899         { 0x00000E20, 0x1F14 },   /* R3616  - EQ1_17 */
900         { 0x00000E21, 0x058C },   /* R3617  - EQ1_18 */
901         { 0x00000E22, 0x0563 },   /* R3618  - EQ1_19 */
902         { 0x00000E23, 0x4000 },   /* R3619  - EQ1_20 */
903         { 0x00000E24, 0x0B75 },   /* R3620  - EQ1_21 */
904         { 0x00000E26, 0x6318 },   /* R3622  - EQ2_1 */
905         { 0x00000E27, 0x6300 },   /* R3623  - EQ2_2 */
906         { 0x00000E28, 0x0FC8 },   /* R3624  - EQ2_3 */
907         { 0x00000E29, 0x03FE },   /* R3625  - EQ2_4 */
908         { 0x00000E2A, 0x00E0 },   /* R3626  - EQ2_5 */
909         { 0x00000E2B, 0x1EC4 },   /* R3627  - EQ2_6 */
910         { 0x00000E2C, 0xF136 },   /* R3628  - EQ2_7 */
911         { 0x00000E2D, 0x0409 },   /* R3629  - EQ2_8 */
912         { 0x00000E2E, 0x04CC },   /* R3630  - EQ2_9 */
913         { 0x00000E2F, 0x1C9B },   /* R3631  - EQ2_10 */
914         { 0x00000E30, 0xF337 },   /* R3632  - EQ2_11 */
915         { 0x00000E31, 0x040B },   /* R3633  - EQ2_12 */
916         { 0x00000E32, 0x0CBB },   /* R3634  - EQ2_13 */
917         { 0x00000E33, 0x16F8 },   /* R3635  - EQ2_14 */
918         { 0x00000E34, 0xF7D9 },   /* R3636  - EQ2_15 */
919         { 0x00000E35, 0x040A },   /* R3637  - EQ2_16 */
920         { 0x00000E36, 0x1F14 },   /* R3638  - EQ2_17 */
921         { 0x00000E37, 0x058C },   /* R3639  - EQ2_18 */
922         { 0x00000E38, 0x0563 },   /* R3640  - EQ2_19 */
923         { 0x00000E39, 0x4000 },   /* R3641  - EQ2_20 */
924         { 0x00000E3A, 0x0B75 },   /* R3642  - EQ2_21 */
925         { 0x00000E3C, 0x6318 },   /* R3644  - EQ3_1 */
926         { 0x00000E3D, 0x6300 },   /* R3645  - EQ3_2 */
927         { 0x00000E3E, 0x0FC8 },   /* R3646  - EQ3_3 */
928         { 0x00000E3F, 0x03FE },   /* R3647  - EQ3_4 */
929         { 0x00000E40, 0x00E0 },   /* R3648  - EQ3_5 */
930         { 0x00000E41, 0x1EC4 },   /* R3649  - EQ3_6 */
931         { 0x00000E42, 0xF136 },   /* R3650  - EQ3_7 */
932         { 0x00000E43, 0x0409 },   /* R3651  - EQ3_8 */
933         { 0x00000E44, 0x04CC },   /* R3652  - EQ3_9 */
934         { 0x00000E45, 0x1C9B },   /* R3653  - EQ3_10 */
935         { 0x00000E46, 0xF337 },   /* R3654  - EQ3_11 */
936         { 0x00000E47, 0x040B },   /* R3655  - EQ3_12 */
937         { 0x00000E48, 0x0CBB },   /* R3656  - EQ3_13 */
938         { 0x00000E49, 0x16F8 },   /* R3657  - EQ3_14 */
939         { 0x00000E4A, 0xF7D9 },   /* R3658  - EQ3_15 */
940         { 0x00000E4B, 0x040A },   /* R3659  - EQ3_16 */
941         { 0x00000E4C, 0x1F14 },   /* R3660  - EQ3_17 */
942         { 0x00000E4D, 0x058C },   /* R3661  - EQ3_18 */
943         { 0x00000E4E, 0x0563 },   /* R3662  - EQ3_19 */
944         { 0x00000E4F, 0x4000 },   /* R3663  - EQ3_20 */
945         { 0x00000E50, 0x0B75 },   /* R3664  - EQ3_21 */
946         { 0x00000E52, 0x6318 },   /* R3666  - EQ4_1 */
947         { 0x00000E53, 0x6300 },   /* R3667  - EQ4_2 */
948         { 0x00000E54, 0x0FC8 },   /* R3668  - EQ4_3 */
949         { 0x00000E55, 0x03FE },   /* R3669  - EQ4_4 */
950         { 0x00000E56, 0x00E0 },   /* R3670  - EQ4_5 */
951         { 0x00000E57, 0x1EC4 },   /* R3671  - EQ4_6 */
952         { 0x00000E58, 0xF136 },   /* R3672  - EQ4_7 */
953         { 0x00000E59, 0x0409 },   /* R3673  - EQ4_8 */
954         { 0x00000E5A, 0x04CC },   /* R3674  - EQ4_9 */
955         { 0x00000E5B, 0x1C9B },   /* R3675  - EQ4_10 */
956         { 0x00000E5C, 0xF337 },   /* R3676  - EQ4_11 */
957         { 0x00000E5D, 0x040B },   /* R3677  - EQ4_12 */
958         { 0x00000E5E, 0x0CBB },   /* R3678  - EQ4_13 */
959         { 0x00000E5F, 0x16F8 },   /* R3679  - EQ4_14 */
960         { 0x00000E60, 0xF7D9 },   /* R3680  - EQ4_15 */
961         { 0x00000E61, 0x040A },   /* R3681  - EQ4_16 */
962         { 0x00000E62, 0x1F14 },   /* R3682  - EQ4_17 */
963         { 0x00000E63, 0x058C },   /* R3683  - EQ4_18 */
964         { 0x00000E64, 0x0563 },   /* R3684  - EQ4_19 */
965         { 0x00000E65, 0x4000 },   /* R3685  - EQ4_20 */
966         { 0x00000E66, 0x0B75 },   /* R3686  - EQ4_21 */
967         { 0x00000E80, 0x0018 },   /* R3712  - DRC1 ctrl1 */
968         { 0x00000E81, 0x0933 },   /* R3713  - DRC1 ctrl2 */
969         { 0x00000E82, 0x0018 },   /* R3714  - DRC1 ctrl3 */
970         { 0x00000E83, 0x0000 },   /* R3715  - DRC1 ctrl4 */
971         { 0x00000E84, 0x0000 },   /* R3716  - DRC1 ctrl5 */
972         { 0x00000EC0, 0x0000 },   /* R3776  - HPLPF1_1 */
973         { 0x00000EC1, 0x0000 },   /* R3777  - HPLPF1_2 */
974         { 0x00000EC4, 0x0000 },   /* R3780  - HPLPF2_1 */
975         { 0x00000EC5, 0x0000 },   /* R3781  - HPLPF2_2 */
976         { 0x00000EC8, 0x0000 },   /* R3784  - HPLPF3_1 */
977         { 0x00000EC9, 0x0000 },   /* R3785  - HPLPF3_2 */
978         { 0x00000ECC, 0x0000 },   /* R3788  - HPLPF4_1 */
979         { 0x00000ECD, 0x0000 },   /* R3789  - HPLPF4_2 */
980         { 0x00000EE0, 0x0000 },   /* R3808  - ASRC_ENABLE */
981         { 0x00000EE2, 0x0000 },   /* R3810  - ASRC_RATE1 */
982         { 0x00000EE3, 0x4000 },   /* R3811  - ASRC_RATE2 */
983         { 0x00000EF0, 0x0000 },   /* R3824  - ISRC 1 CTRL 1 */
984         { 0x00000EF1, 0x0000 },   /* R3825  - ISRC 1 CTRL 2 */
985         { 0x00000EF2, 0x0000 },   /* R3826  - ISRC 1 CTRL 3 */
986         { 0x00000EF3, 0x0000 },   /* R3827  - ISRC 2 CTRL 1 */
987         { 0x00000EF4, 0x0000 },   /* R3828  - ISRC 2 CTRL 2 */
988         { 0x00000EF5, 0x0000 },   /* R3829  - ISRC 2 CTRL 3 */
989         { 0x00001100, 0x0010 },   /* R4352  - DSP1 Control 1 */
990 };
991
992 static bool wm5102_readable_register(struct device *dev, unsigned int reg)
993 {
994         switch (reg) {
995         case ARIZONA_SOFTWARE_RESET:
996         case ARIZONA_DEVICE_REVISION:
997         case ARIZONA_CTRL_IF_SPI_CFG_1:
998         case ARIZONA_CTRL_IF_I2C1_CFG_1:
999         case ARIZONA_WRITE_SEQUENCER_CTRL_0:
1000         case ARIZONA_WRITE_SEQUENCER_CTRL_1:
1001         case ARIZONA_WRITE_SEQUENCER_CTRL_2:
1002         case ARIZONA_WRITE_SEQUENCER_CTRL_3:
1003         case ARIZONA_TONE_GENERATOR_1:
1004         case ARIZONA_TONE_GENERATOR_2:
1005         case ARIZONA_TONE_GENERATOR_3:
1006         case ARIZONA_TONE_GENERATOR_4:
1007         case ARIZONA_TONE_GENERATOR_5:
1008         case ARIZONA_PWM_DRIVE_1:
1009         case ARIZONA_PWM_DRIVE_2:
1010         case ARIZONA_PWM_DRIVE_3:
1011         case ARIZONA_WAKE_CONTROL:
1012         case ARIZONA_SEQUENCE_CONTROL:
1013         case ARIZONA_SAMPLE_RATE_SEQUENCE_SELECT_1:
1014         case ARIZONA_SAMPLE_RATE_SEQUENCE_SELECT_2:
1015         case ARIZONA_SAMPLE_RATE_SEQUENCE_SELECT_3:
1016         case ARIZONA_SAMPLE_RATE_SEQUENCE_SELECT_4:
1017         case ARIZONA_ALWAYS_ON_TRIGGERS_SEQUENCE_SELECT_1:
1018         case ARIZONA_ALWAYS_ON_TRIGGERS_SEQUENCE_SELECT_2:
1019         case ARIZONA_ALWAYS_ON_TRIGGERS_SEQUENCE_SELECT_3:
1020         case ARIZONA_ALWAYS_ON_TRIGGERS_SEQUENCE_SELECT_4:
1021         case ARIZONA_ALWAYS_ON_TRIGGERS_SEQUENCE_SELECT_5:
1022         case ARIZONA_ALWAYS_ON_TRIGGERS_SEQUENCE_SELECT_6:
1023         case ARIZONA_COMFORT_NOISE_GENERATOR:
1024         case ARIZONA_HAPTICS_CONTROL_1:
1025         case ARIZONA_HAPTICS_CONTROL_2:
1026         case ARIZONA_HAPTICS_PHASE_1_INTENSITY:
1027         case ARIZONA_HAPTICS_PHASE_1_DURATION:
1028         case ARIZONA_HAPTICS_PHASE_2_INTENSITY:
1029         case ARIZONA_HAPTICS_PHASE_2_DURATION:
1030         case ARIZONA_HAPTICS_PHASE_3_INTENSITY:
1031         case ARIZONA_HAPTICS_PHASE_3_DURATION:
1032         case ARIZONA_HAPTICS_STATUS:
1033         case ARIZONA_CLOCK_32K_1:
1034         case ARIZONA_SYSTEM_CLOCK_1:
1035         case ARIZONA_SAMPLE_RATE_1:
1036         case ARIZONA_SAMPLE_RATE_2:
1037         case ARIZONA_SAMPLE_RATE_3:
1038         case ARIZONA_SAMPLE_RATE_1_STATUS:
1039         case ARIZONA_SAMPLE_RATE_2_STATUS:
1040         case ARIZONA_SAMPLE_RATE_3_STATUS:
1041         case ARIZONA_ASYNC_CLOCK_1:
1042         case ARIZONA_ASYNC_SAMPLE_RATE_1:
1043         case ARIZONA_ASYNC_SAMPLE_RATE_1_STATUS:
1044         case ARIZONA_ASYNC_SAMPLE_RATE_2:
1045         case ARIZONA_ASYNC_SAMPLE_RATE_2_STATUS:
1046         case ARIZONA_OUTPUT_SYSTEM_CLOCK:
1047         case ARIZONA_OUTPUT_ASYNC_CLOCK:
1048         case ARIZONA_RATE_ESTIMATOR_1:
1049         case ARIZONA_RATE_ESTIMATOR_2:
1050         case ARIZONA_RATE_ESTIMATOR_3:
1051         case ARIZONA_RATE_ESTIMATOR_4:
1052         case ARIZONA_RATE_ESTIMATOR_5:
1053         case ARIZONA_DYNAMIC_FREQUENCY_SCALING_1:
1054         case ARIZONA_FLL1_CONTROL_1:
1055         case ARIZONA_FLL1_CONTROL_2:
1056         case ARIZONA_FLL1_CONTROL_3:
1057         case ARIZONA_FLL1_CONTROL_4:
1058         case ARIZONA_FLL1_CONTROL_5:
1059         case ARIZONA_FLL1_CONTROL_6:
1060         case ARIZONA_FLL1_CONTROL_7:
1061         case ARIZONA_FLL1_SYNCHRONISER_1:
1062         case ARIZONA_FLL1_SYNCHRONISER_2:
1063         case ARIZONA_FLL1_SYNCHRONISER_3:
1064         case ARIZONA_FLL1_SYNCHRONISER_4:
1065         case ARIZONA_FLL1_SYNCHRONISER_5:
1066         case ARIZONA_FLL1_SYNCHRONISER_6:
1067         case ARIZONA_FLL1_SYNCHRONISER_7:
1068         case ARIZONA_FLL1_SPREAD_SPECTRUM:
1069         case ARIZONA_FLL1_GPIO_CLOCK:
1070         case ARIZONA_FLL2_CONTROL_1:
1071         case ARIZONA_FLL2_CONTROL_2:
1072         case ARIZONA_FLL2_CONTROL_3:
1073         case ARIZONA_FLL2_CONTROL_4:
1074         case ARIZONA_FLL2_CONTROL_5:
1075         case ARIZONA_FLL2_CONTROL_6:
1076         case ARIZONA_FLL2_CONTROL_7:
1077         case ARIZONA_FLL2_SYNCHRONISER_1:
1078         case ARIZONA_FLL2_SYNCHRONISER_2:
1079         case ARIZONA_FLL2_SYNCHRONISER_3:
1080         case ARIZONA_FLL2_SYNCHRONISER_4:
1081         case ARIZONA_FLL2_SYNCHRONISER_5:
1082         case ARIZONA_FLL2_SYNCHRONISER_6:
1083         case ARIZONA_FLL2_SYNCHRONISER_7:
1084         case ARIZONA_FLL2_SPREAD_SPECTRUM:
1085         case ARIZONA_FLL2_GPIO_CLOCK:
1086         case ARIZONA_MIC_CHARGE_PUMP_1:
1087         case ARIZONA_LDO1_CONTROL_1:
1088         case ARIZONA_LDO1_CONTROL_2:
1089         case ARIZONA_LDO2_CONTROL_1:
1090         case ARIZONA_MIC_BIAS_CTRL_1:
1091         case ARIZONA_MIC_BIAS_CTRL_2:
1092         case ARIZONA_MIC_BIAS_CTRL_3:
1093         case ARIZONA_HP_CTRL_1L:
1094         case ARIZONA_HP_CTRL_1R:
1095         case ARIZONA_ACCESSORY_DETECT_MODE_1:
1096         case ARIZONA_HEADPHONE_DETECT_1:
1097         case ARIZONA_HEADPHONE_DETECT_2:
1098         case ARIZONA_HP_DACVAL:
1099         case ARIZONA_MICD_CLAMP_CONTROL:
1100         case ARIZONA_MIC_DETECT_1:
1101         case ARIZONA_MIC_DETECT_2:
1102         case ARIZONA_MIC_DETECT_3:
1103         case ARIZONA_MIC_DETECT_LEVEL_1:
1104         case ARIZONA_MIC_DETECT_LEVEL_2:
1105         case ARIZONA_MIC_DETECT_LEVEL_3:
1106         case ARIZONA_MIC_DETECT_LEVEL_4:
1107         case ARIZONA_MIC_NOISE_MIX_CONTROL_1:
1108         case ARIZONA_ISOLATION_CONTROL:
1109         case ARIZONA_JACK_DETECT_ANALOGUE:
1110         case ARIZONA_INPUT_ENABLES:
1111         case ARIZONA_INPUT_RATE:
1112         case ARIZONA_INPUT_VOLUME_RAMP:
1113         case ARIZONA_IN1L_CONTROL:
1114         case ARIZONA_ADC_DIGITAL_VOLUME_1L:
1115         case ARIZONA_DMIC1L_CONTROL:
1116         case ARIZONA_IN1R_CONTROL:
1117         case ARIZONA_ADC_DIGITAL_VOLUME_1R:
1118         case ARIZONA_DMIC1R_CONTROL:
1119         case ARIZONA_IN2L_CONTROL:
1120         case ARIZONA_ADC_DIGITAL_VOLUME_2L:
1121         case ARIZONA_DMIC2L_CONTROL:
1122         case ARIZONA_IN2R_CONTROL:
1123         case ARIZONA_ADC_DIGITAL_VOLUME_2R:
1124         case ARIZONA_DMIC2R_CONTROL:
1125         case ARIZONA_IN3L_CONTROL:
1126         case ARIZONA_ADC_DIGITAL_VOLUME_3L:
1127         case ARIZONA_DMIC3L_CONTROL:
1128         case ARIZONA_IN3R_CONTROL:
1129         case ARIZONA_ADC_DIGITAL_VOLUME_3R:
1130         case ARIZONA_DMIC3R_CONTROL:
1131         case ARIZONA_OUTPUT_ENABLES_1:
1132         case ARIZONA_OUTPUT_STATUS_1:
1133         case ARIZONA_OUTPUT_RATE_1:
1134         case ARIZONA_OUTPUT_VOLUME_RAMP:
1135         case ARIZONA_OUTPUT_PATH_CONFIG_1L:
1136         case ARIZONA_DAC_DIGITAL_VOLUME_1L:
1137         case ARIZONA_DAC_VOLUME_LIMIT_1L:
1138         case ARIZONA_NOISE_GATE_SELECT_1L:
1139         case ARIZONA_OUTPUT_PATH_CONFIG_1R:
1140         case ARIZONA_DAC_DIGITAL_VOLUME_1R:
1141         case ARIZONA_DAC_VOLUME_LIMIT_1R:
1142         case ARIZONA_NOISE_GATE_SELECT_1R:
1143         case ARIZONA_OUTPUT_PATH_CONFIG_2L:
1144         case ARIZONA_DAC_DIGITAL_VOLUME_2L:
1145         case ARIZONA_DAC_VOLUME_LIMIT_2L:
1146         case ARIZONA_NOISE_GATE_SELECT_2L:
1147         case ARIZONA_OUTPUT_PATH_CONFIG_2R:
1148         case ARIZONA_DAC_DIGITAL_VOLUME_2R:
1149         case ARIZONA_DAC_VOLUME_LIMIT_2R:
1150         case ARIZONA_NOISE_GATE_SELECT_2R:
1151         case ARIZONA_OUTPUT_PATH_CONFIG_3L:
1152         case ARIZONA_DAC_DIGITAL_VOLUME_3L:
1153         case ARIZONA_DAC_VOLUME_LIMIT_3L:
1154         case ARIZONA_NOISE_GATE_SELECT_3L:
1155         case ARIZONA_OUTPUT_PATH_CONFIG_4L:
1156         case ARIZONA_DAC_DIGITAL_VOLUME_4L:
1157         case ARIZONA_OUT_VOLUME_4L:
1158         case ARIZONA_NOISE_GATE_SELECT_4L:
1159         case ARIZONA_DAC_DIGITAL_VOLUME_4R:
1160         case ARIZONA_OUT_VOLUME_4R:
1161         case ARIZONA_NOISE_GATE_SELECT_4R:
1162         case ARIZONA_OUTPUT_PATH_CONFIG_5L:
1163         case ARIZONA_DAC_DIGITAL_VOLUME_5L:
1164         case ARIZONA_DAC_VOLUME_LIMIT_5L:
1165         case ARIZONA_NOISE_GATE_SELECT_5L:
1166         case ARIZONA_DAC_DIGITAL_VOLUME_5R:
1167         case ARIZONA_DAC_VOLUME_LIMIT_5R:
1168         case ARIZONA_NOISE_GATE_SELECT_5R:
1169         case ARIZONA_DRE_ENABLE:
1170         case ARIZONA_DRE_CONTROL_2:
1171         case ARIZONA_DRE_CONTROL_3:
1172         case ARIZONA_DAC_AEC_CONTROL_1:
1173         case ARIZONA_NOISE_GATE_CONTROL:
1174         case ARIZONA_PDM_SPK1_CTRL_1:
1175         case ARIZONA_PDM_SPK1_CTRL_2:
1176         case ARIZONA_DAC_COMP_1:
1177         case ARIZONA_DAC_COMP_2:
1178         case ARIZONA_DAC_COMP_3:
1179         case ARIZONA_DAC_COMP_4:
1180         case ARIZONA_AIF1_BCLK_CTRL:
1181         case ARIZONA_AIF1_TX_PIN_CTRL:
1182         case ARIZONA_AIF1_RX_PIN_CTRL:
1183         case ARIZONA_AIF1_RATE_CTRL:
1184         case ARIZONA_AIF1_FORMAT:
1185         case ARIZONA_AIF1_TX_BCLK_RATE:
1186         case ARIZONA_AIF1_RX_BCLK_RATE:
1187         case ARIZONA_AIF1_FRAME_CTRL_1:
1188         case ARIZONA_AIF1_FRAME_CTRL_2:
1189         case ARIZONA_AIF1_FRAME_CTRL_3:
1190         case ARIZONA_AIF1_FRAME_CTRL_4:
1191         case ARIZONA_AIF1_FRAME_CTRL_5:
1192         case ARIZONA_AIF1_FRAME_CTRL_6:
1193         case ARIZONA_AIF1_FRAME_CTRL_7:
1194         case ARIZONA_AIF1_FRAME_CTRL_8:
1195         case ARIZONA_AIF1_FRAME_CTRL_9:
1196         case ARIZONA_AIF1_FRAME_CTRL_10:
1197         case ARIZONA_AIF1_FRAME_CTRL_11:
1198         case ARIZONA_AIF1_FRAME_CTRL_12:
1199         case ARIZONA_AIF1_FRAME_CTRL_13:
1200         case ARIZONA_AIF1_FRAME_CTRL_14:
1201         case ARIZONA_AIF1_FRAME_CTRL_15:
1202         case ARIZONA_AIF1_FRAME_CTRL_16:
1203         case ARIZONA_AIF1_FRAME_CTRL_17:
1204         case ARIZONA_AIF1_FRAME_CTRL_18:
1205         case ARIZONA_AIF1_TX_ENABLES:
1206         case ARIZONA_AIF1_RX_ENABLES:
1207         case ARIZONA_AIF2_BCLK_CTRL:
1208         case ARIZONA_AIF2_TX_PIN_CTRL:
1209         case ARIZONA_AIF2_RX_PIN_CTRL:
1210         case ARIZONA_AIF2_RATE_CTRL:
1211         case ARIZONA_AIF2_FORMAT:
1212         case ARIZONA_AIF2_TX_BCLK_RATE:
1213         case ARIZONA_AIF2_RX_BCLK_RATE:
1214         case ARIZONA_AIF2_FRAME_CTRL_1:
1215         case ARIZONA_AIF2_FRAME_CTRL_2:
1216         case ARIZONA_AIF2_FRAME_CTRL_3:
1217         case ARIZONA_AIF2_FRAME_CTRL_4:
1218         case ARIZONA_AIF2_FRAME_CTRL_11:
1219         case ARIZONA_AIF2_FRAME_CTRL_12:
1220         case ARIZONA_AIF2_TX_ENABLES:
1221         case ARIZONA_AIF2_RX_ENABLES:
1222         case ARIZONA_AIF3_BCLK_CTRL:
1223         case ARIZONA_AIF3_TX_PIN_CTRL:
1224         case ARIZONA_AIF3_RX_PIN_CTRL:
1225         case ARIZONA_AIF3_RATE_CTRL:
1226         case ARIZONA_AIF3_FORMAT:
1227         case ARIZONA_AIF3_TX_BCLK_RATE:
1228         case ARIZONA_AIF3_RX_BCLK_RATE:
1229         case ARIZONA_AIF3_FRAME_CTRL_1:
1230         case ARIZONA_AIF3_FRAME_CTRL_2:
1231         case ARIZONA_AIF3_FRAME_CTRL_3:
1232         case ARIZONA_AIF3_FRAME_CTRL_4:
1233         case ARIZONA_AIF3_FRAME_CTRL_11:
1234         case ARIZONA_AIF3_FRAME_CTRL_12:
1235         case ARIZONA_AIF3_TX_ENABLES:
1236         case ARIZONA_AIF3_RX_ENABLES:
1237         case ARIZONA_SLIMBUS_FRAMER_REF_GEAR:
1238         case ARIZONA_SLIMBUS_RATES_1:
1239         case ARIZONA_SLIMBUS_RATES_2:
1240         case ARIZONA_SLIMBUS_RATES_3:
1241         case ARIZONA_SLIMBUS_RATES_4:
1242         case ARIZONA_SLIMBUS_RATES_5:
1243         case ARIZONA_SLIMBUS_RATES_6:
1244         case ARIZONA_SLIMBUS_RATES_7:
1245         case ARIZONA_SLIMBUS_RATES_8:
1246         case ARIZONA_SLIMBUS_RX_CHANNEL_ENABLE:
1247         case ARIZONA_SLIMBUS_TX_CHANNEL_ENABLE:
1248         case ARIZONA_SLIMBUS_RX_PORT_STATUS:
1249         case ARIZONA_SLIMBUS_TX_PORT_STATUS:
1250         case ARIZONA_PWM1MIX_INPUT_1_SOURCE:
1251         case ARIZONA_PWM1MIX_INPUT_1_VOLUME:
1252         case ARIZONA_PWM1MIX_INPUT_2_SOURCE:
1253         case ARIZONA_PWM1MIX_INPUT_2_VOLUME:
1254         case ARIZONA_PWM1MIX_INPUT_3_SOURCE:
1255         case ARIZONA_PWM1MIX_INPUT_3_VOLUME:
1256         case ARIZONA_PWM1MIX_INPUT_4_SOURCE:
1257         case ARIZONA_PWM1MIX_INPUT_4_VOLUME:
1258         case ARIZONA_PWM2MIX_INPUT_1_SOURCE:
1259         case ARIZONA_PWM2MIX_INPUT_1_VOLUME:
1260         case ARIZONA_PWM2MIX_INPUT_2_SOURCE:
1261         case ARIZONA_PWM2MIX_INPUT_2_VOLUME:
1262         case ARIZONA_PWM2MIX_INPUT_3_SOURCE:
1263         case ARIZONA_PWM2MIX_INPUT_3_VOLUME:
1264         case ARIZONA_PWM2MIX_INPUT_4_SOURCE:
1265         case ARIZONA_PWM2MIX_INPUT_4_VOLUME:
1266         case ARIZONA_MICMIX_INPUT_1_SOURCE:
1267         case ARIZONA_MICMIX_INPUT_1_VOLUME:
1268         case ARIZONA_MICMIX_INPUT_2_SOURCE:
1269         case ARIZONA_MICMIX_INPUT_2_VOLUME:
1270         case ARIZONA_MICMIX_INPUT_3_SOURCE:
1271         case ARIZONA_MICMIX_INPUT_3_VOLUME:
1272         case ARIZONA_MICMIX_INPUT_4_SOURCE:
1273         case ARIZONA_MICMIX_INPUT_4_VOLUME:
1274         case ARIZONA_NOISEMIX_INPUT_1_SOURCE:
1275         case ARIZONA_NOISEMIX_INPUT_1_VOLUME:
1276         case ARIZONA_NOISEMIX_INPUT_2_SOURCE:
1277         case ARIZONA_NOISEMIX_INPUT_2_VOLUME:
1278         case ARIZONA_NOISEMIX_INPUT_3_SOURCE:
1279         case ARIZONA_NOISEMIX_INPUT_3_VOLUME:
1280         case ARIZONA_NOISEMIX_INPUT_4_SOURCE:
1281         case ARIZONA_NOISEMIX_INPUT_4_VOLUME:
1282         case ARIZONA_OUT1LMIX_INPUT_1_SOURCE:
1283         case ARIZONA_OUT1LMIX_INPUT_1_VOLUME:
1284         case ARIZONA_OUT1LMIX_INPUT_2_SOURCE:
1285         case ARIZONA_OUT1LMIX_INPUT_2_VOLUME:
1286         case ARIZONA_OUT1LMIX_INPUT_3_SOURCE:
1287         case ARIZONA_OUT1LMIX_INPUT_3_VOLUME:
1288         case ARIZONA_OUT1LMIX_INPUT_4_SOURCE:
1289         case ARIZONA_OUT1LMIX_INPUT_4_VOLUME:
1290         case ARIZONA_OUT1RMIX_INPUT_1_SOURCE:
1291         case ARIZONA_OUT1RMIX_INPUT_1_VOLUME:
1292         case ARIZONA_OUT1RMIX_INPUT_2_SOURCE:
1293         case ARIZONA_OUT1RMIX_INPUT_2_VOLUME:
1294         case ARIZONA_OUT1RMIX_INPUT_3_SOURCE:
1295         case ARIZONA_OUT1RMIX_INPUT_3_VOLUME:
1296         case ARIZONA_OUT1RMIX_INPUT_4_SOURCE:
1297         case ARIZONA_OUT1RMIX_INPUT_4_VOLUME:
1298         case ARIZONA_OUT2LMIX_INPUT_1_SOURCE:
1299         case ARIZONA_OUT2LMIX_INPUT_1_VOLUME:
1300         case ARIZONA_OUT2LMIX_INPUT_2_SOURCE:
1301         case ARIZONA_OUT2LMIX_INPUT_2_VOLUME:
1302         case ARIZONA_OUT2LMIX_INPUT_3_SOURCE:
1303         case ARIZONA_OUT2LMIX_INPUT_3_VOLUME:
1304         case ARIZONA_OUT2LMIX_INPUT_4_SOURCE:
1305         case ARIZONA_OUT2LMIX_INPUT_4_VOLUME:
1306         case ARIZONA_OUT2RMIX_INPUT_1_SOURCE:
1307         case ARIZONA_OUT2RMIX_INPUT_1_VOLUME:
1308         case ARIZONA_OUT2RMIX_INPUT_2_SOURCE:
1309         case ARIZONA_OUT2RMIX_INPUT_2_VOLUME:
1310         case ARIZONA_OUT2RMIX_INPUT_3_SOURCE:
1311         case ARIZONA_OUT2RMIX_INPUT_3_VOLUME:
1312         case ARIZONA_OUT2RMIX_INPUT_4_SOURCE:
1313         case ARIZONA_OUT2RMIX_INPUT_4_VOLUME:
1314         case ARIZONA_OUT3LMIX_INPUT_1_SOURCE:
1315         case ARIZONA_OUT3LMIX_INPUT_1_VOLUME:
1316         case ARIZONA_OUT3LMIX_INPUT_2_SOURCE:
1317         case ARIZONA_OUT3LMIX_INPUT_2_VOLUME:
1318         case ARIZONA_OUT3LMIX_INPUT_3_SOURCE:
1319         case ARIZONA_OUT3LMIX_INPUT_3_VOLUME:
1320         case ARIZONA_OUT3LMIX_INPUT_4_SOURCE:
1321         case ARIZONA_OUT3LMIX_INPUT_4_VOLUME:
1322         case ARIZONA_OUT4LMIX_INPUT_1_SOURCE:
1323         case ARIZONA_OUT4LMIX_INPUT_1_VOLUME:
1324         case ARIZONA_OUT4LMIX_INPUT_2_SOURCE:
1325         case ARIZONA_OUT4LMIX_INPUT_2_VOLUME:
1326         case ARIZONA_OUT4LMIX_INPUT_3_SOURCE:
1327         case ARIZONA_OUT4LMIX_INPUT_3_VOLUME:
1328         case ARIZONA_OUT4LMIX_INPUT_4_SOURCE:
1329         case ARIZONA_OUT4LMIX_INPUT_4_VOLUME:
1330         case ARIZONA_OUT4RMIX_INPUT_1_SOURCE:
1331         case ARIZONA_OUT4RMIX_INPUT_1_VOLUME:
1332         case ARIZONA_OUT4RMIX_INPUT_2_SOURCE:
1333         case ARIZONA_OUT4RMIX_INPUT_2_VOLUME:
1334         case ARIZONA_OUT4RMIX_INPUT_3_SOURCE:
1335         case ARIZONA_OUT4RMIX_INPUT_3_VOLUME:
1336         case ARIZONA_OUT4RMIX_INPUT_4_SOURCE:
1337         case ARIZONA_OUT4RMIX_INPUT_4_VOLUME:
1338         case ARIZONA_OUT5LMIX_INPUT_1_SOURCE:
1339         case ARIZONA_OUT5LMIX_INPUT_1_VOLUME:
1340         case ARIZONA_OUT5LMIX_INPUT_2_SOURCE:
1341         case ARIZONA_OUT5LMIX_INPUT_2_VOLUME:
1342         case ARIZONA_OUT5LMIX_INPUT_3_SOURCE:
1343         case ARIZONA_OUT5LMIX_INPUT_3_VOLUME:
1344         case ARIZONA_OUT5LMIX_INPUT_4_SOURCE:
1345         case ARIZONA_OUT5LMIX_INPUT_4_VOLUME:
1346         case ARIZONA_OUT5RMIX_INPUT_1_SOURCE:
1347         case ARIZONA_OUT5RMIX_INPUT_1_VOLUME:
1348         case ARIZONA_OUT5RMIX_INPUT_2_SOURCE:
1349         case ARIZONA_OUT5RMIX_INPUT_2_VOLUME:
1350         case ARIZONA_OUT5RMIX_INPUT_3_SOURCE:
1351         case ARIZONA_OUT5RMIX_INPUT_3_VOLUME:
1352         case ARIZONA_OUT5RMIX_INPUT_4_SOURCE:
1353         case ARIZONA_OUT5RMIX_INPUT_4_VOLUME:
1354         case ARIZONA_AIF1TX1MIX_INPUT_1_SOURCE:
1355         case ARIZONA_AIF1TX1MIX_INPUT_1_VOLUME:
1356         case ARIZONA_AIF1TX1MIX_INPUT_2_SOURCE:
1357         case ARIZONA_AIF1TX1MIX_INPUT_2_VOLUME:
1358         case ARIZONA_AIF1TX1MIX_INPUT_3_SOURCE:
1359         case ARIZONA_AIF1TX1MIX_INPUT_3_VOLUME:
1360         case ARIZONA_AIF1TX1MIX_INPUT_4_SOURCE:
1361         case ARIZONA_AIF1TX1MIX_INPUT_4_VOLUME:
1362         case ARIZONA_AIF1TX2MIX_INPUT_1_SOURCE:
1363         case ARIZONA_AIF1TX2MIX_INPUT_1_VOLUME:
1364         case ARIZONA_AIF1TX2MIX_INPUT_2_SOURCE:
1365         case ARIZONA_AIF1TX2MIX_INPUT_2_VOLUME:
1366         case ARIZONA_AIF1TX2MIX_INPUT_3_SOURCE:
1367         case ARIZONA_AIF1TX2MIX_INPUT_3_VOLUME:
1368         case ARIZONA_AIF1TX2MIX_INPUT_4_SOURCE:
1369         case ARIZONA_AIF1TX2MIX_INPUT_4_VOLUME:
1370         case ARIZONA_AIF1TX3MIX_INPUT_1_SOURCE:
1371         case ARIZONA_AIF1TX3MIX_INPUT_1_VOLUME:
1372         case ARIZONA_AIF1TX3MIX_INPUT_2_SOURCE:
1373         case ARIZONA_AIF1TX3MIX_INPUT_2_VOLUME:
1374         case ARIZONA_AIF1TX3MIX_INPUT_3_SOURCE:
1375         case ARIZONA_AIF1TX3MIX_INPUT_3_VOLUME:
1376         case ARIZONA_AIF1TX3MIX_INPUT_4_SOURCE:
1377         case ARIZONA_AIF1TX3MIX_INPUT_4_VOLUME:
1378         case ARIZONA_AIF1TX4MIX_INPUT_1_SOURCE:
1379         case ARIZONA_AIF1TX4MIX_INPUT_1_VOLUME:
1380         case ARIZONA_AIF1TX4MIX_INPUT_2_SOURCE:
1381         case ARIZONA_AIF1TX4MIX_INPUT_2_VOLUME:
1382         case ARIZONA_AIF1TX4MIX_INPUT_3_SOURCE:
1383         case ARIZONA_AIF1TX4MIX_INPUT_3_VOLUME:
1384         case ARIZONA_AIF1TX4MIX_INPUT_4_SOURCE:
1385         case ARIZONA_AIF1TX4MIX_INPUT_4_VOLUME:
1386         case ARIZONA_AIF1TX5MIX_INPUT_1_SOURCE:
1387         case ARIZONA_AIF1TX5MIX_INPUT_1_VOLUME:
1388         case ARIZONA_AIF1TX5MIX_INPUT_2_SOURCE:
1389         case ARIZONA_AIF1TX5MIX_INPUT_2_VOLUME:
1390         case ARIZONA_AIF1TX5MIX_INPUT_3_SOURCE:
1391         case ARIZONA_AIF1TX5MIX_INPUT_3_VOLUME:
1392         case ARIZONA_AIF1TX5MIX_INPUT_4_SOURCE:
1393         case ARIZONA_AIF1TX5MIX_INPUT_4_VOLUME:
1394         case ARIZONA_AIF1TX6MIX_INPUT_1_SOURCE:
1395         case ARIZONA_AIF1TX6MIX_INPUT_1_VOLUME:
1396         case ARIZONA_AIF1TX6MIX_INPUT_2_SOURCE:
1397         case ARIZONA_AIF1TX6MIX_INPUT_2_VOLUME:
1398         case ARIZONA_AIF1TX6MIX_INPUT_3_SOURCE:
1399         case ARIZONA_AIF1TX6MIX_INPUT_3_VOLUME:
1400         case ARIZONA_AIF1TX6MIX_INPUT_4_SOURCE:
1401         case ARIZONA_AIF1TX6MIX_INPUT_4_VOLUME:
1402         case ARIZONA_AIF1TX7MIX_INPUT_1_SOURCE:
1403         case ARIZONA_AIF1TX7MIX_INPUT_1_VOLUME:
1404         case ARIZONA_AIF1TX7MIX_INPUT_2_SOURCE:
1405         case ARIZONA_AIF1TX7MIX_INPUT_2_VOLUME:
1406         case ARIZONA_AIF1TX7MIX_INPUT_3_SOURCE:
1407         case ARIZONA_AIF1TX7MIX_INPUT_3_VOLUME:
1408         case ARIZONA_AIF1TX7MIX_INPUT_4_SOURCE:
1409         case ARIZONA_AIF1TX7MIX_INPUT_4_VOLUME:
1410         case ARIZONA_AIF1TX8MIX_INPUT_1_SOURCE:
1411         case ARIZONA_AIF1TX8MIX_INPUT_1_VOLUME:
1412         case ARIZONA_AIF1TX8MIX_INPUT_2_SOURCE:
1413         case ARIZONA_AIF1TX8MIX_INPUT_2_VOLUME:
1414         case ARIZONA_AIF1TX8MIX_INPUT_3_SOURCE:
1415         case ARIZONA_AIF1TX8MIX_INPUT_3_VOLUME:
1416         case ARIZONA_AIF1TX8MIX_INPUT_4_SOURCE:
1417         case ARIZONA_AIF1TX8MIX_INPUT_4_VOLUME:
1418         case ARIZONA_AIF2TX1MIX_INPUT_1_SOURCE:
1419         case ARIZONA_AIF2TX1MIX_INPUT_1_VOLUME:
1420         case ARIZONA_AIF2TX1MIX_INPUT_2_SOURCE:
1421         case ARIZONA_AIF2TX1MIX_INPUT_2_VOLUME:
1422         case ARIZONA_AIF2TX1MIX_INPUT_3_SOURCE:
1423         case ARIZONA_AIF2TX1MIX_INPUT_3_VOLUME:
1424         case ARIZONA_AIF2TX1MIX_INPUT_4_SOURCE:
1425         case ARIZONA_AIF2TX1MIX_INPUT_4_VOLUME:
1426         case ARIZONA_AIF2TX2MIX_INPUT_1_SOURCE:
1427         case ARIZONA_AIF2TX2MIX_INPUT_1_VOLUME:
1428         case ARIZONA_AIF2TX2MIX_INPUT_2_SOURCE:
1429         case ARIZONA_AIF2TX2MIX_INPUT_2_VOLUME:
1430         case ARIZONA_AIF2TX2MIX_INPUT_3_SOURCE:
1431         case ARIZONA_AIF2TX2MIX_INPUT_3_VOLUME:
1432         case ARIZONA_AIF2TX2MIX_INPUT_4_SOURCE:
1433         case ARIZONA_AIF2TX2MIX_INPUT_4_VOLUME:
1434         case ARIZONA_AIF3TX1MIX_INPUT_1_SOURCE:
1435         case ARIZONA_AIF3TX1MIX_INPUT_1_VOLUME:
1436         case ARIZONA_AIF3TX1MIX_INPUT_2_SOURCE:
1437         case ARIZONA_AIF3TX1MIX_INPUT_2_VOLUME:
1438         case ARIZONA_AIF3TX1MIX_INPUT_3_SOURCE:
1439         case ARIZONA_AIF3TX1MIX_INPUT_3_VOLUME:
1440         case ARIZONA_AIF3TX1MIX_INPUT_4_SOURCE:
1441         case ARIZONA_AIF3TX1MIX_INPUT_4_VOLUME:
1442         case ARIZONA_AIF3TX2MIX_INPUT_1_SOURCE:
1443         case ARIZONA_AIF3TX2MIX_INPUT_1_VOLUME:
1444         case ARIZONA_AIF3TX2MIX_INPUT_2_SOURCE:
1445         case ARIZONA_AIF3TX2MIX_INPUT_2_VOLUME:
1446         case ARIZONA_AIF3TX2MIX_INPUT_3_SOURCE:
1447         case ARIZONA_AIF3TX2MIX_INPUT_3_VOLUME:
1448         case ARIZONA_AIF3TX2MIX_INPUT_4_SOURCE:
1449         case ARIZONA_AIF3TX2MIX_INPUT_4_VOLUME:
1450         case ARIZONA_SLIMTX1MIX_INPUT_1_SOURCE:
1451         case ARIZONA_SLIMTX1MIX_INPUT_1_VOLUME:
1452         case ARIZONA_SLIMTX1MIX_INPUT_2_SOURCE:
1453         case ARIZONA_SLIMTX1MIX_INPUT_2_VOLUME:
1454         case ARIZONA_SLIMTX1MIX_INPUT_3_SOURCE:
1455         case ARIZONA_SLIMTX1MIX_INPUT_3_VOLUME:
1456         case ARIZONA_SLIMTX1MIX_INPUT_4_SOURCE:
1457         case ARIZONA_SLIMTX1MIX_INPUT_4_VOLUME:
1458         case ARIZONA_SLIMTX2MIX_INPUT_1_SOURCE:
1459         case ARIZONA_SLIMTX2MIX_INPUT_1_VOLUME:
1460         case ARIZONA_SLIMTX2MIX_INPUT_2_SOURCE:
1461         case ARIZONA_SLIMTX2MIX_INPUT_2_VOLUME:
1462         case ARIZONA_SLIMTX2MIX_INPUT_3_SOURCE:
1463         case ARIZONA_SLIMTX2MIX_INPUT_3_VOLUME:
1464         case ARIZONA_SLIMTX2MIX_INPUT_4_SOURCE:
1465         case ARIZONA_SLIMTX2MIX_INPUT_4_VOLUME:
1466         case ARIZONA_SLIMTX3MIX_INPUT_1_SOURCE:
1467         case ARIZONA_SLIMTX3MIX_INPUT_1_VOLUME:
1468         case ARIZONA_SLIMTX3MIX_INPUT_2_SOURCE:
1469         case ARIZONA_SLIMTX3MIX_INPUT_2_VOLUME:
1470         case ARIZONA_SLIMTX3MIX_INPUT_3_SOURCE:
1471         case ARIZONA_SLIMTX3MIX_INPUT_3_VOLUME:
1472         case ARIZONA_SLIMTX3MIX_INPUT_4_SOURCE:
1473         case ARIZONA_SLIMTX3MIX_INPUT_4_VOLUME:
1474         case ARIZONA_SLIMTX4MIX_INPUT_1_SOURCE:
1475         case ARIZONA_SLIMTX4MIX_INPUT_1_VOLUME:
1476         case ARIZONA_SLIMTX4MIX_INPUT_2_SOURCE:
1477         case ARIZONA_SLIMTX4MIX_INPUT_2_VOLUME:
1478         case ARIZONA_SLIMTX4MIX_INPUT_3_SOURCE:
1479         case ARIZONA_SLIMTX4MIX_INPUT_3_VOLUME:
1480         case ARIZONA_SLIMTX4MIX_INPUT_4_SOURCE:
1481         case ARIZONA_SLIMTX4MIX_INPUT_4_VOLUME:
1482         case ARIZONA_SLIMTX5MIX_INPUT_1_SOURCE:
1483         case ARIZONA_SLIMTX5MIX_INPUT_1_VOLUME:
1484         case ARIZONA_SLIMTX5MIX_INPUT_2_SOURCE:
1485         case ARIZONA_SLIMTX5MIX_INPUT_2_VOLUME:
1486         case ARIZONA_SLIMTX5MIX_INPUT_3_SOURCE:
1487         case ARIZONA_SLIMTX5MIX_INPUT_3_VOLUME:
1488         case ARIZONA_SLIMTX5MIX_INPUT_4_SOURCE:
1489         case ARIZONA_SLIMTX5MIX_INPUT_4_VOLUME:
1490         case ARIZONA_SLIMTX6MIX_INPUT_1_SOURCE:
1491         case ARIZONA_SLIMTX6MIX_INPUT_1_VOLUME:
1492         case ARIZONA_SLIMTX6MIX_INPUT_2_SOURCE:
1493         case ARIZONA_SLIMTX6MIX_INPUT_2_VOLUME:
1494         case ARIZONA_SLIMTX6MIX_INPUT_3_SOURCE:
1495         case ARIZONA_SLIMTX6MIX_INPUT_3_VOLUME:
1496         case ARIZONA_SLIMTX6MIX_INPUT_4_SOURCE:
1497         case ARIZONA_SLIMTX6MIX_INPUT_4_VOLUME:
1498         case ARIZONA_SLIMTX7MIX_INPUT_1_SOURCE:
1499         case ARIZONA_SLIMTX7MIX_INPUT_1_VOLUME:
1500         case ARIZONA_SLIMTX7MIX_INPUT_2_SOURCE:
1501         case ARIZONA_SLIMTX7MIX_INPUT_2_VOLUME:
1502         case ARIZONA_SLIMTX7MIX_INPUT_3_SOURCE:
1503         case ARIZONA_SLIMTX7MIX_INPUT_3_VOLUME:
1504         case ARIZONA_SLIMTX7MIX_INPUT_4_SOURCE:
1505         case ARIZONA_SLIMTX7MIX_INPUT_4_VOLUME:
1506         case ARIZONA_SLIMTX8MIX_INPUT_1_SOURCE:
1507         case ARIZONA_SLIMTX8MIX_INPUT_1_VOLUME:
1508         case ARIZONA_SLIMTX8MIX_INPUT_2_SOURCE:
1509         case ARIZONA_SLIMTX8MIX_INPUT_2_VOLUME:
1510         case ARIZONA_SLIMTX8MIX_INPUT_3_SOURCE:
1511         case ARIZONA_SLIMTX8MIX_INPUT_3_VOLUME:
1512         case ARIZONA_SLIMTX8MIX_INPUT_4_SOURCE:
1513         case ARIZONA_SLIMTX8MIX_INPUT_4_VOLUME:
1514         case ARIZONA_EQ1MIX_INPUT_1_SOURCE:
1515         case ARIZONA_EQ1MIX_INPUT_1_VOLUME:
1516         case ARIZONA_EQ1MIX_INPUT_2_SOURCE:
1517         case ARIZONA_EQ1MIX_INPUT_2_VOLUME:
1518         case ARIZONA_EQ1MIX_INPUT_3_SOURCE:
1519         case ARIZONA_EQ1MIX_INPUT_3_VOLUME:
1520         case ARIZONA_EQ1MIX_INPUT_4_SOURCE:
1521         case ARIZONA_EQ1MIX_INPUT_4_VOLUME:
1522         case ARIZONA_EQ2MIX_INPUT_1_SOURCE:
1523         case ARIZONA_EQ2MIX_INPUT_1_VOLUME:
1524         case ARIZONA_EQ2MIX_INPUT_2_SOURCE:
1525         case ARIZONA_EQ2MIX_INPUT_2_VOLUME:
1526         case ARIZONA_EQ2MIX_INPUT_3_SOURCE:
1527         case ARIZONA_EQ2MIX_INPUT_3_VOLUME:
1528         case ARIZONA_EQ2MIX_INPUT_4_SOURCE:
1529         case ARIZONA_EQ2MIX_INPUT_4_VOLUME:
1530         case ARIZONA_EQ3MIX_INPUT_1_SOURCE:
1531         case ARIZONA_EQ3MIX_INPUT_1_VOLUME:
1532         case ARIZONA_EQ3MIX_INPUT_2_SOURCE:
1533         case ARIZONA_EQ3MIX_INPUT_2_VOLUME:
1534         case ARIZONA_EQ3MIX_INPUT_3_SOURCE:
1535         case ARIZONA_EQ3MIX_INPUT_3_VOLUME:
1536         case ARIZONA_EQ3MIX_INPUT_4_SOURCE:
1537         case ARIZONA_EQ3MIX_INPUT_4_VOLUME:
1538         case ARIZONA_EQ4MIX_INPUT_1_SOURCE:
1539         case ARIZONA_EQ4MIX_INPUT_1_VOLUME:
1540         case ARIZONA_EQ4MIX_INPUT_2_SOURCE:
1541         case ARIZONA_EQ4MIX_INPUT_2_VOLUME:
1542         case ARIZONA_EQ4MIX_INPUT_3_SOURCE:
1543         case ARIZONA_EQ4MIX_INPUT_3_VOLUME:
1544         case ARIZONA_EQ4MIX_INPUT_4_SOURCE:
1545         case ARIZONA_EQ4MIX_INPUT_4_VOLUME:
1546         case ARIZONA_DRC1LMIX_INPUT_1_SOURCE:
1547         case ARIZONA_DRC1LMIX_INPUT_1_VOLUME:
1548         case ARIZONA_DRC1LMIX_INPUT_2_SOURCE:
1549         case ARIZONA_DRC1LMIX_INPUT_2_VOLUME:
1550         case ARIZONA_DRC1LMIX_INPUT_3_SOURCE:
1551         case ARIZONA_DRC1LMIX_INPUT_3_VOLUME:
1552         case ARIZONA_DRC1LMIX_INPUT_4_SOURCE:
1553         case ARIZONA_DRC1LMIX_INPUT_4_VOLUME:
1554         case ARIZONA_DRC1RMIX_INPUT_1_SOURCE:
1555         case ARIZONA_DRC1RMIX_INPUT_1_VOLUME:
1556         case ARIZONA_DRC1RMIX_INPUT_2_SOURCE:
1557         case ARIZONA_DRC1RMIX_INPUT_2_VOLUME:
1558         case ARIZONA_DRC1RMIX_INPUT_3_SOURCE:
1559         case ARIZONA_DRC1RMIX_INPUT_3_VOLUME:
1560         case ARIZONA_DRC1RMIX_INPUT_4_SOURCE:
1561         case ARIZONA_DRC1RMIX_INPUT_4_VOLUME:
1562         case ARIZONA_HPLP1MIX_INPUT_1_SOURCE:
1563         case ARIZONA_HPLP1MIX_INPUT_1_VOLUME:
1564         case ARIZONA_HPLP1MIX_INPUT_2_SOURCE:
1565         case ARIZONA_HPLP1MIX_INPUT_2_VOLUME:
1566         case ARIZONA_HPLP1MIX_INPUT_3_SOURCE:
1567         case ARIZONA_HPLP1MIX_INPUT_3_VOLUME:
1568         case ARIZONA_HPLP1MIX_INPUT_4_SOURCE:
1569         case ARIZONA_HPLP1MIX_INPUT_4_VOLUME:
1570         case ARIZONA_HPLP2MIX_INPUT_1_SOURCE:
1571         case ARIZONA_HPLP2MIX_INPUT_1_VOLUME:
1572         case ARIZONA_HPLP2MIX_INPUT_2_SOURCE:
1573         case ARIZONA_HPLP2MIX_INPUT_2_VOLUME:
1574         case ARIZONA_HPLP2MIX_INPUT_3_SOURCE:
1575         case ARIZONA_HPLP2MIX_INPUT_3_VOLUME:
1576         case ARIZONA_HPLP2MIX_INPUT_4_SOURCE:
1577         case ARIZONA_HPLP2MIX_INPUT_4_VOLUME:
1578         case ARIZONA_HPLP3MIX_INPUT_1_SOURCE:
1579         case ARIZONA_HPLP3MIX_INPUT_1_VOLUME:
1580         case ARIZONA_HPLP3MIX_INPUT_2_SOURCE:
1581         case ARIZONA_HPLP3MIX_INPUT_2_VOLUME:
1582         case ARIZONA_HPLP3MIX_INPUT_3_SOURCE:
1583         case ARIZONA_HPLP3MIX_INPUT_3_VOLUME:
1584         case ARIZONA_HPLP3MIX_INPUT_4_SOURCE:
1585         case ARIZONA_HPLP3MIX_INPUT_4_VOLUME:
1586         case ARIZONA_HPLP4MIX_INPUT_1_SOURCE:
1587         case ARIZONA_HPLP4MIX_INPUT_1_VOLUME:
1588         case ARIZONA_HPLP4MIX_INPUT_2_SOURCE:
1589         case ARIZONA_HPLP4MIX_INPUT_2_VOLUME:
1590         case ARIZONA_HPLP4MIX_INPUT_3_SOURCE:
1591         case ARIZONA_HPLP4MIX_INPUT_3_VOLUME:
1592         case ARIZONA_HPLP4MIX_INPUT_4_SOURCE:
1593         case ARIZONA_HPLP4MIX_INPUT_4_VOLUME:
1594         case ARIZONA_DSP1LMIX_INPUT_1_SOURCE:
1595         case ARIZONA_DSP1LMIX_INPUT_1_VOLUME:
1596         case ARIZONA_DSP1LMIX_INPUT_2_SOURCE:
1597         case ARIZONA_DSP1LMIX_INPUT_2_VOLUME:
1598         case ARIZONA_DSP1LMIX_INPUT_3_SOURCE:
1599         case ARIZONA_DSP1LMIX_INPUT_3_VOLUME:
1600         case ARIZONA_DSP1LMIX_INPUT_4_SOURCE:
1601         case ARIZONA_DSP1LMIX_INPUT_4_VOLUME:
1602         case ARIZONA_DSP1RMIX_INPUT_1_SOURCE:
1603         case ARIZONA_DSP1RMIX_INPUT_1_VOLUME:
1604         case ARIZONA_DSP1RMIX_INPUT_2_SOURCE:
1605         case ARIZONA_DSP1RMIX_INPUT_2_VOLUME:
1606         case ARIZONA_DSP1RMIX_INPUT_3_SOURCE:
1607         case ARIZONA_DSP1RMIX_INPUT_3_VOLUME:
1608         case ARIZONA_DSP1RMIX_INPUT_4_SOURCE:
1609         case ARIZONA_DSP1RMIX_INPUT_4_VOLUME:
1610         case ARIZONA_DSP1AUX1MIX_INPUT_1_SOURCE:
1611         case ARIZONA_DSP1AUX2MIX_INPUT_1_SOURCE:
1612         case ARIZONA_DSP1AUX3MIX_INPUT_1_SOURCE:
1613         case ARIZONA_DSP1AUX4MIX_INPUT_1_SOURCE:
1614         case ARIZONA_DSP1AUX5MIX_INPUT_1_SOURCE:
1615         case ARIZONA_DSP1AUX6MIX_INPUT_1_SOURCE:
1616         case ARIZONA_ASRC1LMIX_INPUT_1_SOURCE:
1617         case ARIZONA_ASRC1RMIX_INPUT_1_SOURCE:
1618         case ARIZONA_ASRC2LMIX_INPUT_1_SOURCE:
1619         case ARIZONA_ASRC2RMIX_INPUT_1_SOURCE:
1620         case ARIZONA_ISRC1DEC1MIX_INPUT_1_SOURCE:
1621         case ARIZONA_ISRC1DEC2MIX_INPUT_1_SOURCE:
1622         case ARIZONA_ISRC1INT1MIX_INPUT_1_SOURCE:
1623         case ARIZONA_ISRC1INT2MIX_INPUT_1_SOURCE:
1624         case ARIZONA_ISRC2DEC1MIX_INPUT_1_SOURCE:
1625         case ARIZONA_ISRC2DEC2MIX_INPUT_1_SOURCE:
1626         case ARIZONA_ISRC2INT1MIX_INPUT_1_SOURCE:
1627         case ARIZONA_ISRC2INT2MIX_INPUT_1_SOURCE:
1628         case ARIZONA_GPIO1_CTRL:
1629         case ARIZONA_GPIO2_CTRL:
1630         case ARIZONA_GPIO3_CTRL:
1631         case ARIZONA_GPIO4_CTRL:
1632         case ARIZONA_GPIO5_CTRL:
1633         case ARIZONA_IRQ_CTRL_1:
1634         case ARIZONA_GPIO_DEBOUNCE_CONFIG:
1635         case ARIZONA_MISC_PAD_CTRL_1:
1636         case ARIZONA_MISC_PAD_CTRL_2:
1637         case ARIZONA_MISC_PAD_CTRL_3:
1638         case ARIZONA_MISC_PAD_CTRL_4:
1639         case ARIZONA_MISC_PAD_CTRL_5:
1640         case ARIZONA_MISC_PAD_CTRL_6:
1641         case ARIZONA_INTERRUPT_STATUS_1:
1642         case ARIZONA_INTERRUPT_STATUS_2:
1643         case ARIZONA_INTERRUPT_STATUS_3:
1644         case ARIZONA_INTERRUPT_STATUS_4:
1645         case ARIZONA_INTERRUPT_STATUS_5:
1646         case ARIZONA_INTERRUPT_STATUS_1_MASK:
1647         case ARIZONA_INTERRUPT_STATUS_2_MASK:
1648         case ARIZONA_INTERRUPT_STATUS_3_MASK:
1649         case ARIZONA_INTERRUPT_STATUS_4_MASK:
1650         case ARIZONA_INTERRUPT_STATUS_5_MASK:
1651         case ARIZONA_INTERRUPT_CONTROL:
1652         case ARIZONA_IRQ2_STATUS_1:
1653         case ARIZONA_IRQ2_STATUS_2:
1654         case ARIZONA_IRQ2_STATUS_3:
1655         case ARIZONA_IRQ2_STATUS_4:
1656         case ARIZONA_IRQ2_STATUS_5:
1657         case ARIZONA_IRQ2_STATUS_1_MASK:
1658         case ARIZONA_IRQ2_STATUS_2_MASK:
1659         case ARIZONA_IRQ2_STATUS_3_MASK:
1660         case ARIZONA_IRQ2_STATUS_4_MASK:
1661         case ARIZONA_IRQ2_STATUS_5_MASK:
1662         case ARIZONA_IRQ2_CONTROL:
1663         case ARIZONA_INTERRUPT_RAW_STATUS_2:
1664         case ARIZONA_INTERRUPT_RAW_STATUS_3:
1665         case ARIZONA_INTERRUPT_RAW_STATUS_4:
1666         case ARIZONA_INTERRUPT_RAW_STATUS_5:
1667         case ARIZONA_INTERRUPT_RAW_STATUS_6:
1668         case ARIZONA_INTERRUPT_RAW_STATUS_7:
1669         case ARIZONA_INTERRUPT_RAW_STATUS_8:
1670         case ARIZONA_IRQ_PIN_STATUS:
1671         case ARIZONA_ADSP2_IRQ0:
1672         case ARIZONA_AOD_WKUP_AND_TRIG:
1673         case ARIZONA_AOD_IRQ1:
1674         case ARIZONA_AOD_IRQ2:
1675         case ARIZONA_AOD_IRQ_MASK_IRQ1:
1676         case ARIZONA_AOD_IRQ_MASK_IRQ2:
1677         case ARIZONA_AOD_IRQ_RAW_STATUS:
1678         case ARIZONA_JACK_DETECT_DEBOUNCE:
1679         case ARIZONA_FX_CTRL1:
1680         case ARIZONA_FX_CTRL2:
1681         case ARIZONA_EQ1_1:
1682         case ARIZONA_EQ1_2:
1683         case ARIZONA_EQ1_3:
1684         case ARIZONA_EQ1_4:
1685         case ARIZONA_EQ1_5:
1686         case ARIZONA_EQ1_6:
1687         case ARIZONA_EQ1_7:
1688         case ARIZONA_EQ1_8:
1689         case ARIZONA_EQ1_9:
1690         case ARIZONA_EQ1_10:
1691         case ARIZONA_EQ1_11:
1692         case ARIZONA_EQ1_12:
1693         case ARIZONA_EQ1_13:
1694         case ARIZONA_EQ1_14:
1695         case ARIZONA_EQ1_15:
1696         case ARIZONA_EQ1_16:
1697         case ARIZONA_EQ1_17:
1698         case ARIZONA_EQ1_18:
1699         case ARIZONA_EQ1_19:
1700         case ARIZONA_EQ1_20:
1701         case ARIZONA_EQ1_21:
1702         case ARIZONA_EQ2_1:
1703         case ARIZONA_EQ2_2:
1704         case ARIZONA_EQ2_3:
1705         case ARIZONA_EQ2_4:
1706         case ARIZONA_EQ2_5:
1707         case ARIZONA_EQ2_6:
1708         case ARIZONA_EQ2_7:
1709         case ARIZONA_EQ2_8:
1710         case ARIZONA_EQ2_9:
1711         case ARIZONA_EQ2_10:
1712         case ARIZONA_EQ2_11:
1713         case ARIZONA_EQ2_12:
1714         case ARIZONA_EQ2_13:
1715         case ARIZONA_EQ2_14:
1716         case ARIZONA_EQ2_15:
1717         case ARIZONA_EQ2_16:
1718         case ARIZONA_EQ2_17:
1719         case ARIZONA_EQ2_18:
1720         case ARIZONA_EQ2_19:
1721         case ARIZONA_EQ2_20:
1722         case ARIZONA_EQ2_21:
1723         case ARIZONA_EQ3_1:
1724         case ARIZONA_EQ3_2:
1725         case ARIZONA_EQ3_3:
1726         case ARIZONA_EQ3_4:
1727         case ARIZONA_EQ3_5:
1728         case ARIZONA_EQ3_6:
1729         case ARIZONA_EQ3_7:
1730         case ARIZONA_EQ3_8:
1731         case ARIZONA_EQ3_9:
1732         case ARIZONA_EQ3_10:
1733         case ARIZONA_EQ3_11:
1734         case ARIZONA_EQ3_12:
1735         case ARIZONA_EQ3_13:
1736         case ARIZONA_EQ3_14:
1737         case ARIZONA_EQ3_15:
1738         case ARIZONA_EQ3_16:
1739         case ARIZONA_EQ3_17:
1740         case ARIZONA_EQ3_18:
1741         case ARIZONA_EQ3_19:
1742         case ARIZONA_EQ3_20:
1743         case ARIZONA_EQ3_21:
1744         case ARIZONA_EQ4_1:
1745         case ARIZONA_EQ4_2:
1746         case ARIZONA_EQ4_3:
1747         case ARIZONA_EQ4_4:
1748         case ARIZONA_EQ4_5:
1749         case ARIZONA_EQ4_6:
1750         case ARIZONA_EQ4_7:
1751         case ARIZONA_EQ4_8:
1752         case ARIZONA_EQ4_9:
1753         case ARIZONA_EQ4_10:
1754         case ARIZONA_EQ4_11:
1755         case ARIZONA_EQ4_12:
1756         case ARIZONA_EQ4_13:
1757         case ARIZONA_EQ4_14:
1758         case ARIZONA_EQ4_15:
1759         case ARIZONA_EQ4_16:
1760         case ARIZONA_EQ4_17:
1761         case ARIZONA_EQ4_18:
1762         case ARIZONA_EQ4_19:
1763         case ARIZONA_EQ4_20:
1764         case ARIZONA_EQ4_21:
1765         case ARIZONA_DRC1_CTRL1:
1766         case ARIZONA_DRC1_CTRL2:
1767         case ARIZONA_DRC1_CTRL3:
1768         case ARIZONA_DRC1_CTRL4:
1769         case ARIZONA_DRC1_CTRL5:
1770         case ARIZONA_HPLPF1_1:
1771         case ARIZONA_HPLPF1_2:
1772         case ARIZONA_HPLPF2_1:
1773         case ARIZONA_HPLPF2_2:
1774         case ARIZONA_HPLPF3_1:
1775         case ARIZONA_HPLPF3_2:
1776         case ARIZONA_HPLPF4_1:
1777         case ARIZONA_HPLPF4_2:
1778         case ARIZONA_ASRC_ENABLE:
1779         case ARIZONA_ASRC_RATE1:
1780         case ARIZONA_ASRC_RATE2:
1781         case ARIZONA_ISRC_1_CTRL_1:
1782         case ARIZONA_ISRC_1_CTRL_2:
1783         case ARIZONA_ISRC_1_CTRL_3:
1784         case ARIZONA_ISRC_2_CTRL_1:
1785         case ARIZONA_ISRC_2_CTRL_2:
1786         case ARIZONA_ISRC_2_CTRL_3:
1787         case ARIZONA_DSP1_CONTROL_1:
1788         case ARIZONA_DSP1_CLOCKING_1:
1789         case ARIZONA_DSP1_STATUS_1:
1790         case ARIZONA_DSP1_STATUS_2:
1791         case ARIZONA_DSP1_STATUS_3:
1792         case ARIZONA_DSP1_WDMA_BUFFER_1:
1793         case ARIZONA_DSP1_WDMA_BUFFER_2:
1794         case ARIZONA_DSP1_WDMA_BUFFER_3:
1795         case ARIZONA_DSP1_WDMA_BUFFER_4:
1796         case ARIZONA_DSP1_WDMA_BUFFER_5:
1797         case ARIZONA_DSP1_WDMA_BUFFER_6:
1798         case ARIZONA_DSP1_WDMA_BUFFER_7:
1799         case ARIZONA_DSP1_WDMA_BUFFER_8:
1800         case ARIZONA_DSP1_RDMA_BUFFER_1:
1801         case ARIZONA_DSP1_RDMA_BUFFER_2:
1802         case ARIZONA_DSP1_RDMA_BUFFER_3:
1803         case ARIZONA_DSP1_RDMA_BUFFER_4:
1804         case ARIZONA_DSP1_RDMA_BUFFER_5:
1805         case ARIZONA_DSP1_RDMA_BUFFER_6:
1806         case ARIZONA_DSP1_WDMA_CONFIG_1:
1807         case ARIZONA_DSP1_WDMA_CONFIG_2:
1808         case ARIZONA_DSP1_RDMA_CONFIG_1:
1809         case ARIZONA_DSP1_SCRATCH_0:
1810         case ARIZONA_DSP1_SCRATCH_1:
1811         case ARIZONA_DSP1_SCRATCH_2:
1812         case ARIZONA_DSP1_SCRATCH_3:
1813                 return true;
1814         default:
1815                 if ((reg >= 0x100000 && reg < 0x106000) ||
1816                     (reg >= 0x180000 && reg < 0x180800) ||
1817                     (reg >= 0x190000 && reg < 0x194800) ||
1818                     (reg >= 0x1a8000 && reg < 0x1a9800))
1819                         return true;
1820                 else
1821                         return false;
1822         }
1823 }
1824
1825 static bool wm5102_volatile_register(struct device *dev, unsigned int reg)
1826 {
1827         switch (reg) {
1828         case ARIZONA_SOFTWARE_RESET:
1829         case ARIZONA_DEVICE_REVISION:
1830         case ARIZONA_WRITE_SEQUENCER_CTRL_0:
1831         case ARIZONA_WRITE_SEQUENCER_CTRL_1:
1832         case ARIZONA_WRITE_SEQUENCER_CTRL_2:
1833         case ARIZONA_WRITE_SEQUENCER_CTRL_3:
1834         case ARIZONA_OUTPUT_STATUS_1:
1835         case ARIZONA_SLIMBUS_RX_PORT_STATUS:
1836         case ARIZONA_SLIMBUS_TX_PORT_STATUS:
1837         case ARIZONA_SAMPLE_RATE_1_STATUS:
1838         case ARIZONA_SAMPLE_RATE_2_STATUS:
1839         case ARIZONA_SAMPLE_RATE_3_STATUS:
1840         case ARIZONA_HAPTICS_STATUS:
1841         case ARIZONA_ASYNC_SAMPLE_RATE_1_STATUS:
1842         case ARIZONA_ASYNC_SAMPLE_RATE_2_STATUS:
1843         case ARIZONA_DAC_COMP_1:
1844         case ARIZONA_DAC_COMP_2:
1845         case ARIZONA_DAC_COMP_3:
1846         case ARIZONA_DAC_COMP_4:
1847         case ARIZONA_FX_CTRL2:
1848         case ARIZONA_INTERRUPT_STATUS_1:
1849         case ARIZONA_INTERRUPT_STATUS_2:
1850         case ARIZONA_INTERRUPT_STATUS_3:
1851         case ARIZONA_INTERRUPT_STATUS_4:
1852         case ARIZONA_INTERRUPT_STATUS_5:
1853         case ARIZONA_IRQ2_STATUS_1:
1854         case ARIZONA_IRQ2_STATUS_2:
1855         case ARIZONA_IRQ2_STATUS_3:
1856         case ARIZONA_IRQ2_STATUS_4:
1857         case ARIZONA_IRQ2_STATUS_5:
1858         case ARIZONA_INTERRUPT_RAW_STATUS_2:
1859         case ARIZONA_INTERRUPT_RAW_STATUS_3:
1860         case ARIZONA_INTERRUPT_RAW_STATUS_4:
1861         case ARIZONA_INTERRUPT_RAW_STATUS_5:
1862         case ARIZONA_INTERRUPT_RAW_STATUS_6:
1863         case ARIZONA_INTERRUPT_RAW_STATUS_7:
1864         case ARIZONA_INTERRUPT_RAW_STATUS_8:
1865         case ARIZONA_IRQ_PIN_STATUS:
1866         case ARIZONA_AOD_WKUP_AND_TRIG:
1867         case ARIZONA_AOD_IRQ1:
1868         case ARIZONA_AOD_IRQ2:
1869         case ARIZONA_AOD_IRQ_RAW_STATUS:
1870         case ARIZONA_DSP1_CLOCKING_1:
1871         case ARIZONA_DSP1_STATUS_1:
1872         case ARIZONA_DSP1_STATUS_2:
1873         case ARIZONA_DSP1_STATUS_3:
1874         case ARIZONA_DSP1_WDMA_BUFFER_1:
1875         case ARIZONA_DSP1_WDMA_BUFFER_2:
1876         case ARIZONA_DSP1_WDMA_BUFFER_3:
1877         case ARIZONA_DSP1_WDMA_BUFFER_4:
1878         case ARIZONA_DSP1_WDMA_BUFFER_5:
1879         case ARIZONA_DSP1_WDMA_BUFFER_6:
1880         case ARIZONA_DSP1_WDMA_BUFFER_7:
1881         case ARIZONA_DSP1_WDMA_BUFFER_8:
1882         case ARIZONA_DSP1_RDMA_BUFFER_1:
1883         case ARIZONA_DSP1_RDMA_BUFFER_2:
1884         case ARIZONA_DSP1_RDMA_BUFFER_3:
1885         case ARIZONA_DSP1_RDMA_BUFFER_4:
1886         case ARIZONA_DSP1_RDMA_BUFFER_5:
1887         case ARIZONA_DSP1_RDMA_BUFFER_6:
1888         case ARIZONA_DSP1_WDMA_CONFIG_1:
1889         case ARIZONA_DSP1_WDMA_CONFIG_2:
1890         case ARIZONA_DSP1_RDMA_CONFIG_1:
1891         case ARIZONA_DSP1_SCRATCH_0:
1892         case ARIZONA_DSP1_SCRATCH_1:
1893         case ARIZONA_DSP1_SCRATCH_2:
1894         case ARIZONA_DSP1_SCRATCH_3:
1895         case ARIZONA_HP_CTRL_1L:
1896         case ARIZONA_HP_CTRL_1R:
1897         case ARIZONA_HEADPHONE_DETECT_2:
1898         case ARIZONA_HP_DACVAL:
1899         case ARIZONA_MIC_DETECT_3:
1900                 return true;
1901         default:
1902                 if ((reg >= 0x100000 && reg < 0x106000) ||
1903                     (reg >= 0x180000 && reg < 0x180800) ||
1904                     (reg >= 0x190000 && reg < 0x194800) ||
1905                     (reg >= 0x1a8000 && reg < 0x1a9800))
1906                         return true;
1907                 else
1908                         return false;
1909         }
1910 }
1911
1912 #define WM5102_MAX_REGISTER 0x1a9800
1913
1914 const struct regmap_config wm5102_spi_regmap = {
1915         .reg_bits = 32,
1916         .pad_bits = 16,
1917         .val_bits = 16,
1918         .reg_format_endian = REGMAP_ENDIAN_BIG,
1919         .val_format_endian = REGMAP_ENDIAN_BIG,
1920
1921         .max_register = WM5102_MAX_REGISTER,
1922         .readable_reg = wm5102_readable_register,
1923         .volatile_reg = wm5102_volatile_register,
1924
1925         .cache_type = REGCACHE_RBTREE,
1926         .reg_defaults = wm5102_reg_default,
1927         .num_reg_defaults = ARRAY_SIZE(wm5102_reg_default),
1928 };
1929 EXPORT_SYMBOL_GPL(wm5102_spi_regmap);
1930
1931 const struct regmap_config wm5102_i2c_regmap = {
1932         .reg_bits = 32,
1933         .val_bits = 16,
1934         .reg_format_endian = REGMAP_ENDIAN_BIG,
1935         .val_format_endian = REGMAP_ENDIAN_BIG,
1936
1937         .max_register = WM5102_MAX_REGISTER,
1938         .readable_reg = wm5102_readable_register,
1939         .volatile_reg = wm5102_volatile_register,
1940
1941         .cache_type = REGCACHE_RBTREE,
1942         .reg_defaults = wm5102_reg_default,
1943         .num_reg_defaults = ARRAY_SIZE(wm5102_reg_default),
1944 };
1945 EXPORT_SYMBOL_GPL(wm5102_i2c_regmap);