0001
0002
0003
0004
0005
0006
0007
0008
0009
0010 #include <linux/module.h>
0011
0012 #include <linux/mfd/arizona/core.h>
0013 #include <linux/mfd/arizona/registers.h>
0014 #include <linux/device.h>
0015
0016 #include "arizona.h"
0017
0018 #define CS47L24_NUM_ISR 5
0019
0020 static const struct reg_sequence cs47l24_reva_patch[] = {
0021 { 0x80, 0x3 },
0022 { 0x27C, 0x0010 },
0023 { 0x221, 0x0070 },
0024 { 0x80, 0x0 },
0025 };
0026
0027 int cs47l24_patch(struct arizona *arizona)
0028 {
0029 return regmap_register_patch(arizona->regmap,
0030 cs47l24_reva_patch,
0031 ARRAY_SIZE(cs47l24_reva_patch));
0032 }
0033 EXPORT_SYMBOL_GPL(cs47l24_patch);
0034
0035 static const struct regmap_irq cs47l24_irqs[ARIZONA_NUM_IRQ] = {
0036 [ARIZONA_IRQ_GP2] = { .reg_offset = 0, .mask = ARIZONA_GP2_EINT1 },
0037 [ARIZONA_IRQ_GP1] = { .reg_offset = 0, .mask = ARIZONA_GP1_EINT1 },
0038
0039 [ARIZONA_IRQ_DSP3_RAM_RDY] = {
0040 .reg_offset = 1, .mask = ARIZONA_DSP3_RAM_RDY_EINT1
0041 },
0042 [ARIZONA_IRQ_DSP2_RAM_RDY] = {
0043 .reg_offset = 1, .mask = ARIZONA_DSP2_RAM_RDY_EINT1
0044 },
0045 [ARIZONA_IRQ_DSP_IRQ8] = {
0046 .reg_offset = 1, .mask = ARIZONA_DSP_IRQ8_EINT1
0047 },
0048 [ARIZONA_IRQ_DSP_IRQ7] = {
0049 .reg_offset = 1, .mask = ARIZONA_DSP_IRQ7_EINT1
0050 },
0051 [ARIZONA_IRQ_DSP_IRQ6] = {
0052 .reg_offset = 1, .mask = ARIZONA_DSP_IRQ6_EINT1
0053 },
0054 [ARIZONA_IRQ_DSP_IRQ5] = {
0055 .reg_offset = 1, .mask = ARIZONA_DSP_IRQ5_EINT1
0056 },
0057 [ARIZONA_IRQ_DSP_IRQ4] = {
0058 .reg_offset = 1, .mask = ARIZONA_DSP_IRQ4_EINT1
0059 },
0060 [ARIZONA_IRQ_DSP_IRQ3] = {
0061 .reg_offset = 1, .mask = ARIZONA_DSP_IRQ3_EINT1
0062 },
0063 [ARIZONA_IRQ_DSP_IRQ2] = {
0064 .reg_offset = 1, .mask = ARIZONA_DSP_IRQ2_EINT1
0065 },
0066 [ARIZONA_IRQ_DSP_IRQ1] = {
0067 .reg_offset = 1, .mask = ARIZONA_DSP_IRQ1_EINT1
0068 },
0069
0070 [ARIZONA_IRQ_SPK_OVERHEAT_WARN] = {
0071 .reg_offset = 2, .mask = ARIZONA_SPK_OVERHEAT_WARN_EINT1
0072 },
0073 [ARIZONA_IRQ_SPK_OVERHEAT] = {
0074 .reg_offset = 2, .mask = ARIZONA_SPK_OVERHEAT_EINT1
0075 },
0076 [ARIZONA_IRQ_WSEQ_DONE] = {
0077 .reg_offset = 2, .mask = ARIZONA_WSEQ_DONE_EINT1
0078 },
0079 [ARIZONA_IRQ_DRC2_SIG_DET] = {
0080 .reg_offset = 2, .mask = ARIZONA_DRC2_SIG_DET_EINT1
0081 },
0082 [ARIZONA_IRQ_DRC1_SIG_DET] = {
0083 .reg_offset = 2, .mask = ARIZONA_DRC1_SIG_DET_EINT1
0084 },
0085 [ARIZONA_IRQ_ASRC2_LOCK] = {
0086 .reg_offset = 2, .mask = ARIZONA_ASRC2_LOCK_EINT1
0087 },
0088 [ARIZONA_IRQ_ASRC1_LOCK] = {
0089 .reg_offset = 2, .mask = ARIZONA_ASRC1_LOCK_EINT1
0090 },
0091 [ARIZONA_IRQ_UNDERCLOCKED] = {
0092 .reg_offset = 2, .mask = ARIZONA_UNDERCLOCKED_EINT1
0093 },
0094 [ARIZONA_IRQ_OVERCLOCKED] = {
0095 .reg_offset = 2, .mask = ARIZONA_OVERCLOCKED_EINT1
0096 },
0097 [ARIZONA_IRQ_FLL2_LOCK] = {
0098 .reg_offset = 2, .mask = ARIZONA_FLL2_LOCK_EINT1
0099 },
0100 [ARIZONA_IRQ_FLL1_LOCK] = {
0101 .reg_offset = 2, .mask = ARIZONA_FLL1_LOCK_EINT1
0102 },
0103 [ARIZONA_IRQ_CLKGEN_ERR] = {
0104 .reg_offset = 2, .mask = ARIZONA_CLKGEN_ERR_EINT1
0105 },
0106 [ARIZONA_IRQ_CLKGEN_ERR_ASYNC] = {
0107 .reg_offset = 2, .mask = ARIZONA_CLKGEN_ERR_ASYNC_EINT1
0108 },
0109
0110 [ARIZONA_IRQ_CTRLIF_ERR] = {
0111 .reg_offset = 3, .mask = ARIZONA_V2_CTRLIF_ERR_EINT1
0112 },
0113 [ARIZONA_IRQ_MIXER_DROPPED_SAMPLES] = {
0114 .reg_offset = 3, .mask = ARIZONA_V2_MIXER_DROPPED_SAMPLE_EINT1
0115 },
0116 [ARIZONA_IRQ_ASYNC_CLK_ENA_LOW] = {
0117 .reg_offset = 3, .mask = ARIZONA_V2_ASYNC_CLK_ENA_LOW_EINT1
0118 },
0119 [ARIZONA_IRQ_SYSCLK_ENA_LOW] = {
0120 .reg_offset = 3, .mask = ARIZONA_V2_SYSCLK_ENA_LOW_EINT1
0121 },
0122 [ARIZONA_IRQ_ISRC1_CFG_ERR] = {
0123 .reg_offset = 3, .mask = ARIZONA_V2_ISRC1_CFG_ERR_EINT1
0124 },
0125 [ARIZONA_IRQ_ISRC2_CFG_ERR] = {
0126 .reg_offset = 3, .mask = ARIZONA_V2_ISRC2_CFG_ERR_EINT1
0127 },
0128 [ARIZONA_IRQ_ISRC3_CFG_ERR] = {
0129 .reg_offset = 3, .mask = ARIZONA_V2_ISRC3_CFG_ERR_EINT1
0130 },
0131 [ARIZONA_IRQ_HP1R_DONE] = {
0132 .reg_offset = 3, .mask = ARIZONA_HP1R_DONE_EINT1
0133 },
0134 [ARIZONA_IRQ_HP1L_DONE] = {
0135 .reg_offset = 3, .mask = ARIZONA_HP1L_DONE_EINT1
0136 },
0137
0138 [ARIZONA_IRQ_BOOT_DONE] = {
0139 .reg_offset = 4, .mask = ARIZONA_BOOT_DONE_EINT1
0140 },
0141 [ARIZONA_IRQ_ASRC_CFG_ERR] = {
0142 .reg_offset = 4, .mask = ARIZONA_V2_ASRC_CFG_ERR_EINT1
0143 },
0144 [ARIZONA_IRQ_FLL2_CLOCK_OK] = {
0145 .reg_offset = 4, .mask = ARIZONA_FLL2_CLOCK_OK_EINT1
0146 },
0147 [ARIZONA_IRQ_FLL1_CLOCK_OK] = {
0148 .reg_offset = 4, .mask = ARIZONA_FLL1_CLOCK_OK_EINT1
0149 },
0150
0151 [ARIZONA_IRQ_DSP_SHARED_WR_COLL] = {
0152 .reg_offset = 5, .mask = ARIZONA_DSP_SHARED_WR_COLL_EINT1
0153 },
0154 [ARIZONA_IRQ_SPK_SHUTDOWN] = {
0155 .reg_offset = 5, .mask = ARIZONA_SPK_SHUTDOWN_EINT1
0156 },
0157 [ARIZONA_IRQ_SPK1R_SHORT] = {
0158 .reg_offset = 5, .mask = ARIZONA_SPK1R_SHORT_EINT1
0159 },
0160 [ARIZONA_IRQ_SPK1L_SHORT] = {
0161 .reg_offset = 5, .mask = ARIZONA_SPK1L_SHORT_EINT1
0162 },
0163 [ARIZONA_IRQ_HP1R_SC_POS] = {
0164 .reg_offset = 5, .mask = ARIZONA_HP1R_SC_POS_EINT1
0165 },
0166 [ARIZONA_IRQ_HP1L_SC_POS] = {
0167 .reg_offset = 5, .mask = ARIZONA_HP1L_SC_POS_EINT1
0168 },
0169 };
0170
0171 const struct regmap_irq_chip cs47l24_irq = {
0172 .name = "cs47l24 IRQ",
0173 .status_base = ARIZONA_INTERRUPT_STATUS_1,
0174 .mask_base = ARIZONA_INTERRUPT_STATUS_1_MASK,
0175 .ack_base = ARIZONA_INTERRUPT_STATUS_1,
0176 .num_regs = 6,
0177 .irqs = cs47l24_irqs,
0178 .num_irqs = ARRAY_SIZE(cs47l24_irqs),
0179 };
0180 EXPORT_SYMBOL_GPL(cs47l24_irq);
0181
0182 static const struct reg_default cs47l24_reg_default[] = {
0183 { 0x00000008, 0x0019 },
0184 { 0x00000020, 0x0000 },
0185 { 0x00000021, 0x1000 },
0186 { 0x00000022, 0x0000 },
0187 { 0x00000023, 0x1000 },
0188 { 0x00000024, 0x0000 },
0189 { 0x00000030, 0x0000 },
0190 { 0x00000031, 0x0100 },
0191 { 0x00000032, 0x0100 },
0192 { 0x00000041, 0x0000 },
0193 { 0x00000061, 0x01FF },
0194 { 0x00000062, 0x01FF },
0195 { 0x00000063, 0x01FF },
0196 { 0x00000064, 0x01FF },
0197 { 0x00000070, 0x0000 },
0198 { 0x00000090, 0x0000 },
0199 { 0x00000091, 0x7FFF },
0200 { 0x00000092, 0x0000 },
0201 { 0x00000093, 0x0000 },
0202 { 0x00000094, 0x0000 },
0203 { 0x00000095, 0x0000 },
0204 { 0x00000096, 0x0000 },
0205 { 0x00000097, 0x0000 },
0206 { 0x00000100, 0x0002 },
0207 { 0x00000101, 0x0504 },
0208 { 0x00000102, 0x0011 },
0209 { 0x00000103, 0x0011 },
0210 { 0x00000104, 0x0011 },
0211 { 0x00000112, 0x0305 },
0212 { 0x00000113, 0x0011 },
0213 { 0x00000114, 0x0011 },
0214 { 0x00000149, 0x0000 },
0215 { 0x0000014A, 0x0000 },
0216 { 0x00000152, 0x0000 },
0217 { 0x00000153, 0x0000 },
0218 { 0x00000154, 0x0000 },
0219 { 0x00000155, 0x0000 },
0220 { 0x00000156, 0x0000 },
0221 { 0x00000171, 0x0002 },
0222 { 0x00000172, 0x0008 },
0223 { 0x00000173, 0x0018 },
0224 { 0x00000174, 0x007D },
0225 { 0x00000175, 0x0006 },
0226 { 0x00000176, 0x0000 },
0227 { 0x00000179, 0x0000 },
0228 { 0x00000181, 0x0000 },
0229 { 0x00000182, 0x0000 },
0230 { 0x00000183, 0x0000 },
0231 { 0x00000184, 0x0000 },
0232 { 0x00000185, 0x0000 },
0233 { 0x00000186, 0x0000 },
0234 { 0x00000187, 0x0001 },
0235 { 0x00000189, 0x0000 },
0236 { 0x0000018A, 0x000C },
0237 { 0x00000191, 0x0002 },
0238 { 0x00000192, 0x0008 },
0239 { 0x00000193, 0x0018 },
0240 { 0x00000194, 0x007D },
0241 { 0x00000195, 0x000C },
0242 { 0x00000196, 0x0000 },
0243 { 0x00000199, 0x0000 },
0244 { 0x000001A1, 0x0000 },
0245 { 0x000001A2, 0x0000 },
0246 { 0x000001A3, 0x0000 },
0247 { 0x000001A4, 0x0000 },
0248 { 0x000001A5, 0x0000 },
0249 { 0x000001A6, 0x0000 },
0250 { 0x000001A7, 0x0001 },
0251 { 0x000001A9, 0x0000 },
0252 { 0x000001AA, 0x000C },
0253 { 0x00000218, 0x00E6 },
0254 { 0x00000219, 0x00E6 },
0255 { 0x00000300, 0x0000 },
0256 { 0x00000308, 0x0000 },
0257 { 0x00000309, 0x0022 },
0258 { 0x0000030C, 0x0002 },
0259 { 0x00000310, 0x2000 },
0260 { 0x00000311, 0x0180 },
0261 { 0x00000312, 0x0000 },
0262 { 0x00000314, 0x0000 },
0263 { 0x00000315, 0x0180 },
0264 { 0x00000316, 0x0000 },
0265 { 0x00000318, 0x2000 },
0266 { 0x00000319, 0x0180 },
0267 { 0x0000031A, 0x0000 },
0268 { 0x0000031C, 0x0000 },
0269 { 0x0000031D, 0x0180 },
0270 { 0x0000031E, 0x0000 },
0271 { 0x00000400, 0x0000 },
0272 { 0x00000408, 0x0000 },
0273 { 0x00000409, 0x0022 },
0274 { 0x00000410, 0x0080 },
0275 { 0x00000411, 0x0180 },
0276 { 0x00000412, 0x0081 },
0277 { 0x00000413, 0x0001 },
0278 { 0x00000415, 0x0180 },
0279 { 0x00000416, 0x0081 },
0280 { 0x00000417, 0x0002 },
0281 { 0x00000429, 0x0180 },
0282 { 0x0000042A, 0x0081 },
0283 { 0x0000042B, 0x0040 },
0284 { 0x00000450, 0x0000 },
0285 { 0x00000458, 0x0000 },
0286 { 0x000004A0, 0x3480 },
0287 { 0x00000500, 0x000C },
0288 { 0x00000501, 0x0008 },
0289 { 0x00000502, 0x0000 },
0290 { 0x00000503, 0x0000 },
0291 { 0x00000504, 0x0000 },
0292 { 0x00000505, 0x0040 },
0293 { 0x00000506, 0x0040 },
0294 { 0x00000507, 0x1818 },
0295 { 0x00000508, 0x1818 },
0296 { 0x00000509, 0x0000 },
0297 { 0x0000050A, 0x0001 },
0298 { 0x0000050B, 0x0002 },
0299 { 0x0000050C, 0x0003 },
0300 { 0x0000050D, 0x0004 },
0301 { 0x0000050E, 0x0005 },
0302 { 0x0000050F, 0x0006 },
0303 { 0x00000510, 0x0007 },
0304 { 0x00000511, 0x0000 },
0305 { 0x00000512, 0x0001 },
0306 { 0x00000513, 0x0002 },
0307 { 0x00000514, 0x0003 },
0308 { 0x00000515, 0x0004 },
0309 { 0x00000516, 0x0005 },
0310 { 0x00000517, 0x0006 },
0311 { 0x00000518, 0x0007 },
0312 { 0x00000519, 0x0000 },
0313 { 0x0000051A, 0x0000 },
0314 { 0x00000540, 0x000C },
0315 { 0x00000541, 0x0008 },
0316 { 0x00000542, 0x0000 },
0317 { 0x00000543, 0x0000 },
0318 { 0x00000544, 0x0000 },
0319 { 0x00000545, 0x0040 },
0320 { 0x00000546, 0x0040 },
0321 { 0x00000547, 0x1818 },
0322 { 0x00000548, 0x1818 },
0323 { 0x00000549, 0x0000 },
0324 { 0x0000054A, 0x0001 },
0325 { 0x0000054B, 0x0002 },
0326 { 0x0000054C, 0x0003 },
0327 { 0x0000054D, 0x0004 },
0328 { 0x0000054E, 0x0005 },
0329 { 0x00000551, 0x0000 },
0330 { 0x00000552, 0x0001 },
0331 { 0x00000553, 0x0002 },
0332 { 0x00000554, 0x0003 },
0333 { 0x00000555, 0x0004 },
0334 { 0x00000556, 0x0005 },
0335 { 0x00000559, 0x0000 },
0336 { 0x0000055A, 0x0000 },
0337 { 0x00000580, 0x000C },
0338 { 0x00000581, 0x0008 },
0339 { 0x00000582, 0x0000 },
0340 { 0x00000583, 0x0000 },
0341 { 0x00000584, 0x0000 },
0342 { 0x00000585, 0x0040 },
0343 { 0x00000586, 0x0040 },
0344 { 0x00000587, 0x1818 },
0345 { 0x00000588, 0x1818 },
0346 { 0x00000589, 0x0000 },
0347 { 0x0000058A, 0x0001 },
0348 { 0x00000591, 0x0000 },
0349 { 0x00000592, 0x0001 },
0350 { 0x00000599, 0x0000 },
0351 { 0x0000059A, 0x0000 },
0352 { 0x00000640, 0x0000 },
0353 { 0x00000641, 0x0080 },
0354 { 0x00000642, 0x0000 },
0355 { 0x00000643, 0x0080 },
0356 { 0x00000644, 0x0000 },
0357 { 0x00000645, 0x0080 },
0358 { 0x00000646, 0x0000 },
0359 { 0x00000647, 0x0080 },
0360 { 0x00000648, 0x0000 },
0361 { 0x00000649, 0x0080 },
0362 { 0x0000064A, 0x0000 },
0363 { 0x0000064B, 0x0080 },
0364 { 0x0000064C, 0x0000 },
0365 { 0x0000064D, 0x0080 },
0366 { 0x0000064E, 0x0000 },
0367 { 0x0000064F, 0x0080 },
0368 { 0x00000680, 0x0000 },
0369 { 0x00000681, 0x0080 },
0370 { 0x00000682, 0x0000 },
0371 { 0x00000683, 0x0080 },
0372 { 0x00000684, 0x0000 },
0373 { 0x00000685, 0x0080 },
0374 { 0x00000686, 0x0000 },
0375 { 0x00000687, 0x0080 },
0376 { 0x00000688, 0x0000 },
0377 { 0x00000689, 0x0080 },
0378 { 0x0000068A, 0x0000 },
0379 { 0x0000068B, 0x0080 },
0380 { 0x0000068C, 0x0000 },
0381 { 0x0000068D, 0x0080 },
0382 { 0x0000068E, 0x0000 },
0383 { 0x0000068F, 0x0080 },
0384 { 0x000006B0, 0x0000 },
0385 { 0x000006B1, 0x0080 },
0386 { 0x000006B2, 0x0000 },
0387 { 0x000006B3, 0x0080 },
0388 { 0x000006B4, 0x0000 },
0389 { 0x000006B5, 0x0080 },
0390 { 0x000006B6, 0x0000 },
0391 { 0x000006B7, 0x0080 },
0392 { 0x00000700, 0x0000 },
0393 { 0x00000701, 0x0080 },
0394 { 0x00000702, 0x0000 },
0395 { 0x00000703, 0x0080 },
0396 { 0x00000704, 0x0000 },
0397 { 0x00000705, 0x0080 },
0398 { 0x00000706, 0x0000 },
0399 { 0x00000707, 0x0080 },
0400 { 0x00000708, 0x0000 },
0401 { 0x00000709, 0x0080 },
0402 { 0x0000070A, 0x0000 },
0403 { 0x0000070B, 0x0080 },
0404 { 0x0000070C, 0x0000 },
0405 { 0x0000070D, 0x0080 },
0406 { 0x0000070E, 0x0000 },
0407 { 0x0000070F, 0x0080 },
0408 { 0x00000710, 0x0000 },
0409 { 0x00000711, 0x0080 },
0410 { 0x00000712, 0x0000 },
0411 { 0x00000713, 0x0080 },
0412 { 0x00000714, 0x0000 },
0413 { 0x00000715, 0x0080 },
0414 { 0x00000716, 0x0000 },
0415 { 0x00000717, 0x0080 },
0416 { 0x00000718, 0x0000 },
0417 { 0x00000719, 0x0080 },
0418 { 0x0000071A, 0x0000 },
0419 { 0x0000071B, 0x0080 },
0420 { 0x0000071C, 0x0000 },
0421 { 0x0000071D, 0x0080 },
0422 { 0x0000071E, 0x0000 },
0423 { 0x0000071F, 0x0080 },
0424 { 0x00000720, 0x0000 },
0425 { 0x00000721, 0x0080 },
0426 { 0x00000722, 0x0000 },
0427 { 0x00000723, 0x0080 },
0428 { 0x00000724, 0x0000 },
0429 { 0x00000725, 0x0080 },
0430 { 0x00000726, 0x0000 },
0431 { 0x00000727, 0x0080 },
0432 { 0x00000728, 0x0000 },
0433 { 0x00000729, 0x0080 },
0434 { 0x0000072A, 0x0000 },
0435 { 0x0000072B, 0x0080 },
0436 { 0x0000072C, 0x0000 },
0437 { 0x0000072D, 0x0080 },
0438 { 0x0000072E, 0x0000 },
0439 { 0x0000072F, 0x0080 },
0440 { 0x00000730, 0x0000 },
0441 { 0x00000731, 0x0080 },
0442 { 0x00000732, 0x0000 },
0443 { 0x00000733, 0x0080 },
0444 { 0x00000734, 0x0000 },
0445 { 0x00000735, 0x0080 },
0446 { 0x00000736, 0x0000 },
0447 { 0x00000737, 0x0080 },
0448 { 0x00000738, 0x0000 },
0449 { 0x00000739, 0x0080 },
0450 { 0x0000073A, 0x0000 },
0451 { 0x0000073B, 0x0080 },
0452 { 0x0000073C, 0x0000 },
0453 { 0x0000073D, 0x0080 },
0454 { 0x0000073E, 0x0000 },
0455 { 0x0000073F, 0x0080 },
0456 { 0x00000740, 0x0000 },
0457 { 0x00000741, 0x0080 },
0458 { 0x00000742, 0x0000 },
0459 { 0x00000743, 0x0080 },
0460 { 0x00000744, 0x0000 },
0461 { 0x00000745, 0x0080 },
0462 { 0x00000746, 0x0000 },
0463 { 0x00000747, 0x0080 },
0464 { 0x00000748, 0x0000 },
0465 { 0x00000749, 0x0080 },
0466 { 0x0000074A, 0x0000 },
0467 { 0x0000074B, 0x0080 },
0468 { 0x0000074C, 0x0000 },
0469 { 0x0000074D, 0x0080 },
0470 { 0x0000074E, 0x0000 },
0471 { 0x0000074F, 0x0080 },
0472 { 0x00000750, 0x0000 },
0473 { 0x00000751, 0x0080 },
0474 { 0x00000752, 0x0000 },
0475 { 0x00000753, 0x0080 },
0476 { 0x00000754, 0x0000 },
0477 { 0x00000755, 0x0080 },
0478 { 0x00000756, 0x0000 },
0479 { 0x00000757, 0x0080 },
0480 { 0x00000758, 0x0000 },
0481 { 0x00000759, 0x0080 },
0482 { 0x0000075A, 0x0000 },
0483 { 0x0000075B, 0x0080 },
0484 { 0x0000075C, 0x0000 },
0485 { 0x0000075D, 0x0080 },
0486 { 0x0000075E, 0x0000 },
0487 { 0x0000075F, 0x0080 },
0488 { 0x00000760, 0x0000 },
0489 { 0x00000761, 0x0080 },
0490 { 0x00000762, 0x0000 },
0491 { 0x00000763, 0x0080 },
0492 { 0x00000764, 0x0000 },
0493 { 0x00000765, 0x0080 },
0494 { 0x00000766, 0x0000 },
0495 { 0x00000767, 0x0080 },
0496 { 0x00000768, 0x0000 },
0497 { 0x00000769, 0x0080 },
0498 { 0x0000076A, 0x0000 },
0499 { 0x0000076B, 0x0080 },
0500 { 0x0000076C, 0x0000 },
0501 { 0x0000076D, 0x0080 },
0502 { 0x0000076E, 0x0000 },
0503 { 0x0000076F, 0x0080 },
0504 { 0x00000780, 0x0000 },
0505 { 0x00000781, 0x0080 },
0506 { 0x00000782, 0x0000 },
0507 { 0x00000783, 0x0080 },
0508 { 0x00000784, 0x0000 },
0509 { 0x00000785, 0x0080 },
0510 { 0x00000786, 0x0000 },
0511 { 0x00000787, 0x0080 },
0512 { 0x00000788, 0x0000 },
0513 { 0x00000789, 0x0080 },
0514 { 0x0000078A, 0x0000 },
0515 { 0x0000078B, 0x0080 },
0516 { 0x0000078C, 0x0000 },
0517 { 0x0000078D, 0x0080 },
0518 { 0x0000078E, 0x0000 },
0519 { 0x0000078F, 0x0080 },
0520 { 0x00000880, 0x0000 },
0521 { 0x00000881, 0x0080 },
0522 { 0x00000882, 0x0000 },
0523 { 0x00000883, 0x0080 },
0524 { 0x00000884, 0x0000 },
0525 { 0x00000885, 0x0080 },
0526 { 0x00000886, 0x0000 },
0527 { 0x00000887, 0x0080 },
0528 { 0x00000888, 0x0000 },
0529 { 0x00000889, 0x0080 },
0530 { 0x0000088A, 0x0000 },
0531 { 0x0000088B, 0x0080 },
0532 { 0x0000088C, 0x0000 },
0533 { 0x0000088D, 0x0080 },
0534 { 0x0000088E, 0x0000 },
0535 { 0x0000088F, 0x0080 },
0536 { 0x000008C0, 0x0000 },
0537 { 0x000008C1, 0x0080 },
0538 { 0x000008C2, 0x0000 },
0539 { 0x000008C3, 0x0080 },
0540 { 0x000008C4, 0x0000 },
0541 { 0x000008C5, 0x0080 },
0542 { 0x000008C6, 0x0000 },
0543 { 0x000008C7, 0x0080 },
0544 { 0x000008C8, 0x0000 },
0545 { 0x000008C9, 0x0080 },
0546 { 0x000008CA, 0x0000 },
0547 { 0x000008CB, 0x0080 },
0548 { 0x000008CC, 0x0000 },
0549 { 0x000008CD, 0x0080 },
0550 { 0x000008CE, 0x0000 },
0551 { 0x000008CF, 0x0080 },
0552 { 0x000008D0, 0x0000 },
0553 { 0x000008D1, 0x0080 },
0554 { 0x000008D2, 0x0000 },
0555 { 0x000008D3, 0x0080 },
0556 { 0x000008D4, 0x0000 },
0557 { 0x000008D5, 0x0080 },
0558 { 0x000008D6, 0x0000 },
0559 { 0x000008D7, 0x0080 },
0560 { 0x000008D8, 0x0000 },
0561 { 0x000008D9, 0x0080 },
0562 { 0x000008DA, 0x0000 },
0563 { 0x000008DB, 0x0080 },
0564 { 0x000008DC, 0x0000 },
0565 { 0x000008DD, 0x0080 },
0566 { 0x000008DE, 0x0000 },
0567 { 0x000008DF, 0x0080 },
0568 { 0x00000900, 0x0000 },
0569 { 0x00000901, 0x0080 },
0570 { 0x00000902, 0x0000 },
0571 { 0x00000903, 0x0080 },
0572 { 0x00000904, 0x0000 },
0573 { 0x00000905, 0x0080 },
0574 { 0x00000906, 0x0000 },
0575 { 0x00000907, 0x0080 },
0576 { 0x00000908, 0x0000 },
0577 { 0x00000909, 0x0080 },
0578 { 0x0000090A, 0x0000 },
0579 { 0x0000090B, 0x0080 },
0580 { 0x0000090C, 0x0000 },
0581 { 0x0000090D, 0x0080 },
0582 { 0x0000090E, 0x0000 },
0583 { 0x0000090F, 0x0080 },
0584 { 0x00000910, 0x0000 },
0585 { 0x00000911, 0x0080 },
0586 { 0x00000912, 0x0000 },
0587 { 0x00000913, 0x0080 },
0588 { 0x00000914, 0x0000 },
0589 { 0x00000915, 0x0080 },
0590 { 0x00000916, 0x0000 },
0591 { 0x00000917, 0x0080 },
0592 { 0x00000918, 0x0000 },
0593 { 0x00000919, 0x0080 },
0594 { 0x0000091A, 0x0000 },
0595 { 0x0000091B, 0x0080 },
0596 { 0x0000091C, 0x0000 },
0597 { 0x0000091D, 0x0080 },
0598 { 0x0000091E, 0x0000 },
0599 { 0x0000091F, 0x0080 },
0600 { 0x00000980, 0x0000 },
0601 { 0x00000981, 0x0080 },
0602 { 0x00000982, 0x0000 },
0603 { 0x00000983, 0x0080 },
0604 { 0x00000984, 0x0000 },
0605 { 0x00000985, 0x0080 },
0606 { 0x00000986, 0x0000 },
0607 { 0x00000987, 0x0080 },
0608 { 0x00000988, 0x0000 },
0609 { 0x00000989, 0x0080 },
0610 { 0x0000098A, 0x0000 },
0611 { 0x0000098B, 0x0080 },
0612 { 0x0000098C, 0x0000 },
0613 { 0x0000098D, 0x0080 },
0614 { 0x0000098E, 0x0000 },
0615 { 0x0000098F, 0x0080 },
0616 { 0x00000990, 0x0000 },
0617 { 0x00000998, 0x0000 },
0618 { 0x000009A0, 0x0000 },
0619 { 0x000009A8, 0x0000 },
0620 { 0x000009B0, 0x0000 },
0621 { 0x000009B8, 0x0000 },
0622 { 0x000009C0, 0x0000 },
0623 { 0x000009C1, 0x0080 },
0624 { 0x000009C2, 0x0000 },
0625 { 0x000009C3, 0x0080 },
0626 { 0x000009C4, 0x0000 },
0627 { 0x000009C5, 0x0080 },
0628 { 0x000009C6, 0x0000 },
0629 { 0x000009C7, 0x0080 },
0630 { 0x000009C8, 0x0000 },
0631 { 0x000009C9, 0x0080 },
0632 { 0x000009CA, 0x0000 },
0633 { 0x000009CB, 0x0080 },
0634 { 0x000009CC, 0x0000 },
0635 { 0x000009CD, 0x0080 },
0636 { 0x000009CE, 0x0000 },
0637 { 0x000009CF, 0x0080 },
0638 { 0x000009D0, 0x0000 },
0639 { 0x000009D8, 0x0000 },
0640 { 0x000009E0, 0x0000 },
0641 { 0x000009E8, 0x0000 },
0642 { 0x000009F0, 0x0000 },
0643 { 0x000009F8, 0x0000 },
0644 { 0x00000A80, 0x0000 },
0645 { 0x00000A88, 0x0000 },
0646 { 0x00000A90, 0x0000 },
0647 { 0x00000A98, 0x0000 },
0648 { 0x00000B00, 0x0000 },
0649 { 0x00000B08, 0x0000 },
0650 { 0x00000B10, 0x0000 },
0651 { 0x00000B18, 0x0000 },
0652 { 0x00000B20, 0x0000 },
0653 { 0x00000B28, 0x0000 },
0654 { 0x00000B30, 0x0000 },
0655 { 0x00000B38, 0x0000 },
0656 { 0x00000B40, 0x0000 },
0657 { 0x00000B48, 0x0000 },
0658 { 0x00000B50, 0x0000 },
0659 { 0x00000B58, 0x0000 },
0660 { 0x00000B60, 0x0000 },
0661 { 0x00000B68, 0x0000 },
0662 { 0x00000B70, 0x0000 },
0663 { 0x00000B78, 0x0000 },
0664 { 0x00000B80, 0x0000 },
0665 { 0x00000B88, 0x0000 },
0666 { 0x00000B90, 0x0000 },
0667 { 0x00000B98, 0x0000 },
0668 { 0x00000BA0, 0x0000 },
0669 { 0x00000BA8, 0x0000 },
0670 { 0x00000BB0, 0x0000 },
0671 { 0x00000BB8, 0x0000 },
0672 { 0x00000C00, 0xA101 },
0673 { 0x00000C01, 0xA101 },
0674 { 0x00000C0F, 0x0400 },
0675 { 0x00000C10, 0x1000 },
0676 { 0x00000C20, 0x0002 },
0677 { 0x00000C21, 0x0000 },
0678 { 0x00000C22, 0x0000 },
0679 { 0x00000C23, 0x0000 },
0680 { 0x00000C24, 0x0000 },
0681 { 0x00000C25, 0x0000 },
0682 { 0x00000C30, 0x0404 },
0683 { 0x00000C32, 0x0404 },
0684 { 0x00000C33, 0x0404 },
0685 { 0x00000C34, 0x0404 },
0686 { 0x00000C35, 0x0404 },
0687 { 0x00000C36, 0x0400 },
0688 { 0x00000C37, 0x0404 },
0689 { 0x00000C39, 0x0400 },
0690 { 0x00000D08, 0x0007 },
0691 { 0x00000D09, 0x06FF },
0692 { 0x00000D0A, 0xCFEF },
0693 { 0x00000D0B, 0xFFC3 },
0694 { 0x00000D0C, 0x000B },
0695 { 0x00000D0D, 0xD005 },
0696 { 0x00000D0F, 0x0000 },
0697 { 0x00000D18, 0x0007 },
0698 { 0x00000D19, 0x06FF },
0699 { 0x00000D1A, 0xCFEF },
0700 { 0x00000D1B, 0xFFC3 },
0701 { 0x00000D1C, 0x000B },
0702 { 0x00000D1D, 0xD005 },
0703 { 0x00000D1F, 0x0000 },
0704 { 0x00000E00, 0x0000 },
0705 { 0x00000E10, 0x6318 },
0706 { 0x00000E11, 0x6300 },
0707 { 0x00000E12, 0x0FC8 },
0708 { 0x00000E13, 0x03FE },
0709 { 0x00000E14, 0x00E0 },
0710 { 0x00000E15, 0x1EC4 },
0711 { 0x00000E16, 0xF136 },
0712 { 0x00000E17, 0x0409 },
0713 { 0x00000E18, 0x04CC },
0714 { 0x00000E19, 0x1C9B },
0715 { 0x00000E1A, 0xF337 },
0716 { 0x00000E1B, 0x040B },
0717 { 0x00000E1C, 0x0CBB },
0718 { 0x00000E1D, 0x16F8 },
0719 { 0x00000E1E, 0xF7D9 },
0720 { 0x00000E1F, 0x040A },
0721 { 0x00000E20, 0x1F14 },
0722 { 0x00000E21, 0x058C },
0723 { 0x00000E22, 0x0563 },
0724 { 0x00000E23, 0x4000 },
0725 { 0x00000E24, 0x0B75 },
0726 { 0x00000E26, 0x6318 },
0727 { 0x00000E27, 0x6300 },
0728 { 0x00000E28, 0x0FC8 },
0729 { 0x00000E29, 0x03FE },
0730 { 0x00000E2A, 0x00E0 },
0731 { 0x00000E2B, 0x1EC4 },
0732 { 0x00000E2C, 0xF136 },
0733 { 0x00000E2D, 0x0409 },
0734 { 0x00000E2E, 0x04CC },
0735 { 0x00000E2F, 0x1C9B },
0736 { 0x00000E30, 0xF337 },
0737 { 0x00000E31, 0x040B },
0738 { 0x00000E32, 0x0CBB },
0739 { 0x00000E33, 0x16F8 },
0740 { 0x00000E34, 0xF7D9 },
0741 { 0x00000E35, 0x040A },
0742 { 0x00000E36, 0x1F14 },
0743 { 0x00000E37, 0x058C },
0744 { 0x00000E38, 0x0563 },
0745 { 0x00000E39, 0x4000 },
0746 { 0x00000E3A, 0x0B75 },
0747 { 0x00000E80, 0x0018 },
0748 { 0x00000E81, 0x0933 },
0749 { 0x00000E82, 0x0018 },
0750 { 0x00000E83, 0x0000 },
0751 { 0x00000E84, 0x0000 },
0752 { 0x00000E89, 0x0018 },
0753 { 0x00000E8A, 0x0933 },
0754 { 0x00000E8B, 0x0018 },
0755 { 0x00000E8C, 0x0000 },
0756 { 0x00000E8D, 0x0000 },
0757 { 0x00000EC0, 0x0000 },
0758 { 0x00000EC1, 0x0000 },
0759 { 0x00000EC4, 0x0000 },
0760 { 0x00000EC5, 0x0000 },
0761 { 0x00000EC8, 0x0000 },
0762 { 0x00000EC9, 0x0000 },
0763 { 0x00000ECC, 0x0000 },
0764 { 0x00000ECD, 0x0000 },
0765 { 0x00000EE0, 0x0000 },
0766 { 0x00000EE2, 0x0000 },
0767 { 0x00000EE3, 0x4000 },
0768 { 0x00000EF0, 0x0000 },
0769 { 0x00000EF1, 0x0000 },
0770 { 0x00000EF2, 0x0000 },
0771 { 0x00000EF3, 0x0000 },
0772 { 0x00000EF4, 0x0000 },
0773 { 0x00000EF5, 0x0000 },
0774 { 0x00000EF6, 0x0000 },
0775 { 0x00000EF7, 0x0000 },
0776 { 0x00000EF8, 0x0000 },
0777 { 0x00001200, 0x0010 },
0778 { 0x00001300, 0x0010 },
0779 };
0780
0781 static bool cs47l24_is_adsp_memory(unsigned int reg)
0782 {
0783 switch (reg) {
0784 case 0x200000 ... 0x205fff:
0785 case 0x280000 ... 0x281fff:
0786 case 0x290000 ... 0x2a7fff:
0787 case 0x2a8000 ... 0x2b3fff:
0788 case 0x300000 ... 0x308fff:
0789 case 0x380000 ... 0x381fff:
0790 case 0x390000 ... 0x3a7fff:
0791 case 0x3a8000 ... 0x3b3fff:
0792 return true;
0793 default:
0794 return false;
0795 }
0796 }
0797
0798 static bool cs47l24_readable_register(struct device *dev, unsigned int reg)
0799 {
0800 switch (reg) {
0801 case ARIZONA_SOFTWARE_RESET:
0802 case ARIZONA_DEVICE_REVISION:
0803 case ARIZONA_CTRL_IF_SPI_CFG_1:
0804 case ARIZONA_WRITE_SEQUENCER_CTRL_0:
0805 case ARIZONA_WRITE_SEQUENCER_CTRL_1:
0806 case ARIZONA_WRITE_SEQUENCER_CTRL_2:
0807 case ARIZONA_TONE_GENERATOR_1:
0808 case ARIZONA_TONE_GENERATOR_2:
0809 case ARIZONA_TONE_GENERATOR_3:
0810 case ARIZONA_TONE_GENERATOR_4:
0811 case ARIZONA_TONE_GENERATOR_5:
0812 case ARIZONA_PWM_DRIVE_1:
0813 case ARIZONA_PWM_DRIVE_2:
0814 case ARIZONA_PWM_DRIVE_3:
0815 case ARIZONA_SEQUENCE_CONTROL:
0816 case ARIZONA_SAMPLE_RATE_SEQUENCE_SELECT_1:
0817 case ARIZONA_SAMPLE_RATE_SEQUENCE_SELECT_2:
0818 case ARIZONA_SAMPLE_RATE_SEQUENCE_SELECT_3:
0819 case ARIZONA_SAMPLE_RATE_SEQUENCE_SELECT_4:
0820 case ARIZONA_COMFORT_NOISE_GENERATOR:
0821 case ARIZONA_HAPTICS_CONTROL_1:
0822 case ARIZONA_HAPTICS_CONTROL_2:
0823 case ARIZONA_HAPTICS_PHASE_1_INTENSITY:
0824 case ARIZONA_HAPTICS_PHASE_1_DURATION:
0825 case ARIZONA_HAPTICS_PHASE_2_INTENSITY:
0826 case ARIZONA_HAPTICS_PHASE_2_DURATION:
0827 case ARIZONA_HAPTICS_PHASE_3_INTENSITY:
0828 case ARIZONA_HAPTICS_PHASE_3_DURATION:
0829 case ARIZONA_HAPTICS_STATUS:
0830 case ARIZONA_CLOCK_32K_1:
0831 case ARIZONA_SYSTEM_CLOCK_1:
0832 case ARIZONA_SAMPLE_RATE_1:
0833 case ARIZONA_SAMPLE_RATE_2:
0834 case ARIZONA_SAMPLE_RATE_3:
0835 case ARIZONA_SAMPLE_RATE_1_STATUS:
0836 case ARIZONA_SAMPLE_RATE_2_STATUS:
0837 case ARIZONA_SAMPLE_RATE_3_STATUS:
0838 case ARIZONA_ASYNC_CLOCK_1:
0839 case ARIZONA_ASYNC_SAMPLE_RATE_1:
0840 case ARIZONA_ASYNC_SAMPLE_RATE_1_STATUS:
0841 case ARIZONA_ASYNC_SAMPLE_RATE_2:
0842 case ARIZONA_ASYNC_SAMPLE_RATE_2_STATUS:
0843 case ARIZONA_OUTPUT_SYSTEM_CLOCK:
0844 case ARIZONA_OUTPUT_ASYNC_CLOCK:
0845 case ARIZONA_RATE_ESTIMATOR_1:
0846 case ARIZONA_RATE_ESTIMATOR_2:
0847 case ARIZONA_RATE_ESTIMATOR_3:
0848 case ARIZONA_RATE_ESTIMATOR_4:
0849 case ARIZONA_RATE_ESTIMATOR_5:
0850 case ARIZONA_FLL1_CONTROL_1:
0851 case ARIZONA_FLL1_CONTROL_2:
0852 case ARIZONA_FLL1_CONTROL_3:
0853 case ARIZONA_FLL1_CONTROL_4:
0854 case ARIZONA_FLL1_CONTROL_5:
0855 case ARIZONA_FLL1_CONTROL_6:
0856 case ARIZONA_FLL1_CONTROL_7:
0857 case ARIZONA_FLL1_SYNCHRONISER_1:
0858 case ARIZONA_FLL1_SYNCHRONISER_2:
0859 case ARIZONA_FLL1_SYNCHRONISER_3:
0860 case ARIZONA_FLL1_SYNCHRONISER_4:
0861 case ARIZONA_FLL1_SYNCHRONISER_5:
0862 case ARIZONA_FLL1_SYNCHRONISER_6:
0863 case ARIZONA_FLL1_SYNCHRONISER_7:
0864 case ARIZONA_FLL1_SPREAD_SPECTRUM:
0865 case ARIZONA_FLL1_GPIO_CLOCK:
0866 case ARIZONA_FLL2_CONTROL_1:
0867 case ARIZONA_FLL2_CONTROL_2:
0868 case ARIZONA_FLL2_CONTROL_3:
0869 case ARIZONA_FLL2_CONTROL_4:
0870 case ARIZONA_FLL2_CONTROL_5:
0871 case ARIZONA_FLL2_CONTROL_6:
0872 case ARIZONA_FLL2_CONTROL_7:
0873 case ARIZONA_FLL2_SYNCHRONISER_1:
0874 case ARIZONA_FLL2_SYNCHRONISER_2:
0875 case ARIZONA_FLL2_SYNCHRONISER_3:
0876 case ARIZONA_FLL2_SYNCHRONISER_4:
0877 case ARIZONA_FLL2_SYNCHRONISER_5:
0878 case ARIZONA_FLL2_SYNCHRONISER_6:
0879 case ARIZONA_FLL2_SYNCHRONISER_7:
0880 case ARIZONA_FLL2_SPREAD_SPECTRUM:
0881 case ARIZONA_FLL2_GPIO_CLOCK:
0882 case ARIZONA_MIC_BIAS_CTRL_1:
0883 case ARIZONA_MIC_BIAS_CTRL_2:
0884 case ARIZONA_HP_CTRL_1L:
0885 case ARIZONA_HP_CTRL_1R:
0886 case ARIZONA_INPUT_ENABLES:
0887 case ARIZONA_INPUT_ENABLES_STATUS:
0888 case ARIZONA_INPUT_RATE:
0889 case ARIZONA_INPUT_VOLUME_RAMP:
0890 case ARIZONA_HPF_CONTROL:
0891 case ARIZONA_IN1L_CONTROL:
0892 case ARIZONA_ADC_DIGITAL_VOLUME_1L:
0893 case ARIZONA_DMIC1L_CONTROL:
0894 case ARIZONA_IN1R_CONTROL:
0895 case ARIZONA_ADC_DIGITAL_VOLUME_1R:
0896 case ARIZONA_DMIC1R_CONTROL:
0897 case ARIZONA_IN2L_CONTROL:
0898 case ARIZONA_ADC_DIGITAL_VOLUME_2L:
0899 case ARIZONA_DMIC2L_CONTROL:
0900 case ARIZONA_IN2R_CONTROL:
0901 case ARIZONA_ADC_DIGITAL_VOLUME_2R:
0902 case ARIZONA_DMIC2R_CONTROL:
0903 case ARIZONA_OUTPUT_ENABLES_1:
0904 case ARIZONA_OUTPUT_STATUS_1:
0905 case ARIZONA_RAW_OUTPUT_STATUS_1:
0906 case ARIZONA_OUTPUT_RATE_1:
0907 case ARIZONA_OUTPUT_VOLUME_RAMP:
0908 case ARIZONA_OUTPUT_PATH_CONFIG_1L:
0909 case ARIZONA_DAC_DIGITAL_VOLUME_1L:
0910 case ARIZONA_DAC_VOLUME_LIMIT_1L:
0911 case ARIZONA_NOISE_GATE_SELECT_1L:
0912 case ARIZONA_DAC_DIGITAL_VOLUME_1R:
0913 case ARIZONA_DAC_VOLUME_LIMIT_1R:
0914 case ARIZONA_NOISE_GATE_SELECT_1R:
0915 case ARIZONA_DAC_DIGITAL_VOLUME_4L:
0916 case ARIZONA_OUT_VOLUME_4L:
0917 case ARIZONA_NOISE_GATE_SELECT_4L:
0918 case ARIZONA_DAC_AEC_CONTROL_1:
0919 case ARIZONA_NOISE_GATE_CONTROL:
0920 case ARIZONA_HP1_SHORT_CIRCUIT_CTRL:
0921 case ARIZONA_AIF1_BCLK_CTRL:
0922 case ARIZONA_AIF1_TX_PIN_CTRL:
0923 case ARIZONA_AIF1_RX_PIN_CTRL:
0924 case ARIZONA_AIF1_RATE_CTRL:
0925 case ARIZONA_AIF1_FORMAT:
0926 case ARIZONA_AIF1_TX_BCLK_RATE:
0927 case ARIZONA_AIF1_RX_BCLK_RATE:
0928 case ARIZONA_AIF1_FRAME_CTRL_1:
0929 case ARIZONA_AIF1_FRAME_CTRL_2:
0930 case ARIZONA_AIF1_FRAME_CTRL_3:
0931 case ARIZONA_AIF1_FRAME_CTRL_4:
0932 case ARIZONA_AIF1_FRAME_CTRL_5:
0933 case ARIZONA_AIF1_FRAME_CTRL_6:
0934 case ARIZONA_AIF1_FRAME_CTRL_7:
0935 case ARIZONA_AIF1_FRAME_CTRL_8:
0936 case ARIZONA_AIF1_FRAME_CTRL_9:
0937 case ARIZONA_AIF1_FRAME_CTRL_10:
0938 case ARIZONA_AIF1_FRAME_CTRL_11:
0939 case ARIZONA_AIF1_FRAME_CTRL_12:
0940 case ARIZONA_AIF1_FRAME_CTRL_13:
0941 case ARIZONA_AIF1_FRAME_CTRL_14:
0942 case ARIZONA_AIF1_FRAME_CTRL_15:
0943 case ARIZONA_AIF1_FRAME_CTRL_16:
0944 case ARIZONA_AIF1_FRAME_CTRL_17:
0945 case ARIZONA_AIF1_FRAME_CTRL_18:
0946 case ARIZONA_AIF1_TX_ENABLES:
0947 case ARIZONA_AIF1_RX_ENABLES:
0948 case ARIZONA_AIF2_BCLK_CTRL:
0949 case ARIZONA_AIF2_TX_PIN_CTRL:
0950 case ARIZONA_AIF2_RX_PIN_CTRL:
0951 case ARIZONA_AIF2_RATE_CTRL:
0952 case ARIZONA_AIF2_FORMAT:
0953 case ARIZONA_AIF2_TX_BCLK_RATE:
0954 case ARIZONA_AIF2_RX_BCLK_RATE:
0955 case ARIZONA_AIF2_FRAME_CTRL_1:
0956 case ARIZONA_AIF2_FRAME_CTRL_2:
0957 case ARIZONA_AIF2_FRAME_CTRL_3:
0958 case ARIZONA_AIF2_FRAME_CTRL_4:
0959 case ARIZONA_AIF2_FRAME_CTRL_5:
0960 case ARIZONA_AIF2_FRAME_CTRL_6:
0961 case ARIZONA_AIF2_FRAME_CTRL_7:
0962 case ARIZONA_AIF2_FRAME_CTRL_8:
0963 case ARIZONA_AIF2_FRAME_CTRL_11:
0964 case ARIZONA_AIF2_FRAME_CTRL_12:
0965 case ARIZONA_AIF2_FRAME_CTRL_13:
0966 case ARIZONA_AIF2_FRAME_CTRL_14:
0967 case ARIZONA_AIF2_FRAME_CTRL_15:
0968 case ARIZONA_AIF2_FRAME_CTRL_16:
0969 case ARIZONA_AIF2_TX_ENABLES:
0970 case ARIZONA_AIF2_RX_ENABLES:
0971 case ARIZONA_AIF3_BCLK_CTRL:
0972 case ARIZONA_AIF3_TX_PIN_CTRL:
0973 case ARIZONA_AIF3_RX_PIN_CTRL:
0974 case ARIZONA_AIF3_RATE_CTRL:
0975 case ARIZONA_AIF3_FORMAT:
0976 case ARIZONA_AIF3_TX_BCLK_RATE:
0977 case ARIZONA_AIF3_RX_BCLK_RATE:
0978 case ARIZONA_AIF3_FRAME_CTRL_1:
0979 case ARIZONA_AIF3_FRAME_CTRL_2:
0980 case ARIZONA_AIF3_FRAME_CTRL_3:
0981 case ARIZONA_AIF3_FRAME_CTRL_4:
0982 case ARIZONA_AIF3_FRAME_CTRL_11:
0983 case ARIZONA_AIF3_FRAME_CTRL_12:
0984 case ARIZONA_AIF3_TX_ENABLES:
0985 case ARIZONA_AIF3_RX_ENABLES:
0986 case ARIZONA_PWM1MIX_INPUT_1_SOURCE:
0987 case ARIZONA_PWM1MIX_INPUT_1_VOLUME:
0988 case ARIZONA_PWM1MIX_INPUT_2_SOURCE:
0989 case ARIZONA_PWM1MIX_INPUT_2_VOLUME:
0990 case ARIZONA_PWM1MIX_INPUT_3_SOURCE:
0991 case ARIZONA_PWM1MIX_INPUT_3_VOLUME:
0992 case ARIZONA_PWM1MIX_INPUT_4_SOURCE:
0993 case ARIZONA_PWM1MIX_INPUT_4_VOLUME:
0994 case ARIZONA_PWM2MIX_INPUT_1_SOURCE:
0995 case ARIZONA_PWM2MIX_INPUT_1_VOLUME:
0996 case ARIZONA_PWM2MIX_INPUT_2_SOURCE:
0997 case ARIZONA_PWM2MIX_INPUT_2_VOLUME:
0998 case ARIZONA_PWM2MIX_INPUT_3_SOURCE:
0999 case ARIZONA_PWM2MIX_INPUT_3_VOLUME:
1000 case ARIZONA_PWM2MIX_INPUT_4_SOURCE:
1001 case ARIZONA_PWM2MIX_INPUT_4_VOLUME:
1002 case ARIZONA_OUT1LMIX_INPUT_1_SOURCE:
1003 case ARIZONA_OUT1LMIX_INPUT_1_VOLUME:
1004 case ARIZONA_OUT1LMIX_INPUT_2_SOURCE:
1005 case ARIZONA_OUT1LMIX_INPUT_2_VOLUME:
1006 case ARIZONA_OUT1LMIX_INPUT_3_SOURCE:
1007 case ARIZONA_OUT1LMIX_INPUT_3_VOLUME:
1008 case ARIZONA_OUT1LMIX_INPUT_4_SOURCE:
1009 case ARIZONA_OUT1LMIX_INPUT_4_VOLUME:
1010 case ARIZONA_OUT1RMIX_INPUT_1_SOURCE:
1011 case ARIZONA_OUT1RMIX_INPUT_1_VOLUME:
1012 case ARIZONA_OUT1RMIX_INPUT_2_SOURCE:
1013 case ARIZONA_OUT1RMIX_INPUT_2_VOLUME:
1014 case ARIZONA_OUT1RMIX_INPUT_3_SOURCE:
1015 case ARIZONA_OUT1RMIX_INPUT_3_VOLUME:
1016 case ARIZONA_OUT1RMIX_INPUT_4_SOURCE:
1017 case ARIZONA_OUT1RMIX_INPUT_4_VOLUME:
1018 case ARIZONA_OUT4LMIX_INPUT_1_SOURCE:
1019 case ARIZONA_OUT4LMIX_INPUT_1_VOLUME:
1020 case ARIZONA_OUT4LMIX_INPUT_2_SOURCE:
1021 case ARIZONA_OUT4LMIX_INPUT_2_VOLUME:
1022 case ARIZONA_OUT4LMIX_INPUT_3_SOURCE:
1023 case ARIZONA_OUT4LMIX_INPUT_3_VOLUME:
1024 case ARIZONA_OUT4LMIX_INPUT_4_SOURCE:
1025 case ARIZONA_OUT4LMIX_INPUT_4_VOLUME:
1026 case ARIZONA_AIF1TX1MIX_INPUT_1_SOURCE:
1027 case ARIZONA_AIF1TX1MIX_INPUT_1_VOLUME:
1028 case ARIZONA_AIF1TX1MIX_INPUT_2_SOURCE:
1029 case ARIZONA_AIF1TX1MIX_INPUT_2_VOLUME:
1030 case ARIZONA_AIF1TX1MIX_INPUT_3_SOURCE:
1031 case ARIZONA_AIF1TX1MIX_INPUT_3_VOLUME:
1032 case ARIZONA_AIF1TX1MIX_INPUT_4_SOURCE:
1033 case ARIZONA_AIF1TX1MIX_INPUT_4_VOLUME:
1034 case ARIZONA_AIF1TX2MIX_INPUT_1_SOURCE:
1035 case ARIZONA_AIF1TX2MIX_INPUT_1_VOLUME:
1036 case ARIZONA_AIF1TX2MIX_INPUT_2_SOURCE:
1037 case ARIZONA_AIF1TX2MIX_INPUT_2_VOLUME:
1038 case ARIZONA_AIF1TX2MIX_INPUT_3_SOURCE:
1039 case ARIZONA_AIF1TX2MIX_INPUT_3_VOLUME:
1040 case ARIZONA_AIF1TX2MIX_INPUT_4_SOURCE:
1041 case ARIZONA_AIF1TX2MIX_INPUT_4_VOLUME:
1042 case ARIZONA_AIF1TX3MIX_INPUT_1_SOURCE:
1043 case ARIZONA_AIF1TX3MIX_INPUT_1_VOLUME:
1044 case ARIZONA_AIF1TX3MIX_INPUT_2_SOURCE:
1045 case ARIZONA_AIF1TX3MIX_INPUT_2_VOLUME:
1046 case ARIZONA_AIF1TX3MIX_INPUT_3_SOURCE:
1047 case ARIZONA_AIF1TX3MIX_INPUT_3_VOLUME:
1048 case ARIZONA_AIF1TX3MIX_INPUT_4_SOURCE:
1049 case ARIZONA_AIF1TX3MIX_INPUT_4_VOLUME:
1050 case ARIZONA_AIF1TX4MIX_INPUT_1_SOURCE:
1051 case ARIZONA_AIF1TX4MIX_INPUT_1_VOLUME:
1052 case ARIZONA_AIF1TX4MIX_INPUT_2_SOURCE:
1053 case ARIZONA_AIF1TX4MIX_INPUT_2_VOLUME:
1054 case ARIZONA_AIF1TX4MIX_INPUT_3_SOURCE:
1055 case ARIZONA_AIF1TX4MIX_INPUT_3_VOLUME:
1056 case ARIZONA_AIF1TX4MIX_INPUT_4_SOURCE:
1057 case ARIZONA_AIF1TX4MIX_INPUT_4_VOLUME:
1058 case ARIZONA_AIF1TX5MIX_INPUT_1_SOURCE:
1059 case ARIZONA_AIF1TX5MIX_INPUT_1_VOLUME:
1060 case ARIZONA_AIF1TX5MIX_INPUT_2_SOURCE:
1061 case ARIZONA_AIF1TX5MIX_INPUT_2_VOLUME:
1062 case ARIZONA_AIF1TX5MIX_INPUT_3_SOURCE:
1063 case ARIZONA_AIF1TX5MIX_INPUT_3_VOLUME:
1064 case ARIZONA_AIF1TX5MIX_INPUT_4_SOURCE:
1065 case ARIZONA_AIF1TX5MIX_INPUT_4_VOLUME:
1066 case ARIZONA_AIF1TX6MIX_INPUT_1_SOURCE:
1067 case ARIZONA_AIF1TX6MIX_INPUT_1_VOLUME:
1068 case ARIZONA_AIF1TX6MIX_INPUT_2_SOURCE:
1069 case ARIZONA_AIF1TX6MIX_INPUT_2_VOLUME:
1070 case ARIZONA_AIF1TX6MIX_INPUT_3_SOURCE:
1071 case ARIZONA_AIF1TX6MIX_INPUT_3_VOLUME:
1072 case ARIZONA_AIF1TX6MIX_INPUT_4_SOURCE:
1073 case ARIZONA_AIF1TX6MIX_INPUT_4_VOLUME:
1074 case ARIZONA_AIF1TX7MIX_INPUT_1_SOURCE:
1075 case ARIZONA_AIF1TX7MIX_INPUT_1_VOLUME:
1076 case ARIZONA_AIF1TX7MIX_INPUT_2_SOURCE:
1077 case ARIZONA_AIF1TX7MIX_INPUT_2_VOLUME:
1078 case ARIZONA_AIF1TX7MIX_INPUT_3_SOURCE:
1079 case ARIZONA_AIF1TX7MIX_INPUT_3_VOLUME:
1080 case ARIZONA_AIF1TX7MIX_INPUT_4_SOURCE:
1081 case ARIZONA_AIF1TX7MIX_INPUT_4_VOLUME:
1082 case ARIZONA_AIF1TX8MIX_INPUT_1_SOURCE:
1083 case ARIZONA_AIF1TX8MIX_INPUT_1_VOLUME:
1084 case ARIZONA_AIF1TX8MIX_INPUT_2_SOURCE:
1085 case ARIZONA_AIF1TX8MIX_INPUT_2_VOLUME:
1086 case ARIZONA_AIF1TX8MIX_INPUT_3_SOURCE:
1087 case ARIZONA_AIF1TX8MIX_INPUT_3_VOLUME:
1088 case ARIZONA_AIF1TX8MIX_INPUT_4_SOURCE:
1089 case ARIZONA_AIF1TX8MIX_INPUT_4_VOLUME:
1090 case ARIZONA_AIF2TX1MIX_INPUT_1_SOURCE:
1091 case ARIZONA_AIF2TX1MIX_INPUT_1_VOLUME:
1092 case ARIZONA_AIF2TX1MIX_INPUT_2_SOURCE:
1093 case ARIZONA_AIF2TX1MIX_INPUT_2_VOLUME:
1094 case ARIZONA_AIF2TX1MIX_INPUT_3_SOURCE:
1095 case ARIZONA_AIF2TX1MIX_INPUT_3_VOLUME:
1096 case ARIZONA_AIF2TX1MIX_INPUT_4_SOURCE:
1097 case ARIZONA_AIF2TX1MIX_INPUT_4_VOLUME:
1098 case ARIZONA_AIF2TX2MIX_INPUT_1_SOURCE:
1099 case ARIZONA_AIF2TX2MIX_INPUT_1_VOLUME:
1100 case ARIZONA_AIF2TX2MIX_INPUT_2_SOURCE:
1101 case ARIZONA_AIF2TX2MIX_INPUT_2_VOLUME:
1102 case ARIZONA_AIF2TX2MIX_INPUT_3_SOURCE:
1103 case ARIZONA_AIF2TX2MIX_INPUT_3_VOLUME:
1104 case ARIZONA_AIF2TX2MIX_INPUT_4_SOURCE:
1105 case ARIZONA_AIF2TX2MIX_INPUT_4_VOLUME:
1106 case ARIZONA_AIF2TX3MIX_INPUT_1_SOURCE:
1107 case ARIZONA_AIF2TX3MIX_INPUT_1_VOLUME:
1108 case ARIZONA_AIF2TX3MIX_INPUT_2_SOURCE:
1109 case ARIZONA_AIF2TX3MIX_INPUT_2_VOLUME:
1110 case ARIZONA_AIF2TX3MIX_INPUT_3_SOURCE:
1111 case ARIZONA_AIF2TX3MIX_INPUT_3_VOLUME:
1112 case ARIZONA_AIF2TX3MIX_INPUT_4_SOURCE:
1113 case ARIZONA_AIF2TX3MIX_INPUT_4_VOLUME:
1114 case ARIZONA_AIF2TX4MIX_INPUT_1_SOURCE:
1115 case ARIZONA_AIF2TX4MIX_INPUT_1_VOLUME:
1116 case ARIZONA_AIF2TX4MIX_INPUT_2_SOURCE:
1117 case ARIZONA_AIF2TX4MIX_INPUT_2_VOLUME:
1118 case ARIZONA_AIF2TX4MIX_INPUT_3_SOURCE:
1119 case ARIZONA_AIF2TX4MIX_INPUT_3_VOLUME:
1120 case ARIZONA_AIF2TX4MIX_INPUT_4_SOURCE:
1121 case ARIZONA_AIF2TX4MIX_INPUT_4_VOLUME:
1122 case ARIZONA_AIF2TX5MIX_INPUT_1_SOURCE:
1123 case ARIZONA_AIF2TX5MIX_INPUT_1_VOLUME:
1124 case ARIZONA_AIF2TX5MIX_INPUT_2_SOURCE:
1125 case ARIZONA_AIF2TX5MIX_INPUT_2_VOLUME:
1126 case ARIZONA_AIF2TX5MIX_INPUT_3_SOURCE:
1127 case ARIZONA_AIF2TX5MIX_INPUT_3_VOLUME:
1128 case ARIZONA_AIF2TX5MIX_INPUT_4_SOURCE:
1129 case ARIZONA_AIF2TX5MIX_INPUT_4_VOLUME:
1130 case ARIZONA_AIF2TX6MIX_INPUT_1_SOURCE:
1131 case ARIZONA_AIF2TX6MIX_INPUT_1_VOLUME:
1132 case ARIZONA_AIF2TX6MIX_INPUT_2_SOURCE:
1133 case ARIZONA_AIF2TX6MIX_INPUT_2_VOLUME:
1134 case ARIZONA_AIF2TX6MIX_INPUT_3_SOURCE:
1135 case ARIZONA_AIF2TX6MIX_INPUT_3_VOLUME:
1136 case ARIZONA_AIF2TX6MIX_INPUT_4_SOURCE:
1137 case ARIZONA_AIF2TX6MIX_INPUT_4_VOLUME:
1138 case ARIZONA_AIF3TX1MIX_INPUT_1_SOURCE:
1139 case ARIZONA_AIF3TX1MIX_INPUT_1_VOLUME:
1140 case ARIZONA_AIF3TX1MIX_INPUT_2_SOURCE:
1141 case ARIZONA_AIF3TX1MIX_INPUT_2_VOLUME:
1142 case ARIZONA_AIF3TX1MIX_INPUT_3_SOURCE:
1143 case ARIZONA_AIF3TX1MIX_INPUT_3_VOLUME:
1144 case ARIZONA_AIF3TX1MIX_INPUT_4_SOURCE:
1145 case ARIZONA_AIF3TX1MIX_INPUT_4_VOLUME:
1146 case ARIZONA_AIF3TX2MIX_INPUT_1_SOURCE:
1147 case ARIZONA_AIF3TX2MIX_INPUT_1_VOLUME:
1148 case ARIZONA_AIF3TX2MIX_INPUT_2_SOURCE:
1149 case ARIZONA_AIF3TX2MIX_INPUT_2_VOLUME:
1150 case ARIZONA_AIF3TX2MIX_INPUT_3_SOURCE:
1151 case ARIZONA_AIF3TX2MIX_INPUT_3_VOLUME:
1152 case ARIZONA_AIF3TX2MIX_INPUT_4_SOURCE:
1153 case ARIZONA_AIF3TX2MIX_INPUT_4_VOLUME:
1154 case ARIZONA_EQ1MIX_INPUT_1_SOURCE:
1155 case ARIZONA_EQ1MIX_INPUT_1_VOLUME:
1156 case ARIZONA_EQ1MIX_INPUT_2_SOURCE:
1157 case ARIZONA_EQ1MIX_INPUT_2_VOLUME:
1158 case ARIZONA_EQ1MIX_INPUT_3_SOURCE:
1159 case ARIZONA_EQ1MIX_INPUT_3_VOLUME:
1160 case ARIZONA_EQ1MIX_INPUT_4_SOURCE:
1161 case ARIZONA_EQ1MIX_INPUT_4_VOLUME:
1162 case ARIZONA_EQ2MIX_INPUT_1_SOURCE:
1163 case ARIZONA_EQ2MIX_INPUT_1_VOLUME:
1164 case ARIZONA_EQ2MIX_INPUT_2_SOURCE:
1165 case ARIZONA_EQ2MIX_INPUT_2_VOLUME:
1166 case ARIZONA_EQ2MIX_INPUT_3_SOURCE:
1167 case ARIZONA_EQ2MIX_INPUT_3_VOLUME:
1168 case ARIZONA_EQ2MIX_INPUT_4_SOURCE:
1169 case ARIZONA_EQ2MIX_INPUT_4_VOLUME:
1170 case ARIZONA_DRC1LMIX_INPUT_1_SOURCE:
1171 case ARIZONA_DRC1LMIX_INPUT_1_VOLUME:
1172 case ARIZONA_DRC1LMIX_INPUT_2_SOURCE:
1173 case ARIZONA_DRC1LMIX_INPUT_2_VOLUME:
1174 case ARIZONA_DRC1LMIX_INPUT_3_SOURCE:
1175 case ARIZONA_DRC1LMIX_INPUT_3_VOLUME:
1176 case ARIZONA_DRC1LMIX_INPUT_4_SOURCE:
1177 case ARIZONA_DRC1LMIX_INPUT_4_VOLUME:
1178 case ARIZONA_DRC1RMIX_INPUT_1_SOURCE:
1179 case ARIZONA_DRC1RMIX_INPUT_1_VOLUME:
1180 case ARIZONA_DRC1RMIX_INPUT_2_SOURCE:
1181 case ARIZONA_DRC1RMIX_INPUT_2_VOLUME:
1182 case ARIZONA_DRC1RMIX_INPUT_3_SOURCE:
1183 case ARIZONA_DRC1RMIX_INPUT_3_VOLUME:
1184 case ARIZONA_DRC1RMIX_INPUT_4_SOURCE:
1185 case ARIZONA_DRC1RMIX_INPUT_4_VOLUME:
1186 case ARIZONA_DRC2LMIX_INPUT_1_SOURCE:
1187 case ARIZONA_DRC2LMIX_INPUT_1_VOLUME:
1188 case ARIZONA_DRC2LMIX_INPUT_2_SOURCE:
1189 case ARIZONA_DRC2LMIX_INPUT_2_VOLUME:
1190 case ARIZONA_DRC2LMIX_INPUT_3_SOURCE:
1191 case ARIZONA_DRC2LMIX_INPUT_3_VOLUME:
1192 case ARIZONA_DRC2LMIX_INPUT_4_SOURCE:
1193 case ARIZONA_DRC2LMIX_INPUT_4_VOLUME:
1194 case ARIZONA_DRC2RMIX_INPUT_1_SOURCE:
1195 case ARIZONA_DRC2RMIX_INPUT_1_VOLUME:
1196 case ARIZONA_DRC2RMIX_INPUT_2_SOURCE:
1197 case ARIZONA_DRC2RMIX_INPUT_2_VOLUME:
1198 case ARIZONA_DRC2RMIX_INPUT_3_SOURCE:
1199 case ARIZONA_DRC2RMIX_INPUT_3_VOLUME:
1200 case ARIZONA_DRC2RMIX_INPUT_4_SOURCE:
1201 case ARIZONA_DRC2RMIX_INPUT_4_VOLUME:
1202 case ARIZONA_HPLP1MIX_INPUT_1_SOURCE:
1203 case ARIZONA_HPLP1MIX_INPUT_1_VOLUME:
1204 case ARIZONA_HPLP1MIX_INPUT_2_SOURCE:
1205 case ARIZONA_HPLP1MIX_INPUT_2_VOLUME:
1206 case ARIZONA_HPLP1MIX_INPUT_3_SOURCE:
1207 case ARIZONA_HPLP1MIX_INPUT_3_VOLUME:
1208 case ARIZONA_HPLP1MIX_INPUT_4_SOURCE:
1209 case ARIZONA_HPLP1MIX_INPUT_4_VOLUME:
1210 case ARIZONA_HPLP2MIX_INPUT_1_SOURCE:
1211 case ARIZONA_HPLP2MIX_INPUT_1_VOLUME:
1212 case ARIZONA_HPLP2MIX_INPUT_2_SOURCE:
1213 case ARIZONA_HPLP2MIX_INPUT_2_VOLUME:
1214 case ARIZONA_HPLP2MIX_INPUT_3_SOURCE:
1215 case ARIZONA_HPLP2MIX_INPUT_3_VOLUME:
1216 case ARIZONA_HPLP2MIX_INPUT_4_SOURCE:
1217 case ARIZONA_HPLP2MIX_INPUT_4_VOLUME:
1218 case ARIZONA_HPLP3MIX_INPUT_1_SOURCE:
1219 case ARIZONA_HPLP3MIX_INPUT_1_VOLUME:
1220 case ARIZONA_HPLP3MIX_INPUT_2_SOURCE:
1221 case ARIZONA_HPLP3MIX_INPUT_2_VOLUME:
1222 case ARIZONA_HPLP3MIX_INPUT_3_SOURCE:
1223 case ARIZONA_HPLP3MIX_INPUT_3_VOLUME:
1224 case ARIZONA_HPLP3MIX_INPUT_4_SOURCE:
1225 case ARIZONA_HPLP3MIX_INPUT_4_VOLUME:
1226 case ARIZONA_HPLP4MIX_INPUT_1_SOURCE:
1227 case ARIZONA_HPLP4MIX_INPUT_1_VOLUME:
1228 case ARIZONA_HPLP4MIX_INPUT_2_SOURCE:
1229 case ARIZONA_HPLP4MIX_INPUT_2_VOLUME:
1230 case ARIZONA_HPLP4MIX_INPUT_3_SOURCE:
1231 case ARIZONA_HPLP4MIX_INPUT_3_VOLUME:
1232 case ARIZONA_HPLP4MIX_INPUT_4_SOURCE:
1233 case ARIZONA_HPLP4MIX_INPUT_4_VOLUME:
1234 case ARIZONA_DSP2LMIX_INPUT_1_SOURCE:
1235 case ARIZONA_DSP2LMIX_INPUT_1_VOLUME:
1236 case ARIZONA_DSP2LMIX_INPUT_2_SOURCE:
1237 case ARIZONA_DSP2LMIX_INPUT_2_VOLUME:
1238 case ARIZONA_DSP2LMIX_INPUT_3_SOURCE:
1239 case ARIZONA_DSP2LMIX_INPUT_3_VOLUME:
1240 case ARIZONA_DSP2LMIX_INPUT_4_SOURCE:
1241 case ARIZONA_DSP2LMIX_INPUT_4_VOLUME:
1242 case ARIZONA_DSP2RMIX_INPUT_1_SOURCE:
1243 case ARIZONA_DSP2RMIX_INPUT_1_VOLUME:
1244 case ARIZONA_DSP2RMIX_INPUT_2_SOURCE:
1245 case ARIZONA_DSP2RMIX_INPUT_2_VOLUME:
1246 case ARIZONA_DSP2RMIX_INPUT_3_SOURCE:
1247 case ARIZONA_DSP2RMIX_INPUT_3_VOLUME:
1248 case ARIZONA_DSP2RMIX_INPUT_4_SOURCE:
1249 case ARIZONA_DSP2RMIX_INPUT_4_VOLUME:
1250 case ARIZONA_DSP2AUX1MIX_INPUT_1_SOURCE:
1251 case ARIZONA_DSP2AUX2MIX_INPUT_1_SOURCE:
1252 case ARIZONA_DSP2AUX3MIX_INPUT_1_SOURCE:
1253 case ARIZONA_DSP2AUX4MIX_INPUT_1_SOURCE:
1254 case ARIZONA_DSP2AUX5MIX_INPUT_1_SOURCE:
1255 case ARIZONA_DSP2AUX6MIX_INPUT_1_SOURCE:
1256 case ARIZONA_DSP3LMIX_INPUT_1_SOURCE:
1257 case ARIZONA_DSP3LMIX_INPUT_1_VOLUME:
1258 case ARIZONA_DSP3LMIX_INPUT_2_SOURCE:
1259 case ARIZONA_DSP3LMIX_INPUT_2_VOLUME:
1260 case ARIZONA_DSP3LMIX_INPUT_3_SOURCE:
1261 case ARIZONA_DSP3LMIX_INPUT_3_VOLUME:
1262 case ARIZONA_DSP3LMIX_INPUT_4_SOURCE:
1263 case ARIZONA_DSP3LMIX_INPUT_4_VOLUME:
1264 case ARIZONA_DSP3RMIX_INPUT_1_SOURCE:
1265 case ARIZONA_DSP3RMIX_INPUT_1_VOLUME:
1266 case ARIZONA_DSP3RMIX_INPUT_2_SOURCE:
1267 case ARIZONA_DSP3RMIX_INPUT_2_VOLUME:
1268 case ARIZONA_DSP3RMIX_INPUT_3_SOURCE:
1269 case ARIZONA_DSP3RMIX_INPUT_3_VOLUME:
1270 case ARIZONA_DSP3RMIX_INPUT_4_SOURCE:
1271 case ARIZONA_DSP3RMIX_INPUT_4_VOLUME:
1272 case ARIZONA_DSP3AUX1MIX_INPUT_1_SOURCE:
1273 case ARIZONA_DSP3AUX2MIX_INPUT_1_SOURCE:
1274 case ARIZONA_DSP3AUX3MIX_INPUT_1_SOURCE:
1275 case ARIZONA_DSP3AUX4MIX_INPUT_1_SOURCE:
1276 case ARIZONA_DSP3AUX5MIX_INPUT_1_SOURCE:
1277 case ARIZONA_DSP3AUX6MIX_INPUT_1_SOURCE:
1278 case ARIZONA_ASRC1LMIX_INPUT_1_SOURCE:
1279 case ARIZONA_ASRC1RMIX_INPUT_1_SOURCE:
1280 case ARIZONA_ASRC2LMIX_INPUT_1_SOURCE:
1281 case ARIZONA_ASRC2RMIX_INPUT_1_SOURCE:
1282 case ARIZONA_ISRC1DEC1MIX_INPUT_1_SOURCE:
1283 case ARIZONA_ISRC1DEC2MIX_INPUT_1_SOURCE:
1284 case ARIZONA_ISRC1DEC3MIX_INPUT_1_SOURCE:
1285 case ARIZONA_ISRC1DEC4MIX_INPUT_1_SOURCE:
1286 case ARIZONA_ISRC1INT1MIX_INPUT_1_SOURCE:
1287 case ARIZONA_ISRC1INT2MIX_INPUT_1_SOURCE:
1288 case ARIZONA_ISRC1INT3MIX_INPUT_1_SOURCE:
1289 case ARIZONA_ISRC1INT4MIX_INPUT_1_SOURCE:
1290 case ARIZONA_ISRC2DEC1MIX_INPUT_1_SOURCE:
1291 case ARIZONA_ISRC2DEC2MIX_INPUT_1_SOURCE:
1292 case ARIZONA_ISRC2DEC3MIX_INPUT_1_SOURCE:
1293 case ARIZONA_ISRC2DEC4MIX_INPUT_1_SOURCE:
1294 case ARIZONA_ISRC2INT1MIX_INPUT_1_SOURCE:
1295 case ARIZONA_ISRC2INT2MIX_INPUT_1_SOURCE:
1296 case ARIZONA_ISRC2INT3MIX_INPUT_1_SOURCE:
1297 case ARIZONA_ISRC2INT4MIX_INPUT_1_SOURCE:
1298 case ARIZONA_ISRC3DEC1MIX_INPUT_1_SOURCE:
1299 case ARIZONA_ISRC3DEC2MIX_INPUT_1_SOURCE:
1300 case ARIZONA_ISRC3DEC3MIX_INPUT_1_SOURCE:
1301 case ARIZONA_ISRC3DEC4MIX_INPUT_1_SOURCE:
1302 case ARIZONA_ISRC3INT1MIX_INPUT_1_SOURCE:
1303 case ARIZONA_ISRC3INT2MIX_INPUT_1_SOURCE:
1304 case ARIZONA_ISRC3INT3MIX_INPUT_1_SOURCE:
1305 case ARIZONA_ISRC3INT4MIX_INPUT_1_SOURCE:
1306 case ARIZONA_GPIO1_CTRL:
1307 case ARIZONA_GPIO2_CTRL:
1308 case ARIZONA_IRQ_CTRL_1:
1309 case ARIZONA_GPIO_DEBOUNCE_CONFIG:
1310 case ARIZONA_MISC_PAD_CTRL_1:
1311 case ARIZONA_MISC_PAD_CTRL_2:
1312 case ARIZONA_MISC_PAD_CTRL_3:
1313 case ARIZONA_MISC_PAD_CTRL_4:
1314 case ARIZONA_MISC_PAD_CTRL_5:
1315 case ARIZONA_MISC_PAD_CTRL_6:
1316 case ARIZONA_MISC_PAD_CTRL_7:
1317 case ARIZONA_MISC_PAD_CTRL_9:
1318 case ARIZONA_MISC_PAD_CTRL_10:
1319 case ARIZONA_MISC_PAD_CTRL_11:
1320 case ARIZONA_MISC_PAD_CTRL_12:
1321 case ARIZONA_MISC_PAD_CTRL_13:
1322 case ARIZONA_MISC_PAD_CTRL_14:
1323 case ARIZONA_MISC_PAD_CTRL_16:
1324 case ARIZONA_INTERRUPT_STATUS_1:
1325 case ARIZONA_INTERRUPT_STATUS_2:
1326 case ARIZONA_INTERRUPT_STATUS_3:
1327 case ARIZONA_INTERRUPT_STATUS_4:
1328 case ARIZONA_INTERRUPT_STATUS_5:
1329 case ARIZONA_INTERRUPT_STATUS_6:
1330 case ARIZONA_INTERRUPT_STATUS_1_MASK:
1331 case ARIZONA_INTERRUPT_STATUS_2_MASK:
1332 case ARIZONA_INTERRUPT_STATUS_3_MASK:
1333 case ARIZONA_INTERRUPT_STATUS_4_MASK:
1334 case ARIZONA_INTERRUPT_STATUS_5_MASK:
1335 case ARIZONA_INTERRUPT_STATUS_6_MASK:
1336 case ARIZONA_INTERRUPT_CONTROL:
1337 case ARIZONA_IRQ2_STATUS_1:
1338 case ARIZONA_IRQ2_STATUS_2:
1339 case ARIZONA_IRQ2_STATUS_3:
1340 case ARIZONA_IRQ2_STATUS_4:
1341 case ARIZONA_IRQ2_STATUS_5:
1342 case ARIZONA_IRQ2_STATUS_6:
1343 case ARIZONA_IRQ2_STATUS_1_MASK:
1344 case ARIZONA_IRQ2_STATUS_2_MASK:
1345 case ARIZONA_IRQ2_STATUS_3_MASK:
1346 case ARIZONA_IRQ2_STATUS_4_MASK:
1347 case ARIZONA_IRQ2_STATUS_5_MASK:
1348 case ARIZONA_IRQ2_STATUS_6_MASK:
1349 case ARIZONA_IRQ2_CONTROL:
1350 case ARIZONA_INTERRUPT_RAW_STATUS_2:
1351 case ARIZONA_INTERRUPT_RAW_STATUS_3:
1352 case ARIZONA_INTERRUPT_RAW_STATUS_4:
1353 case ARIZONA_INTERRUPT_RAW_STATUS_5:
1354 case ARIZONA_INTERRUPT_RAW_STATUS_6:
1355 case ARIZONA_INTERRUPT_RAW_STATUS_7:
1356 case ARIZONA_INTERRUPT_RAW_STATUS_8:
1357 case ARIZONA_INTERRUPT_RAW_STATUS_9:
1358 case ARIZONA_IRQ_PIN_STATUS:
1359 case ARIZONA_FX_CTRL1:
1360 case ARIZONA_FX_CTRL2:
1361 case ARIZONA_EQ1_1:
1362 case ARIZONA_EQ1_2:
1363 case ARIZONA_EQ1_3:
1364 case ARIZONA_EQ1_4:
1365 case ARIZONA_EQ1_5:
1366 case ARIZONA_EQ1_6:
1367 case ARIZONA_EQ1_7:
1368 case ARIZONA_EQ1_8:
1369 case ARIZONA_EQ1_9:
1370 case ARIZONA_EQ1_10:
1371 case ARIZONA_EQ1_11:
1372 case ARIZONA_EQ1_12:
1373 case ARIZONA_EQ1_13:
1374 case ARIZONA_EQ1_14:
1375 case ARIZONA_EQ1_15:
1376 case ARIZONA_EQ1_16:
1377 case ARIZONA_EQ1_17:
1378 case ARIZONA_EQ1_18:
1379 case ARIZONA_EQ1_19:
1380 case ARIZONA_EQ1_20:
1381 case ARIZONA_EQ1_21:
1382 case ARIZONA_EQ2_1:
1383 case ARIZONA_EQ2_2:
1384 case ARIZONA_EQ2_3:
1385 case ARIZONA_EQ2_4:
1386 case ARIZONA_EQ2_5:
1387 case ARIZONA_EQ2_6:
1388 case ARIZONA_EQ2_7:
1389 case ARIZONA_EQ2_8:
1390 case ARIZONA_EQ2_9:
1391 case ARIZONA_EQ2_10:
1392 case ARIZONA_EQ2_11:
1393 case ARIZONA_EQ2_12:
1394 case ARIZONA_EQ2_13:
1395 case ARIZONA_EQ2_14:
1396 case ARIZONA_EQ2_15:
1397 case ARIZONA_EQ2_16:
1398 case ARIZONA_EQ2_17:
1399 case ARIZONA_EQ2_18:
1400 case ARIZONA_EQ2_19:
1401 case ARIZONA_EQ2_20:
1402 case ARIZONA_EQ2_21:
1403 case ARIZONA_DRC1_CTRL1:
1404 case ARIZONA_DRC1_CTRL2:
1405 case ARIZONA_DRC1_CTRL3:
1406 case ARIZONA_DRC1_CTRL4:
1407 case ARIZONA_DRC1_CTRL5:
1408 case ARIZONA_DRC2_CTRL1:
1409 case ARIZONA_DRC2_CTRL2:
1410 case ARIZONA_DRC2_CTRL3:
1411 case ARIZONA_DRC2_CTRL4:
1412 case ARIZONA_DRC2_CTRL5:
1413 case ARIZONA_HPLPF1_1:
1414 case ARIZONA_HPLPF1_2:
1415 case ARIZONA_HPLPF2_1:
1416 case ARIZONA_HPLPF2_2:
1417 case ARIZONA_HPLPF3_1:
1418 case ARIZONA_HPLPF3_2:
1419 case ARIZONA_HPLPF4_1:
1420 case ARIZONA_HPLPF4_2:
1421 case ARIZONA_ASRC_ENABLE:
1422 case ARIZONA_ASRC_STATUS:
1423 case ARIZONA_ASRC_RATE1:
1424 case ARIZONA_ASRC_RATE2:
1425 case ARIZONA_ISRC_1_CTRL_1:
1426 case ARIZONA_ISRC_1_CTRL_2:
1427 case ARIZONA_ISRC_1_CTRL_3:
1428 case ARIZONA_ISRC_2_CTRL_1:
1429 case ARIZONA_ISRC_2_CTRL_2:
1430 case ARIZONA_ISRC_2_CTRL_3:
1431 case ARIZONA_ISRC_3_CTRL_1:
1432 case ARIZONA_ISRC_3_CTRL_2:
1433 case ARIZONA_ISRC_3_CTRL_3:
1434 case ARIZONA_DSP2_CONTROL_1:
1435 case ARIZONA_DSP2_CLOCKING_1:
1436 case ARIZONA_DSP2_STATUS_1:
1437 case ARIZONA_DSP2_STATUS_2:
1438 case ARIZONA_DSP2_STATUS_3:
1439 case ARIZONA_DSP2_STATUS_4:
1440 case ARIZONA_DSP2_WDMA_BUFFER_1:
1441 case ARIZONA_DSP2_WDMA_BUFFER_2:
1442 case ARIZONA_DSP2_WDMA_BUFFER_3:
1443 case ARIZONA_DSP2_WDMA_BUFFER_4:
1444 case ARIZONA_DSP2_WDMA_BUFFER_5:
1445 case ARIZONA_DSP2_WDMA_BUFFER_6:
1446 case ARIZONA_DSP2_WDMA_BUFFER_7:
1447 case ARIZONA_DSP2_WDMA_BUFFER_8:
1448 case ARIZONA_DSP2_RDMA_BUFFER_1:
1449 case ARIZONA_DSP2_RDMA_BUFFER_2:
1450 case ARIZONA_DSP2_RDMA_BUFFER_3:
1451 case ARIZONA_DSP2_RDMA_BUFFER_4:
1452 case ARIZONA_DSP2_RDMA_BUFFER_5:
1453 case ARIZONA_DSP2_RDMA_BUFFER_6:
1454 case ARIZONA_DSP2_WDMA_CONFIG_1:
1455 case ARIZONA_DSP2_WDMA_CONFIG_2:
1456 case ARIZONA_DSP2_WDMA_OFFSET_1:
1457 case ARIZONA_DSP2_RDMA_CONFIG_1:
1458 case ARIZONA_DSP2_RDMA_OFFSET_1:
1459 case ARIZONA_DSP2_EXTERNAL_START_SELECT_1:
1460 case ARIZONA_DSP2_SCRATCH_0:
1461 case ARIZONA_DSP2_SCRATCH_1:
1462 case ARIZONA_DSP2_SCRATCH_2:
1463 case ARIZONA_DSP2_SCRATCH_3:
1464 case ARIZONA_DSP3_CONTROL_1:
1465 case ARIZONA_DSP3_CLOCKING_1:
1466 case ARIZONA_DSP3_STATUS_1:
1467 case ARIZONA_DSP3_STATUS_2:
1468 case ARIZONA_DSP3_STATUS_3:
1469 case ARIZONA_DSP3_STATUS_4:
1470 case ARIZONA_DSP3_WDMA_BUFFER_1:
1471 case ARIZONA_DSP3_WDMA_BUFFER_2:
1472 case ARIZONA_DSP3_WDMA_BUFFER_3:
1473 case ARIZONA_DSP3_WDMA_BUFFER_4:
1474 case ARIZONA_DSP3_WDMA_BUFFER_5:
1475 case ARIZONA_DSP3_WDMA_BUFFER_6:
1476 case ARIZONA_DSP3_WDMA_BUFFER_7:
1477 case ARIZONA_DSP3_WDMA_BUFFER_8:
1478 case ARIZONA_DSP3_RDMA_BUFFER_1:
1479 case ARIZONA_DSP3_RDMA_BUFFER_2:
1480 case ARIZONA_DSP3_RDMA_BUFFER_3:
1481 case ARIZONA_DSP3_RDMA_BUFFER_4:
1482 case ARIZONA_DSP3_RDMA_BUFFER_5:
1483 case ARIZONA_DSP3_RDMA_BUFFER_6:
1484 case ARIZONA_DSP3_WDMA_CONFIG_1:
1485 case ARIZONA_DSP3_WDMA_CONFIG_2:
1486 case ARIZONA_DSP3_WDMA_OFFSET_1:
1487 case ARIZONA_DSP3_RDMA_CONFIG_1:
1488 case ARIZONA_DSP3_RDMA_OFFSET_1:
1489 case ARIZONA_DSP3_EXTERNAL_START_SELECT_1:
1490 case ARIZONA_DSP3_SCRATCH_0:
1491 case ARIZONA_DSP3_SCRATCH_1:
1492 case ARIZONA_DSP3_SCRATCH_2:
1493 case ARIZONA_DSP3_SCRATCH_3:
1494 return true;
1495 default:
1496 return cs47l24_is_adsp_memory(reg);
1497 }
1498 }
1499
1500 static bool cs47l24_volatile_register(struct device *dev, unsigned int reg)
1501 {
1502 switch (reg) {
1503 case ARIZONA_SOFTWARE_RESET:
1504 case ARIZONA_DEVICE_REVISION:
1505 case ARIZONA_WRITE_SEQUENCER_CTRL_0:
1506 case ARIZONA_WRITE_SEQUENCER_CTRL_1:
1507 case ARIZONA_WRITE_SEQUENCER_CTRL_2:
1508 case ARIZONA_HAPTICS_STATUS:
1509 case ARIZONA_SAMPLE_RATE_1_STATUS:
1510 case ARIZONA_SAMPLE_RATE_2_STATUS:
1511 case ARIZONA_SAMPLE_RATE_3_STATUS:
1512 case ARIZONA_ASYNC_SAMPLE_RATE_1_STATUS:
1513 case ARIZONA_ASYNC_SAMPLE_RATE_2_STATUS:
1514 case ARIZONA_HP_CTRL_1L:
1515 case ARIZONA_HP_CTRL_1R:
1516 case ARIZONA_INPUT_ENABLES_STATUS:
1517 case ARIZONA_OUTPUT_STATUS_1:
1518 case ARIZONA_RAW_OUTPUT_STATUS_1:
1519 case ARIZONA_INTERRUPT_STATUS_1:
1520 case ARIZONA_INTERRUPT_STATUS_2:
1521 case ARIZONA_INTERRUPT_STATUS_3:
1522 case ARIZONA_INTERRUPT_STATUS_4:
1523 case ARIZONA_INTERRUPT_STATUS_5:
1524 case ARIZONA_INTERRUPT_STATUS_6:
1525 case ARIZONA_IRQ2_STATUS_1:
1526 case ARIZONA_IRQ2_STATUS_2:
1527 case ARIZONA_IRQ2_STATUS_3:
1528 case ARIZONA_IRQ2_STATUS_4:
1529 case ARIZONA_IRQ2_STATUS_5:
1530 case ARIZONA_IRQ2_STATUS_6:
1531 case ARIZONA_INTERRUPT_RAW_STATUS_2:
1532 case ARIZONA_INTERRUPT_RAW_STATUS_3:
1533 case ARIZONA_INTERRUPT_RAW_STATUS_4:
1534 case ARIZONA_INTERRUPT_RAW_STATUS_5:
1535 case ARIZONA_INTERRUPT_RAW_STATUS_6:
1536 case ARIZONA_INTERRUPT_RAW_STATUS_7:
1537 case ARIZONA_INTERRUPT_RAW_STATUS_8:
1538 case ARIZONA_INTERRUPT_RAW_STATUS_9:
1539 case ARIZONA_IRQ_PIN_STATUS:
1540 case ARIZONA_FX_CTRL2:
1541 case ARIZONA_ASRC_STATUS:
1542 case ARIZONA_DSP2_STATUS_1:
1543 case ARIZONA_DSP2_STATUS_2:
1544 case ARIZONA_DSP2_STATUS_3:
1545 case ARIZONA_DSP2_STATUS_4:
1546 case ARIZONA_DSP2_WDMA_BUFFER_1:
1547 case ARIZONA_DSP2_WDMA_BUFFER_2:
1548 case ARIZONA_DSP2_WDMA_BUFFER_3:
1549 case ARIZONA_DSP2_WDMA_BUFFER_4:
1550 case ARIZONA_DSP2_WDMA_BUFFER_5:
1551 case ARIZONA_DSP2_WDMA_BUFFER_6:
1552 case ARIZONA_DSP2_WDMA_BUFFER_7:
1553 case ARIZONA_DSP2_WDMA_BUFFER_8:
1554 case ARIZONA_DSP2_RDMA_BUFFER_1:
1555 case ARIZONA_DSP2_RDMA_BUFFER_2:
1556 case ARIZONA_DSP2_RDMA_BUFFER_3:
1557 case ARIZONA_DSP2_RDMA_BUFFER_4:
1558 case ARIZONA_DSP2_RDMA_BUFFER_5:
1559 case ARIZONA_DSP2_RDMA_BUFFER_6:
1560 case ARIZONA_DSP2_WDMA_CONFIG_1:
1561 case ARIZONA_DSP2_WDMA_CONFIG_2:
1562 case ARIZONA_DSP2_WDMA_OFFSET_1:
1563 case ARIZONA_DSP2_RDMA_CONFIG_1:
1564 case ARIZONA_DSP2_RDMA_OFFSET_1:
1565 case ARIZONA_DSP2_EXTERNAL_START_SELECT_1:
1566 case ARIZONA_DSP2_SCRATCH_0:
1567 case ARIZONA_DSP2_SCRATCH_1:
1568 case ARIZONA_DSP2_SCRATCH_2:
1569 case ARIZONA_DSP2_SCRATCH_3:
1570 case ARIZONA_DSP2_CLOCKING_1:
1571 case ARIZONA_DSP3_STATUS_1:
1572 case ARIZONA_DSP3_STATUS_2:
1573 case ARIZONA_DSP3_STATUS_3:
1574 case ARIZONA_DSP3_STATUS_4:
1575 case ARIZONA_DSP3_WDMA_BUFFER_1:
1576 case ARIZONA_DSP3_WDMA_BUFFER_2:
1577 case ARIZONA_DSP3_WDMA_BUFFER_3:
1578 case ARIZONA_DSP3_WDMA_BUFFER_4:
1579 case ARIZONA_DSP3_WDMA_BUFFER_5:
1580 case ARIZONA_DSP3_WDMA_BUFFER_6:
1581 case ARIZONA_DSP3_WDMA_BUFFER_7:
1582 case ARIZONA_DSP3_WDMA_BUFFER_8:
1583 case ARIZONA_DSP3_RDMA_BUFFER_1:
1584 case ARIZONA_DSP3_RDMA_BUFFER_2:
1585 case ARIZONA_DSP3_RDMA_BUFFER_3:
1586 case ARIZONA_DSP3_RDMA_BUFFER_4:
1587 case ARIZONA_DSP3_RDMA_BUFFER_5:
1588 case ARIZONA_DSP3_RDMA_BUFFER_6:
1589 case ARIZONA_DSP3_WDMA_CONFIG_1:
1590 case ARIZONA_DSP3_WDMA_CONFIG_2:
1591 case ARIZONA_DSP3_WDMA_OFFSET_1:
1592 case ARIZONA_DSP3_RDMA_CONFIG_1:
1593 case ARIZONA_DSP3_RDMA_OFFSET_1:
1594 case ARIZONA_DSP3_EXTERNAL_START_SELECT_1:
1595 case ARIZONA_DSP3_SCRATCH_0:
1596 case ARIZONA_DSP3_SCRATCH_1:
1597 case ARIZONA_DSP3_SCRATCH_2:
1598 case ARIZONA_DSP3_SCRATCH_3:
1599 case ARIZONA_DSP3_CLOCKING_1:
1600 return true;
1601 default:
1602 return cs47l24_is_adsp_memory(reg);
1603 }
1604 }
1605
1606 #define CS47L24_MAX_REGISTER 0x3b3fff
1607
1608 const struct regmap_config cs47l24_spi_regmap = {
1609 .reg_bits = 32,
1610 .pad_bits = 16,
1611 .val_bits = 16,
1612 .reg_format_endian = REGMAP_ENDIAN_BIG,
1613 .val_format_endian = REGMAP_ENDIAN_BIG,
1614
1615 .max_register = CS47L24_MAX_REGISTER,
1616 .readable_reg = cs47l24_readable_register,
1617 .volatile_reg = cs47l24_volatile_register,
1618
1619 .cache_type = REGCACHE_RBTREE,
1620 .reg_defaults = cs47l24_reg_default,
1621 .num_reg_defaults = ARRAY_SIZE(cs47l24_reg_default),
1622 };
1623 EXPORT_SYMBOL_GPL(cs47l24_spi_regmap);
1624