Lines Matching +full:0 +full:x3700
31 #define RT5663_DEVICE_ID_2 0x6451
32 #define RT5663_DEVICE_ID_1 0x6406
80 { 0x002a, 0x8020 },
81 { 0x0086, 0x0028 },
82 { 0x0100, 0xa020 },
83 { 0x0117, 0x0f28 },
84 { 0x02fb, 0x8089 },
88 { 0x0000, 0x0000 },
89 { 0x0001, 0xc8c8 },
90 { 0x0002, 0x8080 },
91 { 0x0003, 0x8000 },
92 { 0x0004, 0xc80a },
93 { 0x0005, 0x0000 },
94 { 0x0006, 0x0000 },
95 { 0x0007, 0x0000 },
96 { 0x000a, 0x0000 },
97 { 0x000b, 0x0000 },
98 { 0x000c, 0x0000 },
99 { 0x000d, 0x0000 },
100 { 0x000f, 0x0808 },
101 { 0x0010, 0x4000 },
102 { 0x0011, 0x0000 },
103 { 0x0012, 0x1404 },
104 { 0x0013, 0x1000 },
105 { 0x0014, 0xa00a },
106 { 0x0015, 0x0404 },
107 { 0x0016, 0x0404 },
108 { 0x0017, 0x0011 },
109 { 0x0018, 0xafaf },
110 { 0x0019, 0xafaf },
111 { 0x001a, 0xafaf },
112 { 0x001b, 0x0011 },
113 { 0x001c, 0x2f2f },
114 { 0x001d, 0x2f2f },
115 { 0x001e, 0x2f2f },
116 { 0x001f, 0x0000 },
117 { 0x0020, 0x0000 },
118 { 0x0021, 0x0000 },
119 { 0x0022, 0x5757 },
120 { 0x0023, 0x0039 },
121 { 0x0024, 0x000b },
122 { 0x0026, 0xc0c0 },
123 { 0x0027, 0xc0c0 },
124 { 0x0028, 0xc0c0 },
125 { 0x0029, 0x8080 },
126 { 0x002a, 0xaaaa },
127 { 0x002b, 0xaaaa },
128 { 0x002c, 0xaba8 },
129 { 0x002d, 0x0000 },
130 { 0x002e, 0x0000 },
131 { 0x002f, 0x0000 },
132 { 0x0030, 0x0000 },
133 { 0x0031, 0x5000 },
134 { 0x0032, 0x0000 },
135 { 0x0033, 0x0000 },
136 { 0x0034, 0x0000 },
137 { 0x0035, 0x0000 },
138 { 0x003a, 0x0000 },
139 { 0x003b, 0x0000 },
140 { 0x003c, 0x00ff },
141 { 0x003d, 0x0000 },
142 { 0x003e, 0x00ff },
143 { 0x003f, 0x0000 },
144 { 0x0040, 0x0000 },
145 { 0x0041, 0x00ff },
146 { 0x0042, 0x0000 },
147 { 0x0043, 0x00ff },
148 { 0x0044, 0x0c0c },
149 { 0x0049, 0xc00b },
150 { 0x004a, 0x0000 },
151 { 0x004b, 0x031f },
152 { 0x004d, 0x0000 },
153 { 0x004e, 0x001f },
154 { 0x004f, 0x0000 },
155 { 0x0050, 0x001f },
156 { 0x0052, 0xf000 },
157 { 0x0061, 0x0000 },
158 { 0x0062, 0x0000 },
159 { 0x0063, 0x003e },
160 { 0x0064, 0x0000 },
161 { 0x0065, 0x0000 },
162 { 0x0066, 0x003f },
163 { 0x0067, 0x0000 },
164 { 0x006b, 0x0000 },
165 { 0x006d, 0xff00 },
166 { 0x006e, 0x2808 },
167 { 0x006f, 0x000a },
168 { 0x0070, 0x8000 },
169 { 0x0071, 0x8000 },
170 { 0x0072, 0x8000 },
171 { 0x0073, 0x7000 },
172 { 0x0074, 0x7770 },
173 { 0x0075, 0x0002 },
174 { 0x0076, 0x0001 },
175 { 0x0078, 0x00f0 },
176 { 0x0079, 0x0000 },
177 { 0x007a, 0x0000 },
178 { 0x007b, 0x0000 },
179 { 0x007c, 0x0000 },
180 { 0x007d, 0x0123 },
181 { 0x007e, 0x4500 },
182 { 0x007f, 0x8003 },
183 { 0x0080, 0x0000 },
184 { 0x0081, 0x0000 },
185 { 0x0082, 0x0000 },
186 { 0x0083, 0x0000 },
187 { 0x0084, 0x0000 },
188 { 0x0085, 0x0000 },
189 { 0x0086, 0x0008 },
190 { 0x0087, 0x0000 },
191 { 0x0088, 0x0000 },
192 { 0x0089, 0x0000 },
193 { 0x008a, 0x0000 },
194 { 0x008b, 0x0000 },
195 { 0x008c, 0x0003 },
196 { 0x008e, 0x0060 },
197 { 0x008f, 0x1000 },
198 { 0x0091, 0x0c26 },
199 { 0x0092, 0x0073 },
200 { 0x0093, 0x0000 },
201 { 0x0094, 0x0080 },
202 { 0x0098, 0x0000 },
203 { 0x0099, 0x0000 },
204 { 0x009a, 0x0007 },
205 { 0x009f, 0x0000 },
206 { 0x00a0, 0x0000 },
207 { 0x00a1, 0x0002 },
208 { 0x00a2, 0x0001 },
209 { 0x00a3, 0x0002 },
210 { 0x00a4, 0x0001 },
211 { 0x00ae, 0x2040 },
212 { 0x00af, 0x0000 },
213 { 0x00b6, 0x0000 },
214 { 0x00b7, 0x0000 },
215 { 0x00b8, 0x0000 },
216 { 0x00b9, 0x0000 },
217 { 0x00ba, 0x0002 },
218 { 0x00bb, 0x0000 },
219 { 0x00be, 0x0000 },
220 { 0x00c0, 0x0000 },
221 { 0x00c1, 0x0aaa },
222 { 0x00c2, 0xaa80 },
223 { 0x00c3, 0x0003 },
224 { 0x00c4, 0x0000 },
225 { 0x00d0, 0x0000 },
226 { 0x00d1, 0x2244 },
227 { 0x00d2, 0x0000 },
228 { 0x00d3, 0x3300 },
229 { 0x00d4, 0x2200 },
230 { 0x00d9, 0x0809 },
231 { 0x00da, 0x0000 },
232 { 0x00db, 0x0008 },
233 { 0x00dc, 0x00c0 },
234 { 0x00dd, 0x6724 },
235 { 0x00de, 0x3131 },
236 { 0x00df, 0x0008 },
237 { 0x00e0, 0x4000 },
238 { 0x00e1, 0x3131 },
239 { 0x00e2, 0x600c },
240 { 0x00ea, 0xb320 },
241 { 0x00eb, 0x0000 },
242 { 0x00ec, 0xb300 },
243 { 0x00ed, 0x0000 },
244 { 0x00ee, 0xb320 },
245 { 0x00ef, 0x0000 },
246 { 0x00f0, 0x0201 },
247 { 0x00f1, 0x0ddd },
248 { 0x00f2, 0x0ddd },
249 { 0x00f6, 0x0000 },
250 { 0x00f7, 0x0000 },
251 { 0x00f8, 0x0000 },
252 { 0x00fa, 0x0000 },
253 { 0x00fb, 0x0000 },
254 { 0x00fc, 0x0000 },
255 { 0x00fd, 0x0000 },
256 { 0x00fe, 0x10ec },
257 { 0x00ff, 0x6451 },
258 { 0x0100, 0xaaaa },
259 { 0x0101, 0x000a },
260 { 0x010a, 0xaaaa },
261 { 0x010b, 0xa0a0 },
262 { 0x010c, 0xaeae },
263 { 0x010d, 0xaaaa },
264 { 0x010e, 0xaaaa },
265 { 0x010f, 0xaaaa },
266 { 0x0110, 0xe002 },
267 { 0x0111, 0xa602 },
268 { 0x0112, 0xaaaa },
269 { 0x0113, 0x2000 },
270 { 0x0117, 0x0f00 },
271 { 0x0125, 0x0420 },
272 { 0x0132, 0x0000 },
273 { 0x0133, 0x0000 },
274 { 0x0136, 0x5555 },
275 { 0x0137, 0x5540 },
276 { 0x0138, 0x3700 },
277 { 0x0139, 0x79a1 },
278 { 0x013a, 0x2020 },
279 { 0x013b, 0x2020 },
280 { 0x013c, 0x2005 },
281 { 0x013f, 0x0000 },
282 { 0x0145, 0x0002 },
283 { 0x0146, 0x0000 },
284 { 0x0147, 0x0000 },
285 { 0x0148, 0x0000 },
286 { 0x0160, 0x4ec0 },
287 { 0x0161, 0x0080 },
288 { 0x0162, 0x0200 },
289 { 0x0163, 0x0800 },
290 { 0x0164, 0x0000 },
291 { 0x0165, 0x0000 },
292 { 0x0166, 0x0000 },
293 { 0x0167, 0x000f },
294 { 0x0168, 0x000f },
295 { 0x0170, 0x4e80 },
296 { 0x0171, 0x0080 },
297 { 0x0172, 0x0200 },
298 { 0x0173, 0x0800 },
299 { 0x0174, 0x00ff },
300 { 0x0175, 0x0000 },
301 { 0x0190, 0x4131 },
302 { 0x0191, 0x4131 },
303 { 0x0192, 0x4131 },
304 { 0x0193, 0x4131 },
305 { 0x0194, 0x0000 },
306 { 0x0195, 0x0000 },
307 { 0x0196, 0x0000 },
308 { 0x0197, 0x0000 },
309 { 0x0198, 0x0000 },
310 { 0x0199, 0x0000 },
311 { 0x01a0, 0x1e64 },
312 { 0x01a1, 0x06a3 },
313 { 0x01a2, 0x0000 },
314 { 0x01a3, 0x0000 },
315 { 0x01a4, 0x0000 },
316 { 0x01a5, 0x0000 },
317 { 0x01a6, 0x0000 },
318 { 0x01a7, 0x0000 },
319 { 0x01a8, 0x0000 },
320 { 0x01a9, 0x0000 },
321 { 0x01aa, 0x0000 },
322 { 0x01ab, 0x0000 },
323 { 0x01b5, 0x0000 },
324 { 0x01b6, 0x01c3 },
325 { 0x01b7, 0x02a0 },
326 { 0x01b8, 0x03e9 },
327 { 0x01b9, 0x1389 },
328 { 0x01ba, 0xc351 },
329 { 0x01bb, 0x0009 },
330 { 0x01bc, 0x0018 },
331 { 0x01bd, 0x002a },
332 { 0x01be, 0x004c },
333 { 0x01bf, 0x0097 },
334 { 0x01c0, 0x433d },
335 { 0x01c1, 0x0000 },
336 { 0x01c2, 0x0000 },
337 { 0x01c3, 0x0000 },
338 { 0x01c4, 0x0000 },
339 { 0x01c5, 0x0000 },
340 { 0x01c6, 0x0000 },
341 { 0x01c7, 0x0000 },
342 { 0x01c8, 0x40af },
343 { 0x01c9, 0x0702 },
344 { 0x01ca, 0x0000 },
345 { 0x01cb, 0x0000 },
346 { 0x01cc, 0x5757 },
347 { 0x01cd, 0x5757 },
348 { 0x01ce, 0x5757 },
349 { 0x01cf, 0x5757 },
350 { 0x01d0, 0x5757 },
351 { 0x01d1, 0x5757 },
352 { 0x01d2, 0x5757 },
353 { 0x01d3, 0x5757 },
354 { 0x01d4, 0x5757 },
355 { 0x01d5, 0x5757 },
356 { 0x01d6, 0x003c },
357 { 0x01da, 0x0000 },
358 { 0x01db, 0x0000 },
359 { 0x01dc, 0x0000 },
360 { 0x01de, 0x7c00 },
361 { 0x01df, 0x0320 },
362 { 0x01e0, 0x06a1 },
363 { 0x01e1, 0x0000 },
364 { 0x01e2, 0x0000 },
365 { 0x01e3, 0x0000 },
366 { 0x01e4, 0x0000 },
367 { 0x01e5, 0x0000 },
368 { 0x01e6, 0x0001 },
369 { 0x01e7, 0x0000 },
370 { 0x01e8, 0x0000 },
371 { 0x01ea, 0x0000 },
372 { 0x01eb, 0x0000 },
373 { 0x01ec, 0x0000 },
374 { 0x01ed, 0x0000 },
375 { 0x01ee, 0x0000 },
376 { 0x01ef, 0x0000 },
377 { 0x01f0, 0x0000 },
378 { 0x01f1, 0x0000 },
379 { 0x01f2, 0x0000 },
380 { 0x01f3, 0x0000 },
381 { 0x01f4, 0x0000 },
382 { 0x0200, 0x0000 },
383 { 0x0201, 0x0000 },
384 { 0x0202, 0x0000 },
385 { 0x0203, 0x0000 },
386 { 0x0204, 0x0000 },
387 { 0x0205, 0x0000 },
388 { 0x0206, 0x0000 },
389 { 0x0207, 0x0000 },
390 { 0x0208, 0x0000 },
391 { 0x0210, 0x60b1 },
392 { 0x0211, 0xa000 },
393 { 0x0212, 0x024c },
394 { 0x0213, 0xf7ff },
395 { 0x0214, 0x024c },
396 { 0x0215, 0x0102 },
397 { 0x0216, 0x00a3 },
398 { 0x0217, 0x0048 },
399 { 0x0218, 0x92c0 },
400 { 0x0219, 0x0000 },
401 { 0x021a, 0x00c8 },
402 { 0x021b, 0x0020 },
403 { 0x02fa, 0x0000 },
404 { 0x02fb, 0x0000 },
405 { 0x02fc, 0x0000 },
406 { 0x02ff, 0x0110 },
407 { 0x0300, 0x001f },
408 { 0x0301, 0x032c },
409 { 0x0302, 0x5f21 },
410 { 0x0303, 0x4000 },
411 { 0x0304, 0x4000 },
412 { 0x0305, 0x06d5 },
413 { 0x0306, 0x8000 },
414 { 0x0307, 0x0700 },
415 { 0x0310, 0x4560 },
416 { 0x0311, 0xa4a8 },
417 { 0x0312, 0x7418 },
418 { 0x0313, 0x0000 },
419 { 0x0314, 0x0006 },
420 { 0x0315, 0xffff },
421 { 0x0316, 0xc400 },
422 { 0x0317, 0x0000 },
423 { 0x0330, 0x00a6 },
424 { 0x0331, 0x04c3 },
425 { 0x0332, 0x27c8 },
426 { 0x0333, 0xbf50 },
427 { 0x0334, 0x0045 },
428 { 0x0335, 0x0007 },
429 { 0x0336, 0x7418 },
430 { 0x0337, 0x0501 },
431 { 0x0338, 0x0000 },
432 { 0x0339, 0x0010 },
433 { 0x033a, 0x1010 },
434 { 0x03c0, 0x7e00 },
435 { 0x03c1, 0x8000 },
436 { 0x03c2, 0x8000 },
437 { 0x03c3, 0x8000 },
438 { 0x03c4, 0x8000 },
439 { 0x03c5, 0x8000 },
440 { 0x03c6, 0x8000 },
441 { 0x03c7, 0x8000 },
442 { 0x03c8, 0x8000 },
443 { 0x03c9, 0x8000 },
444 { 0x03ca, 0x8000 },
445 { 0x03cb, 0x8000 },
446 { 0x03cc, 0x8000 },
447 { 0x03d0, 0x0000 },
448 { 0x03d1, 0x0000 },
449 { 0x03d2, 0x0000 },
450 { 0x03d3, 0x0000 },
451 { 0x03d4, 0x2000 },
452 { 0x03d5, 0x2000 },
453 { 0x03d6, 0x0000 },
454 { 0x03d7, 0x0000 },
455 { 0x03d8, 0x2000 },
456 { 0x03d9, 0x2000 },
457 { 0x03da, 0x2000 },
458 { 0x03db, 0x2000 },
459 { 0x03dc, 0x0000 },
460 { 0x03dd, 0x0000 },
461 { 0x03de, 0x0000 },
462 { 0x03df, 0x2000 },
463 { 0x03e0, 0x0000 },
464 { 0x03e1, 0x0000 },
465 { 0x03e2, 0x0000 },
466 { 0x03e3, 0x0000 },
467 { 0x03e4, 0x0000 },
468 { 0x03e5, 0x0000 },
469 { 0x03e6, 0x0000 },
470 { 0x03e7, 0x0000 },
471 { 0x03e8, 0x0000 },
472 { 0x03e9, 0x0000 },
473 { 0x03ea, 0x0000 },
474 { 0x03eb, 0x0000 },
475 { 0x03ec, 0x0000 },
476 { 0x03ed, 0x0000 },
477 { 0x03ee, 0x0000 },
478 { 0x03ef, 0x0000 },
479 { 0x03f0, 0x0800 },
480 { 0x03f1, 0x0800 },
481 { 0x03f2, 0x0800 },
482 { 0x03f3, 0x0800 },
483 { 0x03fe, 0x0000 },
484 { 0x03ff, 0x0000 },
485 { 0x07f0, 0x0000 },
486 { 0x07fa, 0x0000 },
490 { 0x0000, 0x0000 },
491 { 0x0002, 0x0008 },
492 { 0x0005, 0x1000 },
493 { 0x0006, 0x1000 },
494 { 0x000a, 0x0000 },
495 { 0x0010, 0x000f },
496 { 0x0015, 0x42f1 },
497 { 0x0016, 0x0000 },
498 { 0x0018, 0x000b },
499 { 0x0019, 0xafaf },
500 { 0x001c, 0x2f2f },
501 { 0x001f, 0x0000 },
502 { 0x0022, 0x5757 },
503 { 0x0023, 0x0039 },
504 { 0x0026, 0xc0c0 },
505 { 0x0029, 0x8080 },
506 { 0x002a, 0x8020 },
507 { 0x002c, 0x000c },
508 { 0x002d, 0x0000 },
509 { 0x0040, 0x0808 },
510 { 0x0061, 0x0000 },
511 { 0x0062, 0x0000 },
512 { 0x0063, 0x003e },
513 { 0x0064, 0x0000 },
514 { 0x0065, 0x0000 },
515 { 0x0066, 0x0000 },
516 { 0x006b, 0x0000 },
517 { 0x006e, 0x0000 },
518 { 0x006f, 0x0000 },
519 { 0x0070, 0x8020 },
520 { 0x0073, 0x1000 },
521 { 0x0074, 0xe400 },
522 { 0x0075, 0x0002 },
523 { 0x0076, 0x0001 },
524 { 0x0077, 0x00f0 },
525 { 0x0078, 0x0000 },
526 { 0x0079, 0x0000 },
527 { 0x007a, 0x0123 },
528 { 0x007b, 0x8003 },
529 { 0x0080, 0x0000 },
530 { 0x0081, 0x0000 },
531 { 0x0082, 0x0000 },
532 { 0x0083, 0x0000 },
533 { 0x0084, 0x0000 },
534 { 0x0086, 0x0028 },
535 { 0x0087, 0x0000 },
536 { 0x008a, 0x0000 },
537 { 0x008b, 0x0000 },
538 { 0x008c, 0x0003 },
539 { 0x008e, 0x0008 },
540 { 0x008f, 0x1000 },
541 { 0x0090, 0x0646 },
542 { 0x0091, 0x0e3e },
543 { 0x0092, 0x1071 },
544 { 0x0093, 0x0000 },
545 { 0x0094, 0x0080 },
546 { 0x0097, 0x0000 },
547 { 0x0098, 0x0000 },
548 { 0x009a, 0x0000 },
549 { 0x009f, 0x0000 },
550 { 0x00ae, 0x6000 },
551 { 0x00af, 0x0000 },
552 { 0x00b6, 0x0000 },
553 { 0x00b7, 0x0000 },
554 { 0x00b8, 0x0000 },
555 { 0x00ba, 0x0000 },
556 { 0x00bb, 0x0000 },
557 { 0x00be, 0x0000 },
558 { 0x00bf, 0x0000 },
559 { 0x00c0, 0x0000 },
560 { 0x00c1, 0x0000 },
561 { 0x00c5, 0x0000 },
562 { 0x00cb, 0xa02f },
563 { 0x00cc, 0x0000 },
564 { 0x00cd, 0x0e02 },
565 { 0x00d9, 0x08f9 },
566 { 0x00db, 0x0008 },
567 { 0x00dc, 0x00c0 },
568 { 0x00dd, 0x6729 },
569 { 0x00de, 0x3131 },
570 { 0x00df, 0x0008 },
571 { 0x00e0, 0x4000 },
572 { 0x00e1, 0x3131 },
573 { 0x00e2, 0x0043 },
574 { 0x00e4, 0x400b },
575 { 0x00e5, 0x8031 },
576 { 0x00e6, 0x3080 },
577 { 0x00e7, 0x4100 },
578 { 0x00e8, 0x1400 },
579 { 0x00e9, 0xe00a },
580 { 0x00ea, 0x0404 },
581 { 0x00eb, 0x0404 },
582 { 0x00ec, 0xb320 },
583 { 0x00ed, 0x0000 },
584 { 0x00f4, 0x0000 },
585 { 0x00f6, 0x0000 },
586 { 0x00f8, 0x0000 },
587 { 0x00fa, 0x8000 },
588 { 0x00fd, 0x0001 },
589 { 0x00fe, 0x10ec },
590 { 0x00ff, 0x6406 },
591 { 0x0100, 0xa020 },
592 { 0x0108, 0x4444 },
593 { 0x0109, 0x4444 },
594 { 0x010a, 0xaaaa },
595 { 0x010b, 0x00a0 },
596 { 0x010c, 0x8aaa },
597 { 0x010d, 0xaaaa },
598 { 0x010e, 0x2aaa },
599 { 0x010f, 0x002a },
600 { 0x0110, 0xa0a4 },
601 { 0x0111, 0x4602 },
602 { 0x0112, 0x0101 },
603 { 0x0113, 0x2000 },
604 { 0x0114, 0x0000 },
605 { 0x0116, 0x0000 },
606 { 0x0117, 0x0f28 },
607 { 0x0118, 0x0006 },
608 { 0x0125, 0x2424 },
609 { 0x0126, 0x5550 },
610 { 0x0127, 0x0400 },
611 { 0x0128, 0x7711 },
612 { 0x0132, 0x0004 },
613 { 0x0137, 0x5441 },
614 { 0x0139, 0x79a1 },
615 { 0x013a, 0x30c0 },
616 { 0x013b, 0x2000 },
617 { 0x013c, 0x2005 },
618 { 0x013d, 0x30c0 },
619 { 0x013e, 0x0000 },
620 { 0x0140, 0x3700 },
621 { 0x0141, 0x1f00 },
622 { 0x0144, 0x0000 },
623 { 0x0145, 0x0002 },
624 { 0x0146, 0x0000 },
625 { 0x0160, 0x0e80 },
626 { 0x0161, 0x0080 },
627 { 0x0162, 0x0200 },
628 { 0x0163, 0x0800 },
629 { 0x0164, 0x0000 },
630 { 0x0165, 0x0000 },
631 { 0x0166, 0x0000 },
632 { 0x0167, 0x1417 },
633 { 0x0168, 0x0017 },
634 { 0x0169, 0x0017 },
635 { 0x0180, 0x2000 },
636 { 0x0181, 0x0000 },
637 { 0x0182, 0x0000 },
638 { 0x0183, 0x2000 },
639 { 0x0184, 0x0000 },
640 { 0x0185, 0x0000 },
641 { 0x01b0, 0x4b30 },
642 { 0x01b1, 0x0000 },
643 { 0x01b2, 0xd870 },
644 { 0x01b3, 0x0000 },
645 { 0x01b4, 0x0030 },
646 { 0x01b5, 0x5757 },
647 { 0x01b6, 0x5757 },
648 { 0x01b7, 0x5757 },
649 { 0x01b8, 0x5757 },
650 { 0x01c0, 0x433d },
651 { 0x01c1, 0x0540 },
652 { 0x01c2, 0x0000 },
653 { 0x01c3, 0x0000 },
654 { 0x01c4, 0x0000 },
655 { 0x01c5, 0x0009 },
656 { 0x01c6, 0x0018 },
657 { 0x01c7, 0x002a },
658 { 0x01c8, 0x004c },
659 { 0x01c9, 0x0097 },
660 { 0x01ca, 0x01c3 },
661 { 0x01cb, 0x03e9 },
662 { 0x01cc, 0x1389 },
663 { 0x01cd, 0xc351 },
664 { 0x01ce, 0x0000 },
665 { 0x01cf, 0x0000 },
666 { 0x01d0, 0x0000 },
667 { 0x01d1, 0x0000 },
668 { 0x01d2, 0x0000 },
669 { 0x01d3, 0x003c },
670 { 0x01d4, 0x5757 },
671 { 0x01d5, 0x5757 },
672 { 0x01d6, 0x5757 },
673 { 0x01d7, 0x5757 },
674 { 0x01d8, 0x5757 },
675 { 0x01d9, 0x5757 },
676 { 0x01da, 0x0000 },
677 { 0x01db, 0x0000 },
678 { 0x01dd, 0x0009 },
679 { 0x01de, 0x7f00 },
680 { 0x01df, 0x00c8 },
681 { 0x01e0, 0x0691 },
682 { 0x01e1, 0x0000 },
683 { 0x01e2, 0x0000 },
684 { 0x01e3, 0x0000 },
685 { 0x01e4, 0x0000 },
686 { 0x01e5, 0x0040 },
687 { 0x01e6, 0x0000 },
688 { 0x01e7, 0x0000 },
689 { 0x01e8, 0x0000 },
690 { 0x01ea, 0x0000 },
691 { 0x01eb, 0x0000 },
692 { 0x01ec, 0x0000 },
693 { 0x01ed, 0x0000 },
694 { 0x01ee, 0x0000 },
695 { 0x01ef, 0x0000 },
696 { 0x01f0, 0x0000 },
697 { 0x01f1, 0x0000 },
698 { 0x01f2, 0x0000 },
699 { 0x0200, 0x0000 },
700 { 0x0201, 0x2244 },
701 { 0x0202, 0xaaaa },
702 { 0x0250, 0x8010 },
703 { 0x0251, 0x0000 },
704 { 0x0252, 0x028a },
705 { 0x02fa, 0x0000 },
706 { 0x02fb, 0x8089 },
707 { 0x02fc, 0x0300 },
708 { 0x0300, 0x0000 },
709 { 0x03d0, 0x0000 },
710 { 0x03d1, 0x0000 },
711 { 0x03d2, 0x0000 },
712 { 0x03d3, 0x0000 },
713 { 0x03d4, 0x2000 },
714 { 0x03d5, 0x2000 },
715 { 0x03d6, 0x0000 },
716 { 0x03d7, 0x0000 },
717 { 0x03d8, 0x2000 },
718 { 0x03d9, 0x2000 },
719 { 0x03da, 0x2000 },
720 { 0x03db, 0x2000 },
721 { 0x03dc, 0x0000 },
722 { 0x03dd, 0x0000 },
723 { 0x03de, 0x0000 },
724 { 0x03df, 0x2000 },
725 { 0x03e0, 0x0000 },
726 { 0x03e1, 0x0000 },
727 { 0x03e2, 0x0000 },
728 { 0x03e3, 0x0000 },
729 { 0x03e4, 0x0000 },
730 { 0x03e5, 0x0000 },
731 { 0x03e6, 0x0000 },
732 { 0x03e7, 0x0000 },
733 { 0x03e8, 0x0000 },
734 { 0x03e9, 0x0000 },
735 { 0x03ea, 0x0000 },
736 { 0x03eb, 0x0000 },
737 { 0x03ec, 0x0000 },
738 { 0x03ed, 0x0000 },
739 { 0x03ee, 0x0000 },
740 { 0x03ef, 0x0000 },
741 { 0x03f0, 0x0800 },
742 { 0x03f1, 0x0800 },
743 { 0x03f2, 0x0800 },
744 { 0x03f3, 0x0800 },
1373 static const DECLARE_TLV_DB_SCALE(rt5663_hp_vol_tlv, -2400, 150, 0);
1374 static const DECLARE_TLV_DB_SCALE(rt5663_v2_hp_vol_tlv, -2250, 150, 0);
1375 static const DECLARE_TLV_DB_SCALE(dac_vol_tlv, -6525, 75, 0);
1376 static const DECLARE_TLV_DB_SCALE(adc_vol_tlv, -1725, 75, 0);
1378 /* {0, +20, +24, +30, +35, +40, +44, +50, +52} dB */
1380 0, 0, TLV_DB_SCALE_ITEM(0, 0, 0),
1381 1, 1, TLV_DB_SCALE_ITEM(2000, 0, 0),
1382 2, 2, TLV_DB_SCALE_ITEM(2400, 0, 0),
1383 3, 5, TLV_DB_SCALE_ITEM(3000, 500, 0),
1384 6, 6, TLV_DB_SCALE_ITEM(4400, 0, 0),
1385 7, 7, TLV_DB_SCALE_ITEM(5000, 0, 0),
1386 8, 8, TLV_DB_SCALE_ITEM(5200, 0, 0)
1467 int val, i = 0, sleep_time[5] = {300, 150, 100, 50, 30}; in rt5663_v2_jack_detect()
1471 snd_soc_component_write(component, RT5663_CBJ_TYPE_2, 0x8040); in rt5663_v2_jack_detect()
1472 snd_soc_component_write(component, RT5663_CBJ_TYPE_3, 0x1484); in rt5663_v2_jack_detect()
1481 snd_soc_component_update_bits(component, RT5663_RECMIX, 0x8, 0x8); in rt5663_v2_jack_detect()
1485 val = snd_soc_component_read(component, RT5663_CBJ_TYPE_2) & 0x0003; in rt5663_v2_jack_detect()
1486 if (val == 0x1 || val == 0x2 || val == 0x3) in rt5663_v2_jack_detect()
1509 snd_soc_component_update_bits(component, RT5663_RECMIX, 0x8, 0x0); in rt5663_v2_jack_detect()
1519 rt5663->jack_type = 0; in rt5663_v2_jack_detect()
1538 int val, i = 0; in rt5663_jack_detect()
1588 if (!(val & 0x80)) in rt5663_jack_detect()
1598 val = snd_soc_component_read(component, RT5663_EM_JACK_TYPE_2) & 0x0003; in rt5663_jack_detect()
1620 0xffff); in rt5663_jack_detect()
1629 0xffff); in rt5663_jack_detect()
1637 RT5663_PWR_VREF2_MASK, 0); in rt5663_jack_detect()
1646 0xffff); in rt5663_jack_detect()
1654 0xffff); in rt5663_jack_detect()
1661 rt5663->jack_type = 0; in rt5663_jack_detect()
1664 RT5663_PWR_VREF2_MASK, 0); in rt5663_jack_detect()
1676 for (i = 0; i < rt5663->pdata.impedance_sensing_num; i++) { in rt5663_impedance_sensing()
1685 rt5663->imp_table[i].dc_offset_l_manual_mic & 0xffff); in rt5663_impedance_sensing()
1689 rt5663->imp_table[i].dc_offset_r_manual_mic & 0xffff); in rt5663_impedance_sensing()
1694 rt5663->imp_table[i].dc_offset_l_manual & 0xffff); in rt5663_impedance_sensing()
1698 rt5663->imp_table[i].dc_offset_r_manual & 0xffff); in rt5663_impedance_sensing()
1708 snd_soc_component_update_bits(component, RT5663_STO_DRE_1, 0x8000, 0); in rt5663_impedance_sensing()
1709 snd_soc_component_write(component, RT5663_ASRC_2, 0); in rt5663_impedance_sensing()
1710 snd_soc_component_write(component, RT5663_STO1_ADC_MIXER, 0x4040); in rt5663_impedance_sensing()
1723 snd_soc_component_update_bits(component, RT5663_ADDA_CLK_1, RT5663_I2S_PD1_MASK, 0); in rt5663_impedance_sensing()
1724 snd_soc_component_write(component, RT5663_PRE_DIV_GATING_1, 0xff00); in rt5663_impedance_sensing()
1725 snd_soc_component_write(component, RT5663_PRE_DIV_GATING_2, 0xfffc); in rt5663_impedance_sensing()
1726 snd_soc_component_write(component, RT5663_HP_CHARGE_PUMP_1, 0x1232); in rt5663_impedance_sensing()
1727 snd_soc_component_write(component, RT5663_HP_LOGIC_2, 0x0005); in rt5663_impedance_sensing()
1728 snd_soc_component_write(component, RT5663_DEPOP_2, 0x3003); in rt5663_impedance_sensing()
1729 snd_soc_component_update_bits(component, RT5663_DEPOP_1, 0x0030, 0x0030); in rt5663_impedance_sensing()
1730 snd_soc_component_update_bits(component, RT5663_DEPOP_1, 0x0003, 0x0003); in rt5663_impedance_sensing()
1746 snd_soc_component_write(component, RT5663_HP_CHARGE_PUMP_2, 0x1371); in rt5663_impedance_sensing()
1747 snd_soc_component_write(component, RT5663_STO_DAC_MIXER, 0); in rt5663_impedance_sensing()
1748 snd_soc_component_write(component, RT5663_BYPASS_STO_DAC, 0x000c); in rt5663_impedance_sensing()
1749 snd_soc_component_write(component, RT5663_HP_BIAS, 0xafaa); in rt5663_impedance_sensing()
1750 snd_soc_component_write(component, RT5663_CHARGE_PUMP_1, 0x2224); in rt5663_impedance_sensing()
1751 snd_soc_component_write(component, RT5663_HP_OUT_EN, 0x8088); in rt5663_impedance_sensing()
1752 snd_soc_component_write(component, RT5663_CHOP_ADC, 0x3000); in rt5663_impedance_sensing()
1753 snd_soc_component_write(component, RT5663_ADDA_RST, 0xc000); in rt5663_impedance_sensing()
1754 snd_soc_component_write(component, RT5663_STO1_HPF_ADJ1, 0x3320); in rt5663_impedance_sensing()
1755 snd_soc_component_write(component, RT5663_HP_CALIB_2, 0x00c9); in rt5663_impedance_sensing()
1756 snd_soc_component_write(component, RT5663_DUMMY_1, 0x004c); in rt5663_impedance_sensing()
1757 snd_soc_component_write(component, RT5663_ANA_BIAS_CUR_1, 0x7733); in rt5663_impedance_sensing()
1758 snd_soc_component_write(component, RT5663_CHARGE_PUMP_2, 0x7777); in rt5663_impedance_sensing()
1759 snd_soc_component_write(component, RT5663_STO_DRE_9, 0x0007); in rt5663_impedance_sensing()
1760 snd_soc_component_write(component, RT5663_STO_DRE_10, 0x0007); in rt5663_impedance_sensing()
1761 snd_soc_component_write(component, RT5663_DUMMY_2, 0x02a4); in rt5663_impedance_sensing()
1762 snd_soc_component_write(component, RT5663_RECMIX, 0x0005); in rt5663_impedance_sensing()
1763 snd_soc_component_write(component, RT5663_HP_IMP_SEN_1, 0x4334); in rt5663_impedance_sensing()
1764 snd_soc_component_update_bits(component, RT5663_IRQ_3, 0x0004, 0x0004); in rt5663_impedance_sensing()
1765 snd_soc_component_write(component, RT5663_HP_LOGIC_1, 0x2200); in rt5663_impedance_sensing()
1766 snd_soc_component_update_bits(component, RT5663_DEPOP_1, 0x3000, 0x3000); in rt5663_impedance_sensing()
1767 snd_soc_component_write(component, RT5663_HP_LOGIC_1, 0x6200); in rt5663_impedance_sensing()
1769 for (i = 0; i < 100; i++) { in rt5663_impedance_sensing()
1771 if (snd_soc_component_read(component, RT5663_INT_ST_1) & 0x2) in rt5663_impedance_sensing()
1777 snd_soc_component_update_bits(component, RT5663_DEPOP_1, 0x3000, 0); in rt5663_impedance_sensing()
1778 snd_soc_component_write(component, RT5663_INT_ST_1, 0); in rt5663_impedance_sensing()
1779 snd_soc_component_write(component, RT5663_HP_LOGIC_1, 0); in rt5663_impedance_sensing()
1784 snd_soc_component_write(component, RT5663_DUMMY_2, 0x00a4); in rt5663_impedance_sensing()
1786 snd_soc_component_write(component, RT5663_HP_CALIB_2, 0x00c8); in rt5663_impedance_sensing()
1787 snd_soc_component_write(component, RT5663_STO1_HPF_ADJ1, 0xb320); in rt5663_impedance_sensing()
1788 snd_soc_component_write(component, RT5663_ADDA_RST, 0xe400); in rt5663_impedance_sensing()
1789 snd_soc_component_write(component, RT5663_CHOP_ADC, 0x2000); in rt5663_impedance_sensing()
1790 snd_soc_component_write(component, RT5663_HP_OUT_EN, 0x0008); in rt5663_impedance_sensing()
1792 RT5663_PWR_RECMIX1 | RT5663_PWR_RECMIX2, 0); in rt5663_impedance_sensing()
1796 RT5663_PWR_ADC_R1, 0); in rt5663_impedance_sensing()
1798 RT5663_PWR_ADC_S1F | RT5663_PWR_DAC_S1F, 0); in rt5663_impedance_sensing()
1799 snd_soc_component_update_bits(component, RT5663_DEPOP_1, 0x0003, 0); in rt5663_impedance_sensing()
1800 snd_soc_component_update_bits(component, RT5663_DEPOP_1, 0x0030, 0); in rt5663_impedance_sensing()
1801 snd_soc_component_write(component, RT5663_HP_LOGIC_2, 0); in rt5663_impedance_sensing()
1804 RT5663_PWR_VREF1_MASK | RT5663_PWR_VREF2_MASK, 0); in rt5663_impedance_sensing()
1808 for (i = 0; i < rt5663->pdata.impedance_sensing_num; i++) { in rt5663_impedance_sensing()
1823 rt5663->imp_table[i].dc_offset_l_manual_mic & 0xffff); in rt5663_impedance_sensing()
1827 rt5663->imp_table[i].dc_offset_r_manual_mic & 0xffff); in rt5663_impedance_sensing()
1832 rt5663->imp_table[i].dc_offset_l_manual & 0xffff); in rt5663_impedance_sensing()
1836 rt5663->imp_table[i].dc_offset_r_manual & 0xffff); in rt5663_impedance_sensing()
1839 return 0; in rt5663_impedance_sensing()
1847 dev_dbg(component->dev, "%s: val=0x%x\n", __func__, val); in rt5663_button_detect()
1848 btn_type = val & 0xfff0; in rt5663_button_detect()
1874 rt5663_irq(0, rt5663); in rt5663_set_jack_detect()
1876 return 0; in rt5663_set_jack_detect()
1889 return !(val & 0x2000); in rt5663_check_jd_status()
1891 return !(val & 0x1000); in rt5663_check_jd_status()
1904 int btn_type, report = 0; in rt5663_jack_detect_work()
1911 if (rt5663->jack_type == 0) { in rt5663_jack_detect_work()
1941 case 0x8000: in rt5663_jack_detect_work()
1942 case 0x4000: in rt5663_jack_detect_work()
1943 case 0x2000: in rt5663_jack_detect_work()
1946 case 0x1000: in rt5663_jack_detect_work()
1947 case 0x0800: in rt5663_jack_detect_work()
1948 case 0x0400: in rt5663_jack_detect_work()
1951 case 0x0200: in rt5663_jack_detect_work()
1952 case 0x0100: in rt5663_jack_detect_work()
1953 case 0x0080: in rt5663_jack_detect_work()
1956 case 0x0040: in rt5663_jack_detect_work()
1957 case 0x0020: in rt5663_jack_detect_work()
1958 case 0x0010: in rt5663_jack_detect_work()
1961 case 0x0000: /* unpressed */ in rt5663_jack_detect_work()
1964 btn_type = 0; in rt5663_jack_detect_work()
1966 "Unexpected button code 0x%04x\n", in rt5663_jack_detect_work()
1971 if (btn_type == 0) { in rt5663_jack_detect_work()
1985 report = rt5663_v2_jack_detect(rt5663->component, 0); in rt5663_jack_detect_work()
1988 report = rt5663_jack_detect(rt5663->component, 0); in rt5663_jack_detect_work()
1994 dev_dbg(component->dev, "%s jack report: 0x%04x\n", __func__, report); in rt5663_jack_detect_work()
2013 rt5663_v2_jack_detect(rt5663->component, 0); in rt5663_jd_unplug_work()
2016 rt5663_jack_detect(rt5663->component, 0); in rt5663_jd_unplug_work()
2022 snd_soc_jack_report(rt5663->hs_jack, 0, SND_JACK_HEADSET | in rt5663_jd_unplug_work()
2035 87, 0, dac_vol_tlv),
2041 63, 0, adc_vol_tlv),
2051 RT5663_GAIN_CBJ_SHIFT, 8, 0, in_bst_tlv),
2057 RT5663_GAIN_BST1_SHIFT, 8, 0, in_bst_tlv),
2080 return 0; in rt5663_is_sys_clk_from_pll()
2101 return 0; in rt5663_is_using_asrc()
2114 return 0; in rt5663_is_using_asrc()
2118 val = (snd_soc_component_read(component, reg) >> shift) & 0x7; in rt5663_is_using_asrc()
2123 return 0; in rt5663_is_using_asrc()
2134 RT5663_DA_STO1_TRACK_MASK) ? 1 : 0; in rt5663_i2s_use_asrc()
2138 RT5663_V2_AD_STO1_TRACK_MASK) ? 1 : 0; in rt5663_i2s_use_asrc()
2142 RT5663_AD_STO1_TRACK_MASK) ? 1 : 0; in rt5663_i2s_use_asrc()
2155 return 0; in rt5663_i2s_use_asrc()
2176 unsigned int asrc2_mask = 0; in rt5663_sel_asrc_clk_src()
2177 unsigned int asrc2_value = 0; in rt5663_sel_asrc_clk_src()
2178 unsigned int asrc3_mask = 0; in rt5663_sel_asrc_clk_src()
2179 unsigned int asrc3_value = 0; in rt5663_sel_asrc_clk_src()
2218 return 0; in rt5663_sel_asrc_clk_src()
2277 RT5663_EN_DAC_HPO_SHIFT, 1, 0);
2334 RT5663_DACREF_LDO, 0x3e0e, 0x3a0a); in rt5663_hp_event()
2335 snd_soc_component_write(component, RT5663_DEPOP_2, 0x3003); in rt5663_hp_event()
2338 snd_soc_component_write(component, RT5663_HP_CHARGE_PUMP_2, 0x1371); in rt5663_hp_event()
2339 snd_soc_component_write(component, RT5663_HP_BIAS, 0xabba); in rt5663_hp_event()
2340 snd_soc_component_write(component, RT5663_CHARGE_PUMP_1, 0x2224); in rt5663_hp_event()
2341 snd_soc_component_write(component, RT5663_ANA_BIAS_CUR_1, 0x7766); in rt5663_hp_event()
2342 snd_soc_component_write(component, RT5663_HP_BIAS, 0xafaa); in rt5663_hp_event()
2343 snd_soc_component_write(component, RT5663_CHARGE_PUMP_2, 0x7777); in rt5663_hp_event()
2344 snd_soc_component_update_bits(component, RT5663_STO_DRE_1, 0x8000, in rt5663_hp_event()
2345 0x8000); in rt5663_hp_event()
2346 snd_soc_component_update_bits(component, RT5663_DEPOP_1, 0x3000, in rt5663_hp_event()
2347 0x3000); in rt5663_hp_event()
2349 RT5663_DIG_VOL_ZCD, 0x00c0, 0x0080); in rt5663_hp_event()
2359 snd_soc_component_update_bits(component, RT5663_DEPOP_1, 0x3000, 0x0); in rt5663_hp_event()
2363 RT5663_DACREF_LDO, 0x3e0e, 0); in rt5663_hp_event()
2365 RT5663_DIG_VOL_ZCD, 0x00c0, 0); in rt5663_hp_event()
2370 return 0; in rt5663_hp_event()
2373 return 0; in rt5663_hp_event()
2385 snd_soc_component_update_bits(component, RT5663_DEPOP_1, 0x0030, in rt5663_charge_pump_event()
2386 0x0030); in rt5663_charge_pump_event()
2387 snd_soc_component_update_bits(component, RT5663_DEPOP_1, 0x0003, in rt5663_charge_pump_event()
2388 0x0003); in rt5663_charge_pump_event()
2394 snd_soc_component_update_bits(component, RT5663_DEPOP_1, 0x0003, 0); in rt5663_charge_pump_event()
2395 snd_soc_component_update_bits(component, RT5663_DEPOP_1, 0x0030, 0); in rt5663_charge_pump_event()
2400 return 0; in rt5663_charge_pump_event()
2403 return 0; in rt5663_charge_pump_event()
2420 RT5663_PWR_BST2_MASK | RT5663_PWR_BST2_OP_MASK, 0); in rt5663_bst2_power()
2424 return 0; in rt5663_bst2_power()
2427 return 0; in rt5663_bst2_power()
2437 snd_soc_component_write(component, RT5663_PRE_DIV_GATING_1, 0xff00); in rt5663_pre_div_power()
2438 snd_soc_component_write(component, RT5663_PRE_DIV_GATING_2, 0xfffc); in rt5663_pre_div_power()
2442 snd_soc_component_write(component, RT5663_PRE_DIV_GATING_1, 0x0000); in rt5663_pre_div_power()
2443 snd_soc_component_write(component, RT5663_PRE_DIV_GATING_2, 0x0000); in rt5663_pre_div_power()
2447 return 0; in rt5663_pre_div_power()
2450 return 0; in rt5663_pre_div_power()
2454 SND_SOC_DAPM_SUPPLY("PLL", RT5663_PWR_ANLG_3, RT5663_PWR_PLL_SHIFT, 0,
2455 NULL, 0),
2459 RT5663_PWR_MB1_SHIFT, 0),
2461 RT5663_PWR_MB2_SHIFT, 0),
2469 RT5663_PWR_RECMIX1_SHIFT, 0, NULL, 0),
2472 SND_SOC_DAPM_ADC("ADC L", NULL, SND_SOC_NOPM, 0, 0),
2474 RT5663_PWR_ADC_L1_SHIFT, 0, NULL, 0),
2476 RT5663_CKGEN_ADCC_SHIFT, 0, NULL, 0),
2480 0, 0, rt5663_sto1_adc_l_mix,
2485 RT5663_PWR_ADC_S1F_SHIFT, 0, NULL, 0),
2488 SND_SOC_DAPM_SUPPLY("I2S", RT5663_PWR_DIG_1, RT5663_PWR_I2S1_SHIFT, 0,
2489 NULL, 0),
2490 SND_SOC_DAPM_PGA("IF DAC", SND_SOC_NOPM, 0, 0, NULL, 0),
2491 SND_SOC_DAPM_PGA("IF1 DAC1 L", SND_SOC_NOPM, 0, 0, NULL, 0),
2492 SND_SOC_DAPM_PGA("IF1 DAC1 R", SND_SOC_NOPM, 0, 0, NULL, 0),
2493 SND_SOC_DAPM_PGA("IF1 ADC1", SND_SOC_NOPM, 0, 0, NULL, 0),
2494 SND_SOC_DAPM_PGA("IF ADC", SND_SOC_NOPM, 0, 0, NULL, 0),
2497 SND_SOC_DAPM_AIF_IN("AIFRX", "AIF Playback", 0, SND_SOC_NOPM, 0, 0),
2498 SND_SOC_DAPM_AIF_OUT("AIFTX", "AIF Capture", 0, SND_SOC_NOPM, 0, 0),
2501 SND_SOC_DAPM_MIXER("ADDA MIXL", SND_SOC_NOPM, 0, 0, rt5663_adda_l_mix,
2503 SND_SOC_DAPM_MIXER("ADDA MIXR", SND_SOC_NOPM, 0, 0, rt5663_adda_r_mix,
2505 SND_SOC_DAPM_PGA("DAC L1", SND_SOC_NOPM, 0, 0, NULL, 0),
2506 SND_SOC_DAPM_PGA("DAC R1", SND_SOC_NOPM, 0, 0, NULL, 0),
2510 RT5663_PWR_DAC_S1F_SHIFT, 0, NULL, 0),
2511 SND_SOC_DAPM_MIXER("STO1 DAC MIXL", SND_SOC_NOPM, 0, 0,
2513 SND_SOC_DAPM_MIXER("STO1 DAC MIXR", SND_SOC_NOPM, 0, 0,
2518 RT5663_PWR_DAC_L1_SHIFT, 0, NULL, 0),
2520 RT5663_PWR_DAC_R1_SHIFT, 0, NULL, 0),
2521 SND_SOC_DAPM_DAC("DAC L", NULL, SND_SOC_NOPM, 0, 0),
2522 SND_SOC_DAPM_DAC("DAC R", NULL, SND_SOC_NOPM, 0, 0),
2525 SND_SOC_DAPM_SUPPLY("HP Charge Pump", SND_SOC_NOPM, 0, 0,
2528 SND_SOC_DAPM_PGA_S("HP Amp", 1, SND_SOC_NOPM, 0, 0, rt5663_hp_event,
2538 RT5663_PWR_LDO2_SHIFT, 0, NULL, 0),
2540 RT5663_V2_PWR_MIC_DET_SHIFT, 0, NULL, 0),
2542 RT5663_PWR_LDO_DACREF_SHIFT, 0, NULL, 0),
2546 RT5663_I2S1_ASRC_SHIFT, 0, NULL, 0),
2548 RT5663_DAC_STO1_ASRC_SHIFT, 0, NULL, 0),
2550 RT5663_ADC_STO1_ASRC_SHIFT, 0, NULL, 0),
2557 SND_SOC_DAPM_PGA("BST1 CBJ", SND_SOC_NOPM, 0, 0, NULL, 0),
2559 RT5663_PWR_CBJ_SHIFT, 0, NULL, 0),
2560 SND_SOC_DAPM_PGA("BST2", SND_SOC_NOPM, 0, 0, NULL, 0),
2561 SND_SOC_DAPM_SUPPLY("BST2 Power", SND_SOC_NOPM, 0, 0,
2566 SND_SOC_DAPM_MIXER("RECMIX1L", SND_SOC_NOPM, 0, 0, rt5663_recmix1l,
2568 SND_SOC_DAPM_MIXER("RECMIX1R", SND_SOC_NOPM, 0, 0, rt5663_recmix1r,
2571 RT5663_PWR_RECMIX2_SHIFT, 0, NULL, 0),
2574 SND_SOC_DAPM_ADC("ADC R", NULL, SND_SOC_NOPM, 0, 0),
2576 RT5663_PWR_ADC_R1_SHIFT, 0, NULL, 0),
2580 RT5663_STO1_ADC_L1_SRC_SHIFT, 0, NULL, 0),
2582 RT5663_STO1_ADC_R1_SRC_SHIFT, 0, NULL, 0),
2584 RT5663_STO1_ADC_L2_SRC_SHIFT, 1, NULL, 0),
2586 RT5663_STO1_ADC_R2_SRC_SHIFT, 1, NULL, 0),
2588 SND_SOC_DAPM_MUX("STO1 ADC L Mux", SND_SOC_NOPM, 0, 0,
2590 SND_SOC_DAPM_MUX("STO1 ADC R Mux", SND_SOC_NOPM, 0, 0,
2594 SND_SOC_DAPM_MIXER("STO1 ADC MIXR", SND_SOC_NOPM, 0, 0,
2599 RT5663_CKGEN_DAC1_SHIFT, 0, NULL, 0),
2602 SND_SOC_DAPM_SWITCH("HPO Playback", SND_SOC_NOPM, 0, 0,
2608 SND_SOC_DAPM_SUPPLY("Pre Div Power", SND_SOC_NOPM, 0, 0,
2614 RT5663_PWR_LDO_DACREF_SHIFT, 0, NULL, 0),
2618 RT5663_I2S1_ASRC_SHIFT, 0, NULL, 0),
2620 RT5663_DAC_STO1_ASRC_SHIFT, 0, NULL, 0),
2622 RT5663_ADC_STO1_ASRC_SHIFT, 0, NULL, 0),
2625 SND_SOC_DAPM_PGA("BST1", SND_SOC_NOPM, 0, 0, NULL, 0),
2628 SND_SOC_DAPM_PGA("STO1 ADC L1", SND_SOC_NOPM, 0, 0, NULL, 0),
2629 SND_SOC_DAPM_PGA("STO1 ADC L2", SND_SOC_NOPM, 0, 0, NULL, 0),
2632 SND_SOC_DAPM_MUX("DAC L Mux", SND_SOC_NOPM, 0, 0, &rt5663_alg_dacl_mux),
2633 SND_SOC_DAPM_MUX("DAC R Mux", SND_SOC_NOPM, 0, 0, &rt5663_alg_dacr_mux),
2767 unsigned int val_len = 0; in rt5663_hw_params()
2776 if (pre_div < 0) { in rt5663_hw_params()
2807 return 0; in rt5663_hw_params()
2813 unsigned int reg_val = 0; in rt5663_set_dai_fmt()
2854 return 0; in rt5663_set_dai_fmt()
2862 unsigned int reg_val = 0; in rt5663_set_dai_sysclk()
2865 return 0; in rt5663_set_dai_sysclk()
2889 return 0; in rt5663_set_dai_sysclk()
2903 return 0; in rt5663_set_dai_pll()
2908 rt5663->pll_in = 0; in rt5663_set_dai_pll()
2909 rt5663->pll_out = 0; in rt5663_set_dai_pll()
2912 return 0; in rt5663_set_dai_pll()
2931 val = 0x0; in rt5663_set_dai_pll()
2934 val = 0x1; in rt5663_set_dai_pll()
2943 if (ret < 0) { in rt5663_set_dai_pll()
2949 (pll_code.m_bp ? 0 : pll_code.m_code), pll_code.n_code, in rt5663_set_dai_pll()
2955 ((pll_code.m_bp ? 0 : pll_code.m_code) << RT5663_PLL_M_SHIFT) | in rt5663_set_dai_pll()
2962 return 0; in rt5663_set_dai_pll()
2970 unsigned int val = 0, reg; in rt5663_set_tdm_slot()
3029 return 0; in rt5663_set_tdm_slot()
3071 return 0; in rt5663_set_bclk_ratio()
3125 RT5663_PWR_MB_MASK, 0); in rt5663_set_bias_level()
3137 return 0; in rt5663_set_bias_level()
3174 return 0; in rt5663_probe()
3181 regmap_write(rt5663->regmap, RT5663_RESET, 0); in rt5663_remove()
3192 return 0; in rt5663_suspend()
3202 rt5663_irq(0, rt5663); in rt5663_resume()
3204 return 0; in rt5663_resume()
3268 .max_register = 0x07fa,
3281 .max_register = 0x03f3,
3295 .max_register = 0x03f3,
3300 { "rt5663", 0 },
3315 { "10EC5663", 0},
3323 regmap_write(rt5663->regmap, RT5663_BIAS_CUR_8, 0xa402); in rt5663_v2_calibrate()
3324 regmap_write(rt5663->regmap, RT5663_PWR_DIG_1, 0x0100); in rt5663_v2_calibrate()
3325 regmap_write(rt5663->regmap, RT5663_RECMIX, 0x4040); in rt5663_v2_calibrate()
3326 regmap_write(rt5663->regmap, RT5663_DIG_MISC, 0x0001); in rt5663_v2_calibrate()
3327 regmap_write(rt5663->regmap, RT5663_RC_CLK, 0x0380); in rt5663_v2_calibrate()
3328 regmap_write(rt5663->regmap, RT5663_GLB_CLK, 0x8000); in rt5663_v2_calibrate()
3329 regmap_write(rt5663->regmap, RT5663_ADDA_CLK_1, 0x1000); in rt5663_v2_calibrate()
3330 regmap_write(rt5663->regmap, RT5663_CHOP_DAC_L, 0x3030); in rt5663_v2_calibrate()
3331 regmap_write(rt5663->regmap, RT5663_CALIB_ADC, 0x3c05); in rt5663_v2_calibrate()
3332 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_1, 0xa23e); in rt5663_v2_calibrate()
3334 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_1, 0xf23e); in rt5663_v2_calibrate()
3335 regmap_write(rt5663->regmap, RT5663_HP_CALIB_2, 0x0321); in rt5663_v2_calibrate()
3336 regmap_write(rt5663->regmap, RT5663_HP_CALIB_1, 0xfc00); in rt5663_v2_calibrate()
3344 regmap_write(rt5663->regmap, RT5663_RESET, 0x0000); in rt5663_calibrate()
3346 regmap_write(rt5663->regmap, RT5663_ANA_BIAS_CUR_4, 0x00a1); in rt5663_calibrate()
3347 regmap_write(rt5663->regmap, RT5663_RC_CLK, 0x0380); in rt5663_calibrate()
3348 regmap_write(rt5663->regmap, RT5663_GLB_CLK, 0x8000); in rt5663_calibrate()
3349 regmap_write(rt5663->regmap, RT5663_ADDA_CLK_1, 0x1000); in rt5663_calibrate()
3350 regmap_write(rt5663->regmap, RT5663_VREF_RECMIX, 0x0032); in rt5663_calibrate()
3351 regmap_write(rt5663->regmap, RT5663_HP_IMP_SEN_19, 0x000c); in rt5663_calibrate()
3352 regmap_write(rt5663->regmap, RT5663_DUMMY_1, 0x0324); in rt5663_calibrate()
3353 regmap_write(rt5663->regmap, RT5663_DIG_MISC, 0x8001); in rt5663_calibrate()
3354 regmap_write(rt5663->regmap, RT5663_VREFADJ_OP, 0x0f28); in rt5663_calibrate()
3355 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_1, 0xa23b); in rt5663_calibrate()
3357 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_1, 0xf23b); in rt5663_calibrate()
3358 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_2, 0x8000); in rt5663_calibrate()
3359 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_3, 0x0008); in rt5663_calibrate()
3360 regmap_write(rt5663->regmap, RT5663_PRE_DIV_GATING_1, 0xffff); in rt5663_calibrate()
3361 regmap_write(rt5663->regmap, RT5663_PRE_DIV_GATING_2, 0xffff); in rt5663_calibrate()
3362 regmap_write(rt5663->regmap, RT5663_CBJ_1, 0x8c10); in rt5663_calibrate()
3363 regmap_write(rt5663->regmap, RT5663_IL_CMD_2, 0x00c1); in rt5663_calibrate()
3364 regmap_write(rt5663->regmap, RT5663_EM_JACK_TYPE_1, 0xb880); in rt5663_calibrate()
3365 regmap_write(rt5663->regmap, RT5663_EM_JACK_TYPE_2, 0x4110); in rt5663_calibrate()
3366 regmap_write(rt5663->regmap, RT5663_EM_JACK_TYPE_2, 0x4118); in rt5663_calibrate()
3368 count = 0; in rt5663_calibrate()
3371 if (!(value & 0x80)) in rt5663_calibrate()
3380 regmap_write(rt5663->regmap, RT5663_HP_IMP_SEN_19, 0x0000); in rt5663_calibrate()
3381 regmap_write(rt5663->regmap, RT5663_DEPOP_2, 0x3003); in rt5663_calibrate()
3382 regmap_write(rt5663->regmap, RT5663_DEPOP_1, 0x0038); in rt5663_calibrate()
3383 regmap_write(rt5663->regmap, RT5663_DEPOP_1, 0x003b); in rt5663_calibrate()
3384 regmap_write(rt5663->regmap, RT5663_PWR_DIG_2, 0x8400); in rt5663_calibrate()
3385 regmap_write(rt5663->regmap, RT5663_PWR_DIG_1, 0x8df8); in rt5663_calibrate()
3386 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_2, 0x8003); in rt5663_calibrate()
3387 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_3, 0x018c); in rt5663_calibrate()
3388 regmap_write(rt5663->regmap, RT5663_HP_CHARGE_PUMP_1, 0x1e32); in rt5663_calibrate()
3389 regmap_write(rt5663->regmap, RT5663_DUMMY_2, 0x8089); in rt5663_calibrate()
3390 regmap_write(rt5663->regmap, RT5663_DACREF_LDO, 0x3b0b); in rt5663_calibrate()
3392 regmap_write(rt5663->regmap, RT5663_STO_DAC_MIXER, 0x0000); in rt5663_calibrate()
3393 regmap_write(rt5663->regmap, RT5663_BYPASS_STO_DAC, 0x000c); in rt5663_calibrate()
3394 regmap_write(rt5663->regmap, RT5663_HP_BIAS, 0xafaa); in rt5663_calibrate()
3395 regmap_write(rt5663->regmap, RT5663_CHARGE_PUMP_1, 0x2224); in rt5663_calibrate()
3396 regmap_write(rt5663->regmap, RT5663_HP_OUT_EN, 0x8088); in rt5663_calibrate()
3397 regmap_write(rt5663->regmap, RT5663_STO_DRE_9, 0x0017); in rt5663_calibrate()
3398 regmap_write(rt5663->regmap, RT5663_STO_DRE_10, 0x0017); in rt5663_calibrate()
3399 regmap_write(rt5663->regmap, RT5663_STO1_ADC_MIXER, 0x4040); in rt5663_calibrate()
3400 regmap_write(rt5663->regmap, RT5663_CHOP_ADC, 0x3000); in rt5663_calibrate()
3401 regmap_write(rt5663->regmap, RT5663_RECMIX, 0x0005); in rt5663_calibrate()
3402 regmap_write(rt5663->regmap, RT5663_ADDA_RST, 0xc000); in rt5663_calibrate()
3403 regmap_write(rt5663->regmap, RT5663_STO1_HPF_ADJ1, 0x3320); in rt5663_calibrate()
3404 regmap_write(rt5663->regmap, RT5663_HP_CALIB_2, 0x00c9); in rt5663_calibrate()
3405 regmap_write(rt5663->regmap, RT5663_DUMMY_1, 0x004c); in rt5663_calibrate()
3406 regmap_write(rt5663->regmap, RT5663_ANA_BIAS_CUR_1, 0x1111); in rt5663_calibrate()
3407 regmap_write(rt5663->regmap, RT5663_BIAS_CUR_8, 0x4402); in rt5663_calibrate()
3408 regmap_write(rt5663->regmap, RT5663_CHARGE_PUMP_2, 0x3311); in rt5663_calibrate()
3409 regmap_write(rt5663->regmap, RT5663_HP_CALIB_1, 0x0069); in rt5663_calibrate()
3410 regmap_write(rt5663->regmap, RT5663_HP_CALIB_3, 0x06ce); in rt5663_calibrate()
3411 regmap_write(rt5663->regmap, RT5663_HP_CALIB_1_1, 0x6800); in rt5663_calibrate()
3412 regmap_write(rt5663->regmap, RT5663_CHARGE_PUMP_2, 0x1100); in rt5663_calibrate()
3413 regmap_write(rt5663->regmap, RT5663_HP_CALIB_7, 0x0057); in rt5663_calibrate()
3414 regmap_write(rt5663->regmap, RT5663_HP_CALIB_1_1, 0xe800); in rt5663_calibrate()
3416 count = 0; in rt5663_calibrate()
3419 if (value & 0x8000) in rt5663_calibrate()
3429 regmap_write(rt5663->regmap, RT5663_HP_CALIB_1_1, 0x6200); in rt5663_calibrate()
3430 regmap_write(rt5663->regmap, RT5663_HP_CALIB_7, 0x0059); in rt5663_calibrate()
3431 regmap_write(rt5663->regmap, RT5663_HP_CALIB_1_1, 0xe200); in rt5663_calibrate()
3433 count = 0; in rt5663_calibrate()
3436 if (value & 0x8000) in rt5663_calibrate()
3446 regmap_write(rt5663->regmap, RT5663_EM_JACK_TYPE_1, 0xb8e0); in rt5663_calibrate()
3448 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_1, 0x003b); in rt5663_calibrate()
3450 regmap_write(rt5663->regmap, RT5663_PWR_DIG_1, 0x0000); in rt5663_calibrate()
3452 regmap_write(rt5663->regmap, RT5663_DEPOP_1, 0x000b); in rt5663_calibrate()
3454 regmap_write(rt5663->regmap, RT5663_DEPOP_1, 0x0008); in rt5663_calibrate()
3456 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_2, 0x0000); in rt5663_calibrate()
3489 return 0; in rt5663_parse_dp()
3516 for (i = 0; i < ARRAY_SIZE(rt5663->supplies); i++) in rt5663_i2c_probe()
3528 for (i = 0; i < ARRAY_SIZE(rt5663->supplies); i++) { in rt5663_i2c_probe()
3531 if (ret < 0) { in rt5663_i2c_probe()
3590 regmap_write(rt5663->regmap, RT5663_RESET, 0); in rt5663_i2c_probe()
3603 regmap_write(rt5663->regmap, RT5663_RESET, 0); in rt5663_i2c_probe()
3612 if (ret != 0) in rt5663_i2c_probe()
3629 regmap_write(rt5663->regmap, RT5663_BIAS_CUR_8, 0xa402); in rt5663_i2c_probe()
3663 regmap_write(rt5663->regmap, RT5663_VREF_RECMIX, 0x0032); in rt5663_i2c_probe()
3698 return 0; in rt5663_i2c_probe()
3727 regmap_write(rt5663->regmap, RT5663_RESET, 0); in rt5663_i2c_shutdown()