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
0015 #include "arizona.h"
0016
0017 static const struct reg_sequence wm8997_reva_patch[] = {
0018 { 0x80, 0x0003 },
0019 { 0x214, 0x0008 },
0020 { 0x458, 0x0000 },
0021 { 0x0081, 0xE022 },
0022 { 0x294, 0x0000 },
0023 { 0x80, 0x0000 },
0024 { 0x171, 0x0000 },
0025 };
0026
0027
0028 int wm8997_patch(struct arizona *arizona)
0029 {
0030 switch (arizona->rev) {
0031 case 0:
0032 return regmap_register_patch(arizona->regmap,
0033 wm8997_reva_patch,
0034 ARRAY_SIZE(wm8997_reva_patch));
0035 default:
0036 return 0;
0037 }
0038 }
0039 EXPORT_SYMBOL_GPL(wm8997_patch);
0040
0041 static const struct regmap_irq wm8997_aod_irqs[ARIZONA_NUM_IRQ] = {
0042 [ARIZONA_IRQ_GP5_FALL] = { .mask = ARIZONA_GP5_FALL_EINT1 },
0043 [ARIZONA_IRQ_GP5_RISE] = { .mask = ARIZONA_GP5_RISE_EINT1 },
0044 [ARIZONA_IRQ_JD_FALL] = { .mask = ARIZONA_JD1_FALL_EINT1 },
0045 [ARIZONA_IRQ_JD_RISE] = { .mask = ARIZONA_JD1_RISE_EINT1 },
0046 };
0047
0048 const struct regmap_irq_chip wm8997_aod = {
0049 .name = "wm8997 AOD",
0050 .status_base = ARIZONA_AOD_IRQ1,
0051 .mask_base = ARIZONA_AOD_IRQ_MASK_IRQ1,
0052 .ack_base = ARIZONA_AOD_IRQ1,
0053 .num_regs = 1,
0054 .irqs = wm8997_aod_irqs,
0055 .num_irqs = ARRAY_SIZE(wm8997_aod_irqs),
0056 };
0057 EXPORT_SYMBOL_GPL(wm8997_aod);
0058
0059 static const struct regmap_irq wm8997_irqs[ARIZONA_NUM_IRQ] = {
0060 [ARIZONA_IRQ_GP4] = { .reg_offset = 0, .mask = ARIZONA_GP4_EINT1 },
0061 [ARIZONA_IRQ_GP3] = { .reg_offset = 0, .mask = ARIZONA_GP3_EINT1 },
0062 [ARIZONA_IRQ_GP2] = { .reg_offset = 0, .mask = ARIZONA_GP2_EINT1 },
0063 [ARIZONA_IRQ_GP1] = { .reg_offset = 0, .mask = ARIZONA_GP1_EINT1 },
0064
0065 [ARIZONA_IRQ_SPK_OVERHEAT_WARN] = {
0066 .reg_offset = 2, .mask = ARIZONA_SPK_OVERHEAT_WARN_EINT1
0067 },
0068 [ARIZONA_IRQ_SPK_OVERHEAT] = {
0069 .reg_offset = 2, .mask = ARIZONA_SPK_OVERHEAT_EINT1
0070 },
0071 [ARIZONA_IRQ_HPDET] = {
0072 .reg_offset = 2, .mask = ARIZONA_HPDET_EINT1
0073 },
0074 [ARIZONA_IRQ_MICDET] = {
0075 .reg_offset = 2, .mask = ARIZONA_MICDET_EINT1
0076 },
0077 [ARIZONA_IRQ_WSEQ_DONE] = {
0078 .reg_offset = 2, .mask = ARIZONA_WSEQ_DONE_EINT1
0079 },
0080 [ARIZONA_IRQ_DRC1_SIG_DET] = {
0081 .reg_offset = 2, .mask = ARIZONA_DRC1_SIG_DET_EINT1
0082 },
0083 [ARIZONA_IRQ_UNDERCLOCKED] = {
0084 .reg_offset = 2, .mask = ARIZONA_UNDERCLOCKED_EINT1
0085 },
0086 [ARIZONA_IRQ_OVERCLOCKED] = {
0087 .reg_offset = 2, .mask = ARIZONA_OVERCLOCKED_EINT1
0088 },
0089 [ARIZONA_IRQ_FLL2_LOCK] = {
0090 .reg_offset = 2, .mask = ARIZONA_FLL2_LOCK_EINT1
0091 },
0092 [ARIZONA_IRQ_FLL1_LOCK] = {
0093 .reg_offset = 2, .mask = ARIZONA_FLL1_LOCK_EINT1
0094 },
0095 [ARIZONA_IRQ_CLKGEN_ERR] = {
0096 .reg_offset = 2, .mask = ARIZONA_CLKGEN_ERR_EINT1
0097 },
0098 [ARIZONA_IRQ_CLKGEN_ERR_ASYNC] = {
0099 .reg_offset = 2, .mask = ARIZONA_CLKGEN_ERR_ASYNC_EINT1
0100 },
0101
0102 [ARIZONA_IRQ_AIF2_ERR] = {
0103 .reg_offset = 3, .mask = ARIZONA_AIF2_ERR_EINT1
0104 },
0105 [ARIZONA_IRQ_AIF1_ERR] = {
0106 .reg_offset = 3, .mask = ARIZONA_AIF1_ERR_EINT1
0107 },
0108 [ARIZONA_IRQ_CTRLIF_ERR] = {
0109 .reg_offset = 3, .mask = ARIZONA_CTRLIF_ERR_EINT1
0110 },
0111 [ARIZONA_IRQ_MIXER_DROPPED_SAMPLES] = {
0112 .reg_offset = 3, .mask = ARIZONA_MIXER_DROPPED_SAMPLE_EINT1
0113 },
0114 [ARIZONA_IRQ_ASYNC_CLK_ENA_LOW] = {
0115 .reg_offset = 3, .mask = ARIZONA_ASYNC_CLK_ENA_LOW_EINT1
0116 },
0117 [ARIZONA_IRQ_SYSCLK_ENA_LOW] = {
0118 .reg_offset = 3, .mask = ARIZONA_SYSCLK_ENA_LOW_EINT1
0119 },
0120 [ARIZONA_IRQ_ISRC1_CFG_ERR] = {
0121 .reg_offset = 3, .mask = ARIZONA_ISRC1_CFG_ERR_EINT1
0122 },
0123 [ARIZONA_IRQ_ISRC2_CFG_ERR] = {
0124 .reg_offset = 3, .mask = ARIZONA_ISRC2_CFG_ERR_EINT1
0125 },
0126
0127 [ARIZONA_IRQ_BOOT_DONE] = {
0128 .reg_offset = 4, .mask = ARIZONA_BOOT_DONE_EINT1
0129 },
0130 [ARIZONA_IRQ_DCS_DAC_DONE] = {
0131 .reg_offset = 4, .mask = ARIZONA_DCS_DAC_DONE_EINT1
0132 },
0133 [ARIZONA_IRQ_DCS_HP_DONE] = {
0134 .reg_offset = 4, .mask = ARIZONA_DCS_HP_DONE_EINT1
0135 },
0136 [ARIZONA_IRQ_FLL2_CLOCK_OK] = {
0137 .reg_offset = 4, .mask = ARIZONA_FLL2_CLOCK_OK_EINT1
0138 },
0139 [ARIZONA_IRQ_FLL1_CLOCK_OK] = {
0140 .reg_offset = 4, .mask = ARIZONA_FLL1_CLOCK_OK_EINT1
0141 },
0142 };
0143
0144 const struct regmap_irq_chip wm8997_irq = {
0145 .name = "wm8997 IRQ",
0146 .status_base = ARIZONA_INTERRUPT_STATUS_1,
0147 .mask_base = ARIZONA_INTERRUPT_STATUS_1_MASK,
0148 .ack_base = ARIZONA_INTERRUPT_STATUS_1,
0149 .num_regs = 5,
0150 .irqs = wm8997_irqs,
0151 .num_irqs = ARRAY_SIZE(wm8997_irqs),
0152 };
0153 EXPORT_SYMBOL_GPL(wm8997_irq);
0154
0155 static const struct reg_default wm8997_reg_default[] = {
0156 { 0x00000009, 0x0001 },
0157 { 0x00000016, 0x0000 },
0158 { 0x00000017, 0x0000 },
0159 { 0x00000018, 0x0000 },
0160 { 0x00000020, 0x0000 },
0161 { 0x00000021, 0x1000 },
0162 { 0x00000022, 0x0000 },
0163 { 0x00000023, 0x1000 },
0164 { 0x00000024, 0x0000 },
0165 { 0x00000030, 0x0000 },
0166 { 0x00000031, 0x0100 },
0167 { 0x00000032, 0x0100 },
0168 { 0x00000040, 0x0000 },
0169 { 0x00000041, 0x0000 },
0170 { 0x00000061, 0x01FF },
0171 { 0x00000062, 0x01FF },
0172 { 0x00000063, 0x01FF },
0173 { 0x00000064, 0x01FF },
0174 { 0x00000068, 0x01FF },
0175 { 0x00000069, 0x01FF },
0176 { 0x0000006A, 0x01FF },
0177 { 0x0000006B, 0x01FF },
0178 { 0x00000070, 0x0000 },
0179 { 0x00000090, 0x0000 },
0180 { 0x00000091, 0x7FFF },
0181 { 0x00000092, 0x0000 },
0182 { 0x00000093, 0x0000 },
0183 { 0x00000094, 0x0000 },
0184 { 0x00000095, 0x0000 },
0185 { 0x00000096, 0x0000 },
0186 { 0x00000097, 0x0000 },
0187 { 0x00000100, 0x0002 },
0188 { 0x00000101, 0x0304 },
0189 { 0x00000102, 0x0011 },
0190 { 0x00000103, 0x0011 },
0191 { 0x00000104, 0x0011 },
0192 { 0x00000112, 0x0305 },
0193 { 0x00000113, 0x0011 },
0194 { 0x00000149, 0x0000 },
0195 { 0x0000014A, 0x0000 },
0196 { 0x00000152, 0x0000 },
0197 { 0x00000153, 0x0000 },
0198 { 0x00000154, 0x0000 },
0199 { 0x00000155, 0x0000 },
0200 { 0x00000156, 0x0000 },
0201 { 0x00000161, 0x0000 },
0202 { 0x00000171, 0x0000 },
0203 { 0x00000172, 0x0008 },
0204 { 0x00000173, 0x0018 },
0205 { 0x00000174, 0x007D },
0206 { 0x00000175, 0x0004 },
0207 { 0x00000176, 0x0000 },
0208 { 0x00000177, 0x0181 },
0209 { 0x00000181, 0x0000 },
0210 { 0x00000182, 0x0000 },
0211 { 0x00000183, 0x0000 },
0212 { 0x00000184, 0x0000 },
0213 { 0x00000185, 0x0000 },
0214 { 0x00000186, 0x0000 },
0215 { 0x00000189, 0x0000 },
0216 { 0x0000018A, 0x0004 },
0217 { 0x00000191, 0x0000 },
0218 { 0x00000192, 0x0008 },
0219 { 0x00000193, 0x0018 },
0220 { 0x00000194, 0x007D },
0221 { 0x00000195, 0x0004 },
0222 { 0x00000196, 0x0000 },
0223 { 0x00000197, 0x0000 },
0224 { 0x000001A1, 0x0000 },
0225 { 0x000001A2, 0x0000 },
0226 { 0x000001A3, 0x0000 },
0227 { 0x000001A4, 0x0000 },
0228 { 0x000001A5, 0x0000 },
0229 { 0x000001A6, 0x0000 },
0230 { 0x000001A9, 0x0000 },
0231 { 0x000001AA, 0x0004 },
0232 { 0x00000200, 0x0006 },
0233 { 0x00000210, 0x00D4 },
0234 { 0x00000212, 0x0000 },
0235 { 0x00000213, 0x0344 },
0236 { 0x00000218, 0x01A6 },
0237 { 0x00000219, 0x01A6 },
0238 { 0x0000021A, 0x01A6 },
0239 { 0x00000293, 0x0000 },
0240 { 0x0000029B, 0x0020 },
0241 { 0x000002A3, 0x1102 },
0242 { 0x000002A4, 0x009F },
0243 { 0x000002C3, 0x0000 },
0244 { 0x000002CB, 0x0000 },
0245 { 0x000002D3, 0x0000 },
0246 { 0x00000300, 0x0000 },
0247 { 0x00000308, 0x0000 },
0248 { 0x00000309, 0x0022 },
0249 { 0x00000310, 0x2080 },
0250 { 0x00000311, 0x0180 },
0251 { 0x00000312, 0x0000 },
0252 { 0x00000314, 0x0080 },
0253 { 0x00000315, 0x0180 },
0254 { 0x00000316, 0x0000 },
0255 { 0x00000318, 0x2080 },
0256 { 0x00000319, 0x0180 },
0257 { 0x0000031A, 0x0000 },
0258 { 0x0000031C, 0x0080 },
0259 { 0x0000031D, 0x0180 },
0260 { 0x0000031E, 0x0000 },
0261 { 0x00000400, 0x0000 },
0262 { 0x00000408, 0x0000 },
0263 { 0x00000409, 0x0022 },
0264 { 0x00000410, 0x0080 },
0265 { 0x00000411, 0x0180 },
0266 { 0x00000412, 0x0080 },
0267 { 0x00000413, 0x0001 },
0268 { 0x00000414, 0x0080 },
0269 { 0x00000415, 0x0180 },
0270 { 0x00000416, 0x0080 },
0271 { 0x00000417, 0x0002 },
0272 { 0x00000420, 0x0080 },
0273 { 0x00000421, 0x0180 },
0274 { 0x00000422, 0x0080 },
0275 { 0x00000423, 0x0010 },
0276 { 0x00000428, 0x0000 },
0277 { 0x00000429, 0x0180 },
0278 { 0x0000042A, 0x0080 },
0279 { 0x0000042B, 0x0040 },
0280 { 0x00000430, 0x0000 },
0281 { 0x00000431, 0x0180 },
0282 { 0x00000432, 0x0080 },
0283 { 0x00000433, 0x0100 },
0284 { 0x00000435, 0x0180 },
0285 { 0x00000436, 0x0080 },
0286 { 0x00000437, 0x0200 },
0287 { 0x00000450, 0x0000 },
0288 { 0x00000458, 0x0000 },
0289 { 0x00000490, 0x0069 },
0290 { 0x00000491, 0x0000 },
0291 { 0x00000500, 0x000C },
0292 { 0x00000501, 0x0008 },
0293 { 0x00000502, 0x0000 },
0294 { 0x00000503, 0x0000 },
0295 { 0x00000504, 0x0000 },
0296 { 0x00000505, 0x0040 },
0297 { 0x00000506, 0x0040 },
0298 { 0x00000507, 0x1818 },
0299 { 0x00000508, 0x1818 },
0300 { 0x00000509, 0x0000 },
0301 { 0x0000050A, 0x0001 },
0302 { 0x0000050B, 0x0002 },
0303 { 0x0000050C, 0x0003 },
0304 { 0x0000050D, 0x0004 },
0305 { 0x0000050E, 0x0005 },
0306 { 0x0000050F, 0x0006 },
0307 { 0x00000510, 0x0007 },
0308 { 0x00000511, 0x0000 },
0309 { 0x00000512, 0x0001 },
0310 { 0x00000513, 0x0002 },
0311 { 0x00000514, 0x0003 },
0312 { 0x00000515, 0x0004 },
0313 { 0x00000516, 0x0005 },
0314 { 0x00000517, 0x0006 },
0315 { 0x00000518, 0x0007 },
0316 { 0x00000519, 0x0000 },
0317 { 0x0000051A, 0x0000 },
0318 { 0x00000540, 0x000C },
0319 { 0x00000541, 0x0008 },
0320 { 0x00000542, 0x0000 },
0321 { 0x00000543, 0x0000 },
0322 { 0x00000544, 0x0000 },
0323 { 0x00000545, 0x0040 },
0324 { 0x00000546, 0x0040 },
0325 { 0x00000547, 0x1818 },
0326 { 0x00000548, 0x1818 },
0327 { 0x00000549, 0x0000 },
0328 { 0x0000054A, 0x0001 },
0329 { 0x00000551, 0x0000 },
0330 { 0x00000552, 0x0001 },
0331 { 0x00000559, 0x0000 },
0332 { 0x0000055A, 0x0000 },
0333 { 0x000005E3, 0x0004 },
0334 { 0x000005E5, 0x0000 },
0335 { 0x000005E6, 0x0000 },
0336 { 0x000005E7, 0x0000 },
0337 { 0x000005E8, 0x0000 },
0338 { 0x000005E9, 0x0000 },
0339 { 0x000005EA, 0x0000 },
0340 { 0x000005EB, 0x0000 },
0341 { 0x000005EC, 0x0000 },
0342 { 0x000005F5, 0x0000 },
0343 { 0x000005F6, 0x0000 },
0344 { 0x00000640, 0x0000 },
0345 { 0x00000641, 0x0080 },
0346 { 0x00000642, 0x0000 },
0347 { 0x00000643, 0x0080 },
0348 { 0x00000644, 0x0000 },
0349 { 0x00000645, 0x0080 },
0350 { 0x00000646, 0x0000 },
0351 { 0x00000647, 0x0080 },
0352 { 0x00000648, 0x0000 },
0353 { 0x00000649, 0x0080 },
0354 { 0x0000064A, 0x0000 },
0355 { 0x0000064B, 0x0080 },
0356 { 0x0000064C, 0x0000 },
0357 { 0x0000064D, 0x0080 },
0358 { 0x0000064E, 0x0000 },
0359 { 0x0000064F, 0x0080 },
0360 { 0x00000660, 0x0000 },
0361 { 0x00000661, 0x0080 },
0362 { 0x00000662, 0x0000 },
0363 { 0x00000663, 0x0080 },
0364 { 0x00000664, 0x0000 },
0365 { 0x00000665, 0x0080 },
0366 { 0x00000666, 0x0000 },
0367 { 0x00000667, 0x0080 },
0368 { 0x00000668, 0x0000 },
0369 { 0x00000669, 0x0080 },
0370 { 0x0000066A, 0x0000 },
0371 { 0x0000066B, 0x0080 },
0372 { 0x0000066C, 0x0000 },
0373 { 0x0000066D, 0x0080 },
0374 { 0x0000066E, 0x0000 },
0375 { 0x0000066F, 0x0080 },
0376 { 0x00000680, 0x0000 },
0377 { 0x00000681, 0x0080 },
0378 { 0x00000682, 0x0000 },
0379 { 0x00000683, 0x0080 },
0380 { 0x00000684, 0x0000 },
0381 { 0x00000685, 0x0080 },
0382 { 0x00000686, 0x0000 },
0383 { 0x00000687, 0x0080 },
0384 { 0x00000688, 0x0000 },
0385 { 0x00000689, 0x0080 },
0386 { 0x0000068A, 0x0000 },
0387 { 0x0000068B, 0x0080 },
0388 { 0x0000068C, 0x0000 },
0389 { 0x0000068D, 0x0080 },
0390 { 0x0000068E, 0x0000 },
0391 { 0x0000068F, 0x0080 },
0392 { 0x000006A0, 0x0000 },
0393 { 0x000006A1, 0x0080 },
0394 { 0x000006A2, 0x0000 },
0395 { 0x000006A3, 0x0080 },
0396 { 0x000006A4, 0x0000 },
0397 { 0x000006A5, 0x0080 },
0398 { 0x000006A6, 0x0000 },
0399 { 0x000006A7, 0x0080 },
0400 { 0x000006B0, 0x0000 },
0401 { 0x000006B1, 0x0080 },
0402 { 0x000006B2, 0x0000 },
0403 { 0x000006B3, 0x0080 },
0404 { 0x000006B4, 0x0000 },
0405 { 0x000006B5, 0x0080 },
0406 { 0x000006B6, 0x0000 },
0407 { 0x000006B7, 0x0080 },
0408 { 0x000006C0, 0x0000 },
0409 { 0x000006C1, 0x0080 },
0410 { 0x000006C2, 0x0000 },
0411 { 0x000006C3, 0x0080 },
0412 { 0x000006C4, 0x0000 },
0413 { 0x000006C5, 0x0080 },
0414 { 0x000006C6, 0x0000 },
0415 { 0x000006C7, 0x0080 },
0416 { 0x000006C8, 0x0000 },
0417 { 0x000006C9, 0x0080 },
0418 { 0x000006CA, 0x0000 },
0419 { 0x000006CB, 0x0080 },
0420 { 0x000006CC, 0x0000 },
0421 { 0x000006CD, 0x0080 },
0422 { 0x000006CE, 0x0000 },
0423 { 0x000006CF, 0x0080 },
0424 { 0x00000700, 0x0000 },
0425 { 0x00000701, 0x0080 },
0426 { 0x00000702, 0x0000 },
0427 { 0x00000703, 0x0080 },
0428 { 0x00000704, 0x0000 },
0429 { 0x00000705, 0x0080 },
0430 { 0x00000706, 0x0000 },
0431 { 0x00000707, 0x0080 },
0432 { 0x00000708, 0x0000 },
0433 { 0x00000709, 0x0080 },
0434 { 0x0000070A, 0x0000 },
0435 { 0x0000070B, 0x0080 },
0436 { 0x0000070C, 0x0000 },
0437 { 0x0000070D, 0x0080 },
0438 { 0x0000070E, 0x0000 },
0439 { 0x0000070F, 0x0080 },
0440 { 0x00000710, 0x0000 },
0441 { 0x00000711, 0x0080 },
0442 { 0x00000712, 0x0000 },
0443 { 0x00000713, 0x0080 },
0444 { 0x00000714, 0x0000 },
0445 { 0x00000715, 0x0080 },
0446 { 0x00000716, 0x0000 },
0447 { 0x00000717, 0x0080 },
0448 { 0x00000718, 0x0000 },
0449 { 0x00000719, 0x0080 },
0450 { 0x0000071A, 0x0000 },
0451 { 0x0000071B, 0x0080 },
0452 { 0x0000071C, 0x0000 },
0453 { 0x0000071D, 0x0080 },
0454 { 0x0000071E, 0x0000 },
0455 { 0x0000071F, 0x0080 },
0456 { 0x00000720, 0x0000 },
0457 { 0x00000721, 0x0080 },
0458 { 0x00000722, 0x0000 },
0459 { 0x00000723, 0x0080 },
0460 { 0x00000724, 0x0000 },
0461 { 0x00000725, 0x0080 },
0462 { 0x00000726, 0x0000 },
0463 { 0x00000727, 0x0080 },
0464 { 0x00000728, 0x0000 },
0465 { 0x00000729, 0x0080 },
0466 { 0x0000072A, 0x0000 },
0467 { 0x0000072B, 0x0080 },
0468 { 0x0000072C, 0x0000 },
0469 { 0x0000072D, 0x0080 },
0470 { 0x0000072E, 0x0000 },
0471 { 0x0000072F, 0x0080 },
0472 { 0x00000730, 0x0000 },
0473 { 0x00000731, 0x0080 },
0474 { 0x00000732, 0x0000 },
0475 { 0x00000733, 0x0080 },
0476 { 0x00000734, 0x0000 },
0477 { 0x00000735, 0x0080 },
0478 { 0x00000736, 0x0000 },
0479 { 0x00000737, 0x0080 },
0480 { 0x00000738, 0x0000 },
0481 { 0x00000739, 0x0080 },
0482 { 0x0000073A, 0x0000 },
0483 { 0x0000073B, 0x0080 },
0484 { 0x0000073C, 0x0000 },
0485 { 0x0000073D, 0x0080 },
0486 { 0x0000073E, 0x0000 },
0487 { 0x0000073F, 0x0080 },
0488 { 0x00000740, 0x0000 },
0489 { 0x00000741, 0x0080 },
0490 { 0x00000742, 0x0000 },
0491 { 0x00000743, 0x0080 },
0492 { 0x00000744, 0x0000 },
0493 { 0x00000745, 0x0080 },
0494 { 0x00000746, 0x0000 },
0495 { 0x00000747, 0x0080 },
0496 { 0x00000748, 0x0000 },
0497 { 0x00000749, 0x0080 },
0498 { 0x0000074A, 0x0000 },
0499 { 0x0000074B, 0x0080 },
0500 { 0x0000074C, 0x0000 },
0501 { 0x0000074D, 0x0080 },
0502 { 0x0000074E, 0x0000 },
0503 { 0x0000074F, 0x0080 },
0504 { 0x000007C0, 0x0000 },
0505 { 0x000007C1, 0x0080 },
0506 { 0x000007C2, 0x0000 },
0507 { 0x000007C3, 0x0080 },
0508 { 0x000007C4, 0x0000 },
0509 { 0x000007C5, 0x0080 },
0510 { 0x000007C6, 0x0000 },
0511 { 0x000007C7, 0x0080 },
0512 { 0x000007C8, 0x0000 },
0513 { 0x000007C9, 0x0080 },
0514 { 0x000007CA, 0x0000 },
0515 { 0x000007CB, 0x0080 },
0516 { 0x000007CC, 0x0000 },
0517 { 0x000007CD, 0x0080 },
0518 { 0x000007CE, 0x0000 },
0519 { 0x000007CF, 0x0080 },
0520 { 0x000007D0, 0x0000 },
0521 { 0x000007D1, 0x0080 },
0522 { 0x000007D2, 0x0000 },
0523 { 0x000007D3, 0x0080 },
0524 { 0x000007D4, 0x0000 },
0525 { 0x000007D5, 0x0080 },
0526 { 0x000007D6, 0x0000 },
0527 { 0x000007D7, 0x0080 },
0528 { 0x000007D8, 0x0000 },
0529 { 0x000007D9, 0x0080 },
0530 { 0x000007DA, 0x0000 },
0531 { 0x000007DB, 0x0080 },
0532 { 0x000007DC, 0x0000 },
0533 { 0x000007DD, 0x0080 },
0534 { 0x000007DE, 0x0000 },
0535 { 0x000007DF, 0x0080 },
0536 { 0x000007E0, 0x0000 },
0537 { 0x000007E1, 0x0080 },
0538 { 0x000007E2, 0x0000 },
0539 { 0x000007E3, 0x0080 },
0540 { 0x000007E4, 0x0000 },
0541 { 0x000007E5, 0x0080 },
0542 { 0x000007E6, 0x0000 },
0543 { 0x000007E7, 0x0080 },
0544 { 0x000007E8, 0x0000 },
0545 { 0x000007E9, 0x0080 },
0546 { 0x000007EA, 0x0000 },
0547 { 0x000007EB, 0x0080 },
0548 { 0x000007EC, 0x0000 },
0549 { 0x000007ED, 0x0080 },
0550 { 0x000007EE, 0x0000 },
0551 { 0x000007EF, 0x0080 },
0552 { 0x000007F0, 0x0000 },
0553 { 0x000007F1, 0x0080 },
0554 { 0x000007F2, 0x0000 },
0555 { 0x000007F3, 0x0080 },
0556 { 0x000007F4, 0x0000 },
0557 { 0x000007F5, 0x0080 },
0558 { 0x000007F6, 0x0000 },
0559 { 0x000007F7, 0x0080 },
0560 { 0x000007F8, 0x0000 },
0561 { 0x000007F9, 0x0080 },
0562 { 0x000007FA, 0x0000 },
0563 { 0x000007FB, 0x0080 },
0564 { 0x000007FC, 0x0000 },
0565 { 0x000007FD, 0x0080 },
0566 { 0x000007FE, 0x0000 },
0567 { 0x000007FF, 0x0080 },
0568 { 0x00000880, 0x0000 },
0569 { 0x00000881, 0x0080 },
0570 { 0x00000882, 0x0000 },
0571 { 0x00000883, 0x0080 },
0572 { 0x00000884, 0x0000 },
0573 { 0x00000885, 0x0080 },
0574 { 0x00000886, 0x0000 },
0575 { 0x00000887, 0x0080 },
0576 { 0x00000888, 0x0000 },
0577 { 0x00000889, 0x0080 },
0578 { 0x0000088A, 0x0000 },
0579 { 0x0000088B, 0x0080 },
0580 { 0x0000088C, 0x0000 },
0581 { 0x0000088D, 0x0080 },
0582 { 0x0000088E, 0x0000 },
0583 { 0x0000088F, 0x0080 },
0584 { 0x00000890, 0x0000 },
0585 { 0x00000891, 0x0080 },
0586 { 0x00000892, 0x0000 },
0587 { 0x00000893, 0x0080 },
0588 { 0x00000894, 0x0000 },
0589 { 0x00000895, 0x0080 },
0590 { 0x00000896, 0x0000 },
0591 { 0x00000897, 0x0080 },
0592 { 0x00000898, 0x0000 },
0593 { 0x00000899, 0x0080 },
0594 { 0x0000089A, 0x0000 },
0595 { 0x0000089B, 0x0080 },
0596 { 0x0000089C, 0x0000 },
0597 { 0x0000089D, 0x0080 },
0598 { 0x0000089E, 0x0000 },
0599 { 0x0000089F, 0x0080 },
0600 { 0x000008C0, 0x0000 },
0601 { 0x000008C1, 0x0080 },
0602 { 0x000008C2, 0x0000 },
0603 { 0x000008C3, 0x0080 },
0604 { 0x000008C4, 0x0000 },
0605 { 0x000008C5, 0x0080 },
0606 { 0x000008C6, 0x0000 },
0607 { 0x000008C7, 0x0080 },
0608 { 0x000008C8, 0x0000 },
0609 { 0x000008C9, 0x0080 },
0610 { 0x000008CA, 0x0000 },
0611 { 0x000008CB, 0x0080 },
0612 { 0x000008CC, 0x0000 },
0613 { 0x000008CD, 0x0080 },
0614 { 0x000008CE, 0x0000 },
0615 { 0x000008CF, 0x0080 },
0616 { 0x00000900, 0x0000 },
0617 { 0x00000901, 0x0080 },
0618 { 0x00000902, 0x0000 },
0619 { 0x00000903, 0x0080 },
0620 { 0x00000904, 0x0000 },
0621 { 0x00000905, 0x0080 },
0622 { 0x00000906, 0x0000 },
0623 { 0x00000907, 0x0080 },
0624 { 0x00000908, 0x0000 },
0625 { 0x00000909, 0x0080 },
0626 { 0x0000090A, 0x0000 },
0627 { 0x0000090B, 0x0080 },
0628 { 0x0000090C, 0x0000 },
0629 { 0x0000090D, 0x0080 },
0630 { 0x0000090E, 0x0000 },
0631 { 0x0000090F, 0x0080 },
0632 { 0x00000910, 0x0000 },
0633 { 0x00000911, 0x0080 },
0634 { 0x00000912, 0x0000 },
0635 { 0x00000913, 0x0080 },
0636 { 0x00000914, 0x0000 },
0637 { 0x00000915, 0x0080 },
0638 { 0x00000916, 0x0000 },
0639 { 0x00000917, 0x0080 },
0640 { 0x00000918, 0x0000 },
0641 { 0x00000919, 0x0080 },
0642 { 0x0000091A, 0x0000 },
0643 { 0x0000091B, 0x0080 },
0644 { 0x0000091C, 0x0000 },
0645 { 0x0000091D, 0x0080 },
0646 { 0x0000091E, 0x0000 },
0647 { 0x0000091F, 0x0080 },
0648 { 0x00000B00, 0x0000 },
0649 { 0x00000B08, 0x0000 },
0650 { 0x00000B20, 0x0000 },
0651 { 0x00000B28, 0x0000 },
0652 { 0x00000B40, 0x0000 },
0653 { 0x00000B48, 0x0000 },
0654 { 0x00000B60, 0x0000 },
0655 { 0x00000B68, 0x0000 },
0656 { 0x00000C00, 0xA101 },
0657 { 0x00000C01, 0xA101 },
0658 { 0x00000C02, 0xA101 },
0659 { 0x00000C03, 0xA101 },
0660 { 0x00000C04, 0xA101 },
0661 { 0x00000C0F, 0x0400 },
0662 { 0x00000C10, 0x1000 },
0663 { 0x00000C20, 0x8002 },
0664 { 0x00000C21, 0x0001 },
0665 { 0x00000C22, 0x0000 },
0666 { 0x00000C23, 0x0000 },
0667 { 0x00000C24, 0x0000 },
0668 { 0x00000D08, 0xFFFF },
0669 { 0x00000D09, 0xFFFF },
0670 { 0x00000D0A, 0xFFFF },
0671 { 0x00000D0B, 0xFFFF },
0672 { 0x00000D0C, 0xFEFF },
0673 { 0x00000D0F, 0x0000 },
0674 { 0x00000D18, 0xFFFF },
0675 { 0x00000D1A, 0xFFFF },
0676 { 0x00000D1B, 0xFFFF },
0677 { 0x00000D1C, 0xFFFF },
0678 { 0x00000D1F, 0x0000 },
0679 { 0x00000D53, 0xFFFF },
0680 { 0x00000D54, 0xFFFF },
0681 { 0x00000D56, 0x0000 },
0682 { 0x00000E00, 0x0000 },
0683 { 0x00000E10, 0x6318 },
0684 { 0x00000E11, 0x6300 },
0685 { 0x00000E12, 0x0FC8 },
0686 { 0x00000E13, 0x03FE },
0687 { 0x00000E14, 0x00E0 },
0688 { 0x00000E15, 0x1EC4 },
0689 { 0x00000E16, 0xF136 },
0690 { 0x00000E17, 0x0409 },
0691 { 0x00000E18, 0x04CC },
0692 { 0x00000E19, 0x1C9B },
0693 { 0x00000E1A, 0xF337 },
0694 { 0x00000E1B, 0x040B },
0695 { 0x00000E1C, 0x0CBB },
0696 { 0x00000E1D, 0x16F8 },
0697 { 0x00000E1E, 0xF7D9 },
0698 { 0x00000E1F, 0x040A },
0699 { 0x00000E20, 0x1F14 },
0700 { 0x00000E21, 0x058C },
0701 { 0x00000E22, 0x0563 },
0702 { 0x00000E23, 0x4000 },
0703 { 0x00000E24, 0x0B75 },
0704 { 0x00000E26, 0x6318 },
0705 { 0x00000E27, 0x6300 },
0706 { 0x00000E28, 0x0FC8 },
0707 { 0x00000E29, 0x03FE },
0708 { 0x00000E2A, 0x00E0 },
0709 { 0x00000E2B, 0x1EC4 },
0710 { 0x00000E2C, 0xF136 },
0711 { 0x00000E2D, 0x0409 },
0712 { 0x00000E2E, 0x04CC },
0713 { 0x00000E2F, 0x1C9B },
0714 { 0x00000E30, 0xF337 },
0715 { 0x00000E31, 0x040B },
0716 { 0x00000E32, 0x0CBB },
0717 { 0x00000E33, 0x16F8 },
0718 { 0x00000E34, 0xF7D9 },
0719 { 0x00000E35, 0x040A },
0720 { 0x00000E36, 0x1F14 },
0721 { 0x00000E37, 0x058C },
0722 { 0x00000E38, 0x0563 },
0723 { 0x00000E39, 0x4000 },
0724 { 0x00000E3A, 0x0B75 },
0725 { 0x00000E3C, 0x6318 },
0726 { 0x00000E3D, 0x6300 },
0727 { 0x00000E3E, 0x0FC8 },
0728 { 0x00000E3F, 0x03FE },
0729 { 0x00000E40, 0x00E0 },
0730 { 0x00000E41, 0x1EC4 },
0731 { 0x00000E42, 0xF136 },
0732 { 0x00000E43, 0x0409 },
0733 { 0x00000E44, 0x04CC },
0734 { 0x00000E45, 0x1C9B },
0735 { 0x00000E46, 0xF337 },
0736 { 0x00000E47, 0x040B },
0737 { 0x00000E48, 0x0CBB },
0738 { 0x00000E49, 0x16F8 },
0739 { 0x00000E4A, 0xF7D9 },
0740 { 0x00000E4B, 0x040A },
0741 { 0x00000E4C, 0x1F14 },
0742 { 0x00000E4D, 0x058C },
0743 { 0x00000E4E, 0x0563 },
0744 { 0x00000E4F, 0x4000 },
0745 { 0x00000E50, 0x0B75 },
0746 { 0x00000E52, 0x6318 },
0747 { 0x00000E53, 0x6300 },
0748 { 0x00000E54, 0x0FC8 },
0749 { 0x00000E55, 0x03FE },
0750 { 0x00000E56, 0x00E0 },
0751 { 0x00000E57, 0x1EC4 },
0752 { 0x00000E58, 0xF136 },
0753 { 0x00000E59, 0x0409 },
0754 { 0x00000E5A, 0x04CC },
0755 { 0x00000E5B, 0x1C9B },
0756 { 0x00000E5C, 0xF337 },
0757 { 0x00000E5D, 0x040B },
0758 { 0x00000E5E, 0x0CBB },
0759 { 0x00000E5F, 0x16F8 },
0760 { 0x00000E60, 0xF7D9 },
0761 { 0x00000E61, 0x040A },
0762 { 0x00000E62, 0x1F14 },
0763 { 0x00000E63, 0x058C },
0764 { 0x00000E64, 0x0563 },
0765 { 0x00000E65, 0x4000 },
0766 { 0x00000E66, 0x0B75 },
0767 { 0x00000E80, 0x0018 },
0768 { 0x00000E81, 0x0933 },
0769 { 0x00000E82, 0x0018 },
0770 { 0x00000E83, 0x0000 },
0771 { 0x00000E84, 0x0000 },
0772 { 0x00000EC0, 0x0000 },
0773 { 0x00000EC1, 0x0000 },
0774 { 0x00000EC4, 0x0000 },
0775 { 0x00000EC5, 0x0000 },
0776 { 0x00000EC8, 0x0000 },
0777 { 0x00000EC9, 0x0000 },
0778 { 0x00000ECC, 0x0000 },
0779 { 0x00000ECD, 0x0000 },
0780 { 0x00000EF0, 0x0000 },
0781 { 0x00000EF1, 0x0000 },
0782 { 0x00000EF2, 0x0000 },
0783 { 0x00000EF3, 0x0000 },
0784 { 0x00000EF4, 0x0000 },
0785 { 0x00000EF5, 0x0000 },
0786 };
0787
0788 static bool wm8997_readable_register(struct device *dev, unsigned int reg)
0789 {
0790 switch (reg) {
0791 case ARIZONA_SOFTWARE_RESET:
0792 case ARIZONA_DEVICE_REVISION:
0793 case ARIZONA_CTRL_IF_I2C1_CFG_1:
0794 case ARIZONA_WRITE_SEQUENCER_CTRL_0:
0795 case ARIZONA_WRITE_SEQUENCER_CTRL_1:
0796 case ARIZONA_WRITE_SEQUENCER_CTRL_2:
0797 case ARIZONA_TONE_GENERATOR_1:
0798 case ARIZONA_TONE_GENERATOR_2:
0799 case ARIZONA_TONE_GENERATOR_3:
0800 case ARIZONA_TONE_GENERATOR_4:
0801 case ARIZONA_TONE_GENERATOR_5:
0802 case ARIZONA_PWM_DRIVE_1:
0803 case ARIZONA_PWM_DRIVE_2:
0804 case ARIZONA_PWM_DRIVE_3:
0805 case ARIZONA_WAKE_CONTROL:
0806 case ARIZONA_SEQUENCE_CONTROL:
0807 case ARIZONA_SAMPLE_RATE_SEQUENCE_SELECT_1:
0808 case ARIZONA_SAMPLE_RATE_SEQUENCE_SELECT_2:
0809 case ARIZONA_SAMPLE_RATE_SEQUENCE_SELECT_3:
0810 case ARIZONA_SAMPLE_RATE_SEQUENCE_SELECT_4:
0811 case ARIZONA_ALWAYS_ON_TRIGGERS_SEQUENCE_SELECT_3:
0812 case ARIZONA_ALWAYS_ON_TRIGGERS_SEQUENCE_SELECT_4:
0813 case ARIZONA_ALWAYS_ON_TRIGGERS_SEQUENCE_SELECT_5:
0814 case ARIZONA_ALWAYS_ON_TRIGGERS_SEQUENCE_SELECT_6:
0815 case ARIZONA_COMFORT_NOISE_GENERATOR:
0816 case ARIZONA_HAPTICS_CONTROL_1:
0817 case ARIZONA_HAPTICS_CONTROL_2:
0818 case ARIZONA_HAPTICS_PHASE_1_INTENSITY:
0819 case ARIZONA_HAPTICS_PHASE_1_DURATION:
0820 case ARIZONA_HAPTICS_PHASE_2_INTENSITY:
0821 case ARIZONA_HAPTICS_PHASE_2_DURATION:
0822 case ARIZONA_HAPTICS_PHASE_3_INTENSITY:
0823 case ARIZONA_HAPTICS_PHASE_3_DURATION:
0824 case ARIZONA_HAPTICS_STATUS:
0825 case ARIZONA_CLOCK_32K_1:
0826 case ARIZONA_SYSTEM_CLOCK_1:
0827 case ARIZONA_SAMPLE_RATE_1:
0828 case ARIZONA_SAMPLE_RATE_2:
0829 case ARIZONA_SAMPLE_RATE_3:
0830 case ARIZONA_SAMPLE_RATE_1_STATUS:
0831 case ARIZONA_SAMPLE_RATE_2_STATUS:
0832 case ARIZONA_SAMPLE_RATE_3_STATUS:
0833 case ARIZONA_ASYNC_CLOCK_1:
0834 case ARIZONA_ASYNC_SAMPLE_RATE_1:
0835 case ARIZONA_ASYNC_SAMPLE_RATE_1_STATUS:
0836 case ARIZONA_OUTPUT_SYSTEM_CLOCK:
0837 case ARIZONA_OUTPUT_ASYNC_CLOCK:
0838 case ARIZONA_RATE_ESTIMATOR_1:
0839 case ARIZONA_RATE_ESTIMATOR_2:
0840 case ARIZONA_RATE_ESTIMATOR_3:
0841 case ARIZONA_RATE_ESTIMATOR_4:
0842 case ARIZONA_RATE_ESTIMATOR_5:
0843 case ARIZONA_DYNAMIC_FREQUENCY_SCALING_1:
0844 case ARIZONA_FLL1_CONTROL_1:
0845 case ARIZONA_FLL1_CONTROL_2:
0846 case ARIZONA_FLL1_CONTROL_3:
0847 case ARIZONA_FLL1_CONTROL_4:
0848 case ARIZONA_FLL1_CONTROL_5:
0849 case ARIZONA_FLL1_CONTROL_6:
0850 case ARIZONA_FLL1_LOOP_FILTER_TEST_1:
0851 case ARIZONA_FLL1_NCO_TEST_0:
0852 case ARIZONA_FLL1_SYNCHRONISER_1:
0853 case ARIZONA_FLL1_SYNCHRONISER_2:
0854 case ARIZONA_FLL1_SYNCHRONISER_3:
0855 case ARIZONA_FLL1_SYNCHRONISER_4:
0856 case ARIZONA_FLL1_SYNCHRONISER_5:
0857 case ARIZONA_FLL1_SYNCHRONISER_6:
0858 case ARIZONA_FLL1_SPREAD_SPECTRUM:
0859 case ARIZONA_FLL1_GPIO_CLOCK:
0860 case ARIZONA_FLL2_CONTROL_1:
0861 case ARIZONA_FLL2_CONTROL_2:
0862 case ARIZONA_FLL2_CONTROL_3:
0863 case ARIZONA_FLL2_CONTROL_4:
0864 case ARIZONA_FLL2_CONTROL_5:
0865 case ARIZONA_FLL2_CONTROL_6:
0866 case ARIZONA_FLL2_LOOP_FILTER_TEST_1:
0867 case ARIZONA_FLL2_NCO_TEST_0:
0868 case ARIZONA_FLL2_SYNCHRONISER_1:
0869 case ARIZONA_FLL2_SYNCHRONISER_2:
0870 case ARIZONA_FLL2_SYNCHRONISER_3:
0871 case ARIZONA_FLL2_SYNCHRONISER_4:
0872 case ARIZONA_FLL2_SYNCHRONISER_5:
0873 case ARIZONA_FLL2_SYNCHRONISER_6:
0874 case ARIZONA_FLL2_SPREAD_SPECTRUM:
0875 case ARIZONA_FLL2_GPIO_CLOCK:
0876 case ARIZONA_MIC_CHARGE_PUMP_1:
0877 case ARIZONA_LDO1_CONTROL_1:
0878 case ARIZONA_LDO1_CONTROL_2:
0879 case ARIZONA_LDO2_CONTROL_1:
0880 case ARIZONA_MIC_BIAS_CTRL_1:
0881 case ARIZONA_MIC_BIAS_CTRL_2:
0882 case ARIZONA_MIC_BIAS_CTRL_3:
0883 case ARIZONA_HP_CTRL_1L:
0884 case ARIZONA_HP_CTRL_1R:
0885 case ARIZONA_ACCESSORY_DETECT_MODE_1:
0886 case ARIZONA_HEADPHONE_DETECT_1:
0887 case ARIZONA_HEADPHONE_DETECT_2:
0888 case ARIZONA_MIC_DETECT_1:
0889 case ARIZONA_MIC_DETECT_2:
0890 case ARIZONA_MIC_DETECT_3:
0891 case ARIZONA_MIC_NOISE_MIX_CONTROL_1:
0892 case ARIZONA_ISOLATION_CONTROL:
0893 case ARIZONA_JACK_DETECT_ANALOGUE:
0894 case ARIZONA_INPUT_ENABLES:
0895 case ARIZONA_INPUT_ENABLES_STATUS:
0896 case ARIZONA_INPUT_RATE:
0897 case ARIZONA_INPUT_VOLUME_RAMP:
0898 case ARIZONA_IN1L_CONTROL:
0899 case ARIZONA_ADC_DIGITAL_VOLUME_1L:
0900 case ARIZONA_DMIC1L_CONTROL:
0901 case ARIZONA_IN1R_CONTROL:
0902 case ARIZONA_ADC_DIGITAL_VOLUME_1R:
0903 case ARIZONA_DMIC1R_CONTROL:
0904 case ARIZONA_IN2L_CONTROL:
0905 case ARIZONA_ADC_DIGITAL_VOLUME_2L:
0906 case ARIZONA_DMIC2L_CONTROL:
0907 case ARIZONA_IN2R_CONTROL:
0908 case ARIZONA_ADC_DIGITAL_VOLUME_2R:
0909 case ARIZONA_DMIC2R_CONTROL:
0910 case ARIZONA_OUTPUT_ENABLES_1:
0911 case ARIZONA_OUTPUT_STATUS_1:
0912 case ARIZONA_RAW_OUTPUT_STATUS_1:
0913 case ARIZONA_OUTPUT_RATE_1:
0914 case ARIZONA_OUTPUT_VOLUME_RAMP:
0915 case ARIZONA_OUTPUT_PATH_CONFIG_1L:
0916 case ARIZONA_DAC_DIGITAL_VOLUME_1L:
0917 case ARIZONA_DAC_VOLUME_LIMIT_1L:
0918 case ARIZONA_NOISE_GATE_SELECT_1L:
0919 case ARIZONA_OUTPUT_PATH_CONFIG_1R:
0920 case ARIZONA_DAC_DIGITAL_VOLUME_1R:
0921 case ARIZONA_DAC_VOLUME_LIMIT_1R:
0922 case ARIZONA_NOISE_GATE_SELECT_1R:
0923 case ARIZONA_OUTPUT_PATH_CONFIG_3L:
0924 case ARIZONA_DAC_DIGITAL_VOLUME_3L:
0925 case ARIZONA_DAC_VOLUME_LIMIT_3L:
0926 case ARIZONA_NOISE_GATE_SELECT_3L:
0927 case ARIZONA_OUTPUT_PATH_CONFIG_4L:
0928 case ARIZONA_DAC_DIGITAL_VOLUME_4L:
0929 case ARIZONA_OUT_VOLUME_4L:
0930 case ARIZONA_NOISE_GATE_SELECT_4L:
0931 case ARIZONA_OUTPUT_PATH_CONFIG_5L:
0932 case ARIZONA_DAC_DIGITAL_VOLUME_5L:
0933 case ARIZONA_DAC_VOLUME_LIMIT_5L:
0934 case ARIZONA_NOISE_GATE_SELECT_5L:
0935 case ARIZONA_DAC_DIGITAL_VOLUME_5R:
0936 case ARIZONA_DAC_VOLUME_LIMIT_5R:
0937 case ARIZONA_NOISE_GATE_SELECT_5R:
0938 case ARIZONA_DAC_AEC_CONTROL_1:
0939 case ARIZONA_NOISE_GATE_CONTROL:
0940 case ARIZONA_PDM_SPK1_CTRL_1:
0941 case ARIZONA_PDM_SPK1_CTRL_2:
0942 case ARIZONA_AIF1_BCLK_CTRL:
0943 case ARIZONA_AIF1_TX_PIN_CTRL:
0944 case ARIZONA_AIF1_RX_PIN_CTRL:
0945 case ARIZONA_AIF1_RATE_CTRL:
0946 case ARIZONA_AIF1_FORMAT:
0947 case ARIZONA_AIF1_TX_BCLK_RATE:
0948 case ARIZONA_AIF1_RX_BCLK_RATE:
0949 case ARIZONA_AIF1_FRAME_CTRL_1:
0950 case ARIZONA_AIF1_FRAME_CTRL_2:
0951 case ARIZONA_AIF1_FRAME_CTRL_3:
0952 case ARIZONA_AIF1_FRAME_CTRL_4:
0953 case ARIZONA_AIF1_FRAME_CTRL_5:
0954 case ARIZONA_AIF1_FRAME_CTRL_6:
0955 case ARIZONA_AIF1_FRAME_CTRL_7:
0956 case ARIZONA_AIF1_FRAME_CTRL_8:
0957 case ARIZONA_AIF1_FRAME_CTRL_9:
0958 case ARIZONA_AIF1_FRAME_CTRL_10:
0959 case ARIZONA_AIF1_FRAME_CTRL_11:
0960 case ARIZONA_AIF1_FRAME_CTRL_12:
0961 case ARIZONA_AIF1_FRAME_CTRL_13:
0962 case ARIZONA_AIF1_FRAME_CTRL_14:
0963 case ARIZONA_AIF1_FRAME_CTRL_15:
0964 case ARIZONA_AIF1_FRAME_CTRL_16:
0965 case ARIZONA_AIF1_FRAME_CTRL_17:
0966 case ARIZONA_AIF1_FRAME_CTRL_18:
0967 case ARIZONA_AIF1_TX_ENABLES:
0968 case ARIZONA_AIF1_RX_ENABLES:
0969 case ARIZONA_AIF2_BCLK_CTRL:
0970 case ARIZONA_AIF2_TX_PIN_CTRL:
0971 case ARIZONA_AIF2_RX_PIN_CTRL:
0972 case ARIZONA_AIF2_RATE_CTRL:
0973 case ARIZONA_AIF2_FORMAT:
0974 case ARIZONA_AIF2_TX_BCLK_RATE:
0975 case ARIZONA_AIF2_RX_BCLK_RATE:
0976 case ARIZONA_AIF2_FRAME_CTRL_1:
0977 case ARIZONA_AIF2_FRAME_CTRL_2:
0978 case ARIZONA_AIF2_FRAME_CTRL_3:
0979 case ARIZONA_AIF2_FRAME_CTRL_4:
0980 case ARIZONA_AIF2_FRAME_CTRL_11:
0981 case ARIZONA_AIF2_FRAME_CTRL_12:
0982 case ARIZONA_AIF2_TX_ENABLES:
0983 case ARIZONA_AIF2_RX_ENABLES:
0984 case ARIZONA_SLIMBUS_FRAMER_REF_GEAR:
0985 case ARIZONA_SLIMBUS_RATES_1:
0986 case ARIZONA_SLIMBUS_RATES_2:
0987 case ARIZONA_SLIMBUS_RATES_3:
0988 case ARIZONA_SLIMBUS_RATES_4:
0989 case ARIZONA_SLIMBUS_RATES_5:
0990 case ARIZONA_SLIMBUS_RATES_6:
0991 case ARIZONA_SLIMBUS_RATES_7:
0992 case ARIZONA_SLIMBUS_RATES_8:
0993 case ARIZONA_SLIMBUS_RX_CHANNEL_ENABLE:
0994 case ARIZONA_SLIMBUS_TX_CHANNEL_ENABLE:
0995 case ARIZONA_SLIMBUS_RX_PORT_STATUS:
0996 case ARIZONA_SLIMBUS_TX_PORT_STATUS:
0997 case ARIZONA_PWM1MIX_INPUT_1_SOURCE:
0998 case ARIZONA_PWM1MIX_INPUT_1_VOLUME:
0999 case ARIZONA_PWM1MIX_INPUT_2_SOURCE:
1000 case ARIZONA_PWM1MIX_INPUT_2_VOLUME:
1001 case ARIZONA_PWM1MIX_INPUT_3_SOURCE:
1002 case ARIZONA_PWM1MIX_INPUT_3_VOLUME:
1003 case ARIZONA_PWM1MIX_INPUT_4_SOURCE:
1004 case ARIZONA_PWM1MIX_INPUT_4_VOLUME:
1005 case ARIZONA_PWM2MIX_INPUT_1_SOURCE:
1006 case ARIZONA_PWM2MIX_INPUT_1_VOLUME:
1007 case ARIZONA_PWM2MIX_INPUT_2_SOURCE:
1008 case ARIZONA_PWM2MIX_INPUT_2_VOLUME:
1009 case ARIZONA_PWM2MIX_INPUT_3_SOURCE:
1010 case ARIZONA_PWM2MIX_INPUT_3_VOLUME:
1011 case ARIZONA_PWM2MIX_INPUT_4_SOURCE:
1012 case ARIZONA_PWM2MIX_INPUT_4_VOLUME:
1013 case ARIZONA_MICMIX_INPUT_1_SOURCE:
1014 case ARIZONA_MICMIX_INPUT_1_VOLUME:
1015 case ARIZONA_MICMIX_INPUT_2_SOURCE:
1016 case ARIZONA_MICMIX_INPUT_2_VOLUME:
1017 case ARIZONA_MICMIX_INPUT_3_SOURCE:
1018 case ARIZONA_MICMIX_INPUT_3_VOLUME:
1019 case ARIZONA_MICMIX_INPUT_4_SOURCE:
1020 case ARIZONA_MICMIX_INPUT_4_VOLUME:
1021 case ARIZONA_NOISEMIX_INPUT_1_SOURCE:
1022 case ARIZONA_NOISEMIX_INPUT_1_VOLUME:
1023 case ARIZONA_NOISEMIX_INPUT_2_SOURCE:
1024 case ARIZONA_NOISEMIX_INPUT_2_VOLUME:
1025 case ARIZONA_NOISEMIX_INPUT_3_SOURCE:
1026 case ARIZONA_NOISEMIX_INPUT_3_VOLUME:
1027 case ARIZONA_NOISEMIX_INPUT_4_SOURCE:
1028 case ARIZONA_NOISEMIX_INPUT_4_VOLUME:
1029 case ARIZONA_OUT1LMIX_INPUT_1_SOURCE:
1030 case ARIZONA_OUT1LMIX_INPUT_1_VOLUME:
1031 case ARIZONA_OUT1LMIX_INPUT_2_SOURCE:
1032 case ARIZONA_OUT1LMIX_INPUT_2_VOLUME:
1033 case ARIZONA_OUT1LMIX_INPUT_3_SOURCE:
1034 case ARIZONA_OUT1LMIX_INPUT_3_VOLUME:
1035 case ARIZONA_OUT1LMIX_INPUT_4_SOURCE:
1036 case ARIZONA_OUT1LMIX_INPUT_4_VOLUME:
1037 case ARIZONA_OUT1RMIX_INPUT_1_SOURCE:
1038 case ARIZONA_OUT1RMIX_INPUT_1_VOLUME:
1039 case ARIZONA_OUT1RMIX_INPUT_2_SOURCE:
1040 case ARIZONA_OUT1RMIX_INPUT_2_VOLUME:
1041 case ARIZONA_OUT1RMIX_INPUT_3_SOURCE:
1042 case ARIZONA_OUT1RMIX_INPUT_3_VOLUME:
1043 case ARIZONA_OUT1RMIX_INPUT_4_SOURCE:
1044 case ARIZONA_OUT1RMIX_INPUT_4_VOLUME:
1045 case ARIZONA_OUT3LMIX_INPUT_1_SOURCE:
1046 case ARIZONA_OUT3LMIX_INPUT_1_VOLUME:
1047 case ARIZONA_OUT3LMIX_INPUT_2_SOURCE:
1048 case ARIZONA_OUT3LMIX_INPUT_2_VOLUME:
1049 case ARIZONA_OUT3LMIX_INPUT_3_SOURCE:
1050 case ARIZONA_OUT3LMIX_INPUT_3_VOLUME:
1051 case ARIZONA_OUT3LMIX_INPUT_4_SOURCE:
1052 case ARIZONA_OUT3LMIX_INPUT_4_VOLUME:
1053 case ARIZONA_OUT4LMIX_INPUT_1_SOURCE:
1054 case ARIZONA_OUT4LMIX_INPUT_1_VOLUME:
1055 case ARIZONA_OUT4LMIX_INPUT_2_SOURCE:
1056 case ARIZONA_OUT4LMIX_INPUT_2_VOLUME:
1057 case ARIZONA_OUT4LMIX_INPUT_3_SOURCE:
1058 case ARIZONA_OUT4LMIX_INPUT_3_VOLUME:
1059 case ARIZONA_OUT4LMIX_INPUT_4_SOURCE:
1060 case ARIZONA_OUT4LMIX_INPUT_4_VOLUME:
1061 case ARIZONA_OUT5LMIX_INPUT_1_SOURCE:
1062 case ARIZONA_OUT5LMIX_INPUT_1_VOLUME:
1063 case ARIZONA_OUT5LMIX_INPUT_2_SOURCE:
1064 case ARIZONA_OUT5LMIX_INPUT_2_VOLUME:
1065 case ARIZONA_OUT5LMIX_INPUT_3_SOURCE:
1066 case ARIZONA_OUT5LMIX_INPUT_3_VOLUME:
1067 case ARIZONA_OUT5LMIX_INPUT_4_SOURCE:
1068 case ARIZONA_OUT5LMIX_INPUT_4_VOLUME:
1069 case ARIZONA_OUT5RMIX_INPUT_1_SOURCE:
1070 case ARIZONA_OUT5RMIX_INPUT_1_VOLUME:
1071 case ARIZONA_OUT5RMIX_INPUT_2_SOURCE:
1072 case ARIZONA_OUT5RMIX_INPUT_2_VOLUME:
1073 case ARIZONA_OUT5RMIX_INPUT_3_SOURCE:
1074 case ARIZONA_OUT5RMIX_INPUT_3_VOLUME:
1075 case ARIZONA_OUT5RMIX_INPUT_4_SOURCE:
1076 case ARIZONA_OUT5RMIX_INPUT_4_VOLUME:
1077 case ARIZONA_AIF1TX1MIX_INPUT_1_SOURCE:
1078 case ARIZONA_AIF1TX1MIX_INPUT_1_VOLUME:
1079 case ARIZONA_AIF1TX1MIX_INPUT_2_SOURCE:
1080 case ARIZONA_AIF1TX1MIX_INPUT_2_VOLUME:
1081 case ARIZONA_AIF1TX1MIX_INPUT_3_SOURCE:
1082 case ARIZONA_AIF1TX1MIX_INPUT_3_VOLUME:
1083 case ARIZONA_AIF1TX1MIX_INPUT_4_SOURCE:
1084 case ARIZONA_AIF1TX1MIX_INPUT_4_VOLUME:
1085 case ARIZONA_AIF1TX2MIX_INPUT_1_SOURCE:
1086 case ARIZONA_AIF1TX2MIX_INPUT_1_VOLUME:
1087 case ARIZONA_AIF1TX2MIX_INPUT_2_SOURCE:
1088 case ARIZONA_AIF1TX2MIX_INPUT_2_VOLUME:
1089 case ARIZONA_AIF1TX2MIX_INPUT_3_SOURCE:
1090 case ARIZONA_AIF1TX2MIX_INPUT_3_VOLUME:
1091 case ARIZONA_AIF1TX2MIX_INPUT_4_SOURCE:
1092 case ARIZONA_AIF1TX2MIX_INPUT_4_VOLUME:
1093 case ARIZONA_AIF1TX3MIX_INPUT_1_SOURCE:
1094 case ARIZONA_AIF1TX3MIX_INPUT_1_VOLUME:
1095 case ARIZONA_AIF1TX3MIX_INPUT_2_SOURCE:
1096 case ARIZONA_AIF1TX3MIX_INPUT_2_VOLUME:
1097 case ARIZONA_AIF1TX3MIX_INPUT_3_SOURCE:
1098 case ARIZONA_AIF1TX3MIX_INPUT_3_VOLUME:
1099 case ARIZONA_AIF1TX3MIX_INPUT_4_SOURCE:
1100 case ARIZONA_AIF1TX3MIX_INPUT_4_VOLUME:
1101 case ARIZONA_AIF1TX4MIX_INPUT_1_SOURCE:
1102 case ARIZONA_AIF1TX4MIX_INPUT_1_VOLUME:
1103 case ARIZONA_AIF1TX4MIX_INPUT_2_SOURCE:
1104 case ARIZONA_AIF1TX4MIX_INPUT_2_VOLUME:
1105 case ARIZONA_AIF1TX4MIX_INPUT_3_SOURCE:
1106 case ARIZONA_AIF1TX4MIX_INPUT_3_VOLUME:
1107 case ARIZONA_AIF1TX4MIX_INPUT_4_SOURCE:
1108 case ARIZONA_AIF1TX4MIX_INPUT_4_VOLUME:
1109 case ARIZONA_AIF1TX5MIX_INPUT_1_SOURCE:
1110 case ARIZONA_AIF1TX5MIX_INPUT_1_VOLUME:
1111 case ARIZONA_AIF1TX5MIX_INPUT_2_SOURCE:
1112 case ARIZONA_AIF1TX5MIX_INPUT_2_VOLUME:
1113 case ARIZONA_AIF1TX5MIX_INPUT_3_SOURCE:
1114 case ARIZONA_AIF1TX5MIX_INPUT_3_VOLUME:
1115 case ARIZONA_AIF1TX5MIX_INPUT_4_SOURCE:
1116 case ARIZONA_AIF1TX5MIX_INPUT_4_VOLUME:
1117 case ARIZONA_AIF1TX6MIX_INPUT_1_SOURCE:
1118 case ARIZONA_AIF1TX6MIX_INPUT_1_VOLUME:
1119 case ARIZONA_AIF1TX6MIX_INPUT_2_SOURCE:
1120 case ARIZONA_AIF1TX6MIX_INPUT_2_VOLUME:
1121 case ARIZONA_AIF1TX6MIX_INPUT_3_SOURCE:
1122 case ARIZONA_AIF1TX6MIX_INPUT_3_VOLUME:
1123 case ARIZONA_AIF1TX6MIX_INPUT_4_SOURCE:
1124 case ARIZONA_AIF1TX6MIX_INPUT_4_VOLUME:
1125 case ARIZONA_AIF1TX7MIX_INPUT_1_SOURCE:
1126 case ARIZONA_AIF1TX7MIX_INPUT_1_VOLUME:
1127 case ARIZONA_AIF1TX7MIX_INPUT_2_SOURCE:
1128 case ARIZONA_AIF1TX7MIX_INPUT_2_VOLUME:
1129 case ARIZONA_AIF1TX7MIX_INPUT_3_SOURCE:
1130 case ARIZONA_AIF1TX7MIX_INPUT_3_VOLUME:
1131 case ARIZONA_AIF1TX7MIX_INPUT_4_SOURCE:
1132 case ARIZONA_AIF1TX7MIX_INPUT_4_VOLUME:
1133 case ARIZONA_AIF1TX8MIX_INPUT_1_SOURCE:
1134 case ARIZONA_AIF1TX8MIX_INPUT_1_VOLUME:
1135 case ARIZONA_AIF1TX8MIX_INPUT_2_SOURCE:
1136 case ARIZONA_AIF1TX8MIX_INPUT_2_VOLUME:
1137 case ARIZONA_AIF1TX8MIX_INPUT_3_SOURCE:
1138 case ARIZONA_AIF1TX8MIX_INPUT_3_VOLUME:
1139 case ARIZONA_AIF1TX8MIX_INPUT_4_SOURCE:
1140 case ARIZONA_AIF1TX8MIX_INPUT_4_VOLUME:
1141 case ARIZONA_AIF2TX1MIX_INPUT_1_SOURCE:
1142 case ARIZONA_AIF2TX1MIX_INPUT_1_VOLUME:
1143 case ARIZONA_AIF2TX1MIX_INPUT_2_SOURCE:
1144 case ARIZONA_AIF2TX1MIX_INPUT_2_VOLUME:
1145 case ARIZONA_AIF2TX1MIX_INPUT_3_SOURCE:
1146 case ARIZONA_AIF2TX1MIX_INPUT_3_VOLUME:
1147 case ARIZONA_AIF2TX1MIX_INPUT_4_SOURCE:
1148 case ARIZONA_AIF2TX1MIX_INPUT_4_VOLUME:
1149 case ARIZONA_AIF2TX2MIX_INPUT_1_SOURCE:
1150 case ARIZONA_AIF2TX2MIX_INPUT_1_VOLUME:
1151 case ARIZONA_AIF2TX2MIX_INPUT_2_SOURCE:
1152 case ARIZONA_AIF2TX2MIX_INPUT_2_VOLUME:
1153 case ARIZONA_AIF2TX2MIX_INPUT_3_SOURCE:
1154 case ARIZONA_AIF2TX2MIX_INPUT_3_VOLUME:
1155 case ARIZONA_AIF2TX2MIX_INPUT_4_SOURCE:
1156 case ARIZONA_AIF2TX2MIX_INPUT_4_VOLUME:
1157 case ARIZONA_SLIMTX1MIX_INPUT_1_SOURCE:
1158 case ARIZONA_SLIMTX1MIX_INPUT_1_VOLUME:
1159 case ARIZONA_SLIMTX1MIX_INPUT_2_SOURCE:
1160 case ARIZONA_SLIMTX1MIX_INPUT_2_VOLUME:
1161 case ARIZONA_SLIMTX1MIX_INPUT_3_SOURCE:
1162 case ARIZONA_SLIMTX1MIX_INPUT_3_VOLUME:
1163 case ARIZONA_SLIMTX1MIX_INPUT_4_SOURCE:
1164 case ARIZONA_SLIMTX1MIX_INPUT_4_VOLUME:
1165 case ARIZONA_SLIMTX2MIX_INPUT_1_SOURCE:
1166 case ARIZONA_SLIMTX2MIX_INPUT_1_VOLUME:
1167 case ARIZONA_SLIMTX2MIX_INPUT_2_SOURCE:
1168 case ARIZONA_SLIMTX2MIX_INPUT_2_VOLUME:
1169 case ARIZONA_SLIMTX2MIX_INPUT_3_SOURCE:
1170 case ARIZONA_SLIMTX2MIX_INPUT_3_VOLUME:
1171 case ARIZONA_SLIMTX2MIX_INPUT_4_SOURCE:
1172 case ARIZONA_SLIMTX2MIX_INPUT_4_VOLUME:
1173 case ARIZONA_SLIMTX3MIX_INPUT_1_SOURCE:
1174 case ARIZONA_SLIMTX3MIX_INPUT_1_VOLUME:
1175 case ARIZONA_SLIMTX3MIX_INPUT_2_SOURCE:
1176 case ARIZONA_SLIMTX3MIX_INPUT_2_VOLUME:
1177 case ARIZONA_SLIMTX3MIX_INPUT_3_SOURCE:
1178 case ARIZONA_SLIMTX3MIX_INPUT_3_VOLUME:
1179 case ARIZONA_SLIMTX3MIX_INPUT_4_SOURCE:
1180 case ARIZONA_SLIMTX3MIX_INPUT_4_VOLUME:
1181 case ARIZONA_SLIMTX4MIX_INPUT_1_SOURCE:
1182 case ARIZONA_SLIMTX4MIX_INPUT_1_VOLUME:
1183 case ARIZONA_SLIMTX4MIX_INPUT_2_SOURCE:
1184 case ARIZONA_SLIMTX4MIX_INPUT_2_VOLUME:
1185 case ARIZONA_SLIMTX4MIX_INPUT_3_SOURCE:
1186 case ARIZONA_SLIMTX4MIX_INPUT_3_VOLUME:
1187 case ARIZONA_SLIMTX4MIX_INPUT_4_SOURCE:
1188 case ARIZONA_SLIMTX4MIX_INPUT_4_VOLUME:
1189 case ARIZONA_SLIMTX5MIX_INPUT_1_SOURCE:
1190 case ARIZONA_SLIMTX5MIX_INPUT_1_VOLUME:
1191 case ARIZONA_SLIMTX5MIX_INPUT_2_SOURCE:
1192 case ARIZONA_SLIMTX5MIX_INPUT_2_VOLUME:
1193 case ARIZONA_SLIMTX5MIX_INPUT_3_SOURCE:
1194 case ARIZONA_SLIMTX5MIX_INPUT_3_VOLUME:
1195 case ARIZONA_SLIMTX5MIX_INPUT_4_SOURCE:
1196 case ARIZONA_SLIMTX5MIX_INPUT_4_VOLUME:
1197 case ARIZONA_SLIMTX6MIX_INPUT_1_SOURCE:
1198 case ARIZONA_SLIMTX6MIX_INPUT_1_VOLUME:
1199 case ARIZONA_SLIMTX6MIX_INPUT_2_SOURCE:
1200 case ARIZONA_SLIMTX6MIX_INPUT_2_VOLUME:
1201 case ARIZONA_SLIMTX6MIX_INPUT_3_SOURCE:
1202 case ARIZONA_SLIMTX6MIX_INPUT_3_VOLUME:
1203 case ARIZONA_SLIMTX6MIX_INPUT_4_SOURCE:
1204 case ARIZONA_SLIMTX6MIX_INPUT_4_VOLUME:
1205 case ARIZONA_SLIMTX7MIX_INPUT_1_SOURCE:
1206 case ARIZONA_SLIMTX7MIX_INPUT_1_VOLUME:
1207 case ARIZONA_SLIMTX7MIX_INPUT_2_SOURCE:
1208 case ARIZONA_SLIMTX7MIX_INPUT_2_VOLUME:
1209 case ARIZONA_SLIMTX7MIX_INPUT_3_SOURCE:
1210 case ARIZONA_SLIMTX7MIX_INPUT_3_VOLUME:
1211 case ARIZONA_SLIMTX7MIX_INPUT_4_SOURCE:
1212 case ARIZONA_SLIMTX7MIX_INPUT_4_VOLUME:
1213 case ARIZONA_SLIMTX8MIX_INPUT_1_SOURCE:
1214 case ARIZONA_SLIMTX8MIX_INPUT_1_VOLUME:
1215 case ARIZONA_SLIMTX8MIX_INPUT_2_SOURCE:
1216 case ARIZONA_SLIMTX8MIX_INPUT_2_VOLUME:
1217 case ARIZONA_SLIMTX8MIX_INPUT_3_SOURCE:
1218 case ARIZONA_SLIMTX8MIX_INPUT_3_VOLUME:
1219 case ARIZONA_SLIMTX8MIX_INPUT_4_SOURCE:
1220 case ARIZONA_SLIMTX8MIX_INPUT_4_VOLUME:
1221 case ARIZONA_EQ1MIX_INPUT_1_SOURCE:
1222 case ARIZONA_EQ1MIX_INPUT_1_VOLUME:
1223 case ARIZONA_EQ1MIX_INPUT_2_SOURCE:
1224 case ARIZONA_EQ1MIX_INPUT_2_VOLUME:
1225 case ARIZONA_EQ1MIX_INPUT_3_SOURCE:
1226 case ARIZONA_EQ1MIX_INPUT_3_VOLUME:
1227 case ARIZONA_EQ1MIX_INPUT_4_SOURCE:
1228 case ARIZONA_EQ1MIX_INPUT_4_VOLUME:
1229 case ARIZONA_EQ2MIX_INPUT_1_SOURCE:
1230 case ARIZONA_EQ2MIX_INPUT_1_VOLUME:
1231 case ARIZONA_EQ2MIX_INPUT_2_SOURCE:
1232 case ARIZONA_EQ2MIX_INPUT_2_VOLUME:
1233 case ARIZONA_EQ2MIX_INPUT_3_SOURCE:
1234 case ARIZONA_EQ2MIX_INPUT_3_VOLUME:
1235 case ARIZONA_EQ2MIX_INPUT_4_SOURCE:
1236 case ARIZONA_EQ2MIX_INPUT_4_VOLUME:
1237 case ARIZONA_EQ3MIX_INPUT_1_SOURCE:
1238 case ARIZONA_EQ3MIX_INPUT_1_VOLUME:
1239 case ARIZONA_EQ3MIX_INPUT_2_SOURCE:
1240 case ARIZONA_EQ3MIX_INPUT_2_VOLUME:
1241 case ARIZONA_EQ3MIX_INPUT_3_SOURCE:
1242 case ARIZONA_EQ3MIX_INPUT_3_VOLUME:
1243 case ARIZONA_EQ3MIX_INPUT_4_SOURCE:
1244 case ARIZONA_EQ3MIX_INPUT_4_VOLUME:
1245 case ARIZONA_EQ4MIX_INPUT_1_SOURCE:
1246 case ARIZONA_EQ4MIX_INPUT_1_VOLUME:
1247 case ARIZONA_EQ4MIX_INPUT_2_SOURCE:
1248 case ARIZONA_EQ4MIX_INPUT_2_VOLUME:
1249 case ARIZONA_EQ4MIX_INPUT_3_SOURCE:
1250 case ARIZONA_EQ4MIX_INPUT_3_VOLUME:
1251 case ARIZONA_EQ4MIX_INPUT_4_SOURCE:
1252 case ARIZONA_EQ4MIX_INPUT_4_VOLUME:
1253 case ARIZONA_DRC1LMIX_INPUT_1_SOURCE:
1254 case ARIZONA_DRC1LMIX_INPUT_1_VOLUME:
1255 case ARIZONA_DRC1LMIX_INPUT_2_SOURCE:
1256 case ARIZONA_DRC1LMIX_INPUT_2_VOLUME:
1257 case ARIZONA_DRC1LMIX_INPUT_3_SOURCE:
1258 case ARIZONA_DRC1LMIX_INPUT_3_VOLUME:
1259 case ARIZONA_DRC1LMIX_INPUT_4_SOURCE:
1260 case ARIZONA_DRC1LMIX_INPUT_4_VOLUME:
1261 case ARIZONA_DRC1RMIX_INPUT_1_SOURCE:
1262 case ARIZONA_DRC1RMIX_INPUT_1_VOLUME:
1263 case ARIZONA_DRC1RMIX_INPUT_2_SOURCE:
1264 case ARIZONA_DRC1RMIX_INPUT_2_VOLUME:
1265 case ARIZONA_DRC1RMIX_INPUT_3_SOURCE:
1266 case ARIZONA_DRC1RMIX_INPUT_3_VOLUME:
1267 case ARIZONA_DRC1RMIX_INPUT_4_SOURCE:
1268 case ARIZONA_DRC1RMIX_INPUT_4_VOLUME:
1269 case ARIZONA_HPLP1MIX_INPUT_1_SOURCE:
1270 case ARIZONA_HPLP1MIX_INPUT_1_VOLUME:
1271 case ARIZONA_HPLP1MIX_INPUT_2_SOURCE:
1272 case ARIZONA_HPLP1MIX_INPUT_2_VOLUME:
1273 case ARIZONA_HPLP1MIX_INPUT_3_SOURCE:
1274 case ARIZONA_HPLP1MIX_INPUT_3_VOLUME:
1275 case ARIZONA_HPLP1MIX_INPUT_4_SOURCE:
1276 case ARIZONA_HPLP1MIX_INPUT_4_VOLUME:
1277 case ARIZONA_HPLP2MIX_INPUT_1_SOURCE:
1278 case ARIZONA_HPLP2MIX_INPUT_1_VOLUME:
1279 case ARIZONA_HPLP2MIX_INPUT_2_SOURCE:
1280 case ARIZONA_HPLP2MIX_INPUT_2_VOLUME:
1281 case ARIZONA_HPLP2MIX_INPUT_3_SOURCE:
1282 case ARIZONA_HPLP2MIX_INPUT_3_VOLUME:
1283 case ARIZONA_HPLP2MIX_INPUT_4_SOURCE:
1284 case ARIZONA_HPLP2MIX_INPUT_4_VOLUME:
1285 case ARIZONA_HPLP3MIX_INPUT_1_SOURCE:
1286 case ARIZONA_HPLP3MIX_INPUT_1_VOLUME:
1287 case ARIZONA_HPLP3MIX_INPUT_2_SOURCE:
1288 case ARIZONA_HPLP3MIX_INPUT_2_VOLUME:
1289 case ARIZONA_HPLP3MIX_INPUT_3_SOURCE:
1290 case ARIZONA_HPLP3MIX_INPUT_3_VOLUME:
1291 case ARIZONA_HPLP3MIX_INPUT_4_SOURCE:
1292 case ARIZONA_HPLP3MIX_INPUT_4_VOLUME:
1293 case ARIZONA_HPLP4MIX_INPUT_1_SOURCE:
1294 case ARIZONA_HPLP4MIX_INPUT_1_VOLUME:
1295 case ARIZONA_HPLP4MIX_INPUT_2_SOURCE:
1296 case ARIZONA_HPLP4MIX_INPUT_2_VOLUME:
1297 case ARIZONA_HPLP4MIX_INPUT_3_SOURCE:
1298 case ARIZONA_HPLP4MIX_INPUT_3_VOLUME:
1299 case ARIZONA_HPLP4MIX_INPUT_4_SOURCE:
1300 case ARIZONA_HPLP4MIX_INPUT_4_VOLUME:
1301 case ARIZONA_ISRC1DEC1MIX_INPUT_1_SOURCE:
1302 case ARIZONA_ISRC1DEC2MIX_INPUT_1_SOURCE:
1303 case ARIZONA_ISRC1INT1MIX_INPUT_1_SOURCE:
1304 case ARIZONA_ISRC1INT2MIX_INPUT_1_SOURCE:
1305 case ARIZONA_ISRC2DEC1MIX_INPUT_1_SOURCE:
1306 case ARIZONA_ISRC2DEC2MIX_INPUT_1_SOURCE:
1307 case ARIZONA_ISRC2INT1MIX_INPUT_1_SOURCE:
1308 case ARIZONA_ISRC2INT2MIX_INPUT_1_SOURCE:
1309 case ARIZONA_GPIO1_CTRL:
1310 case ARIZONA_GPIO2_CTRL:
1311 case ARIZONA_GPIO3_CTRL:
1312 case ARIZONA_GPIO4_CTRL:
1313 case ARIZONA_GPIO5_CTRL:
1314 case ARIZONA_IRQ_CTRL_1:
1315 case ARIZONA_GPIO_DEBOUNCE_CONFIG:
1316 case ARIZONA_MISC_PAD_CTRL_1:
1317 case ARIZONA_MISC_PAD_CTRL_2:
1318 case ARIZONA_MISC_PAD_CTRL_3:
1319 case ARIZONA_MISC_PAD_CTRL_4:
1320 case ARIZONA_MISC_PAD_CTRL_5:
1321 case ARIZONA_INTERRUPT_STATUS_1:
1322 case ARIZONA_INTERRUPT_STATUS_2:
1323 case ARIZONA_INTERRUPT_STATUS_3:
1324 case ARIZONA_INTERRUPT_STATUS_4:
1325 case ARIZONA_INTERRUPT_STATUS_5:
1326 case ARIZONA_INTERRUPT_STATUS_1_MASK:
1327 case ARIZONA_INTERRUPT_STATUS_2_MASK:
1328 case ARIZONA_INTERRUPT_STATUS_3_MASK:
1329 case ARIZONA_INTERRUPT_STATUS_4_MASK:
1330 case ARIZONA_INTERRUPT_STATUS_5_MASK:
1331 case ARIZONA_INTERRUPT_CONTROL:
1332 case ARIZONA_IRQ2_STATUS_1:
1333 case ARIZONA_IRQ2_STATUS_3:
1334 case ARIZONA_IRQ2_STATUS_4:
1335 case ARIZONA_IRQ2_STATUS_5:
1336 case ARIZONA_IRQ2_STATUS_1_MASK:
1337 case ARIZONA_IRQ2_STATUS_3_MASK:
1338 case ARIZONA_IRQ2_STATUS_4_MASK:
1339 case ARIZONA_IRQ2_STATUS_5_MASK:
1340 case ARIZONA_IRQ2_CONTROL:
1341 case ARIZONA_INTERRUPT_RAW_STATUS_3:
1342 case ARIZONA_INTERRUPT_RAW_STATUS_4:
1343 case ARIZONA_INTERRUPT_RAW_STATUS_5:
1344 case ARIZONA_INTERRUPT_RAW_STATUS_6:
1345 case ARIZONA_INTERRUPT_RAW_STATUS_7:
1346 case ARIZONA_INTERRUPT_RAW_STATUS_8:
1347 case ARIZONA_IRQ_PIN_STATUS:
1348 case ARIZONA_AOD_WKUP_AND_TRIG:
1349 case ARIZONA_AOD_IRQ1:
1350 case ARIZONA_AOD_IRQ2:
1351 case ARIZONA_AOD_IRQ_MASK_IRQ1:
1352 case ARIZONA_AOD_IRQ_MASK_IRQ2:
1353 case ARIZONA_AOD_IRQ_RAW_STATUS:
1354 case ARIZONA_JACK_DETECT_DEBOUNCE:
1355 case ARIZONA_FX_CTRL1:
1356 case ARIZONA_FX_CTRL2:
1357 case ARIZONA_EQ1_1:
1358 case ARIZONA_EQ1_2:
1359 case ARIZONA_EQ1_3:
1360 case ARIZONA_EQ1_4:
1361 case ARIZONA_EQ1_5:
1362 case ARIZONA_EQ1_6:
1363 case ARIZONA_EQ1_7:
1364 case ARIZONA_EQ1_8:
1365 case ARIZONA_EQ1_9:
1366 case ARIZONA_EQ1_10:
1367 case ARIZONA_EQ1_11:
1368 case ARIZONA_EQ1_12:
1369 case ARIZONA_EQ1_13:
1370 case ARIZONA_EQ1_14:
1371 case ARIZONA_EQ1_15:
1372 case ARIZONA_EQ1_16:
1373 case ARIZONA_EQ1_17:
1374 case ARIZONA_EQ1_18:
1375 case ARIZONA_EQ1_19:
1376 case ARIZONA_EQ1_20:
1377 case ARIZONA_EQ1_21:
1378 case ARIZONA_EQ2_1:
1379 case ARIZONA_EQ2_2:
1380 case ARIZONA_EQ2_3:
1381 case ARIZONA_EQ2_4:
1382 case ARIZONA_EQ2_5:
1383 case ARIZONA_EQ2_6:
1384 case ARIZONA_EQ2_7:
1385 case ARIZONA_EQ2_8:
1386 case ARIZONA_EQ2_9:
1387 case ARIZONA_EQ2_10:
1388 case ARIZONA_EQ2_11:
1389 case ARIZONA_EQ2_12:
1390 case ARIZONA_EQ2_13:
1391 case ARIZONA_EQ2_14:
1392 case ARIZONA_EQ2_15:
1393 case ARIZONA_EQ2_16:
1394 case ARIZONA_EQ2_17:
1395 case ARIZONA_EQ2_18:
1396 case ARIZONA_EQ2_19:
1397 case ARIZONA_EQ2_20:
1398 case ARIZONA_EQ2_21:
1399 case ARIZONA_EQ3_1:
1400 case ARIZONA_EQ3_2:
1401 case ARIZONA_EQ3_3:
1402 case ARIZONA_EQ3_4:
1403 case ARIZONA_EQ3_5:
1404 case ARIZONA_EQ3_6:
1405 case ARIZONA_EQ3_7:
1406 case ARIZONA_EQ3_8:
1407 case ARIZONA_EQ3_9:
1408 case ARIZONA_EQ3_10:
1409 case ARIZONA_EQ3_11:
1410 case ARIZONA_EQ3_12:
1411 case ARIZONA_EQ3_13:
1412 case ARIZONA_EQ3_14:
1413 case ARIZONA_EQ3_15:
1414 case ARIZONA_EQ3_16:
1415 case ARIZONA_EQ3_17:
1416 case ARIZONA_EQ3_18:
1417 case ARIZONA_EQ3_19:
1418 case ARIZONA_EQ3_20:
1419 case ARIZONA_EQ3_21:
1420 case ARIZONA_EQ4_1:
1421 case ARIZONA_EQ4_2:
1422 case ARIZONA_EQ4_3:
1423 case ARIZONA_EQ4_4:
1424 case ARIZONA_EQ4_5:
1425 case ARIZONA_EQ4_6:
1426 case ARIZONA_EQ4_7:
1427 case ARIZONA_EQ4_8:
1428 case ARIZONA_EQ4_9:
1429 case ARIZONA_EQ4_10:
1430 case ARIZONA_EQ4_11:
1431 case ARIZONA_EQ4_12:
1432 case ARIZONA_EQ4_13:
1433 case ARIZONA_EQ4_14:
1434 case ARIZONA_EQ4_15:
1435 case ARIZONA_EQ4_16:
1436 case ARIZONA_EQ4_17:
1437 case ARIZONA_EQ4_18:
1438 case ARIZONA_EQ4_19:
1439 case ARIZONA_EQ4_20:
1440 case ARIZONA_EQ4_21:
1441 case ARIZONA_DRC1_CTRL1:
1442 case ARIZONA_DRC1_CTRL2:
1443 case ARIZONA_DRC1_CTRL3:
1444 case ARIZONA_DRC1_CTRL4:
1445 case ARIZONA_DRC1_CTRL5:
1446 case ARIZONA_HPLPF1_1:
1447 case ARIZONA_HPLPF1_2:
1448 case ARIZONA_HPLPF2_1:
1449 case ARIZONA_HPLPF2_2:
1450 case ARIZONA_HPLPF3_1:
1451 case ARIZONA_HPLPF3_2:
1452 case ARIZONA_HPLPF4_1:
1453 case ARIZONA_HPLPF4_2:
1454 case ARIZONA_ISRC_1_CTRL_1:
1455 case ARIZONA_ISRC_1_CTRL_2:
1456 case ARIZONA_ISRC_1_CTRL_3:
1457 case ARIZONA_ISRC_2_CTRL_1:
1458 case ARIZONA_ISRC_2_CTRL_2:
1459 case ARIZONA_ISRC_2_CTRL_3:
1460 return true;
1461 default:
1462 return false;
1463 }
1464 }
1465
1466 static bool wm8997_volatile_register(struct device *dev, unsigned int reg)
1467 {
1468 switch (reg) {
1469 case ARIZONA_SOFTWARE_RESET:
1470 case ARIZONA_DEVICE_REVISION:
1471 case ARIZONA_HAPTICS_STATUS:
1472 case ARIZONA_SAMPLE_RATE_1_STATUS:
1473 case ARIZONA_SAMPLE_RATE_2_STATUS:
1474 case ARIZONA_SAMPLE_RATE_3_STATUS:
1475 case ARIZONA_ASYNC_SAMPLE_RATE_1_STATUS:
1476 case ARIZONA_FLL1_NCO_TEST_0:
1477 case ARIZONA_FLL2_NCO_TEST_0:
1478 case ARIZONA_MIC_DETECT_3:
1479 case ARIZONA_HP_CTRL_1L:
1480 case ARIZONA_HP_CTRL_1R:
1481 case ARIZONA_HEADPHONE_DETECT_2:
1482 case ARIZONA_INPUT_ENABLES_STATUS:
1483 case ARIZONA_OUTPUT_STATUS_1:
1484 case ARIZONA_RAW_OUTPUT_STATUS_1:
1485 case ARIZONA_SLIMBUS_RX_PORT_STATUS:
1486 case ARIZONA_SLIMBUS_TX_PORT_STATUS:
1487 case ARIZONA_INTERRUPT_STATUS_1:
1488 case ARIZONA_INTERRUPT_STATUS_2:
1489 case ARIZONA_INTERRUPT_STATUS_3:
1490 case ARIZONA_INTERRUPT_STATUS_4:
1491 case ARIZONA_INTERRUPT_STATUS_5:
1492 case ARIZONA_IRQ2_STATUS_1:
1493 case ARIZONA_IRQ2_STATUS_3:
1494 case ARIZONA_IRQ2_STATUS_4:
1495 case ARIZONA_IRQ2_STATUS_5:
1496 case ARIZONA_INTERRUPT_RAW_STATUS_3:
1497 case ARIZONA_INTERRUPT_RAW_STATUS_4:
1498 case ARIZONA_INTERRUPT_RAW_STATUS_5:
1499 case ARIZONA_INTERRUPT_RAW_STATUS_6:
1500 case ARIZONA_INTERRUPT_RAW_STATUS_7:
1501 case ARIZONA_INTERRUPT_RAW_STATUS_8:
1502 case ARIZONA_IRQ_PIN_STATUS:
1503 case ARIZONA_AOD_WKUP_AND_TRIG:
1504 case ARIZONA_AOD_IRQ1:
1505 case ARIZONA_AOD_IRQ2:
1506 case ARIZONA_AOD_IRQ_RAW_STATUS:
1507 case ARIZONA_FX_CTRL2:
1508 return true;
1509 default:
1510 return false;
1511 }
1512 }
1513
1514 #define WM8997_MAX_REGISTER 0x31ff
1515
1516 const struct regmap_config wm8997_i2c_regmap = {
1517 .reg_bits = 32,
1518 .val_bits = 16,
1519 .reg_format_endian = REGMAP_ENDIAN_BIG,
1520 .val_format_endian = REGMAP_ENDIAN_BIG,
1521
1522 .max_register = WM8997_MAX_REGISTER,
1523 .readable_reg = wm8997_readable_register,
1524 .volatile_reg = wm8997_volatile_register,
1525
1526 .cache_type = REGCACHE_RBTREE,
1527 .reg_defaults = wm8997_reg_default,
1528 .num_reg_defaults = ARRAY_SIZE(wm8997_reg_default),
1529 };
1530 EXPORT_SYMBOL_GPL(wm8997_i2c_regmap);