Lines Matching +full:0 +full:xc0800000
37 #define FLOAT_ZERO 0x00000000
38 #define FLOAT_ONE 0x3f800000
39 #define FLOAT_TWO 0x40000000
40 #define FLOAT_THREE 0x40400000
41 #define FLOAT_FIVE 0x40a00000
42 #define FLOAT_SIX 0x40c00000
43 #define FLOAT_EIGHT 0x41000000
44 #define FLOAT_MINUS_5 0xc0a00000
46 #define UNSOL_TAG_DSP 0x16
55 #define MASTERCONTROL 0x80
59 #define WIDGET_CHIP_CTRL 0x15
60 #define WIDGET_DSP_CTRL 0x16
70 #define SCP_SET 0
107 #define VNODE_START_NID 0x80
117 #define EFFECT_START_NID 0x90
170 #define DSP_CAPTURE_INIT_LATENCY 0
181 int direct; /* 0:output; 1:input*/
187 #define EFX_DIR_OUT 0
193 .mid = 0x96,
194 .reqs = {0, 1},
197 .def_vals = {0x3F800000, 0x3F2B851F}
201 .mid = 0x96,
205 .def_vals = {0x3F800000, 0x3F266666}
209 .mid = 0x96,
213 .def_vals = {0x00000000, 0x3F000000}
217 .mid = 0x96,
221 .def_vals = {0x3F800000, 0x3F3D70A4, 0x00000000}
225 .mid = 0x96,
229 .def_vals = {0x3F800000, 0x42A00000, 0x3F000000}
233 .mid = 0x96,
238 .def_vals = {0x00000000, 0x00000000, 0x00000000, 0x00000000,
239 0x00000000, 0x00000000, 0x00000000, 0x00000000,
240 0x00000000, 0x00000000, 0x00000000, 0x00000000}
244 .mid = 0x95,
245 .reqs = {0, 1, 2, 3},
248 .def_vals = {0x00000000, 0x3F3A9692, 0x00000000, 0x00000000}
252 .mid = 0x95,
256 .def_vals = {0x3F800000, 0x3D7DF3B6, 0x41F00000, 0x41F00000}
260 .mid = 0x95,
264 .def_vals = {0x00000000, 0x3F3D70A4}
268 .mid = 0x95,
272 .def_vals = {0x3F800000, 0x3F000000}
276 .mid = 0x95,
280 .def_vals = {0x00000000, 0x43C80000, 0x44AF0000, 0x44FA0000,
281 0x3F800000, 0x3F800000, 0x3F800000, 0x00000000,
282 0x00000000}
290 #define TUNING_CTL_START_NID 0xC0
313 int direct; /* 0:output; 1:input*/
321 .mid = 0x95,
324 .def_val = 0x41F00000
329 .mid = 0x95,
332 .def_val = 0x3F3D70A4
337 .mid = 0x96,
340 .def_val = 0x00000000
345 .mid = 0x96,
348 .def_val = 0x00000000
353 .mid = 0x96,
356 .def_val = 0x00000000
361 .mid = 0x96,
364 .def_val = 0x00000000
369 .mid = 0x96,
372 .def_val = 0x00000000
377 .mid = 0x96,
380 .def_val = 0x00000000
385 .mid = 0x96,
388 .def_val = 0x00000000
393 .mid = 0x96,
396 .def_val = 0x00000000
401 .mid = 0x96,
404 .def_val = 0x00000000
409 .mid = 0x96,
412 .def_val = 0x00000000
435 .mid = 0x95,
441 .vals = { 0x00000000, 0x43C80000, 0x44AF0000,
442 0x44FA0000, 0x3F800000, 0x3F800000,
443 0x3F800000, 0x00000000, 0x00000000 }
446 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
447 0x44FA0000, 0x3F19999A, 0x3F866666,
448 0x3F800000, 0x00000000, 0x00000000 }
451 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
452 0x450AC000, 0x4017AE14, 0x3F6B851F,
453 0x3F800000, 0x00000000, 0x00000000 }
456 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
457 0x44FA0000, 0x40400000, 0x3F28F5C3,
458 0x3F800000, 0x00000000, 0x00000000 }
461 .vals = { 0x3F800000, 0x44324000, 0x44BB8000,
462 0x44E10000, 0x3FB33333, 0x3FB9999A,
463 0x3F800000, 0x3E3A2E43, 0x00000000 }
466 .vals = { 0x3F800000, 0x43EA0000, 0x44A52000,
467 0x45098000, 0x3F266666, 0x3FC00000,
468 0x3F800000, 0x00000000, 0x00000000 }
471 .vals = { 0x3F800000, 0x43C70000, 0x44AE6000,
472 0x45193000, 0x3F8E147B, 0x3F75C28F,
473 0x3F800000, 0x00000000, 0x00000000 }
476 .vals = { 0x3F800000, 0x43930000, 0x44BEE000,
477 0x45007000, 0x3F451EB8, 0x3F7851EC,
478 0x3F800000, 0x00000000, 0x00000000 }
481 .vals = { 0x3F800000, 0x43BFC5AC, 0x44B28FDF,
482 0x451F6000, 0x3F266666, 0x3FA7D945,
483 0x3F800000, 0x3CF5C28F, 0x00000000 }
486 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
487 0x44FA0000, 0x3FB2718B, 0x3F800000,
488 0xBC07010E, 0x00000000, 0x00000000 }
491 .vals = { 0x3F800000, 0x43C20000, 0x44906000,
492 0x44E70000, 0x3F4CCCCD, 0x3F8A3D71,
493 0x3F0A3D71, 0x00000000, 0x00000000 }
496 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
497 0x44FA0000, 0x3F800000, 0x3F800000,
498 0x3E4CCCCD, 0x00000000, 0x00000000 }
501 .vals = { 0x3F800000, 0x43A9C5AC, 0x44AA4FDF,
502 0x44FFC000, 0x3EDBB56F, 0x3F99C4CA,
503 0x3F800000, 0x00000000, 0x00000000 }
506 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
507 0x44FA0000, 0x3F800000, 0x3F1A043C,
508 0x3F800000, 0x00000000, 0x00000000 }
531 .mid = 0x96,
538 .vals = { 0x00000000, 0x00000000, 0x00000000,
539 0x00000000, 0x00000000, 0x00000000,
540 0x00000000, 0x00000000, 0x00000000,
541 0x00000000, 0x00000000 }
544 .vals = { 0x00000000, 0x00000000, 0x3F8CCCCD,
545 0x40000000, 0x00000000, 0x00000000,
546 0x00000000, 0x00000000, 0x40000000,
547 0x40000000, 0x40000000 }
550 .vals = { 0x00000000, 0x00000000, 0x40C00000,
551 0x40C00000, 0x40466666, 0x00000000,
552 0x00000000, 0x00000000, 0x00000000,
553 0x40466666, 0x40466666 }
556 .vals = { 0x00000000, 0xBF99999A, 0x00000000,
557 0x3FA66666, 0x3FA66666, 0x3F8CCCCD,
558 0x00000000, 0x00000000, 0x40000000,
559 0x40466666, 0x40800000 }
562 .vals = { 0x00000000, 0xBF99999A, 0x40000000,
563 0x40466666, 0x40866666, 0xBF99999A,
564 0xBF99999A, 0x00000000, 0x00000000,
565 0x40800000, 0x40800000 }
568 .vals = { 0x00000000, 0x00000000, 0x00000000,
569 0x3F8CCCCD, 0x40800000, 0x40800000,
570 0x40800000, 0x00000000, 0x3F8CCCCD,
571 0x40466666, 0x40466666 }
574 .vals = { 0x00000000, 0x00000000, 0x40000000,
575 0x40000000, 0x00000000, 0x00000000,
576 0x00000000, 0x3F8CCCCD, 0x40000000,
577 0x40000000, 0x40000000 }
580 .vals = { 0x00000000, 0xBFCCCCCD, 0x00000000,
581 0x40000000, 0x40000000, 0x00000000,
582 0xBF99999A, 0xBF99999A, 0x00000000,
583 0x40466666, 0x40C00000 }
586 .vals = { 0x00000000, 0xBF99999A, 0xBF99999A,
587 0x3F8CCCCD, 0x40000000, 0xBF99999A,
588 0xBF99999A, 0x00000000, 0x00000000,
589 0x40800000, 0x40800000 }
592 .vals = { 0x00000000, 0xC0000000, 0xBF99999A,
593 0xBF99999A, 0x00000000, 0x40466666,
594 0x40800000, 0x40466666, 0x00000000,
595 0x00000000, 0x3F8CCCCD }
607 SPEAKER_BASS_REDIRECT = 0x15,
608 SPEAKER_BASS_REDIRECT_XOVER_FREQ = 0x16,
609 /* Between 0x16-0x1a are the X-Bass reqs. */
610 SPEAKER_FULL_RANGE_FRONT_L_R = 0x1a,
611 SPEAKER_FULL_RANGE_CENTER_LFE = 0x1b,
612 SPEAKER_FULL_RANGE_REAR_L_R = 0x1c,
613 SPEAKER_FULL_RANGE_SURROUND_L_R = 0x1d,
614 SPEAKER_BASS_REDIRECT_SUB_GAIN = 0x1e,
619 * module ID 0x96, the output effects module.
625 * connect software, the QUERY_SPEAKER_EQ_ADDRESS req on mid 0x80 is
635 SPEAKER_TUNING_USE_SPEAKER_EQ = 0x1f,
636 SPEAKER_TUNING_ENABLE_CENTER_EQ = 0x20,
637 SPEAKER_TUNING_FRONT_LEFT_VOL_LEVEL = 0x21,
638 SPEAKER_TUNING_FRONT_RIGHT_VOL_LEVEL = 0x22,
639 SPEAKER_TUNING_CENTER_VOL_LEVEL = 0x23,
640 SPEAKER_TUNING_LFE_VOL_LEVEL = 0x24,
641 SPEAKER_TUNING_REAR_LEFT_VOL_LEVEL = 0x25,
642 SPEAKER_TUNING_REAR_RIGHT_VOL_LEVEL = 0x26,
643 SPEAKER_TUNING_SURROUND_LEFT_VOL_LEVEL = 0x27,
644 SPEAKER_TUNING_SURROUND_RIGHT_VOL_LEVEL = 0x28,
649 SPEAKER_TUNING_FRONT_LEFT_INVERT = 0x29,
650 SPEAKER_TUNING_FRONT_RIGHT_INVERT = 0x2a,
651 SPEAKER_TUNING_CENTER_INVERT = 0x2b,
652 SPEAKER_TUNING_LFE_INVERT = 0x2c,
653 SPEAKER_TUNING_REAR_LEFT_INVERT = 0x2d,
654 SPEAKER_TUNING_REAR_RIGHT_INVERT = 0x2e,
655 SPEAKER_TUNING_SURROUND_LEFT_INVERT = 0x2f,
656 SPEAKER_TUNING_SURROUND_RIGHT_INVERT = 0x30,
658 SPEAKER_TUNING_FRONT_LEFT_DELAY = 0x31,
659 SPEAKER_TUNING_FRONT_RIGHT_DELAY = 0x32,
660 SPEAKER_TUNING_CENTER_DELAY = 0x33,
661 SPEAKER_TUNING_LFE_DELAY = 0x34,
662 SPEAKER_TUNING_REAR_LEFT_DELAY = 0x35,
663 SPEAKER_TUNING_REAR_RIGHT_DELAY = 0x36,
664 SPEAKER_TUNING_SURROUND_LEFT_DELAY = 0x37,
665 SPEAKER_TUNING_SURROUND_RIGHT_DELAY = 0x38,
667 SPEAKER_TUNING_MAIN_VOLUME = 0x39,
668 SPEAKER_TUNING_MUTE = 0x3a,
709 #define DSP_VOL_OUT 0
720 .mid = 0x32,
724 .mid = 0x37,
738 .group = { 0x30, 0x30, 0x48, 0x48, 0x48, 0x30 },
739 .target = { 0x2e, 0x30, 0x0d, 0x17, 0x19, 0x32 },
741 .vals = { { 0x00, 0x00, 0x40, 0x00, 0x00, 0x3f },
743 { 0x3f, 0x3f, 0x00, 0x00, 0x00, 0x00 } },
747 .group = { 0x30, 0x30, 0x48, 0x48, 0x48, 0x30 },
748 .target = { 0x2e, 0x30, 0x0d, 0x17, 0x19, 0x32 },
750 .vals = { { 0x00, 0x00, 0x40, 0x00, 0x00, 0x3f },
752 { 0x3f, 0x3f, 0x00, 0x00, 0x02, 0x00 } },
764 .vals = { 0xff, 0x2c, 0xf5, 0x32 }
767 .vals = { 0x38, 0xa8, 0x3e, 0x4c }
770 .vals = { 0xff, 0xff, 0xff, 0x7f }
781 .val = 0xa0
784 .val = 0xc0
787 .val = 0x80
804 { .stream_id = 0x14,
805 .count = 0x04,
806 .offset = { 0x00, 0x04, 0x08, 0x0c },
807 .value = { 0x0001f8c0, 0x0001f9c1, 0x0001fac6, 0x0001fbc7 },
809 { .stream_id = 0x0c,
810 .count = 0x0c,
811 .offset = { 0x00, 0x04, 0x08, 0x0c, 0x10, 0x14, 0x18, 0x1c,
812 0x20, 0x24, 0x28, 0x2c },
813 .value = { 0x0001e0c0, 0x0001e1c1, 0x0001e4c2, 0x0001e5c3,
814 0x0001e2c4, 0x0001e3c5, 0x0001e8c6, 0x0001e9c7,
815 0x0001ecc8, 0x0001edc9, 0x0001eaca, 0x0001ebcb },
817 { .stream_id = 0x0c,
818 .count = 0x08,
819 .offset = { 0x08, 0x0c, 0x10, 0x14, 0x20, 0x24, 0x28, 0x2c },
820 .value = { 0x000140c2, 0x000141c3, 0x000150c4, 0x000151c5,
821 0x000142c8, 0x000143c9, 0x000152ca, 0x000153cb },
827 VENDOR_DSPIO_SCP_WRITE_DATA_LOW = 0x000,
828 VENDOR_DSPIO_SCP_WRITE_DATA_HIGH = 0x100,
830 VENDOR_DSPIO_STATUS = 0xF01,
831 VENDOR_DSPIO_SCP_POST_READ_DATA = 0x702,
832 VENDOR_DSPIO_SCP_READ_DATA = 0xF02,
833 VENDOR_DSPIO_DSP_INIT = 0x703,
834 VENDOR_DSPIO_SCP_POST_COUNT_QUERY = 0x704,
835 VENDOR_DSPIO_SCP_READ_COUNT = 0xF04,
838 VENDOR_CHIPIO_ADDRESS_LOW = 0x000,
839 VENDOR_CHIPIO_ADDRESS_HIGH = 0x100,
840 VENDOR_CHIPIO_STREAM_FORMAT = 0x200,
841 VENDOR_CHIPIO_DATA_LOW = 0x300,
842 VENDOR_CHIPIO_DATA_HIGH = 0x400,
844 VENDOR_CHIPIO_8051_WRITE_DIRECT = 0x500,
845 VENDOR_CHIPIO_8051_READ_DIRECT = 0xD00,
847 VENDOR_CHIPIO_GET_PARAMETER = 0xF00,
848 VENDOR_CHIPIO_STATUS = 0xF01,
849 VENDOR_CHIPIO_HIC_POST_READ = 0x702,
850 VENDOR_CHIPIO_HIC_READ_DATA = 0xF03,
852 VENDOR_CHIPIO_8051_DATA_WRITE = 0x707,
853 VENDOR_CHIPIO_8051_DATA_READ = 0xF07,
854 VENDOR_CHIPIO_8051_PMEM_READ = 0xF08,
855 VENDOR_CHIPIO_8051_IRAM_WRITE = 0x709,
856 VENDOR_CHIPIO_8051_IRAM_READ = 0xF09,
858 VENDOR_CHIPIO_CT_EXTENSIONS_ENABLE = 0x70A,
859 VENDOR_CHIPIO_CT_EXTENSIONS_GET = 0xF0A,
861 VENDOR_CHIPIO_PLL_PMU_WRITE = 0x70C,
862 VENDOR_CHIPIO_PLL_PMU_READ = 0xF0C,
863 VENDOR_CHIPIO_8051_ADDRESS_LOW = 0x70D,
864 VENDOR_CHIPIO_8051_ADDRESS_HIGH = 0x70E,
865 VENDOR_CHIPIO_FLAG_SET = 0x70F,
866 VENDOR_CHIPIO_FLAGS_GET = 0xF0F,
867 VENDOR_CHIPIO_PARAM_SET = 0x710,
868 VENDOR_CHIPIO_PARAM_GET = 0xF10,
870 VENDOR_CHIPIO_PORT_ALLOC_CONFIG_SET = 0x711,
871 VENDOR_CHIPIO_PORT_ALLOC_SET = 0x712,
872 VENDOR_CHIPIO_PORT_ALLOC_GET = 0xF12,
873 VENDOR_CHIPIO_PORT_FREE_SET = 0x713,
875 VENDOR_CHIPIO_PARAM_EX_ID_GET = 0xF17,
876 VENDOR_CHIPIO_PARAM_EX_ID_SET = 0x717,
877 VENDOR_CHIPIO_PARAM_EX_VALUE_GET = 0xF18,
878 VENDOR_CHIPIO_PARAM_EX_VALUE_SET = 0x718,
880 VENDOR_CHIPIO_DMIC_CTL_SET = 0x788,
881 VENDOR_CHIPIO_DMIC_CTL_GET = 0xF88,
882 VENDOR_CHIPIO_DMIC_PIN_SET = 0x789,
883 VENDOR_CHIPIO_DMIC_PIN_GET = 0xF89,
884 VENDOR_CHIPIO_DMIC_MCLK_SET = 0x78A,
885 VENDOR_CHIPIO_DMIC_MCLK_GET = 0xF8A,
887 VENDOR_CHIPIO_EAPD_SEL_SET = 0x78D
895 CONTROL_FLAG_C_MGR = 0,
952 /* 0: None, 1: Mic1In*/
954 /* 0: force HDA, 1: allow DSP if HDA Spdif1Out stream is idle */
1000 VENDOR_STATUS_DSPIO_OK = 0x00,
1002 VENDOR_STATUS_DSPIO_BUSY = 0x01,
1004 VENDOR_STATUS_DSPIO_SCP_COMMAND_QUEUE_FULL = 0x02,
1006 VENDOR_STATUS_DSPIO_SCP_RESPONSE_QUEUE_EMPTY = 0x03
1014 VENDOR_STATUS_CHIPIO_OK = 0x00,
1016 VENDOR_STATUS_CHIPIO_BUSY = 0x01
1023 SR_6_000 = 0x00,
1024 SR_8_000 = 0x01,
1025 SR_9_600 = 0x02,
1026 SR_11_025 = 0x03,
1027 SR_16_000 = 0x04,
1028 SR_22_050 = 0x05,
1029 SR_24_000 = 0x06,
1030 SR_32_000 = 0x07,
1031 SR_44_100 = 0x08,
1032 SR_48_000 = 0x09,
1033 SR_88_200 = 0x0A,
1034 SR_96_000 = 0x0B,
1035 SR_144_000 = 0x0C,
1036 SR_176_400 = 0x0D,
1037 SR_192_000 = 0x0E,
1038 SR_384_000 = 0x0F,
1040 SR_COUNT = 0x10,
1042 SR_RATE_UNKNOWN = 0x1F
1047 DSP_DOWNLOAD_INIT = 0,
1053 #define get_hdafmt_chs(fmt) (fmt & 0xf)
1054 #define get_hdafmt_bits(fmt) ((fmt >> 4) & 0x7)
1055 #define get_hdafmt_rate(fmt) ((fmt >> 8) & 0x7f)
1056 #define get_hdafmt_type(fmt) ((fmt >> 15) & 0x1)
1194 { 0x0b, 0x90170110 }, /* Builtin Speaker */
1195 { 0x0c, 0x411111f0 }, /* N/A */
1196 { 0x0d, 0x411111f0 }, /* N/A */
1197 { 0x0e, 0x411111f0 }, /* N/A */
1198 { 0x0f, 0x0321101f }, /* HP */
1199 { 0x10, 0x411111f0 }, /* Headset? disabled for now */
1200 { 0x11, 0x03a11021 }, /* Mic */
1201 { 0x12, 0xd5a30140 }, /* Builtin Mic */
1202 { 0x13, 0x411111f0 }, /* N/A */
1203 { 0x18, 0x411111f0 }, /* N/A */
1209 { 0x0b, 0x01017010 }, /* Port G -- Lineout FRONT L/R */
1210 { 0x0c, 0x014510f0 }, /* SPDIF Out 1 */
1211 { 0x0d, 0x014510f0 }, /* Digital Out */
1212 { 0x0e, 0x01c510f0 }, /* SPDIF In */
1213 { 0x0f, 0x0221701f }, /* Port A -- BackPanel HP */
1214 { 0x10, 0x01017012 }, /* Port D -- Center/LFE or FP Hp */
1215 { 0x11, 0x01017014 }, /* Port B -- LineMicIn2 / Rear L/R */
1216 { 0x12, 0x01a170f0 }, /* Port C -- LineIn1 */
1217 { 0x13, 0x908700f0 }, /* What U Hear In*/
1218 { 0x18, 0x50d000f0 }, /* N/A */
1224 { 0x0b, 0x01047110 }, /* Port G -- Lineout FRONT L/R */
1225 { 0x0c, 0x414510f0 }, /* SPDIF Out 1 - Disabled*/
1226 { 0x0d, 0x014510f0 }, /* Digital Out */
1227 { 0x0e, 0x41c520f0 }, /* SPDIF In - Disabled*/
1228 { 0x0f, 0x0122711f }, /* Port A -- BackPanel HP */
1229 { 0x10, 0x01017111 }, /* Port D -- Center/LFE */
1230 { 0x11, 0x01017114 }, /* Port B -- LineMicIn2 / Rear L/R */
1231 { 0x12, 0x01a271f0 }, /* Port C -- LineIn1 */
1232 { 0x13, 0x908700f0 }, /* What U Hear In*/
1233 { 0x18, 0x50d000f0 }, /* N/A */
1239 { 0x0b, 0x01014110 }, /* Port G -- Lineout FRONT L/R */
1240 { 0x0c, 0x014510f0 }, /* SPDIF Out 1 */
1241 { 0x0d, 0x014510f0 }, /* Digital Out */
1242 { 0x0e, 0x01c520f0 }, /* SPDIF In */
1243 { 0x0f, 0x0221401f }, /* Port A -- BackPanel HP */
1244 { 0x10, 0x01016011 }, /* Port D -- Center/LFE or FP Hp */
1245 { 0x11, 0x01011014 }, /* Port B -- LineMicIn2 / Rear L/R */
1246 { 0x12, 0x02a090f0 }, /* Port C -- LineIn1 */
1247 { 0x13, 0x908700f0 }, /* What U Hear In*/
1248 { 0x18, 0x50d000f0 }, /* N/A */
1254 { 0x0b, 0x01017010 }, /* Port G -- Lineout FRONT L/R */
1255 { 0x0c, 0x014510f0 }, /* SPDIF Out 1 */
1256 { 0x0d, 0x014510f0 }, /* Digital Out */
1257 { 0x0e, 0x01c510f0 }, /* SPDIF In */
1258 { 0x0f, 0x01017114 }, /* Port A -- Rear L/R. */
1259 { 0x10, 0x01017012 }, /* Port D -- Center/LFE or FP Hp */
1260 { 0x11, 0x012170ff }, /* Port B -- LineMicIn2 / Rear Headphone */
1261 { 0x12, 0x01a170f0 }, /* Port C -- LineIn1 */
1262 { 0x13, 0x908700f0 }, /* What U Hear In*/
1263 { 0x18, 0x50d000f0 }, /* N/A */
1269 { 0x0b, 0x01014110 }, /* Port G -- Lineout FRONT L/R */
1270 { 0x0c, 0x014510f0 }, /* SPDIF Out 1 */
1271 { 0x0d, 0x014510f0 }, /* Digital Out */
1272 { 0x0e, 0x41c520f0 }, /* SPDIF In */
1273 { 0x0f, 0x0221401f }, /* Port A -- BackPanel HP */
1274 { 0x10, 0x01016011 }, /* Port D -- Center/LFE or FP Hp */
1275 { 0x11, 0x01011014 }, /* Port B -- LineMicIn2 / Rear L/R */
1276 { 0x12, 0x02a090f0 }, /* Port C -- LineIn1 */
1277 { 0x13, 0x908700f0 }, /* What U Hear In*/
1278 { 0x18, 0x500000f0 }, /* N/A */
1283 { 0x0b, 0x01017010 },
1284 { 0x0c, 0x014510f0 },
1285 { 0x0d, 0x414510f0 },
1286 { 0x0e, 0x01c520f0 },
1287 { 0x0f, 0x01017114 },
1288 { 0x10, 0x01017011 },
1289 { 0x11, 0x018170ff },
1290 { 0x12, 0x01a170f0 },
1291 { 0x13, 0x908700f0 },
1292 { 0x18, 0x500000f0 },
1297 SND_PCI_QUIRK(0x1028, 0x057b, "Alienware M17x R4", QUIRK_ALIENWARE_M17XR4),
1298 SND_PCI_QUIRK(0x1028, 0x0685, "Alienware 15 2015", QUIRK_ALIENWARE),
1299 SND_PCI_QUIRK(0x1028, 0x0688, "Alienware 17 2015", QUIRK_ALIENWARE),
1300 SND_PCI_QUIRK(0x1028, 0x0708, "Alienware 15 R2 2016", QUIRK_ALIENWARE),
1301 SND_PCI_QUIRK(0x1102, 0x0010, "Sound Blaster Z", QUIRK_SBZ),
1302 SND_PCI_QUIRK(0x1102, 0x0023, "Sound Blaster Z", QUIRK_SBZ),
1303 SND_PCI_QUIRK(0x1102, 0x0027, "Sound Blaster Z", QUIRK_SBZ),
1304 SND_PCI_QUIRK(0x1102, 0x0033, "Sound Blaster ZxR", QUIRK_SBZ),
1305 SND_PCI_QUIRK(0x1458, 0xA016, "Recon3Di", QUIRK_R3DI),
1306 SND_PCI_QUIRK(0x1458, 0xA026, "Gigabyte G1.Sniper Z97", QUIRK_R3DI),
1307 SND_PCI_QUIRK(0x1458, 0xA036, "Gigabyte GA-Z170X-Gaming 7", QUIRK_R3DI),
1308 SND_PCI_QUIRK(0x3842, 0x1038, "EVGA X99 Classified", QUIRK_R3DI),
1309 SND_PCI_QUIRK(0x3842, 0x104b, "EVGA X299 Dark", QUIRK_R3DI),
1310 SND_PCI_QUIRK(0x3842, 0x1055, "EVGA Z390 DARK", QUIRK_R3DI),
1311 SND_PCI_QUIRK(0x1102, 0x0013, "Recon3D", QUIRK_R3D),
1312 SND_PCI_QUIRK(0x1102, 0x0018, "Recon3D", QUIRK_R3D),
1313 SND_PCI_QUIRK(0x1102, 0x0051, "Sound Blaster AE-5", QUIRK_AE5),
1314 SND_PCI_QUIRK(0x1102, 0x0191, "Sound Blaster AE-5 Plus", QUIRK_AE5),
1315 SND_PCI_QUIRK(0x1102, 0x0081, "Sound Blaster AE-7", QUIRK_AE7),
1323 unsigned int dac2port; /* ParamID 0x0d value. */
1358 { .dac2port = 0x24,
1362 .mmio_gpio_count = 0,
1363 .scp_cmds_count = 0,
1367 { .dac2port = 0x21,
1370 .hda_gpio_set = 0,
1371 .mmio_gpio_count = 0,
1372 .scp_cmds_count = 0,
1381 { .dac2port = 0x24,
1386 .scp_cmds_count = 0,
1390 { .dac2port = 0x21,
1394 .mmio_gpio_set = { 0 },
1395 .scp_cmds_count = 0,
1404 { .dac2port = 0x18,
1408 .mmio_gpio_set = { 0, 1, 1 },
1409 .scp_cmds_count = 0,
1412 { .dac2port = 0x12,
1416 .mmio_gpio_set = { 1, 1, 0 },
1417 .scp_cmds_count = 0,
1426 { .dac2port = 0x24,
1430 .mmio_gpio_set = { 1, 1, 0 },
1431 .scp_cmds_count = 0,
1435 { .dac2port = 0x21,
1439 .mmio_gpio_set = { 0, 1, 1 },
1440 .scp_cmds_count = 0,
1449 { .dac2port = 0xa4,
1451 .mmio_gpio_count = 0,
1453 .scp_cmd_mid = { 0x96, 0x96 },
1458 .chipio_write_addr = 0x0018b03c,
1459 .chipio_write_data = 0x00000012
1462 { .dac2port = 0xa1,
1464 .mmio_gpio_count = 0,
1466 .scp_cmd_mid = { 0x96, 0x96 },
1471 .chipio_write_addr = 0x0018b03c,
1472 .chipio_write_data = 0x00000012
1480 { .dac2port = 0x58,
1483 .mmio_gpio_pin = { 0 },
1486 .scp_cmd_mid = { 0x96, 0x96 },
1491 .chipio_write_addr = 0x0018b03c,
1492 .chipio_write_data = 0x00000000
1495 { .dac2port = 0x58,
1498 .mmio_gpio_pin = { 0 },
1501 .scp_cmd_mid = { 0x96, 0x96 },
1506 .chipio_write_addr = 0x0018b03c,
1507 .chipio_write_data = 0x00000010
1519 response = snd_hda_codec_read(codec, nid, 0, verb, parm); in codec_send_command()
1522 return ((response == -1) ? -1 : 0); in codec_send_command()
1529 converter_format & 0xffff, res); in codec_set_converter_format()
1536 unsigned char converter_stream_channel = 0; in codec_set_converter_stream_channel()
1538 converter_stream_channel = (stream << 4) | (channel & 0x0f); in codec_set_converter_stream_channel()
1553 res = snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0, in chipio_send()
1556 return 0; in chipio_send()
1573 return 0; in chipio_write_address()
1577 chip_addx & 0xffff); in chipio_write_address()
1585 spec->curr_chip_addx = (res < 0) ? ~0U : chip_addx; in chipio_write_address()
1599 res = chipio_send(codec, VENDOR_CHIPIO_DATA_LOW, data & 0xffff); in chipio_write_data()
1610 (spec->curr_chip_addx + 4) : ~0U; in chipio_write_data()
1621 int status = 0; in chipio_write_data_multiple()
1628 while ((count-- != 0) && (status == 0)) in chipio_write_data_multiple()
1644 res = chipio_send(codec, VENDOR_CHIPIO_HIC_POST_READ, 0); in chipio_read_data()
1648 res = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0); in chipio_read_data()
1653 *data = snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0, in chipio_read_data()
1655 0); in chipio_read_data()
1661 (spec->curr_chip_addx + 4) : ~0U; in chipio_read_data()
1679 if (err < 0) in chipio_write()
1683 if (err < 0) in chipio_write()
1703 if (err < 0) in chipio_write_no_mutex()
1707 if (err < 0) in chipio_write_no_mutex()
1728 if (status < 0) in chipio_write_multiple()
1752 if (err < 0) in chipio_read()
1756 if (err < 0) in chipio_read()
1774 flag_bit = (flag_state ? 1 : 0); in chipio_set_control_flag()
1776 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_set_control_flag()
1791 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_set_control_param()
1795 if (chipio_send(codec, VENDOR_CHIPIO_STATUS, 0) == 0) { in chipio_set_control_param()
1796 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_set_control_param()
1799 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_set_control_param()
1817 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_set_control_param_no_mutex()
1820 if (chipio_send(codec, VENDOR_CHIPIO_STATUS, 0) == 0) { in chipio_set_control_param_no_mutex()
1821 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_set_control_param_no_mutex()
1824 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_set_control_param_no_mutex()
1877 *enable = snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0, in chipio_get_stream_control()
1908 * 0x80-0xFF.
1916 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, verb, addr); in chipio_8051_write_direct()
1921 * Data at addresses 0x2000-0x7fff is mirrored to 0x8000-0xdfff.
1922 * Data at 0x8000-0xdfff can also be used as program memory for the 8051 by
1924 * 0xe000-0xffff is always mapped as program memory, with only 0xf000-0xffff
1932 tmp = addr & 0xff; in chipio_8051_set_address()
1933 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_8051_set_address()
1937 tmp = (addr >> 8) & 0xff; in chipio_8051_set_address()
1938 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_8051_set_address()
1945 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_8051_set_data()
1946 VENDOR_CHIPIO_8051_DATA_WRITE, data & 0xff); in chipio_8051_set_data()
1951 return snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0, in chipio_8051_get_data()
1952 VENDOR_CHIPIO_8051_DATA_READ, 0); in chipio_8051_get_data()
1959 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_8051_set_data_pll()
1960 VENDOR_CHIPIO_PLL_PMU_WRITE, data & 0xff); in chipio_8051_set_data_pll()
1998 chipio_8051_set_address(codec, addr & 0xff); in chipio_8051_write_pll_pmu()
2007 chipio_8051_set_address(codec, addr & 0xff); in chipio_8051_write_pll_pmu_no_mutex()
2020 chipio_8051_write_pll_pmu_no_mutex(codec, 0x00, 0xff); in chipio_enable_clocks()
2021 chipio_8051_write_pll_pmu_no_mutex(codec, 0x05, 0x0b); in chipio_enable_clocks()
2022 chipio_8051_write_pll_pmu_no_mutex(codec, 0x06, 0xff); in chipio_enable_clocks()
2038 res = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0, reg, data); in dspio_send()
2039 if ((res >= 0) && (res != VENDOR_STATUS_DSPIO_BUSY)) in dspio_send()
2056 status = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0, in dspio_write_wait()
2057 VENDOR_DSPIO_STATUS, 0); in dspio_write_wait()
2077 scp_data & 0xffff); in dspio_write()
2078 if (status < 0) in dspio_write()
2083 if (status < 0) in dspio_write()
2087 status = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0, in dspio_write()
2088 VENDOR_DSPIO_STATUS, 0); in dspio_write()
2093 -EIO : 0; in dspio_write()
2102 int status = 0; in dspio_write_multiple()
2108 count = 0; in dspio_write_multiple()
2111 if (status != 0) in dspio_write_multiple()
2123 status = dspio_send(codec, VENDOR_DSPIO_SCP_POST_READ_DATA, 0); in dspio_read()
2127 status = dspio_send(codec, VENDOR_DSPIO_STATUS, 0); in dspio_read()
2132 *data = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0, in dspio_read()
2133 VENDOR_DSPIO_SCP_READ_DATA, 0); in dspio_read()
2135 return 0; in dspio_read()
2141 int status = 0; in dspio_read_multiple()
2150 count = 0; in dspio_read_multiple()
2153 if (status != 0) in dspio_read_multiple()
2159 if (status == 0) { in dspio_read_multiple()
2162 if (status != 0) in dspio_read_multiple()
2181 unsigned int header = 0; in make_scp_header()
2183 header = (data_size & 0x1f) << 27; in make_scp_header()
2184 header |= (error_flag & 0x01) << 26; in make_scp_header()
2185 header |= (resp_flag & 0x01) << 25; in make_scp_header()
2186 header |= (device_flag & 0x01) << 24; in make_scp_header()
2187 header |= (req & 0x7f) << 17; in make_scp_header()
2188 header |= (get_flag & 0x01) << 16; in make_scp_header()
2189 header |= (source_id & 0xff) << 8; in make_scp_header()
2190 header |= target_id & 0xff; in make_scp_header()
2206 *data_size = (header >> 27) & 0x1f; in extract_scp_header()
2208 *error_flag = (header >> 26) & 0x01; in extract_scp_header()
2210 *resp_flag = (header >> 25) & 0x01; in extract_scp_header()
2212 *device_flag = (header >> 24) & 0x01; in extract_scp_header()
2214 *req = (header >> 17) & 0x7f; in extract_scp_header()
2216 *get_flag = (header >> 16) & 0x01; in extract_scp_header()
2218 *source_id = (header >> 8) & 0xff; in extract_scp_header()
2220 *target_id = header & 0xff; in extract_scp_header()
2234 unsigned int dummy = 0; in dspio_clear_response_queue()
2240 } while (status == 0 && time_before(jiffies, timeout)); in dspio_clear_response_queue()
2246 unsigned int data = 0; in dspio_get_response_data()
2249 if (dspio_read(codec, &data) < 0) in dspio_get_response_data()
2252 if ((data & 0x00ffffff) == spec->wait_scp_header) { in dspio_get_response_data()
2258 return 0; in dspio_get_response_data()
2276 unsigned int scp_send_size = 0; in dspio_send_scp_message()
2285 *bytes_returned = 0; in dspio_send_scp_message()
2306 spec->wait_scp_header &= 0xffff0000; in dspio_send_scp_message()
2315 if (status < 0) { in dspio_send_scp_message()
2316 spec->wait_scp = 0; in dspio_send_scp_message()
2322 memset(return_buf, 0, return_buf_size); in dspio_send_scp_message()
2333 status = 0; in dspio_send_scp_message()
2337 spec->wait_scp = 0; in dspio_send_scp_message()
2361 int status = 0; in dspio_scp()
2367 memset(&scp_send, 0, sizeof(scp_send)); in dspio_scp()
2368 memset(&scp_reply, 0, sizeof(scp_reply)); in dspio_scp()
2370 if ((len != 0 && data == NULL) || (len > SCP_MAX_DATA_WORDS)) in dspio_scp()
2378 if (reply != NULL && (reply_len == NULL || (*reply_len == 0))) { in dspio_scp()
2384 0, 0, 0, len/sizeof(unsigned int)); in dspio_scp()
2385 if (data != NULL && len > 0) { in dspio_scp()
2390 ret_bytes = 0; in dspio_scp()
2396 if (status < 0) { in dspio_scp()
2409 return 0; in dspio_scp()
2449 return dspio_set_param(codec, mod_id, 0x20, req, &data, in dspio_set_uint_param()
2458 int status = 0; in dspio_alloc_dma_chan()
2462 status = dspio_scp(codec, MASTERCONTROL, 0x20, in dspio_alloc_dma_chan()
2463 MASTERCONTROL_ALLOC_DMA_CHAN, SCP_GET, NULL, 0, in dspio_alloc_dma_chan()
2466 if (status < 0) { in dspio_alloc_dma_chan()
2471 if ((*dma_chan + 1) == 0) { in dspio_alloc_dma_chan()
2487 int status = 0; in dspio_free_dma_chan()
2488 unsigned int dummy = 0; in dspio_free_dma_chan()
2493 status = dspio_scp(codec, MASTERCONTROL, 0x20, in dspio_free_dma_chan()
2497 if (status < 0) { in dspio_free_dma_chan()
2517 if (err < 0) in dsp_set_run_state()
2523 if (halt_state != 0) { in dsp_set_run_state()
2528 if (err < 0) in dsp_set_run_state()
2535 if (err < 0) in dsp_set_run_state()
2539 return 0; in dsp_set_run_state()
2552 res = dspio_send(codec, VENDOR_DSPIO_DSP_INIT, 0); in dsp_reset()
2561 return 0; in dsp_reset()
2595 (DSPDMAC_CHNLSTART_EN_LOBIT + dma_chan))) != 0); in dsp_is_dma_active()
2604 int status = 0; in dsp_dma_setup_common()
2630 active = 0; in dsp_dma_setup_common()
2638 if (status < 0) { in dsp_dma_setup_common()
2653 if (status < 0) { in dsp_dma_setup_common()
2663 if (status < 0) { in dsp_dma_setup_common()
2674 if (status < 0) { in dsp_dma_setup_common()
2683 if (status < 0) { in dsp_dma_setup_common()
2691 if (status < 0) { in dsp_dma_setup_common()
2698 "ChipA=0x%x,DspA=0x%x,dmaCh=%u, " in dsp_dma_setup_common()
2699 "CHSEL=0x%x,CHPROP=0x%x,Active=0x%x\n", in dsp_dma_setup_common()
2705 return 0; in dsp_dma_setup_common()
2716 int status = 0; in dsp_dma_setup()
2723 unsigned int dma_cfg = 0; in dsp_dma_setup()
2724 unsigned int adr_ofs = 0; in dsp_dma_setup()
2725 unsigned int xfr_cnt = 0; in dsp_dma_setup()
2745 incr_field = 0; in dsp_dma_setup()
2758 if (status < 0) { in dsp_dma_setup()
2765 (code ? 0 : 1)); in dsp_dma_setup()
2769 if (status < 0) { in dsp_dma_setup()
2783 if (status < 0) { in dsp_dma_setup()
2790 "ChipA=0x%x, cnt=0x%x, DMACFG=0x%x, " in dsp_dma_setup()
2791 "ADROFS=0x%x, XFRCNT=0x%x\n", in dsp_dma_setup()
2796 return 0; in dsp_dma_setup()
2805 unsigned int reg = 0; in dsp_dma_start()
2806 int status = 0; in dsp_dma_start()
2814 if (status < 0) { in dsp_dma_start()
2826 if (status < 0) { in dsp_dma_start()
2841 unsigned int reg = 0; in dsp_dma_stop()
2842 int status = 0; in dsp_dma_stop()
2850 if (status < 0) { in dsp_dma_stop()
2861 if (status < 0) { in dsp_dma_stop()
2887 int status = 0; in dsp_allocate_router_ports()
2891 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0); in dsp_allocate_router_ports()
2892 if (status < 0) in dsp_allocate_router_ports()
2899 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in dsp_allocate_router_ports()
2903 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in dsp_allocate_router_ports()
2907 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0); in dsp_allocate_router_ports()
2908 if (status < 0) in dsp_allocate_router_ports()
2911 res = snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0, in dsp_allocate_router_ports()
2912 VENDOR_CHIPIO_PORT_ALLOC_GET, 0); in dsp_allocate_router_ports()
2916 return (res < 0) ? res : 0; in dsp_allocate_router_ports()
2924 int status = 0; in dsp_free_router_ports()
2926 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0); in dsp_free_router_ports()
2927 if (status < 0) in dsp_free_router_ports()
2930 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in dsp_free_router_ports()
2934 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0); in dsp_free_router_ports()
2956 rate_multi, 0, port_map); in dsp_allocate_ports()
2969 unsigned int sample_rate_div = ((get_hdafmt_rate(fmt) >> 0) & 3) + 1; in dsp_allocate_ports_format()
2993 if (status < 0) { in dsp_free_ports()
3014 DMA_STATE_STOP = 0,
3030 return 0; in dma_convert_to_hda_format()
3049 if (status < 0) in dma_reset()
3052 return 0; in dma_reset()
3067 return 0; in dma_set_state()
3071 return 0; in dma_set_state()
3089 return 0; in dma_xfer()
3114 static const u32 g_magic_value = 0x4c46584d;
3115 static const u32 g_chip_addr_magic_value = 0xFFFFFF01;
3129 return p->count == 0; in is_last()
3146 #define INVALID_DMA_CHANNEL (~0U)
3168 status = chipio_write(codec, data[0], data[1]); in dspxfr_hci_write()
3169 if (status < 0) { in dspxfr_hci_write()
3176 return 0; in dspxfr_hci_write()
3184 * @reloc: Relocation address for loading single-segment overlays, or 0 for
3201 int status = 0; in dspxfr_one_seg()
3233 if (fls == NULL || dma_engine == NULL || port_map_mask == 0) { in dspxfr_one_seg()
3243 return hci_write ? dspxfr_hci_write(codec, hci_write) : 0; in dspxfr_one_seg()
3245 chip_addx = (chip_addx & (0xFFFF0000 << 2)) + (reloc << 2); in dspxfr_one_seg()
3265 sample_rate_div = ((get_hdafmt_rate(hda_format) >> 0) & 3) + 1; in dspxfr_one_seg()
3269 hda_frame_size_words = ((sample_rate_div == 0) ? 0 : in dspxfr_one_seg()
3272 if (hda_frame_size_words == 0) { in dspxfr_one_seg()
3282 "chpadr=0x%08x frmsz=%u nchan=%u " in dspxfr_one_seg()
3300 while (words_to_write != 0) { in dspxfr_one_seg()
3307 if (status < 0) in dspxfr_one_seg()
3311 if (status < 0) in dspxfr_one_seg()
3318 if (status < 0) in dspxfr_one_seg()
3321 if (status < 0) in dspxfr_one_seg()
3328 if (status < 0) in dspxfr_one_seg()
3330 if (remainder_words != 0) { in dspxfr_one_seg()
3335 if (status < 0) in dspxfr_one_seg()
3337 remainder_words = 0; in dspxfr_one_seg()
3341 if (status < 0) in dspxfr_one_seg()
3360 if (status < 0) in dspxfr_one_seg()
3368 if (remainder_words != 0) { in dspxfr_one_seg()
3381 * @reloc: Relocation address for loading single-segment overlays, or 0 for
3398 unsigned short hda_format = 0; in dspxfr_image()
3400 unsigned char stream_id = 0; in dspxfr_image()
3424 dma_chan = ovly ? INVALID_DMA_CHANNEL : 0; in dspxfr_image()
3429 if (status < 0) { in dspxfr_image()
3438 if (status < 0) in dspxfr_image()
3444 if (status < 0) { in dspxfr_image()
3451 port_map_mask = 0; in dspxfr_image()
3454 if (status < 0) { in dspxfr_image()
3461 WIDGET_CHIP_CTRL, stream_id, 0, &response); in dspxfr_image()
3462 if (status < 0) { in dspxfr_image()
3476 if (status < 0) in dspxfr_image()
3486 if (port_map_mask != 0) in dspxfr_image()
3489 if (status < 0) in dspxfr_image()
3493 WIDGET_CHIP_CTRL, 0, 0, &response); in dspxfr_image()
3516 chipio_write(codec, XRAM_XRAM_INST_OFFSET(0x18), 0x08080080); in dspload_post_setup()
3517 chipio_write(codec, XRAM_XRAM_INST_OFFSET(0x19), 0x3f800000); in dspload_post_setup()
3520 chipio_write(codec, XRAM_XRAM_INST_OFFSET(0x29), 0x00000002); in dspload_post_setup()
3530 * @reloc: Relocation address for loading single-segment overlays, or 0 for
3533 * @router_chans: number of audio router channels to be allocated (0 means use
3549 int status = 0; in dspload_image()
3554 if (router_chans == 0) { in dspload_image()
3574 if (status < 0) in dspload_image()
3581 if (status < 0) in dspload_image()
3591 } while (0); in dspload_image()
3599 unsigned int data = 0; in dspload_is_loaded()
3600 int status = 0; in dspload_is_loaded()
3602 status = chipio_read(codec, 0x40004, &data); in dspload_is_loaded()
3603 if ((status < 0) || (data != 1)) in dspload_is_loaded()
3636 * the mmio address 0x320 is used to set GPIO pins. The format for the data
3649 gpio_data = gpio_pin & 0xF; in ca0113_mmio_gpio_set()
3650 gpio_data |= ((enable << 8) & 0x100); in ca0113_mmio_gpio_set()
3652 writew(gpio_data, spec->mem_base + 0x320); in ca0113_mmio_gpio_set()
3669 writel(0x0000007e, spec->mem_base + 0x210); in ca0113_mmio_command_set()
3670 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set()
3671 writel(0x0000005a, spec->mem_base + 0x210); in ca0113_mmio_command_set()
3672 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set()
3673 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set()
3675 writel(0x00800005, spec->mem_base + 0x20c); in ca0113_mmio_command_set()
3676 writel(group, spec->mem_base + 0x804); in ca0113_mmio_command_set()
3678 writel(0x00800005, spec->mem_base + 0x20c); in ca0113_mmio_command_set()
3679 write_val = (target & 0xff); in ca0113_mmio_command_set()
3683 writel(write_val, spec->mem_base + 0x204); in ca0113_mmio_command_set()
3689 readl(spec->mem_base + 0x860); in ca0113_mmio_command_set()
3690 readl(spec->mem_base + 0x854); in ca0113_mmio_command_set()
3691 readl(spec->mem_base + 0x840); in ca0113_mmio_command_set()
3693 writel(0x00800004, spec->mem_base + 0x20c); in ca0113_mmio_command_set()
3694 writel(0x00000000, spec->mem_base + 0x210); in ca0113_mmio_command_set()
3695 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set()
3696 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set()
3708 writel(0x0000007e, spec->mem_base + 0x210); in ca0113_mmio_command_set_type2()
3709 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set_type2()
3710 writel(0x0000005a, spec->mem_base + 0x210); in ca0113_mmio_command_set_type2()
3711 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set_type2()
3712 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set_type2()
3714 writel(0x00800003, spec->mem_base + 0x20c); in ca0113_mmio_command_set_type2()
3715 writel(group, spec->mem_base + 0x804); in ca0113_mmio_command_set_type2()
3717 writel(0x00800005, spec->mem_base + 0x20c); in ca0113_mmio_command_set_type2()
3718 write_val = (target & 0xff); in ca0113_mmio_command_set_type2()
3722 writel(write_val, spec->mem_base + 0x204); in ca0113_mmio_command_set_type2()
3724 readl(spec->mem_base + 0x860); in ca0113_mmio_command_set_type2()
3725 readl(spec->mem_base + 0x854); in ca0113_mmio_command_set_type2()
3726 readl(spec->mem_base + 0x840); in ca0113_mmio_command_set_type2()
3728 writel(0x00800004, spec->mem_base + 0x20c); in ca0113_mmio_command_set_type2()
3729 writel(0x00000000, spec->mem_base + 0x210); in ca0113_mmio_command_set_type2()
3730 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set_type2()
3731 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set_type2()
3750 snd_hda_codec_write(codec, 0x01, 0, 0x793, 0x00); in ca0132_gpio_init()
3751 snd_hda_codec_write(codec, 0x01, 0, 0x794, 0x53); in ca0132_gpio_init()
3752 snd_hda_codec_write(codec, 0x01, 0, 0x790, 0x23); in ca0132_gpio_init()
3755 snd_hda_codec_write(codec, 0x01, 0, 0x793, 0x00); in ca0132_gpio_init()
3756 snd_hda_codec_write(codec, 0x01, 0, 0x794, 0x5B); in ca0132_gpio_init()
3771 snd_hda_codec_write(codec, 0x01, 0, in ca0132_gpio_setup()
3772 AC_VERB_SET_GPIO_DIRECTION, 0x07); in ca0132_gpio_setup()
3773 snd_hda_codec_write(codec, 0x01, 0, in ca0132_gpio_setup()
3774 AC_VERB_SET_GPIO_MASK, 0x07); in ca0132_gpio_setup()
3775 snd_hda_codec_write(codec, 0x01, 0, in ca0132_gpio_setup()
3776 AC_VERB_SET_GPIO_DATA, 0x04); in ca0132_gpio_setup()
3777 snd_hda_codec_write(codec, 0x01, 0, in ca0132_gpio_setup()
3778 AC_VERB_SET_GPIO_DATA, 0x06); in ca0132_gpio_setup()
3781 snd_hda_codec_write(codec, 0x01, 0, in ca0132_gpio_setup()
3782 AC_VERB_SET_GPIO_DIRECTION, 0x1E); in ca0132_gpio_setup()
3783 snd_hda_codec_write(codec, 0x01, 0, in ca0132_gpio_setup()
3784 AC_VERB_SET_GPIO_MASK, 0x1F); in ca0132_gpio_setup()
3785 snd_hda_codec_write(codec, 0x01, 0, in ca0132_gpio_setup()
3786 AC_VERB_SET_GPIO_DATA, 0x0C); in ca0132_gpio_setup()
3798 /* Bit 1 - Switch between front/rear mic. 0 = rear, 1 = front */
3800 /* Bit 2 - Switch between headphone/line out. 0 = Headphone, 1 = Line */
3815 /* Set GPIO bit 1 to 0 for rear mic */
3816 R3DI_REAR_MIC = 0,
3822 /* Set GPIO bit 2 to 0 for headphone */
3823 R3DI_HEADPHONE_OUT = 0,
3829 R3DI_DSP_DOWNLOADING = 0,
3841 cur_gpio = snd_hda_codec_read(codec, 0x01, 0, AC_VERB_GET_GPIO_DATA, 0); in r3di_gpio_mic_set()
3851 snd_hda_codec_write(codec, codec->core.afg, 0, in r3di_gpio_mic_set()
3861 cur_gpio = snd_hda_codec_read(codec, 0x01, 0, AC_VERB_GET_GPIO_DATA, 0); in r3di_gpio_dsp_status_set()
3866 snd_hda_codec_write(codec, codec->core.afg, 0, in r3di_gpio_dsp_status_set()
3870 /* Set DOWNLOADING bit to 0. */ in r3di_gpio_dsp_status_set()
3873 snd_hda_codec_write(codec, codec->core.afg, 0, in r3di_gpio_dsp_status_set()
3880 snd_hda_codec_write(codec, codec->core.afg, 0, in r3di_gpio_dsp_status_set()
3895 snd_hda_codec_setup_stream(codec, spec->dacs[0], stream_tag, 0, format); in ca0132_playback_pcm_prepare()
3897 return 0; in ca0132_playback_pcm_prepare()
3907 return 0; in ca0132_playback_pcm_cleanup()
3914 snd_hda_codec_cleanup_stream(codec, spec->dacs[0]); in ca0132_playback_pcm_cleanup()
3916 return 0; in ca0132_playback_pcm_cleanup()
3928 return 0; in ca0132_playback_pcm_delay()
3992 stream_tag, 0, format); in ca0132_capture_pcm_prepare()
3994 return 0; in ca0132_capture_pcm_prepare()
4004 return 0; in ca0132_capture_pcm_cleanup()
4007 return 0; in ca0132_capture_pcm_cleanup()
4019 return 0; in ca0132_capture_pcm_delay()
4045 .private_value = HDA_COMPOSE_AMP_VAL(nid, channel, 0, dir) }
4063 .private_value = HDA_COMPOSE_AMP_VAL(nid, channel, 0, dir) }
4072 .private_value = HDA_COMPOSE_AMP_VAL(nid, channel, 0, dir) }
4092 0xC2B40000, 0xC2B20000, 0xC2B00000, 0xC2AE0000, 0xC2AC0000, 0xC2AA0000,
4093 0xC2A80000, 0xC2A60000, 0xC2A40000, 0xC2A20000, 0xC2A00000, 0xC29E0000,
4094 0xC29C0000, 0xC29A0000, 0xC2980000, 0xC2960000, 0xC2940000, 0xC2920000,
4095 0xC2900000, 0xC28E0000, 0xC28C0000, 0xC28A0000, 0xC2880000, 0xC2860000,
4096 0xC2840000, 0xC2820000, 0xC2800000, 0xC27C0000, 0xC2780000, 0xC2740000,
4097 0xC2700000, 0xC26C0000, 0xC2680000, 0xC2640000, 0xC2600000, 0xC25C0000,
4098 0xC2580000, 0xC2540000, 0xC2500000, 0xC24C0000, 0xC2480000, 0xC2440000,
4099 0xC2400000, 0xC23C0000, 0xC2380000, 0xC2340000, 0xC2300000, 0xC22C0000,
4100 0xC2280000, 0xC2240000, 0xC2200000, 0xC21C0000, 0xC2180000, 0xC2140000,
4101 0xC2100000, 0xC20C0000, 0xC2080000, 0xC2040000, 0xC2000000, 0xC1F80000,
4102 0xC1F00000, 0xC1E80000, 0xC1E00000, 0xC1D80000, 0xC1D00000, 0xC1C80000,
4103 0xC1C00000, 0xC1B80000, 0xC1B00000, 0xC1A80000, 0xC1A00000, 0xC1980000,
4104 0xC1900000, 0xC1880000, 0xC1800000, 0xC1700000, 0xC1600000, 0xC1500000,
4105 0xC1400000, 0xC1300000, 0xC1200000, 0xC1100000, 0xC1000000, 0xC0E00000,
4106 0xC0C00000, 0xC0A00000, 0xC0800000, 0xC0400000, 0xC0000000, 0xBF800000,
4107 0x00000000, 0x3F800000, 0x40000000, 0x40400000, 0x40800000, 0x40A00000,
4108 0x40C00000, 0x40E00000, 0x41000000, 0x41100000
4112 * This table counts from float 0 to 1 in increments of .01, which is
4116 0x00000000, 0x3C23D70A, 0x3CA3D70A, 0x3CF5C28F, 0x3D23D70A, 0x3D4CCCCD,
4117 0x3D75C28F, 0x3D8F5C29, 0x3DA3D70A, 0x3DB851EC, 0x3DCCCCCD, 0x3DE147AE,
4118 0x3DF5C28F, 0x3E051EB8, 0x3E0F5C29, 0x3E19999A, 0x3E23D70A, 0x3E2E147B,
4119 0x3E3851EC, 0x3E428F5C, 0x3E4CCCCD, 0x3E570A3D, 0x3E6147AE, 0x3E6B851F,
4120 0x3E75C28F, 0x3E800000, 0x3E851EB8, 0x3E8A3D71, 0x3E8F5C29, 0x3E947AE1,
4121 0x3E99999A, 0x3E9EB852, 0x3EA3D70A, 0x3EA8F5C3, 0x3EAE147B, 0x3EB33333,
4122 0x3EB851EC, 0x3EBD70A4, 0x3EC28F5C, 0x3EC7AE14, 0x3ECCCCCD, 0x3ED1EB85,
4123 0x3ED70A3D, 0x3EDC28F6, 0x3EE147AE, 0x3EE66666, 0x3EEB851F, 0x3EF0A3D7,
4124 0x3EF5C28F, 0x3EFAE148, 0x3F000000, 0x3F028F5C, 0x3F051EB8, 0x3F07AE14,
4125 0x3F0A3D71, 0x3F0CCCCD, 0x3F0F5C29, 0x3F11EB85, 0x3F147AE1, 0x3F170A3D,
4126 0x3F19999A, 0x3F1C28F6, 0x3F1EB852, 0x3F2147AE, 0x3F23D70A, 0x3F266666,
4127 0x3F28F5C3, 0x3F2B851F, 0x3F2E147B, 0x3F30A3D7, 0x3F333333, 0x3F35C28F,
4128 0x3F3851EC, 0x3F3AE148, 0x3F3D70A4, 0x3F400000, 0x3F428F5C, 0x3F451EB8,
4129 0x3F47AE14, 0x3F4A3D71, 0x3F4CCCCD, 0x3F4F5C29, 0x3F51EB85, 0x3F547AE1,
4130 0x3F570A3D, 0x3F59999A, 0x3F5C28F6, 0x3F5EB852, 0x3F6147AE, 0x3F63D70A,
4131 0x3F666666, 0x3F68F5C3, 0x3F6B851F, 0x3F6E147B, 0x3F70A3D7, 0x3F733333,
4132 0x3F75C28F, 0x3F7851EC, 0x3F7AE148, 0x3F7D70A4, 0x3F800000
4140 0x41200000, 0x41A00000, 0x41F00000, 0x42200000, 0x42480000, 0x42700000,
4141 0x428C0000, 0x42A00000, 0x42B40000, 0x42C80000, 0x42DC0000, 0x42F00000,
4142 0x43020000, 0x430C0000, 0x43160000, 0x43200000, 0x432A0000, 0x43340000,
4143 0x433E0000, 0x43480000, 0x43520000, 0x435C0000, 0x43660000, 0x43700000,
4144 0x437A0000, 0x43820000, 0x43870000, 0x438C0000, 0x43910000, 0x43960000,
4145 0x439B0000, 0x43A00000, 0x43A50000, 0x43AA0000, 0x43AF0000, 0x43B40000,
4146 0x43B90000, 0x43BE0000, 0x43C30000, 0x43C80000, 0x43CD0000, 0x43D20000,
4147 0x43D70000, 0x43DC0000, 0x43E10000, 0x43E60000, 0x43EB0000, 0x43F00000,
4148 0x43F50000, 0x43FA0000, 0x43FF0000, 0x44020000, 0x44048000, 0x44070000,
4149 0x44098000, 0x440C0000, 0x440E8000, 0x44110000, 0x44138000, 0x44160000,
4150 0x44188000, 0x441B0000, 0x441D8000, 0x44200000, 0x44228000, 0x44250000,
4151 0x44278000, 0x442A0000, 0x442C8000, 0x442F0000, 0x44318000, 0x44340000,
4152 0x44368000, 0x44390000, 0x443B8000, 0x443E0000, 0x44408000, 0x44430000,
4153 0x44458000, 0x44480000, 0x444A8000, 0x444D0000, 0x444F8000, 0x44520000,
4154 0x44548000, 0x44570000, 0x44598000, 0x445C0000, 0x445E8000, 0x44610000,
4155 0x44638000, 0x44660000, 0x44688000, 0x446B0000, 0x446D8000, 0x44700000,
4156 0x44728000, 0x44750000, 0x44778000, 0x447A0000
4163 0x41A00000, 0x41A80000, 0x41B00000, 0x41B80000, 0x41C00000, 0x41C80000,
4164 0x41D00000, 0x41D80000, 0x41E00000, 0x41E80000, 0x41F00000, 0x41F80000,
4165 0x42000000, 0x42040000, 0x42080000, 0x420C0000, 0x42100000, 0x42140000,
4166 0x42180000, 0x421C0000, 0x42200000, 0x42240000, 0x42280000, 0x422C0000,
4167 0x42300000, 0x42340000, 0x42380000, 0x423C0000, 0x42400000, 0x42440000,
4168 0x42480000, 0x424C0000, 0x42500000, 0x42540000, 0x42580000, 0x425C0000,
4169 0x42600000, 0x42640000, 0x42680000, 0x426C0000, 0x42700000, 0x42740000,
4170 0x42780000, 0x427C0000, 0x42800000, 0x42820000, 0x42840000, 0x42860000,
4171 0x42880000, 0x428A0000, 0x428C0000, 0x428E0000, 0x42900000, 0x42920000,
4172 0x42940000, 0x42960000, 0x42980000, 0x429A0000, 0x429C0000, 0x429E0000,
4173 0x42A00000, 0x42A20000, 0x42A40000, 0x42A60000, 0x42A80000, 0x42AA0000,
4174 0x42AC0000, 0x42AE0000, 0x42B00000, 0x42B20000, 0x42B40000, 0x42B60000,
4175 0x42B80000, 0x42BA0000, 0x42BC0000, 0x42BE0000, 0x42C00000, 0x42C20000,
4176 0x42C40000, 0x42C60000, 0x42C80000, 0x42CA0000, 0x42CC0000, 0x42CE0000,
4177 0x42D00000, 0x42D20000, 0x42D40000, 0x42D60000, 0x42D80000, 0x42DA0000,
4178 0x42DC0000, 0x42DE0000, 0x42E00000, 0x42E20000, 0x42E40000, 0x42E60000,
4179 0x42E80000, 0x42EA0000, 0x42EC0000, 0x42EE0000, 0x42F00000, 0x42F20000,
4180 0x42F40000, 0x42F60000, 0x42F80000, 0x42FA0000, 0x42FC0000, 0x42FE0000,
4181 0x43000000, 0x43010000, 0x43020000, 0x43030000, 0x43040000, 0x43050000,
4182 0x43060000, 0x43070000, 0x43080000, 0x43090000, 0x430A0000, 0x430B0000,
4183 0x430C0000, 0x430D0000, 0x430E0000, 0x430F0000, 0x43100000, 0x43110000,
4184 0x43120000, 0x43130000, 0x43140000, 0x43150000, 0x43160000, 0x43170000,
4185 0x43180000, 0x43190000, 0x431A0000, 0x431B0000, 0x431C0000, 0x431D0000,
4186 0x431E0000, 0x431F0000, 0x43200000, 0x43210000, 0x43220000, 0x43230000,
4187 0x43240000, 0x43250000, 0x43260000, 0x43270000, 0x43280000, 0x43290000,
4188 0x432A0000, 0x432B0000, 0x432C0000, 0x432D0000, 0x432E0000, 0x432F0000,
4189 0x43300000, 0x43310000, 0x43320000, 0x43330000, 0x43340000
4193 0x00000000, 0x3C23D70A, 0x3CA3D70A, 0x3CF5C28F, 0x3D23D70A, 0x3D4CCCCD,
4194 0x3D75C28F, 0x3D8F5C29, 0x3DA3D70A, 0x3DB851EC, 0x3DCCCCCD, 0x3DE147AE,
4195 0x3DF5C28F, 0x3E051EB8, 0x3E0F5C29, 0x3E19999A, 0x3E23D70A, 0x3E2E147B,
4196 0x3E3851EC, 0x3E428F5C, 0x3E4CCCCD, 0x3E570A3D, 0x3E6147AE, 0x3E6B851F,
4197 0x3E75C28F, 0x3E800000, 0x3E851EB8, 0x3E8A3D71, 0x3E8F5C29, 0x3E947AE1,
4198 0x3E99999A, 0x3E9EB852, 0x3EA3D70A, 0x3EA8F5C3, 0x3EAE147B, 0x3EB33333,
4199 0x3EB851EC, 0x3EBD70A4, 0x3EC28F5C, 0x3EC7AE14, 0x3ECCCCCD, 0x3ED1EB85,
4200 0x3ED70A3D, 0x3EDC28F6, 0x3EE147AE, 0x3EE66666, 0x3EEB851F, 0x3EF0A3D7,
4201 0x3EF5C28F, 0x3EFAE148, 0x3F000000, 0x3F028F5C, 0x3F051EB8, 0x3F07AE14,
4202 0x3F0A3D71, 0x3F0CCCCD, 0x3F0F5C29, 0x3F11EB85, 0x3F147AE1, 0x3F170A3D,
4203 0x3F19999A, 0x3F1C28F6, 0x3F1EB852, 0x3F2147AE, 0x3F23D70A, 0x3F266666,
4204 0x3F28F5C3, 0x3F2B851F, 0x3F2E147B, 0x3F30A3D7, 0x3F333333, 0x3F35C28F,
4205 0x3F3851EC, 0x3F3AE148, 0x3F3D70A4, 0x3F400000, 0x3F428F5C, 0x3F451EB8,
4206 0x3F47AE14, 0x3F4A3D71, 0x3F4CCCCD, 0x3F4F5C29, 0x3F51EB85, 0x3F547AE1,
4207 0x3F570A3D, 0x3F59999A, 0x3F5C28F6, 0x3F5EB852, 0x3F6147AE, 0x3F63D70A,
4208 0x3F666666, 0x3F68F5C3, 0x3F6B851F, 0x3F6E147B, 0x3F70A3D7, 0x3F733333,
4209 0x3F75C28F, 0x3F7851EC, 0x3F7AE148, 0x3F7D70A4, 0x3F800000
4213 0xC1C00000, 0xC1B80000, 0xC1B00000, 0xC1A80000, 0xC1A00000, 0xC1980000,
4214 0xC1900000, 0xC1880000, 0xC1800000, 0xC1700000, 0xC1600000, 0xC1500000,
4215 0xC1400000, 0xC1300000, 0xC1200000, 0xC1100000, 0xC1000000, 0xC0E00000,
4216 0xC0C00000, 0xC0A00000, 0xC0800000, 0xC0400000, 0xC0000000, 0xBF800000,
4217 0x00000000, 0x3F800000, 0x40000000, 0x40400000, 0x40800000, 0x40A00000,
4218 0x40C00000, 0x40E00000, 0x41000000, 0x41100000, 0x41200000, 0x41300000,
4219 0x41400000, 0x41500000, 0x41600000, 0x41700000, 0x41800000, 0x41880000,
4220 0x41900000, 0x41980000, 0x41A00000, 0x41A80000, 0x41B00000, 0x41B80000,
4221 0x41C00000
4227 int i = 0; in tuning_ctl_set()
4229 for (i = 0; i < TUNING_CTLS_COUNT; i++) in tuning_ctl_set()
4236 dspio_set_param(codec, ca0132_tuning_ctls[i].mid, 0x20, in tuning_ctl_set()
4254 return 0; in tuning_ctl_get()
4267 return 0; in voice_focus_ctl_info()
4282 return 0; in voice_focus_ctl_put()
4298 uinfo->value.integer.min = 0; in mic_svm_ctl_info()
4302 return 0; in mic_svm_ctl_info()
4317 return 0; in mic_svm_ctl_put()
4324 return 0; in mic_svm_ctl_put()
4333 uinfo->value.integer.min = 0; in equalizer_ctl_info()
4337 return 0; in equalizer_ctl_info()
4352 return 0; in equalizer_ctl_put()
4362 static const SNDRV_CTL_TLVD_DECLARE_DB_SCALE(voice_focus_db_scale, 2000, 100, 0);
4363 static const SNDRV_CTL_TLVD_DECLARE_DB_SCALE(eq_db_scale, -2400, 100, 0);
4372 HDA_CODEC_VOLUME_MONO(namestr, nid, 1, 0, type); in add_tuning_control()
4376 knew.tlv.c = 0; in add_tuning_control()
4377 knew.tlv.p = 0; in add_tuning_control()
4397 return 0; in add_tuning_control()
4400 HDA_COMPOSE_AMP_VAL(nid, 1, 0, type); in add_tuning_control()
4410 for (i = 0; i < TUNING_CTLS_COUNT; i++) { in add_tuning_ctls()
4416 if (err < 0) in add_tuning_ctls()
4420 return 0; in add_tuning_ctls()
4433 /* EQ defaults to 0dB. */ in ca0132_init_tuning_defaults()
4475 err = dspio_set_uint_param(codec, 0x80, 0x04, tmp); in ca0132_select_out()
4476 if (err < 0) in ca0132_select_out()
4480 err = dspio_set_uint_param(codec, 0x8f, 0x00, tmp); in ca0132_select_out()
4481 if (err < 0) in ca0132_select_out()
4485 snd_hda_codec_write(codec, spec->out_pins[1], 0, in ca0132_select_out()
4486 VENDOR_CHIPIO_EAPD_SEL_SET, 0x02); in ca0132_select_out()
4487 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4488 AC_VERB_SET_EAPD_BTLENABLE, 0x00); in ca0132_select_out()
4489 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4490 VENDOR_CHIPIO_EAPD_SEL_SET, 0x00); in ca0132_select_out()
4491 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4492 AC_VERB_SET_EAPD_BTLENABLE, 0x02); in ca0132_select_out()
4495 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[1], 0, in ca0132_select_out()
4496 AC_VERB_GET_PIN_WIDGET_CONTROL, 0); in ca0132_select_out()
4500 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[0], 0, in ca0132_select_out()
4501 AC_VERB_GET_PIN_WIDGET_CONTROL, 0); in ca0132_select_out()
4502 snd_hda_set_pin_ctl(codec, spec->out_pins[0], in ca0132_select_out()
4508 err = dspio_set_uint_param(codec, 0x80, 0x04, tmp); in ca0132_select_out()
4509 if (err < 0) in ca0132_select_out()
4513 err = dspio_set_uint_param(codec, 0x8f, 0x00, tmp); in ca0132_select_out()
4514 if (err < 0) in ca0132_select_out()
4518 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4519 VENDOR_CHIPIO_EAPD_SEL_SET, 0x00); in ca0132_select_out()
4520 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4521 AC_VERB_SET_EAPD_BTLENABLE, 0x00); in ca0132_select_out()
4522 snd_hda_codec_write(codec, spec->out_pins[1], 0, in ca0132_select_out()
4523 VENDOR_CHIPIO_EAPD_SEL_SET, 0x02); in ca0132_select_out()
4524 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4525 AC_VERB_SET_EAPD_BTLENABLE, 0x02); in ca0132_select_out()
4528 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[0], 0, in ca0132_select_out()
4529 AC_VERB_GET_PIN_WIDGET_CONTROL, 0); in ca0132_select_out()
4530 snd_hda_set_pin_ctl(codec, spec->out_pins[0], in ca0132_select_out()
4533 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[1], 0, in ca0132_select_out()
4534 AC_VERB_GET_PIN_WIDGET_CONTROL, 0); in ca0132_select_out()
4542 return err < 0 ? err : 0; in ca0132_select_out()
4560 for (i = 0; i < AE_CA0113_OUT_SET_COMMANDS; i++) in ae5_mmio_select_out()
4576 return 0; in ca0132_alt_set_full_range_speaker()
4579 tmp = spec->speaker_range_val[0] ? FLOAT_ZERO : FLOAT_ONE; in ca0132_alt_set_full_range_speaker()
4580 err = dspio_set_uint_param(codec, 0x96, in ca0132_alt_set_full_range_speaker()
4582 if (err < 0) in ca0132_alt_set_full_range_speaker()
4587 err = dspio_set_uint_param(codec, 0x96, in ca0132_alt_set_full_range_speaker()
4589 if (err < 0) in ca0132_alt_set_full_range_speaker()
4592 err = dspio_set_uint_param(codec, 0x96, in ca0132_alt_set_full_range_speaker()
4594 if (err < 0) in ca0132_alt_set_full_range_speaker()
4602 err = dspio_set_uint_param(codec, 0x96, in ca0132_alt_set_full_range_speaker()
4604 if (err < 0) in ca0132_alt_set_full_range_speaker()
4608 return 0; in ca0132_alt_set_full_range_speaker()
4624 err = dspio_set_uint_param(codec, 0x96, SPEAKER_BASS_REDIRECT, tmp); in ca0132_alt_surround_set_bass_redirection()
4625 if (err < 0) in ca0132_alt_surround_set_bass_redirection()
4631 err = dspio_set_uint_param(codec, 0x96, in ca0132_alt_surround_set_bass_redirection()
4633 if (err < 0) in ca0132_alt_surround_set_bass_redirection()
4637 return 0; in ca0132_alt_surround_set_bass_redirection()
4652 for (i = 0; i < ARRAY_SIZE(quirk_out_set_data); i++) { in ca0132_alt_select_out_get_quirk_data()
4670 return 0; in ca0132_alt_select_out_quirk_set()
4677 gpio_data = snd_hda_codec_read(codec, codec->core.afg, 0, in ca0132_alt_select_out_quirk_set()
4678 AC_VERB_GET_GPIO_DATA, 0); in ca0132_alt_select_out_quirk_set()
4685 snd_hda_codec_write(codec, codec->core.afg, 0, in ca0132_alt_select_out_quirk_set()
4690 for (i = 0; i < out_info->mmio_gpio_count; i++) { in ca0132_alt_select_out_quirk_set()
4697 for (i = 0; i < out_info->scp_cmds_count; i++) { in ca0132_alt_select_out_quirk_set()
4702 if (err < 0) in ca0132_alt_select_out_quirk_set()
4707 chipio_set_control_param(codec, 0x0d, out_info->dac2port); in ca0132_alt_select_out_quirk_set()
4719 zxr_headphone_gain_set(codec, 0); in ca0132_alt_select_out_quirk_set()
4730 return 0; in ca0132_alt_select_out_quirk_set()
4738 pin_ctl = snd_hda_codec_read(codec, nid, 0, in ca0132_set_out_node_pincfg()
4739 AC_VERB_GET_PIN_WIDGET_CONTROL, 0); in ca0132_set_out_node_pincfg()
4789 err = dspio_set_uint_param(codec, 0x96, SPEAKER_TUNING_MUTE, FLOAT_ONE); in ca0132_alt_select_out()
4790 if (err < 0) in ca0132_alt_select_out()
4793 if (ca0132_alt_select_out_quirk_set(codec) < 0) in ca0132_alt_select_out()
4801 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_alt_select_out()
4802 AC_VERB_SET_EAPD_BTLENABLE, 0x01); in ca0132_alt_select_out()
4805 ca0132_set_out_node_pincfg(codec, spec->out_pins[1], 0, 0); in ca0132_alt_select_out()
4807 ca0132_set_out_node_pincfg(codec, spec->out_pins[0], 1, 0); in ca0132_alt_select_out()
4809 ca0132_set_out_node_pincfg(codec, spec->out_pins[2], 1, 0); in ca0132_alt_select_out()
4811 ca0132_set_out_node_pincfg(codec, spec->out_pins[3], 1, 0); in ca0132_alt_select_out()
4823 err = dspio_set_uint_param(codec, 0x80, 0x04, tmp); in ca0132_alt_select_out()
4824 if (err < 0) in ca0132_alt_select_out()
4830 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_alt_select_out()
4831 AC_VERB_SET_EAPD_BTLENABLE, 0x00); in ca0132_alt_select_out()
4834 ca0132_set_out_node_pincfg(codec, spec->out_pins[0], 0, 0); in ca0132_alt_select_out()
4835 ca0132_set_out_node_pincfg(codec, spec->out_pins[2], 0, 0); in ca0132_alt_select_out()
4836 ca0132_set_out_node_pincfg(codec, spec->out_pins[3], 0, 0); in ca0132_alt_select_out()
4847 err = dspio_set_uint_param(codec, 0x80, 0x04, FLOAT_ONE); in ca0132_alt_select_out()
4849 err = dspio_set_uint_param(codec, 0x80, 0x04, FLOAT_ZERO); in ca0132_alt_select_out()
4851 if (err < 0) in ca0132_alt_select_out()
4864 /* Set speaker EQ bypass attenuation to 0. */ in ca0132_alt_select_out()
4865 err = dspio_set_uint_param(codec, 0x8f, 0x01, FLOAT_ZERO); in ca0132_alt_select_out()
4866 if (err < 0) in ca0132_alt_select_out()
4873 err = dspio_set_uint_param(codec, 0x96, in ca0132_alt_select_out()
4875 if (err < 0) in ca0132_alt_select_out()
4882 err = ca0132_alt_surround_set_bass_redirection(codec, 0); in ca0132_alt_select_out()
4885 err = dspio_set_uint_param(codec, 0x96, in ca0132_alt_select_out()
4887 if (err < 0) in ca0132_alt_select_out()
4892 if (err < 0) in ca0132_alt_select_out()
4899 return err < 0 ? err : 0; in ca0132_alt_select_out()
4915 jack->block_report = 0; in ca0132_unsol_hp_delayed()
4936 return 0; in ca0132_set_vipsource()
4938 /* if CrystalVoice if off, vipsource should be 0 */ in ca0132_set_vipsource()
4940 (val == 0)) { in ca0132_set_vipsource()
4941 chipio_set_control_param(codec, CONTROL_PARAM_VIP_SOURCE, 0); in ca0132_set_vipsource()
4948 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_set_vipsource()
4950 dspio_set_uint_param(codec, 0x80, 0x05, tmp); in ca0132_set_vipsource()
4958 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_set_vipsource()
4960 dspio_set_uint_param(codec, 0x80, 0x05, tmp); in ca0132_set_vipsource()
4974 return 0; in ca0132_alt_set_vipsource()
4978 chipio_set_stream_control(codec, 0x03, 0); in ca0132_alt_set_vipsource()
4979 chipio_set_stream_control(codec, 0x04, 0); in ca0132_alt_set_vipsource()
4981 /* if CrystalVoice is off, vipsource should be 0 */ in ca0132_alt_set_vipsource()
4983 (val == 0) || spec->in_enum_val == REAR_LINE_IN) { in ca0132_alt_set_vipsource()
4985 chipio_set_control_param(codec, CONTROL_PARAM_VIP_SOURCE, 0); in ca0132_alt_set_vipsource()
4988 dspio_set_uint_param(codec, 0x80, 0x05, tmp); in ca0132_alt_set_vipsource()
4993 chipio_set_conn_rate(codec, 0x0F, SR_96_000); in ca0132_alt_set_vipsource()
5005 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_alt_set_vipsource()
5012 chipio_set_conn_rate(codec, 0x0F, SR_16_000); in ca0132_alt_set_vipsource()
5018 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_alt_set_vipsource()
5021 dspio_set_uint_param(codec, 0x80, 0x05, tmp); in ca0132_alt_set_vipsource()
5027 chipio_set_stream_control(codec, 0x03, 1); in ca0132_alt_set_vipsource()
5028 chipio_set_stream_control(codec, 0x04, 1); in ca0132_alt_set_vipsource()
5066 ca0132_mic_boost_set(codec, 0); in ca0132_select_mic()
5074 ca0132_set_dmic(codec, 0); in ca0132_select_mic()
5077 ca0132_effects_set(codec, VOICE_FOCUS, 0); in ca0132_select_mic()
5082 return 0; in ca0132_select_mic()
5100 chipio_set_stream_control(codec, 0x03, 0); in ca0132_alt_select_in()
5101 chipio_set_stream_control(codec, 0x04, 0); in ca0132_alt_select_in()
5110 ca0113_mmio_gpio_set(codec, 0, false); in ca0132_alt_select_in()
5121 ca0113_mmio_command_set(codec, 0x30, 0x28, 0x00); in ca0132_alt_select_in()
5125 ca0113_mmio_command_set(codec, 0x30, 0x28, 0x00); in ca0132_alt_select_in()
5131 dspio_set_uint_param(codec, 0x80, 0x01, FLOAT_ZERO); in ca0132_alt_select_in()
5141 chipio_set_conn_rate(codec, 0x0F, SR_96_000); in ca0132_alt_select_in()
5143 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_alt_select_in()
5145 chipio_set_stream_control(codec, 0x03, 1); in ca0132_alt_select_in()
5146 chipio_set_stream_control(codec, 0x04, 1); in ca0132_alt_select_in()
5149 chipio_write(codec, 0x18B098, 0x0000000C); in ca0132_alt_select_in()
5150 chipio_write(codec, 0x18B09C, 0x0000000C); in ca0132_alt_select_in()
5153 chipio_write(codec, 0x18B098, 0x0000000C); in ca0132_alt_select_in()
5154 chipio_write(codec, 0x18B09C, 0x000000CC); in ca0132_alt_select_in()
5157 chipio_write(codec, 0x18B098, 0x0000000C); in ca0132_alt_select_in()
5158 chipio_write(codec, 0x18B09C, 0x0000004C); in ca0132_alt_select_in()
5166 ca0132_mic_boost_set(codec, 0); in ca0132_alt_select_in()
5170 ca0113_mmio_gpio_set(codec, 0, false); in ca0132_alt_select_in()
5176 ca0113_mmio_command_set(codec, 0x30, 0x28, 0x00); in ca0132_alt_select_in()
5179 ca0113_mmio_command_set(codec, 0x30, 0x28, 0x3f); in ca0132_alt_select_in()
5184 dspio_set_uint_param(codec, 0x80, 0x01, FLOAT_ZERO); in ca0132_alt_select_in()
5193 chipio_set_conn_rate(codec, 0x0F, SR_96_000); in ca0132_alt_select_in()
5199 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_alt_select_in()
5204 chipio_write(codec, 0x18B098, 0x00000000); in ca0132_alt_select_in()
5205 chipio_write(codec, 0x18B09C, 0x00000000); in ca0132_alt_select_in()
5210 chipio_set_stream_control(codec, 0x03, 1); in ca0132_alt_select_in()
5211 chipio_set_stream_control(codec, 0x04, 1); in ca0132_alt_select_in()
5217 ca0113_mmio_gpio_set(codec, 0, true); in ca0132_alt_select_in()
5226 ca0113_mmio_command_set(codec, 0x30, 0x28, 0x3f); in ca0132_alt_select_in()
5237 chipio_set_conn_rate(codec, 0x0F, SR_96_000); in ca0132_alt_select_in()
5239 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_alt_select_in()
5241 chipio_set_stream_control(codec, 0x03, 1); in ca0132_alt_select_in()
5242 chipio_set_stream_control(codec, 0x04, 1); in ca0132_alt_select_in()
5246 chipio_write(codec, 0x18B098, 0x0000000C); in ca0132_alt_select_in()
5247 chipio_write(codec, 0x18B09C, 0x000000CC); in ca0132_alt_select_in()
5250 chipio_write(codec, 0x18B098, 0x0000000C); in ca0132_alt_select_in()
5251 chipio_write(codec, 0x18B09C, 0x0000004C); in ca0132_alt_select_in()
5262 return 0; in ca0132_alt_select_in()
5294 * They return 0 if no changed. Return 1 if changed.
5310 ca0132_voicefx.reqs[0], tmp); in ca0132_voicefx_set()
5323 int err = 0; in ca0132_effects_set()
5326 if ((idx < 0) || (idx >= num_fx)) in ca0132_effects_set()
5327 return 0; /* no changed */ in ca0132_effects_set()
5333 val = 0; in ca0132_effects_set()
5338 val = 0; in ca0132_effects_set()
5346 val = 0; in ca0132_effects_set()
5350 val = 0; in ca0132_effects_set()
5365 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_effects_set()
5370 * to module ID 0x47. No clue why. in ca0132_effects_set()
5384 dspio_set_uint_param(codec, 0x47, 0x00, tmp); in ca0132_effects_set()
5390 val = 0; in ca0132_effects_set()
5393 codec_dbg(codec, "ca0132_effect_set: nid=0x%x, val=%ld\n", in ca0132_effects_set()
5396 on = (val == 0) ? FLOAT_ZERO : FLOAT_ONE; in ca0132_effects_set()
5398 ca0132_effects[idx].reqs[0], on); in ca0132_effects_set()
5400 if (err < 0) in ca0132_effects_set()
5401 return 0; /* no changed */ in ca0132_effects_set()
5413 int i, ret = 0; in ca0132_pe_switch_set()
5434 unsigned int oldval = snd_hda_codec_read(codec, spec->adcs[0], 0, in stop_mic1()
5435 AC_VERB_GET_CONV, 0); in stop_mic1()
5436 if (oldval != 0) in stop_mic1()
5437 snd_hda_codec_write(codec, spec->adcs[0], 0, in stop_mic1()
5439 0); in stop_mic1()
5448 if (oldval != 0) in resume_mic1()
5449 snd_hda_codec_write(codec, spec->adcs[0], 0, in resume_mic1()
5461 int i, ret = 0; in ca0132_cvoice_switch_set()
5474 ret |= ca0132_voicefx_set(codec, (spec->voicefx_val ? 1 : 0)); in ca0132_cvoice_switch_set()
5489 int ret = 0; in ca0132_mic_boost_set()
5492 ret = snd_hda_codec_amp_update(codec, spec->input_pins[0], 0, in ca0132_mic_boost_set()
5493 HDA_INPUT, 0, HDA_AMP_VOLMASK, 3); in ca0132_mic_boost_set()
5495 ret = snd_hda_codec_amp_update(codec, spec->input_pins[0], 0, in ca0132_mic_boost_set()
5496 HDA_INPUT, 0, HDA_AMP_VOLMASK, 0); in ca0132_mic_boost_set()
5504 int ret = 0; in ca0132_alt_mic_boost_set()
5506 ret = snd_hda_codec_amp_update(codec, spec->input_pins[0], 0, in ca0132_alt_mic_boost_set()
5507 HDA_INPUT, 0, HDA_AMP_VOLMASK, val); in ca0132_alt_mic_boost_set()
5515 for (i = 0; i < 4; i++) in ae5_headphone_gain_set()
5516 ca0113_mmio_command_set(codec, 0x48, 0x11 + i, in ae5_headphone_gain_set()
5518 return 0; in ae5_headphone_gain_set()
5529 return 0; in zxr_headphone_gain_set()
5537 hda_nid_t shared_nid = 0; in ca0132_vnode_switch_set()
5539 int ret = 0; in ca0132_vnode_switch_set()
5586 0, dir); in ca0132_vnode_switch_set()
5601 dspio_set_param(codec, 0x96, 0x20, SPEAKER_BASS_REDIRECT_XOVER_FREQ, in ca0132_alt_bass_redirection_xover_set()
5619 int i = 0; in ca0132_alt_slider_ctl_set()
5632 for (i = 0; i < OUT_EFFECTS_COUNT; i++) in ca0132_alt_slider_ctl_set()
5636 dspio_set_param(codec, ca0132_effects[i].mid, 0x20, in ca0132_alt_slider_ctl_set()
5641 for (i = 0; i < OUT_EFFECTS_COUNT; i++) in ca0132_alt_slider_ctl_set()
5645 dspio_set_param(codec, ca0132_effects[i].mid, 0x20, in ca0132_alt_slider_ctl_set()
5652 return 0; in ca0132_alt_slider_ctl_set()
5668 return 0; in ca0132_alt_xbass_xover_slider_ctl_get()
5681 return 0; in ca0132_alt_slider_ctl_get()
5697 return 0; in ca0132_alt_xbass_xover_slider_info()
5707 uinfo->value.integer.min = 0; in ca0132_alt_effect_slider_info()
5711 return 0; in ca0132_alt_effect_slider_info()
5731 return 0; in ca0132_alt_xbass_xover_slider_put()
5741 return 0; in ca0132_alt_xbass_xover_slider_put()
5756 return 0; in ca0132_alt_effect_slider_put()
5763 return 0; in ca0132_alt_effect_slider_put()
5770 * traditional 0-100 in alsamixer that goes in big steps. I like enum better.
5788 return 0; in ca0132_alt_mic_boost_info()
5797 ucontrol->value.enumerated.item[0] = spec->mic_boost_enum_val; in ca0132_alt_mic_boost_get()
5798 return 0; in ca0132_alt_mic_boost_get()
5806 int sel = ucontrol->value.enumerated.item[0]; in ca0132_alt_mic_boost_put()
5810 return 0; in ca0132_alt_mic_boost_put()
5842 return 0; in ae5_headphone_gain_info()
5851 ucontrol->value.enumerated.item[0] = spec->ae5_headphone_gain_val; in ae5_headphone_gain_get()
5852 return 0; in ae5_headphone_gain_get()
5860 int sel = ucontrol->value.enumerated.item[0]; in ae5_headphone_gain_put()
5864 return 0; in ae5_headphone_gain_put()
5895 return 0; in ae5_sound_filter_info()
5904 ucontrol->value.enumerated.item[0] = spec->ae5_filter_val; in ae5_sound_filter_get()
5905 return 0; in ae5_sound_filter_get()
5913 int sel = ucontrol->value.enumerated.item[0]; in ae5_sound_filter_put()
5917 return 0; in ae5_sound_filter_put()
5924 ca0113_mmio_command_set_type2(codec, 0x48, 0x07, in ae5_sound_filter_put()
5945 return 0; in ca0132_alt_input_source_info()
5954 ucontrol->value.enumerated.item[0] = spec->in_enum_val; in ca0132_alt_input_source_get()
5955 return 0; in ca0132_alt_input_source_get()
5963 int sel = ucontrol->value.enumerated.item[0]; in ca0132_alt_input_source_put()
5974 return 0; in ca0132_alt_input_source_put()
5997 return 0; in ca0132_alt_output_select_get_info()
6006 ucontrol->value.enumerated.item[0] = spec->out_enum_val; in ca0132_alt_output_select_get()
6007 return 0; in ca0132_alt_output_select_get()
6015 int sel = ucontrol->value.enumerated.item[0]; in ca0132_alt_output_select_put()
6020 return 0; in ca0132_alt_output_select_put()
6048 return 0; in ca0132_alt_speaker_channel_cfg_get_info()
6057 ucontrol->value.enumerated.item[0] = spec->channel_cfg_val; in ca0132_alt_speaker_channel_cfg_get()
6058 return 0; in ca0132_alt_speaker_channel_cfg_get()
6066 int sel = ucontrol->value.enumerated.item[0]; in ca0132_alt_speaker_channel_cfg_put()
6070 return 0; in ca0132_alt_speaker_channel_cfg_put()
6101 return 0; in ca0132_alt_svm_setting_info()
6110 ucontrol->value.enumerated.item[0] = spec->smart_volume_setting; in ca0132_alt_svm_setting_get()
6111 return 0; in ca0132_alt_svm_setting_get()
6119 int sel = ucontrol->value.enumerated.item[0]; in ca0132_alt_svm_setting_put()
6125 return 0; in ca0132_alt_svm_setting_put()
6133 case 0: in ca0132_alt_svm_setting_put()
6165 return 0; in ca0132_alt_eq_preset_info()
6174 ucontrol->value.enumerated.item[0] = spec->eq_preset_val; in ca0132_alt_eq_preset_get()
6175 return 0; in ca0132_alt_eq_preset_get()
6183 int i, err = 0; in ca0132_alt_eq_preset_put()
6184 int sel = ucontrol->value.enumerated.item[0]; in ca0132_alt_eq_preset_put()
6188 return 0; in ca0132_alt_eq_preset_put()
6193 * Idx 0 is default. in ca0132_alt_eq_preset_put()
6196 for (i = 0; i < EQ_PRESET_MAX_PARAM_COUNT; i++) { in ca0132_alt_eq_preset_put()
6200 if (err < 0) in ca0132_alt_eq_preset_put()
6204 if (err >= 0) in ca0132_alt_eq_preset_put()
6222 return 0; in ca0132_voicefx_info()
6231 ucontrol->value.enumerated.item[0] = spec->voicefx_val; in ca0132_voicefx_get()
6232 return 0; in ca0132_voicefx_get()
6240 int i, err = 0; in ca0132_voicefx_put()
6241 int sel = ucontrol->value.enumerated.item[0]; in ca0132_voicefx_put()
6244 return 0; in ca0132_voicefx_put()
6250 * Idx 0 is default. in ca0132_voicefx_put()
6253 for (i = 0; i < VOICEFX_MAX_PARAM_COUNT; i++) { in ca0132_voicefx_put()
6257 if (err < 0) in ca0132_voicefx_put()
6261 if (err >= 0) { in ca0132_voicefx_put()
6264 ca0132_voicefx_set(codec, (sel ? 1 : 0)); in ca0132_voicefx_put()
6289 return 0; in ca0132_switch_get()
6295 return 0; in ca0132_switch_get()
6299 if (nid == spec->input_pins[0]) { in ca0132_switch_get()
6301 return 0; in ca0132_switch_get()
6306 return 0; in ca0132_switch_get()
6311 return 0; in ca0132_switch_get()
6316 return 0; in ca0132_switch_get()
6319 return 0; in ca0132_switch_get()
6332 codec_dbg(codec, "ca0132_switch_put: nid=0x%x, val=%ld\n", in ca0132_switch_put()
6373 if (nid == spec->input_pins[0]) { in ca0132_switch_put()
6392 changed = 0; in ca0132_switch_put()
6402 changed = 0; in ca0132_switch_put()
6410 changed = 0; in ca0132_switch_put()
6441 ca0132_alt_vol_ctls[dsp_dir].reqs[0], in ca0132_alt_dsp_volume_put()
6473 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(nid, ch, 0, dir); in ca0132_volume_info()
6483 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(nid, ch, 0, dir); in ca0132_volume_info()
6512 return 0; in ca0132_volume_get()
6523 hda_nid_t shared_nid = 0; in ca0132_volume_put()
6547 0, dir); in ca0132_volume_put()
6570 hda_nid_t vnid = 0; in ca0132_alt_volume_put()
6574 case 0x02: in ca0132_alt_volume_put()
6577 case 0x07: in ca0132_alt_volume_put()
6619 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(nid, ch, 0, dir); in ca0132_volume_tlv()
6629 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(nid, ch, 0, dir); in ca0132_volume_tlv()
6647 HDA_CODEC_VOLUME_MONO(namestr, nid, 1, 0, type); in ca0132_alt_add_effect_slider()
6664 HDA_COMPOSE_AMP_VAL(nid, 1, 0, type); in ca0132_alt_add_effect_slider()
6699 VOICEFX, 1, 0, HDA_INPUT); in add_voicefx()
6711 EQ_PRESET_ENUM, 1, 0, HDA_OUTPUT); in add_ca0132_alt_eq_presets()
6728 SMART_VOLUME_ENUM, 1, 0, HDA_OUTPUT); in ca0132_alt_add_svm_enum()
6745 OUTPUT_SOURCE_ENUM, 1, 0, HDA_OUTPUT); in ca0132_alt_add_output_enum()
6762 SPEAKER_CHANNEL_CFG_ENUM, 1, 0, HDA_OUTPUT); in ca0132_alt_add_speaker_channel_cfg_enum()
6805 HDA_CODEC_VOLUME_MONO(namestr, BASS_REDIRECTION_XOVER, 1, 0, in ca0132_alt_add_bass_redirection_crossover()
6837 INPUT_SOURCE_ENUM, 1, 0, HDA_INPUT); in ca0132_alt_add_input_enum()
6846 * Add mic boost enumerated control. Switches through 0dB to 30dB. This adds
6853 MIC_BOOST_ENUM, 1, 0, HDA_INPUT); in ca0132_alt_add_mic_boost_enum()
6871 AE5_HEADPHONE_GAIN_ENUM, 1, 0, HDA_OUTPUT); in ae5_add_headphone_gain_enum()
6888 AE5_SOUND_FILTER_ENUM, 1, 0, HDA_OUTPUT); in ae5_add_sound_filter_enum()
6916 * I think this has to do with the pin for rear surround being 0x11,
6917 * and the center/lfe being 0x10. Usually the pin order is the opposite.
6935 int err = 0; in ca0132_alt_add_chmap_ctls()
6948 elem, hinfo->channels_max, 0, &chmap); in ca0132_alt_add_chmap_ctls()
6949 if (err < 0) in ca0132_alt_add_chmap_ctls()
6964 HDA_CODEC_VOLUME("Analog-Mic2 Capture Volume", 0x08, 0, HDA_INPUT),
6965 HDA_CODEC_MUTE("Analog-Mic2 Capture Switch", 0x08, 0, HDA_INPUT),
6966 HDA_CODEC_VOLUME("What U Hear Capture Volume", 0x0a, 0, HDA_INPUT),
6967 HDA_CODEC_MUTE("What U Hear Capture Switch", 0x0a, 0, HDA_INPUT),
6969 0x12, 1, HDA_INPUT),
6987 CA0132_ALT_CODEC_VOL("Front Playback Volume", 0x02, HDA_OUTPUT),
6989 HDA_CODEC_VOLUME("Surround Playback Volume", 0x04, 0, HDA_OUTPUT),
6990 HDA_CODEC_MUTE("Surround Playback Switch", 0x04, 0, HDA_OUTPUT),
6991 HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x03, 1, 0, HDA_OUTPUT),
6992 HDA_CODEC_MUTE_MONO("Center Playback Switch", 0x03, 1, 0, HDA_OUTPUT),
6993 HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x03, 2, 0, HDA_OUTPUT),
6994 HDA_CODEC_MUTE_MONO("LFE Playback Switch", 0x03, 2, 0, HDA_OUTPUT),
6995 CA0132_ALT_CODEC_VOL("Capture Volume", 0x07, HDA_INPUT),
6997 HDA_CODEC_VOLUME("What U Hear Capture Volume", 0x0a, 0, HDA_INPUT),
6998 HDA_CODEC_MUTE("What U Hear Capture Switch", 0x0a, 0, HDA_INPUT),
7009 CA0132_ALT_CODEC_VOL("Front Playback Volume", 0x02, HDA_OUTPUT),
7011 HDA_CODEC_VOLUME("Surround Playback Volume", 0x04, 0, HDA_OUTPUT),
7012 HDA_CODEC_MUTE("Surround Playback Switch", 0x04, 0, HDA_OUTPUT),
7013 HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x03, 1, 0, HDA_OUTPUT),
7014 HDA_CODEC_MUTE_MONO("Center Playback Switch", 0x03, 1, 0, HDA_OUTPUT),
7015 HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x03, 2, 0, HDA_OUTPUT),
7016 HDA_CODEC_MUTE_MONO("LFE Playback Switch", 0x03, 2, 0, HDA_OUTPUT),
7019 HDA_CODEC_VOLUME("What U Hear Capture Volume", 0x0a, 0, HDA_INPUT),
7020 HDA_CODEC_MUTE("What U Hear Capture Switch", 0x0a, 0, HDA_INPUT),
7030 int err = 0; in ca0132_build_controls()
7033 for (i = 0; i < spec->num_mixers; i++) { in ca0132_build_controls()
7035 if (err < 0) in ca0132_build_controls()
7040 snd_hda_set_vmaster_tlv(codec, spec->dacs[0], HDA_OUTPUT, in ca0132_build_controls()
7044 "Playback Volume", 0); in ca0132_build_controls()
7048 true, 0, &spec->vmaster_mute.sw_kctl); in ca0132_build_controls()
7049 if (err < 0) in ca0132_build_controls()
7057 for (i = 0; i < num_fx; i++) { in ca0132_build_controls()
7068 if (err < 0) in ca0132_build_controls()
7078 if (err < 0) in ca0132_build_controls()
7082 if (err < 0) in ca0132_build_controls()
7086 "Enable OutFX", 0); in ca0132_build_controls()
7087 if (err < 0) in ca0132_build_controls()
7092 if (err < 0) in ca0132_build_controls()
7096 for (i = 0; i < num_sliders; i++) { in ca0132_build_controls()
7101 if (err < 0) in ca0132_build_controls()
7108 if (err < 0) in ca0132_build_controls()
7112 "PlayEnhancement", 0); in ca0132_build_controls()
7113 if (err < 0) in ca0132_build_controls()
7118 if (err < 0) in ca0132_build_controls()
7122 if (err < 0) in ca0132_build_controls()
7132 if (err < 0) in ca0132_build_controls()
7135 if (err < 0) in ca0132_build_controls()
7138 if (err < 0) in ca0132_build_controls()
7141 if (err < 0) in ca0132_build_controls()
7144 if (err < 0) in ca0132_build_controls()
7147 if (err < 0) in ca0132_build_controls()
7150 if (err < 0) in ca0132_build_controls()
7158 if (err < 0) in ca0132_build_controls()
7167 if (err < 0) in ca0132_build_controls()
7170 if (err < 0) in ca0132_build_controls()
7175 if (err < 0) in ca0132_build_controls()
7187 if (err < 0) in ca0132_build_controls()
7193 if (err < 0) in ca0132_build_controls()
7196 if (err < 0) in ca0132_build_controls()
7203 if (err < 0) in ca0132_build_controls()
7210 return 0; in ca0132_build_controls()
7216 int err = 0; in dbpro_build_controls()
7221 if (err < 0) in dbpro_build_controls()
7227 if (err < 0) in dbpro_build_controls()
7231 return 0; in dbpro_build_controls()
7291 info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid = spec->dacs[0]; in ca0132_build_pcms()
7296 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adcs[0]; in ca0132_build_pcms()
7317 return 0; in ca0132_build_pcms()
7334 return 0; in ca0132_build_pcms()
7347 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adcs[0]; in dbpro_build_pcms()
7351 return 0; in dbpro_build_pcms()
7368 return 0; in dbpro_build_pcms()
7376 snd_hda_codec_write(codec, pin, 0, in init_output()
7381 snd_hda_codec_write(codec, dac, 0, in init_output()
7390 snd_hda_codec_write(codec, pin, 0, in init_input()
7392 AMP_IN_UNMUTE(0)); in init_input()
7395 snd_hda_codec_write(codec, adc, 0, AC_VERB_SET_AMP_GAIN_MUTE, in init_input()
7396 AMP_IN_UNMUTE(0)); in init_input()
7398 /* init to 0 dB and unmute. */ in init_input()
7399 snd_hda_codec_amp_stereo(codec, adc, HDA_INPUT, 0, in init_input()
7400 HDA_AMP_VOLMASK, 0x5a); in init_input()
7401 snd_hda_codec_amp_stereo(codec, adc, HDA_INPUT, 0, in init_input()
7402 HDA_AMP_MUTE, 0); in init_input()
7428 ca0132_set_vipsource(codec, 0); in ca0132_set_dmic()
7432 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_set_dmic()
7435 val |= 0x80; in ca0132_set_dmic()
7436 snd_hda_codec_write(codec, spec->input_pins[0], 0, in ca0132_set_dmic()
7439 if (!(spec->dmic_ctl & 0x20)) in ca0132_set_dmic()
7444 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_set_dmic()
7448 val &= 0x5f; in ca0132_set_dmic()
7449 snd_hda_codec_write(codec, spec->input_pins[0], 0, in ca0132_set_dmic()
7452 if (!(spec->dmic_ctl & 0x20)) in ca0132_set_dmic()
7453 chipio_set_control_flag(codec, CONTROL_FLAG_DMIC, 0); in ca0132_set_dmic()
7472 * Bit 2-0: MPIO select in ca0132_init_dmic()
7476 val = 0x01; in ca0132_init_dmic()
7477 snd_hda_codec_write(codec, spec->input_pins[0], 0, in ca0132_init_dmic()
7481 * Bit 2-0: Data1 MPIO select in ca0132_init_dmic()
7486 val = 0x83; in ca0132_init_dmic()
7487 snd_hda_codec_write(codec, spec->input_pins[0], 0, in ca0132_init_dmic()
7490 /* Use Ch-0 and Ch-1. Rate is 48K, mode 1. Disable DMic first. in ca0132_init_dmic()
7491 * Bit 3-0: Channel mask in ca0132_init_dmic()
7498 val = 0x33; in ca0132_init_dmic()
7500 val = 0x23; in ca0132_init_dmic()
7503 snd_hda_codec_write(codec, spec->input_pins[0], 0, in ca0132_init_dmic()
7516 chipio_8051_write_exram_no_mutex(codec, 0x1920, 0x00); in ca0132_init_analog_mic2()
7517 chipio_8051_write_exram_no_mutex(codec, 0x192d, 0x00); in ca0132_init_analog_mic2()
7530 for (i = 0; i < spec->multiout.num_dacs; i++) in ca0132_refresh_widget_caps()
7533 for (i = 0; i < spec->num_outputs; i++) in ca0132_refresh_widget_caps()
7536 for (i = 0; i < spec->num_inputs; i++) { in ca0132_refresh_widget_caps()
7551 if (status >= 0) { in ca0132_alt_free_active_dma_channels()
7552 /* AND against 0xfff to get the active channel bits. */ in ca0132_alt_free_active_dma_channels()
7553 tmp = tmp & 0xfff; in ca0132_alt_free_active_dma_channels()
7568 for (i = 0; i < DSPDMAC_DMA_CFG_CHANNEL_COUNT; i++) { in ca0132_alt_free_active_dma_channels()
7571 if (status < 0) in ca0132_alt_free_active_dma_channels()
7596 * DSP stream that uses the DMA channels. These are 0x0c, the audio output
7597 * stream, 0x03, analog mic 1, and 0x04, analog mic 2.
7601 static const unsigned int dsp_dma_stream_ids[] = { 0x0c, 0x03, 0x04 }; in ca0132_alt_start_dsp_audio_streams()
7611 for (i = 0; i < ARRAY_SIZE(dsp_dma_stream_ids); i++) { in ca0132_alt_start_dsp_audio_streams()
7616 dsp_dma_stream_ids[i], 0); in ca0132_alt_start_dsp_audio_streams()
7631 /* Make sure stream 0x0c is six channels. */ in ca0132_alt_start_dsp_audio_streams()
7632 chipio_set_stream_channels(codec, 0x0c, 6); in ca0132_alt_start_dsp_audio_streams()
7634 for (i = 0; i < ARRAY_SIZE(dsp_dma_stream_ids); i++) { in ca0132_alt_start_dsp_audio_streams()
7646 * The region of ChipIO memory from 0x190000-0x1903fc is a sort of 'audio
7649 * value. The 2-bit number value is seemingly 0 if inactive, 1 if active,
7652 * 0x0001f8c0
7656 * the region of exram memory from 0x1477-0x1575 has each byte represent an
7657 * entry within the 0x190000 range, and when a range of entries is in use, the
7658 * ending value is overwritten with 0xff.
7659 * 0x1578 in exram is a table of 0x25 entries, corresponding to the ChipIO
7660 * streamID's, where each entry is a starting 0x190000 port offset.
7661 * 0x159d in exram is the same as 0x1578, except it contains the ending port
7669 * 0x00-0x1f: HDA audio stream input/output ports.
7670 * 0x80-0xbf: Sample rate converter input/outputs. Only valid ports seem to
7671 * have the lower-nibble set to 0x1, 0x2, and 0x9.
7672 * 0xc0-0xdf: DSP DMA input/output ports. Dynamically assigned.
7673 * 0xe0-0xff: DAC/ADC audio input/output ports.
7676 * 0x03: Mic1 ADC to DSP.
7677 * 0x04: Mic2 ADC to DSP.
7678 * 0x05: HDA node 0x02 audio stream to DSP.
7679 * 0x0f: DSP Mic exit to HDA node 0x07.
7680 * 0x0c: DSP processed audio to DACs.
7681 * 0x14: DAC0, front L/R.
7695 chipio_8051_read_exram(codec, 0x1578 + remap_data->stream_id, in chipio_remap_stream()
7699 * Check if the stream's port value is 0xff, because the 8051 may not in chipio_remap_stream()
7703 if (stream_offset == 0xff) { in chipio_remap_stream()
7704 for (i = 0; i < 5; i++) { in chipio_remap_stream()
7707 chipio_8051_read_exram(codec, 0x1578 + remap_data->stream_id, in chipio_remap_stream()
7710 if (stream_offset != 0xff) in chipio_remap_stream()
7715 if (stream_offset == 0xff) { in chipio_remap_stream()
7716 codec_info(codec, "%s: Stream 0x%02x ports aren't allocated, remap failed!\n", in chipio_remap_stream()
7722 stream_offset *= 0x04; in chipio_remap_stream()
7723 stream_offset += 0x190000; in chipio_remap_stream()
7725 for (i = 0; i < remap_data->count; i++) { in chipio_remap_stream()
7732 chipio_write_no_mutex(codec, 0x19042c, 0x00000001); in chipio_remap_stream()
7740 0x394f9e38, 0x394f9e38, 0x00000000, 0x00000000, 0x00000000, 0x00000000
7745 0x00000000, 0x00000000, 0x3966afcd, 0x3966afcd, 0x3966afcd, 0x3966afcd
7750 0x00000000, 0x00000000, 0x38d1b717, 0x38d1b717, 0x38d1b717, 0x38d1b717
7779 dspio_set_uint_param(codec, 0x96, SPEAKER_TUNING_ENABLE_CENTER_EQ, tmp); in ca0132_alt_init_speaker_tuning()
7784 dspio_set_uint_param(codec, 0x96, i, tmp); in ca0132_alt_init_speaker_tuning()
7789 dspio_set_uint_param(codec, 0x96, i, tmp); in ca0132_alt_init_speaker_tuning()
7792 for (i = 0; i < 6; i++) in ca0132_alt_init_speaker_tuning()
7793 dspio_set_uint_param(codec, 0x96, in ca0132_alt_init_speaker_tuning()
7809 chipio_set_conn_rate(codec, 0x0F, SR_96_000); in ca0132_alt_init_analog_mics()
7813 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_alt_init_analog_mics()
7819 chipio_set_conn_rate(codec, 0x0F, SR_96_000); in ca0132_alt_init_analog_mics()
7821 dspio_set_uint_param(codec, 0x80, 0x01, tmp); in ca0132_alt_init_analog_mics()
7825 * Sets the source of stream 0x14 to connpointID 0x48, and the destination
7826 * connpointID to 0x91. If this isn't done, the destination is 0x71, and
7838 /* This value is 0x43 for 96khz, and 0x83 for 192khz. */ in sbz_connect_streams()
7839 chipio_write_no_mutex(codec, 0x18a020, 0x00000043); in sbz_connect_streams()
7841 /* Setup stream 0x14 with it's source and destination points */ in sbz_connect_streams()
7842 chipio_set_stream_source_dest(codec, 0x14, 0x48, 0x91); in sbz_connect_streams()
7843 chipio_set_conn_rate_no_mutex(codec, 0x48, SR_96_000); in sbz_connect_streams()
7844 chipio_set_conn_rate_no_mutex(codec, 0x91, SR_96_000); in sbz_connect_streams()
7845 chipio_set_stream_channels(codec, 0x14, 2); in sbz_connect_streams()
7846 chipio_set_stream_control(codec, 0x14, 1); in sbz_connect_streams()
7868 chipio_remap_stream(codec, &stream_remap_data[0]); in sbz_chipio_startup_data()
7897 chipio_set_stream_control(codec, 0x03, 0); in ca0132_alt_dsp_initial_mic_setup()
7898 chipio_set_stream_control(codec, 0x04, 0); in ca0132_alt_dsp_initial_mic_setup()
7904 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_alt_dsp_initial_mic_setup()
7906 chipio_set_stream_control(codec, 0x03, 1); in ca0132_alt_dsp_initial_mic_setup()
7907 chipio_set_stream_control(codec, 0x04, 1); in ca0132_alt_dsp_initial_mic_setup()
7911 chipio_write(codec, 0x18b098, 0x0000000c); in ca0132_alt_dsp_initial_mic_setup()
7912 chipio_write(codec, 0x18b09C, 0x0000000c); in ca0132_alt_dsp_initial_mic_setup()
7915 chipio_write(codec, 0x18b098, 0x0000000c); in ca0132_alt_dsp_initial_mic_setup()
7916 chipio_write(codec, 0x18b09c, 0x0000004c); in ca0132_alt_dsp_initial_mic_setup()
7927 chipio_8051_write_direct(codec, 0x93, 0x10); in ae5_post_dsp_register_set()
7928 chipio_8051_write_pll_pmu(codec, 0x44, 0xc2); in ae5_post_dsp_register_set()
7930 writeb(0xff, spec->mem_base + 0x304); in ae5_post_dsp_register_set()
7931 writeb(0xff, spec->mem_base + 0x304); in ae5_post_dsp_register_set()
7932 writeb(0xff, spec->mem_base + 0x304); in ae5_post_dsp_register_set()
7933 writeb(0xff, spec->mem_base + 0x304); in ae5_post_dsp_register_set()
7934 writeb(0x00, spec->mem_base + 0x100); in ae5_post_dsp_register_set()
7935 writeb(0xff, spec->mem_base + 0x304); in ae5_post_dsp_register_set()
7936 writeb(0x00, spec->mem_base + 0x100); in ae5_post_dsp_register_set()
7937 writeb(0xff, spec->mem_base + 0x304); in ae5_post_dsp_register_set()
7938 writeb(0x00, spec->mem_base + 0x100); in ae5_post_dsp_register_set()
7939 writeb(0xff, spec->mem_base + 0x304); in ae5_post_dsp_register_set()
7940 writeb(0x00, spec->mem_base + 0x100); in ae5_post_dsp_register_set()
7941 writeb(0xff, spec->mem_base + 0x304); in ae5_post_dsp_register_set()
7943 ca0113_mmio_command_set(codec, 0x30, 0x2b, 0x3f); in ae5_post_dsp_register_set()
7944 ca0113_mmio_command_set(codec, 0x30, 0x2d, 0x3f); in ae5_post_dsp_register_set()
7945 ca0113_mmio_command_set(codec, 0x48, 0x07, 0x83); in ae5_post_dsp_register_set()
7955 chipio_set_control_param(codec, 3, 0); in ae5_post_dsp_param_setup()
7962 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 0x724, 0x83); in ae5_post_dsp_param_setup()
7963 chipio_set_control_param(codec, CONTROL_PARAM_ASI, 0); in ae5_post_dsp_param_setup()
7965 chipio_8051_write_exram(codec, 0xfa92, 0x22); in ae5_post_dsp_param_setup()
7970 chipio_8051_write_pll_pmu(codec, 0x41, 0xc8); in ae5_post_dsp_pll_setup()
7971 chipio_8051_write_pll_pmu(codec, 0x45, 0xcc); in ae5_post_dsp_pll_setup()
7972 chipio_8051_write_pll_pmu(codec, 0x40, 0xcb); in ae5_post_dsp_pll_setup()
7973 chipio_8051_write_pll_pmu(codec, 0x43, 0xc7); in ae5_post_dsp_pll_setup()
7974 chipio_8051_write_pll_pmu(codec, 0x51, 0x8d); in ae5_post_dsp_pll_setup()
7983 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 0x725, 0x81); in ae5_post_dsp_stream_setup()
7985 chipio_set_conn_rate_no_mutex(codec, 0x70, SR_96_000); in ae5_post_dsp_stream_setup()
7987 chipio_set_stream_source_dest(codec, 0x5, 0x43, 0x0); in ae5_post_dsp_stream_setup()
7989 chipio_set_stream_source_dest(codec, 0x18, 0x9, 0xd0); in ae5_post_dsp_stream_setup()
7990 chipio_set_conn_rate_no_mutex(codec, 0xd0, SR_96_000); in ae5_post_dsp_stream_setup()
7991 chipio_set_stream_channels(codec, 0x18, 6); in ae5_post_dsp_stream_setup()
7992 chipio_set_stream_control(codec, 0x18, 1); in ae5_post_dsp_stream_setup()
7996 chipio_8051_write_pll_pmu_no_mutex(codec, 0x43, 0xc7); in ae5_post_dsp_stream_setup()
7998 ca0113_mmio_command_set(codec, 0x48, 0x01, 0x80); in ae5_post_dsp_stream_setup()
8009 chipio_write_no_mutex(codec, 0x189000, 0x0001f101); in ae5_post_dsp_startup_data()
8010 chipio_write_no_mutex(codec, 0x189004, 0x0001f101); in ae5_post_dsp_startup_data()
8011 chipio_write_no_mutex(codec, 0x189024, 0x00014004); in ae5_post_dsp_startup_data()
8012 chipio_write_no_mutex(codec, 0x189028, 0x0002000f); in ae5_post_dsp_startup_data()
8014 ca0113_mmio_command_set(codec, 0x48, 0x0a, 0x05); in ae5_post_dsp_startup_data()
8016 ca0113_mmio_command_set(codec, 0x48, 0x0b, 0x12); in ae5_post_dsp_startup_data()
8017 ca0113_mmio_command_set(codec, 0x48, 0x04, 0x00); in ae5_post_dsp_startup_data()
8018 ca0113_mmio_command_set(codec, 0x48, 0x06, 0x48); in ae5_post_dsp_startup_data()
8019 ca0113_mmio_command_set(codec, 0x48, 0x0a, 0x05); in ae5_post_dsp_startup_data()
8020 ca0113_mmio_command_set(codec, 0x48, 0x07, 0x83); in ae5_post_dsp_startup_data()
8021 ca0113_mmio_command_set(codec, 0x48, 0x0f, 0x00); in ae5_post_dsp_startup_data()
8022 ca0113_mmio_command_set(codec, 0x48, 0x10, 0x00); in ae5_post_dsp_startup_data()
8023 ca0113_mmio_gpio_set(codec, 0, true); in ae5_post_dsp_startup_data()
8025 ca0113_mmio_command_set(codec, 0x48, 0x07, 0x80); in ae5_post_dsp_startup_data()
8027 chipio_write_no_mutex(codec, 0x18b03c, 0x00000012); in ae5_post_dsp_startup_data()
8029 ca0113_mmio_command_set(codec, 0x48, 0x0f, 0x00); in ae5_post_dsp_startup_data()
8030 ca0113_mmio_command_set(codec, 0x48, 0x10, 0x00); in ae5_post_dsp_startup_data()
8044 ca0113_mmio_command_set(codec, 0x30, 0x30, 0x00); in ae7_post_dsp_setup_ports()
8045 ca0113_mmio_command_set(codec, 0x48, 0x0d, 0x40); in ae7_post_dsp_setup_ports()
8046 ca0113_mmio_command_set(codec, 0x48, 0x17, 0x00); in ae7_post_dsp_setup_ports()
8047 ca0113_mmio_command_set(codec, 0x48, 0x19, 0x00); in ae7_post_dsp_setup_ports()
8048 ca0113_mmio_command_set(codec, 0x48, 0x11, 0xff); in ae7_post_dsp_setup_ports()
8049 ca0113_mmio_command_set(codec, 0x48, 0x12, 0xff); in ae7_post_dsp_setup_ports()
8050 ca0113_mmio_command_set(codec, 0x48, 0x13, 0xff); in ae7_post_dsp_setup_ports()
8051 ca0113_mmio_command_set(codec, 0x48, 0x14, 0x7f); in ae7_post_dsp_setup_ports()
8062 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 0x725, 0x81); in ae7_post_dsp_asi_stream_setup()
8063 ca0113_mmio_command_set(codec, 0x30, 0x2b, 0x00); in ae7_post_dsp_asi_stream_setup()
8065 chipio_set_conn_rate_no_mutex(codec, 0x70, SR_96_000); in ae7_post_dsp_asi_stream_setup()
8067 chipio_set_stream_source_dest(codec, 0x05, 0x43, 0x00); in ae7_post_dsp_asi_stream_setup()
8068 chipio_set_stream_source_dest(codec, 0x18, 0x09, 0xd0); in ae7_post_dsp_asi_stream_setup()
8070 chipio_set_conn_rate_no_mutex(codec, 0xd0, SR_96_000); in ae7_post_dsp_asi_stream_setup()
8071 chipio_set_stream_channels(codec, 0x18, 6); in ae7_post_dsp_asi_stream_setup()
8072 chipio_set_stream_control(codec, 0x18, 1); in ae7_post_dsp_asi_stream_setup()
8082 0x41, 0x45, 0x40, 0x43, 0x51 in ae7_post_dsp_pll_setup()
8085 0xc8, 0xcc, 0xcb, 0xc7, 0x8d in ae7_post_dsp_pll_setup()
8089 for (i = 0; i < ARRAY_SIZE(addr); i++) in ae7_post_dsp_pll_setup()
8097 0x0b, 0x04, 0x06, 0x0a, 0x0c, 0x11, 0x12, 0x13, 0x14 in ae7_post_dsp_asi_setup_ports()
8100 0x12, 0x00, 0x48, 0x05, 0x5f, 0xff, 0xff, 0xff, 0x7f in ae7_post_dsp_asi_setup_ports()
8106 chipio_8051_write_pll_pmu_no_mutex(codec, 0x43, 0xc7); in ae7_post_dsp_asi_setup_ports()
8108 chipio_write_no_mutex(codec, 0x189000, 0x0001f101); in ae7_post_dsp_asi_setup_ports()
8109 chipio_write_no_mutex(codec, 0x189004, 0x0001f101); in ae7_post_dsp_asi_setup_ports()
8110 chipio_write_no_mutex(codec, 0x189024, 0x00014004); in ae7_post_dsp_asi_setup_ports()
8111 chipio_write_no_mutex(codec, 0x189028, 0x0002000f); in ae7_post_dsp_asi_setup_ports()
8116 for (i = 0; i < ARRAY_SIZE(target); i++) in ae7_post_dsp_asi_setup_ports()
8117 ca0113_mmio_command_set(codec, 0x48, target[i], data[i]); in ae7_post_dsp_asi_setup_ports()
8119 ca0113_mmio_command_set_type2(codec, 0x48, 0x07, 0x83); in ae7_post_dsp_asi_setup_ports()
8120 ca0113_mmio_command_set(codec, 0x48, 0x0f, 0x00); in ae7_post_dsp_asi_setup_ports()
8121 ca0113_mmio_command_set(codec, 0x48, 0x10, 0x00); in ae7_post_dsp_asi_setup_ports()
8123 chipio_set_stream_source_dest(codec, 0x21, 0x64, 0x56); in ae7_post_dsp_asi_setup_ports()
8124 chipio_set_stream_channels(codec, 0x21, 2); in ae7_post_dsp_asi_setup_ports()
8125 chipio_set_conn_rate_no_mutex(codec, 0x56, SR_8_000); in ae7_post_dsp_asi_setup_ports()
8127 chipio_set_control_param_no_mutex(codec, CONTROL_PARAM_NODE_ID, 0x09); in ae7_post_dsp_asi_setup_ports()
8133 chipio_set_control_param_no_mutex(codec, 0x20, 0x21); in ae7_post_dsp_asi_setup_ports()
8135 chipio_write_no_mutex(codec, 0x18b038, 0x00000088); in ae7_post_dsp_asi_setup_ports()
8139 * seemingly sends data to the HDA node 0x09, which is the digital in ae7_post_dsp_asi_setup_ports()
8146 ca0113_mmio_gpio_set(codec, 0, 1); in ae7_post_dsp_asi_setup_ports()
8149 ca0113_mmio_command_set_type2(codec, 0x48, 0x07, 0x83); in ae7_post_dsp_asi_setup_ports()
8150 chipio_write_no_mutex(codec, 0x18b03c, 0x00000000); in ae7_post_dsp_asi_setup_ports()
8151 ca0113_mmio_command_set(codec, 0x48, 0x0f, 0x00); in ae7_post_dsp_asi_setup_ports()
8152 ca0113_mmio_command_set(codec, 0x48, 0x10, 0x00); in ae7_post_dsp_asi_setup_ports()
8154 chipio_set_stream_source_dest(codec, 0x05, 0x43, 0x00); in ae7_post_dsp_asi_setup_ports()
8155 chipio_set_stream_source_dest(codec, 0x18, 0x09, 0xd0); in ae7_post_dsp_asi_setup_ports()
8157 chipio_set_conn_rate_no_mutex(codec, 0xd0, SR_96_000); in ae7_post_dsp_asi_setup_ports()
8158 chipio_set_stream_channels(codec, 0x18, 6); in ae7_post_dsp_asi_setup_ports()
8177 chipio_8051_write_direct(codec, 0x93, 0x10); in ae7_post_dsp_asi_setup()
8179 chipio_8051_write_pll_pmu(codec, 0x44, 0xc2); in ae7_post_dsp_asi_setup()
8181 ca0113_mmio_command_set_type2(codec, 0x48, 0x07, 0x83); in ae7_post_dsp_asi_setup()
8182 ca0113_mmio_command_set(codec, 0x30, 0x2e, 0x3f); in ae7_post_dsp_asi_setup()
8187 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 0x724, 0x83); in ae7_post_dsp_asi_setup()
8188 chipio_set_control_param(codec, CONTROL_PARAM_ASI, 0); in ae7_post_dsp_asi_setup()
8189 snd_hda_codec_write(codec, 0x17, 0, 0x794, 0x00); in ae7_post_dsp_asi_setup()
8191 chipio_8051_write_exram(codec, 0xfa92, 0x22); in ae7_post_dsp_asi_setup()
8196 chipio_8051_write_pll_pmu(codec, 0x43, 0xc7); in ae7_post_dsp_asi_setup()
8216 for (idx = 0; idx < num_fx; idx++) { in ca0132_setup_defaults()
8217 for (i = 0; i <= ca0132_effects[idx].params; i++) { in ca0132_setup_defaults()
8226 dspio_set_uint_param(codec, 0x96, 0x3C, tmp); in ca0132_setup_defaults()
8229 dspio_set_uint_param(codec, 0x8f, 0x01, tmp); in ca0132_setup_defaults()
8233 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_setup_defaults()
8234 dspio_set_uint_param(codec, 0x80, 0x01, tmp); in ca0132_setup_defaults()
8238 dspio_set_uint_param(codec, 0x80, 0x05, tmp); in ca0132_setup_defaults()
8242 dspio_set_uint_param(codec, 0x31, 0x00, tmp); in ca0132_setup_defaults()
8264 dspio_set_uint_param(codec, 0x96, 0x3C, tmp); in r3d_setup_defaults()
8268 dspio_set_uint_param(codec, 0x31, 0x00, tmp); in r3d_setup_defaults()
8272 dspio_set_uint_param(codec, 0x32, 0x00, tmp); in r3d_setup_defaults()
8285 for (idx = 0; idx < num_fx; idx++) { in r3d_setup_defaults()
8286 for (i = 0; i <= ca0132_effects[idx].params; i++) { in r3d_setup_defaults()
8319 dspio_set_uint_param(codec, 0x37, 0x08, tmp); in sbz_setup_defaults()
8320 dspio_set_uint_param(codec, 0x37, 0x10, tmp); in sbz_setup_defaults()
8324 dspio_set_uint_param(codec, 0x96, 0x3C, tmp); in sbz_setup_defaults()
8328 dspio_set_uint_param(codec, 0x31, 0x00, tmp); in sbz_setup_defaults()
8332 dspio_set_uint_param(codec, 0x32, 0x00, tmp); in sbz_setup_defaults()
8338 for (idx = 0; idx < num_fx; idx++) { in sbz_setup_defaults()
8339 for (i = 0; i <= ca0132_effects[idx].params; i++) { in sbz_setup_defaults()
8368 dspio_set_uint_param(codec, 0x96, 0x29, tmp); in ae5_setup_defaults()
8369 dspio_set_uint_param(codec, 0x96, 0x2a, tmp); in ae5_setup_defaults()
8370 dspio_set_uint_param(codec, 0x80, 0x0d, tmp); in ae5_setup_defaults()
8371 dspio_set_uint_param(codec, 0x80, 0x0e, tmp); in ae5_setup_defaults()
8373 ca0113_mmio_command_set(codec, 0x30, 0x2e, 0x3f); in ae5_setup_defaults()
8374 ca0113_mmio_gpio_set(codec, 0, false); in ae5_setup_defaults()
8375 ca0113_mmio_command_set(codec, 0x30, 0x28, 0x00); in ae5_setup_defaults()
8379 dspio_set_uint_param(codec, 0x37, 0x08, tmp); in ae5_setup_defaults()
8380 dspio_set_uint_param(codec, 0x37, 0x10, tmp); in ae5_setup_defaults()
8384 dspio_set_uint_param(codec, 0x96, 0x3C, tmp); in ae5_setup_defaults()
8388 dspio_set_uint_param(codec, 0x31, 0x00, tmp); in ae5_setup_defaults()
8392 dspio_set_uint_param(codec, 0x32, 0x00, tmp); in ae5_setup_defaults()
8403 for (idx = 0; idx < num_fx; idx++) { in ae5_setup_defaults()
8404 for (i = 0; i <= ca0132_effects[idx].params; i++) { in ae5_setup_defaults()
8433 dspio_set_uint_param(codec, 0x96, in ae7_setup_defaults()
8435 dspio_set_uint_param(codec, 0x96, in ae7_setup_defaults()
8438 ca0113_mmio_command_set(codec, 0x30, 0x2e, 0x3f); in ae7_setup_defaults()
8441 dspio_set_uint_param(codec, 0x80, 0x0d, tmp); in ae7_setup_defaults()
8442 dspio_set_uint_param(codec, 0x80, 0x0e, tmp); in ae7_setup_defaults()
8444 ca0113_mmio_gpio_set(codec, 0, false); in ae7_setup_defaults()
8448 dspio_set_uint_param(codec, 0x37, 0x08, tmp); in ae7_setup_defaults()
8449 dspio_set_uint_param(codec, 0x37, 0x10, tmp); in ae7_setup_defaults()
8453 dspio_set_uint_param(codec, 0x96, 0x3C, tmp); in ae7_setup_defaults()
8457 dspio_set_uint_param(codec, 0x31, 0x00, tmp); in ae7_setup_defaults()
8461 dspio_set_uint_param(codec, 0x32, 0x00, tmp); in ae7_setup_defaults()
8462 ca0113_mmio_command_set(codec, 0x30, 0x28, 0x00); in ae7_setup_defaults()
8473 * Not sure why, but these are both set to 1. They're only set to 0 in ae7_setup_defaults()
8476 ca0113_mmio_gpio_set(codec, 0, true); in ae7_setup_defaults()
8480 ca0113_mmio_command_set(codec, 0x48, 0x0f, 0x04); in ae7_setup_defaults()
8481 ca0113_mmio_command_set(codec, 0x48, 0x10, 0x04); in ae7_setup_defaults()
8482 ca0113_mmio_command_set_type2(codec, 0x48, 0x07, 0x80); in ae7_setup_defaults()
8486 for (idx = 0; idx < num_fx; idx++) { in ae7_setup_defaults()
8487 for (i = 0; i <= ca0132_effects[idx].params; i++) { in ae7_setup_defaults()
8511 chipio_set_control_flag(codec, CONTROL_FLAG_IDLE_ENABLE, 0); in ca0132_init_flags()
8512 chipio_set_control_flag(codec, CONTROL_FLAG_SPDIF2OUT, 0); in ca0132_init_flags()
8514 CONTROL_FLAG_PORT_D_10KOHM_LOAD, 0); in ca0132_init_flags()
8518 chipio_set_control_flag(codec, CONTROL_FLAG_IDLE_ENABLE, 0); in ca0132_init_flags()
8520 CONTROL_FLAG_PORT_A_COMMON_MODE, 0); in ca0132_init_flags()
8522 CONTROL_FLAG_PORT_D_COMMON_MODE, 0); in ca0132_init_flags()
8524 CONTROL_FLAG_PORT_A_10KOHM_LOAD, 0); in ca0132_init_flags()
8526 CONTROL_FLAG_PORT_D_10KOHM_LOAD, 0); in ca0132_init_flags()
8540 chipio_set_conn_rate(codec, 0x0B, SR_48_000); in ca0132_init_params()
8541 chipio_set_control_param(codec, CONTROL_PARAM_SPDIF1_SOURCE, 0); in ca0132_init_params()
8542 chipio_set_control_param(codec, 0, 0); in ca0132_init_params()
8543 chipio_set_control_param(codec, CONTROL_PARAM_VIP_SOURCE, 0); in ca0132_init_params()
8580 codec->card->dev) != 0) in ca0132_download_dsp_images()
8587 codec->card->dev) != 0) in ca0132_download_dsp_images()
8602 codec->card->dev) != 0) in ca0132_download_dsp_images()
8607 if (dspload_image(codec, dsp_os_image, 0, 0, true, 0)) { in ca0132_download_dsp_images()
8654 if (dspio_get_response_data(codec) >= 0) in ca0132_process_dsp_response()
8655 spec->wait_scp = 0; in ca0132_process_dsp_response()
8707 {0x15, VENDOR_CHIPIO_CT_EXTENSIONS_ENABLE, 0x1},
8714 {0x01, AC_VERB_SET_POWER_STATE, 0x03},
8716 {0x15, VENDOR_CHIPIO_CT_EXTENSIONS_ENABLE, 0},
8724 {0x15, 0x70D, 0xF0},
8725 {0x15, 0x70E, 0xFE},
8726 {0x15, 0x707, 0x75},
8727 {0x15, 0x707, 0xD3},
8728 {0x15, 0x707, 0x09},
8729 {0x15, 0x707, 0x53},
8730 {0x15, 0x707, 0xD4},
8731 {0x15, 0x707, 0xEF},
8732 {0x15, 0x707, 0x75},
8733 {0x15, 0x707, 0xD3},
8734 {0x15, 0x707, 0x09},
8735 {0x15, 0x707, 0x02},
8736 {0x15, 0x707, 0x37},
8737 {0x15, 0x707, 0x78},
8738 {0x15, 0x53C, 0xCE},
8739 {0x15, 0x575, 0xC9},
8740 {0x15, 0x53D, 0xCE},
8741 {0x15, 0x5B7, 0xC9},
8742 {0x15, 0x70D, 0xE8},
8743 {0x15, 0x70E, 0xFE},
8744 {0x15, 0x707, 0x02},
8745 {0x15, 0x707, 0x68},
8746 {0x15, 0x707, 0x62},
8747 {0x15, 0x53A, 0xCE},
8748 {0x15, 0x546, 0xC9},
8749 {0x15, 0x53B, 0xCE},
8750 {0x15, 0x5E8, 0xC9},
8756 {0x15, 0x70D, 0x20},
8757 {0x15, 0x70E, 0x19},
8758 {0x15, 0x707, 0x00},
8759 {0x15, 0x539, 0xCE},
8760 {0x15, 0x546, 0xC9},
8761 {0x15, 0x70D, 0xB7},
8762 {0x15, 0x70E, 0x09},
8763 {0x15, 0x707, 0x10},
8764 {0x15, 0x70D, 0xAF},
8765 {0x15, 0x70E, 0x09},
8766 {0x15, 0x707, 0x01},
8767 {0x15, 0x707, 0x05},
8768 {0x15, 0x70D, 0x73},
8769 {0x15, 0x70E, 0x09},
8770 {0x15, 0x707, 0x14},
8771 {0x15, 0x6FF, 0xC4},
8791 chipio_set_control_flag(codec, CONTROL_FLAG_IDLE_ENABLE, 0); in ca0132_init_chip()
8792 chipio_write_no_mutex(codec, 0x18b0a4, 0x000000c2); in ca0132_init_chip()
8794 snd_hda_codec_write(codec, codec->core.afg, 0, in ca0132_init_chip()
8795 AC_VERB_SET_CODEC_RESET, 0); in ca0132_init_chip()
8796 snd_hda_codec_write(codec, codec->core.afg, 0, in ca0132_init_chip()
8797 AC_VERB_SET_CODEC_RESET, 0); in ca0132_init_chip()
8806 spec->cur_mic_boost = 0; in ca0132_init_chip()
8808 for (i = 0; i < VNODES_COUNT; i++) { in ca0132_init_chip()
8809 spec->vnode_lvol[i] = 0x5a; in ca0132_init_chip()
8810 spec->vnode_rvol[i] = 0x5a; in ca0132_init_chip()
8811 spec->vnode_lswitch[i] = 0; in ca0132_init_chip()
8812 spec->vnode_rswitch[i] = 0; in ca0132_init_chip()
8819 for (i = 0; i < num_fx; i++) { in ca0132_init_chip()
8820 on = (unsigned int)ca0132_effects[i].reqs[0]; in ca0132_init_chip()
8821 spec->effects_switch[i] = on ? 1 : 0; in ca0132_init_chip()
8829 spec->speaker_range_val[0] = 1; in ca0132_init_chip()
8833 for (i = 0; i < EFFECT_LEVEL_SLIDERS; i++) in ca0132_init_chip()
8839 spec->voicefx_val = 0; in ca0132_init_chip()
8841 spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID] = 0; in ca0132_init_chip()
8862 snd_hda_codec_write(codec, 0x01, 0, AC_VERB_SET_GPIO_DATA, 0x00); in r3di_gpio_shutdown()
8873 for (i = 0; i < 4; i++) in sbz_region2_exit()
8874 writeb(0x0, spec->mem_base + 0x100); in sbz_region2_exit()
8875 for (i = 0; i < 8; i++) in sbz_region2_exit()
8876 writeb(0xb3, spec->mem_base + 0x304); in sbz_region2_exit()
8878 ca0113_mmio_gpio_set(codec, 0, false); in sbz_region2_exit()
8887 static const hda_nid_t pins[] = {0x0B, 0x0C, 0x0E, 0x12, 0x13}; in sbz_set_pin_ctl_default()
8890 snd_hda_codec_write(codec, 0x11, 0, in sbz_set_pin_ctl_default()
8891 AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40); in sbz_set_pin_ctl_default()
8893 for (i = 0; i < ARRAY_SIZE(pins); i++) in sbz_set_pin_ctl_default()
8894 snd_hda_codec_write(codec, pins[i], 0, in sbz_set_pin_ctl_default()
8895 AC_VERB_SET_PIN_WIDGET_CONTROL, 0x00); in sbz_set_pin_ctl_default()
8900 static const hda_nid_t pins[] = {0x0B, 0x0E, 0x0F, 0x10, 0x11, 0x12, 0x13}; in ca0132_clear_unsolicited()
8903 for (i = 0; i < ARRAY_SIZE(pins); i++) { in ca0132_clear_unsolicited()
8904 snd_hda_codec_write(codec, pins[i], 0, in ca0132_clear_unsolicited()
8905 AC_VERB_SET_UNSOLICITED_ENABLE, 0x00); in ca0132_clear_unsolicited()
8913 if (dir >= 0) in sbz_gpio_shutdown_commands()
8914 snd_hda_codec_write(codec, 0x01, 0, in sbz_gpio_shutdown_commands()
8916 if (mask >= 0) in sbz_gpio_shutdown_commands()
8917 snd_hda_codec_write(codec, 0x01, 0, in sbz_gpio_shutdown_commands()
8920 if (data >= 0) in sbz_gpio_shutdown_commands()
8921 snd_hda_codec_write(codec, 0x01, 0, in sbz_gpio_shutdown_commands()
8927 static const hda_nid_t pins[] = {0x05, 0x0c, 0x09, 0x0e, 0x08, 0x11, 0x01}; in zxr_dbpro_power_state_shutdown()
8930 for (i = 0; i < ARRAY_SIZE(pins); i++) in zxr_dbpro_power_state_shutdown()
8931 snd_hda_codec_write(codec, pins[i], 0, in zxr_dbpro_power_state_shutdown()
8932 AC_VERB_SET_POWER_STATE, 0x03); in zxr_dbpro_power_state_shutdown()
8937 chipio_set_stream_control(codec, 0x03, 0); in sbz_exit_chip()
8938 chipio_set_stream_control(codec, 0x04, 0); in sbz_exit_chip()
8941 sbz_gpio_shutdown_commands(codec, 0x07, 0x07, -1); in sbz_exit_chip()
8942 sbz_gpio_shutdown_commands(codec, 0x07, 0x07, 0x05); in sbz_exit_chip()
8943 sbz_gpio_shutdown_commands(codec, 0x07, 0x07, 0x01); in sbz_exit_chip()
8945 chipio_set_stream_control(codec, 0x14, 0); in sbz_exit_chip()
8946 chipio_set_stream_control(codec, 0x0C, 0); in sbz_exit_chip()
8948 chipio_set_conn_rate(codec, 0x41, SR_192_000); in sbz_exit_chip()
8949 chipio_set_conn_rate(codec, 0x91, SR_192_000); in sbz_exit_chip()
8951 chipio_write(codec, 0x18a020, 0x00000083); in sbz_exit_chip()
8953 sbz_gpio_shutdown_commands(codec, 0x07, 0x07, 0x03); in sbz_exit_chip()
8954 sbz_gpio_shutdown_commands(codec, 0x07, 0x07, 0x07); in sbz_exit_chip()
8955 sbz_gpio_shutdown_commands(codec, 0x07, 0x07, 0x06); in sbz_exit_chip()
8957 chipio_set_stream_control(codec, 0x0C, 0); in sbz_exit_chip()
8959 chipio_set_control_param(codec, 0x0D, 0x24); in sbz_exit_chip()
8964 snd_hda_codec_write(codec, 0x0B, 0, in sbz_exit_chip()
8965 AC_VERB_SET_EAPD_BTLENABLE, 0x00); in sbz_exit_chip()
8973 snd_hda_codec_write(codec, 0x01, 0, 0x793, 0x00); in r3d_exit_chip()
8974 snd_hda_codec_write(codec, 0x01, 0, 0x794, 0x5b); in r3d_exit_chip()
8979 chipio_set_stream_control(codec, 0x03, 0); in ae5_exit_chip()
8980 chipio_set_stream_control(codec, 0x04, 0); in ae5_exit_chip()
8982 ca0113_mmio_command_set(codec, 0x30, 0x32, 0x3f); in ae5_exit_chip()
8983 ca0113_mmio_command_set(codec, 0x48, 0x07, 0x83); in ae5_exit_chip()
8984 ca0113_mmio_command_set(codec, 0x48, 0x07, 0x83); in ae5_exit_chip()
8985 ca0113_mmio_command_set(codec, 0x30, 0x30, 0x00); in ae5_exit_chip()
8986 ca0113_mmio_command_set(codec, 0x30, 0x2b, 0x00); in ae5_exit_chip()
8987 ca0113_mmio_command_set(codec, 0x30, 0x2d, 0x00); in ae5_exit_chip()
8988 ca0113_mmio_gpio_set(codec, 0, false); in ae5_exit_chip()
8991 snd_hda_codec_write(codec, 0x01, 0, 0x793, 0x00); in ae5_exit_chip()
8992 snd_hda_codec_write(codec, 0x01, 0, 0x794, 0x53); in ae5_exit_chip()
8994 chipio_set_control_param(codec, CONTROL_PARAM_ASI, 0); in ae5_exit_chip()
8996 chipio_set_stream_control(codec, 0x18, 0); in ae5_exit_chip()
8997 chipio_set_stream_control(codec, 0x0c, 0); in ae5_exit_chip()
8999 snd_hda_codec_write(codec, 0x01, 0, 0x724, 0x83); in ae5_exit_chip()
9004 chipio_set_stream_control(codec, 0x18, 0); in ae7_exit_chip()
9005 chipio_set_stream_source_dest(codec, 0x21, 0xc8, 0xc8); in ae7_exit_chip()
9006 chipio_set_stream_channels(codec, 0x21, 0); in ae7_exit_chip()
9007 chipio_set_control_param(codec, CONTROL_PARAM_NODE_ID, 0x09); in ae7_exit_chip()
9008 chipio_set_control_param(codec, 0x20, 0x01); in ae7_exit_chip()
9010 chipio_set_control_param(codec, CONTROL_PARAM_ASI, 0); in ae7_exit_chip()
9012 chipio_set_stream_control(codec, 0x18, 0); in ae7_exit_chip()
9013 chipio_set_stream_control(codec, 0x0c, 0); in ae7_exit_chip()
9015 ca0113_mmio_command_set(codec, 0x30, 0x2b, 0x00); in ae7_exit_chip()
9016 snd_hda_codec_write(codec, 0x15, 0, 0x724, 0x83); in ae7_exit_chip()
9017 ca0113_mmio_command_set_type2(codec, 0x48, 0x07, 0x83); in ae7_exit_chip()
9018 ca0113_mmio_command_set(codec, 0x30, 0x30, 0x00); in ae7_exit_chip()
9019 ca0113_mmio_command_set(codec, 0x30, 0x2e, 0x00); in ae7_exit_chip()
9020 ca0113_mmio_gpio_set(codec, 0, false); in ae7_exit_chip()
9022 ca0113_mmio_command_set(codec, 0x30, 0x32, 0x3f); in ae7_exit_chip()
9024 snd_hda_codec_write(codec, 0x01, 0, 0x793, 0x00); in ae7_exit_chip()
9025 snd_hda_codec_write(codec, 0x01, 0, 0x794, 0x53); in ae7_exit_chip()
9030 chipio_set_stream_control(codec, 0x03, 0); in zxr_exit_chip()
9031 chipio_set_stream_control(codec, 0x04, 0); in zxr_exit_chip()
9032 chipio_set_stream_control(codec, 0x14, 0); in zxr_exit_chip()
9033 chipio_set_stream_control(codec, 0x0C, 0); in zxr_exit_chip()
9035 chipio_set_conn_rate(codec, 0x41, SR_192_000); in zxr_exit_chip()
9036 chipio_set_conn_rate(codec, 0x91, SR_192_000); in zxr_exit_chip()
9038 chipio_write(codec, 0x18a020, 0x00000083); in zxr_exit_chip()
9040 snd_hda_codec_write(codec, 0x01, 0, 0x793, 0x00); in zxr_exit_chip()
9041 snd_hda_codec_write(codec, 0x01, 0, 0x794, 0x53); in zxr_exit_chip()
9045 snd_hda_codec_write(codec, 0x0B, 0, AC_VERB_SET_EAPD_BTLENABLE, 0x00); in zxr_exit_chip()
9050 ca0113_mmio_gpio_set(codec, 0, false); in zxr_exit_chip()
9052 ca0113_mmio_gpio_set(codec, 0, true); in zxr_exit_chip()
9078 unsigned int cur_address = 0x390; in sbz_dsp_startup_check()
9080 unsigned int failure = 0; in sbz_dsp_startup_check()
9088 for (i = 0; i < 4; i++) { in sbz_dsp_startup_check()
9090 cur_address += 0x4; in sbz_dsp_startup_check()
9092 for (i = 0; i < 4; i++) { in sbz_dsp_startup_check()
9093 if (dsp_data_check[i] == 0xa1a2a3a4) in sbz_dsp_startup_check()
9105 while (failure && (reload != 0)) { in sbz_dsp_startup_check()
9110 failure = 0; in sbz_dsp_startup_check()
9111 for (i = 0; i < 4; i++) { in sbz_dsp_startup_check()
9113 cur_address += 0x4; in sbz_dsp_startup_check()
9115 for (i = 0; i < 4; i++) { in sbz_dsp_startup_check()
9116 if (dsp_data_check[i] == 0xa1a2a3a4) in sbz_dsp_startup_check()
9132 * This is for the extra volume verbs 0x797 (left) and 0x798 (right). These add
9137 * to 0 just incase a value has lingered from a boot into Windows.
9141 snd_hda_codec_write(codec, 0x02, 0, 0x797, 0x00); in ca0132_alt_vol_setup()
9142 snd_hda_codec_write(codec, 0x02, 0, 0x798, 0x00); in ca0132_alt_vol_setup()
9143 snd_hda_codec_write(codec, 0x03, 0, 0x797, 0x00); in ca0132_alt_vol_setup()
9144 snd_hda_codec_write(codec, 0x03, 0, 0x798, 0x00); in ca0132_alt_vol_setup()
9145 snd_hda_codec_write(codec, 0x04, 0, 0x797, 0x00); in ca0132_alt_vol_setup()
9146 snd_hda_codec_write(codec, 0x04, 0, 0x798, 0x00); in ca0132_alt_vol_setup()
9147 snd_hda_codec_write(codec, 0x07, 0, 0x797, 0x00); in ca0132_alt_vol_setup()
9148 snd_hda_codec_write(codec, 0x07, 0, 0x798, 0x00); in ca0132_alt_vol_setup()
9158 writel(0x00820680, spec->mem_base + 0x01C); in sbz_pre_dsp_setup()
9159 writel(0x00820680, spec->mem_base + 0x01C); in sbz_pre_dsp_setup()
9161 chipio_write(codec, 0x18b0a4, 0x000000c2); in sbz_pre_dsp_setup()
9163 snd_hda_codec_write(codec, 0x11, 0, in sbz_pre_dsp_setup()
9164 AC_VERB_SET_PIN_WIDGET_CONTROL, 0x44); in sbz_pre_dsp_setup()
9169 chipio_write(codec, 0x18b0a4, 0x000000c2); in r3d_pre_dsp_setup()
9171 chipio_8051_write_exram(codec, 0x1c1e, 0x5b); in r3d_pre_dsp_setup()
9173 snd_hda_codec_write(codec, 0x11, 0, in r3d_pre_dsp_setup()
9174 AC_VERB_SET_PIN_WIDGET_CONTROL, 0x44); in r3d_pre_dsp_setup()
9179 chipio_write(codec, 0x18b0a4, 0x000000c2); in r3di_pre_dsp_setup()
9181 chipio_8051_write_exram(codec, 0x1c1e, 0x5b); in r3di_pre_dsp_setup()
9182 chipio_8051_write_exram(codec, 0x1920, 0x00); in r3di_pre_dsp_setup()
9183 chipio_8051_write_exram(codec, 0x1921, 0x40); in r3di_pre_dsp_setup()
9185 snd_hda_codec_write(codec, 0x11, 0, in r3di_pre_dsp_setup()
9186 AC_VERB_SET_PIN_WIDGET_CONTROL, 0x04); in r3di_pre_dsp_setup()
9196 static const unsigned int addr[] = { 0x43, 0x40, 0x41, 0x42, 0x45 }; in zxr_pre_dsp_setup()
9197 static const unsigned int data[] = { 0x08, 0x0c, 0x0b, 0x07, 0x0d }; in zxr_pre_dsp_setup()
9200 chipio_write(codec, 0x189000, 0x0001f100); in zxr_pre_dsp_setup()
9202 chipio_write(codec, 0x18900c, 0x0001f100); in zxr_pre_dsp_setup()
9207 * 0xfa92 in exram. This function seems to have something to do with in zxr_pre_dsp_setup()
9211 chipio_8051_write_exram(codec, 0xfa92, 0x22); in zxr_pre_dsp_setup()
9213 chipio_8051_write_pll_pmu(codec, 0x51, 0x98); in zxr_pre_dsp_setup()
9215 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 0x725, 0x82); in zxr_pre_dsp_setup()
9218 chipio_write(codec, 0x18902c, 0x00000000); in zxr_pre_dsp_setup()
9220 chipio_write(codec, 0x18902c, 0x00000003); in zxr_pre_dsp_setup()
9223 for (i = 0; i < ARRAY_SIZE(addr); i++) in zxr_pre_dsp_setup()
9233 0x400, 0x408, 0x40c, 0x01c, 0xc0c, 0xc00, 0xc04, 0xc0c, 0xc0c, 0xc0c,
9234 0xc0c, 0xc08, 0xc08, 0xc08, 0xc08, 0xc08, 0xc04
9238 0x00000030, 0x00000000, 0x00000003, 0x00000003, 0x00000003,
9239 0x00000003, 0x000000c1, 0x000000f1, 0x00000001, 0x000000c7,
9240 0x000000c1, 0x00000080
9244 0x00000030, 0x00000000, 0x00000000, 0x00000003, 0x00000003,
9245 0x00000003, 0x00000001, 0x000000f1, 0x00000001, 0x000000c7,
9246 0x000000c1, 0x00000080
9250 0x400, 0x42c, 0x46c, 0x4ac, 0x4ec, 0x43c, 0x47c, 0x4bc, 0x4fc, 0x408,
9251 0x100, 0x410, 0x40c, 0x100, 0x100, 0x830, 0x86c, 0x800, 0x86c, 0x800,
9252 0x804, 0x20c, 0x01c, 0xc0c, 0xc00, 0xc04, 0xc0c, 0xc0c, 0xc0c, 0xc0c,
9253 0xc08, 0xc08, 0xc08, 0xc08, 0xc08, 0xc04, 0x01c
9257 0x00000001, 0x00000000, 0x00000000, 0x00000000, 0x00000000,
9258 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000001,
9259 0x00000600, 0x00000014, 0x00000001, 0x0000060f, 0x0000070f,
9260 0x00000aff, 0x00000000, 0x0000006b, 0x00000001, 0x0000006b,
9261 0x00000057, 0x00800000, 0x00880680, 0x00000080, 0x00000030,
9262 0x00000000, 0x00000000, 0x00000003, 0x00000003, 0x00000003,
9263 0x00000001, 0x000000f1, 0x00000001, 0x000000c7, 0x000000c1,
9264 0x00000080, 0x00880680
9274 for (i = 0; i < 3; i++) in ca0132_mmio_init_sbz()
9275 writel(0x00000000, spec->mem_base + addr[i]); in ca0132_mmio_init_sbz()
9280 tmp[0] = 0x00880480; in ca0132_mmio_init_sbz()
9281 tmp[1] = 0x00000080; in ca0132_mmio_init_sbz()
9284 tmp[0] = 0x00820680; in ca0132_mmio_init_sbz()
9285 tmp[1] = 0x00000083; in ca0132_mmio_init_sbz()
9288 tmp[0] = 0x00880680; in ca0132_mmio_init_sbz()
9289 tmp[1] = 0x00000083; in ca0132_mmio_init_sbz()
9292 tmp[0] = 0x00000000; in ca0132_mmio_init_sbz()
9293 tmp[1] = 0x00000000; in ca0132_mmio_init_sbz()
9297 for (i = 0; i < 2; i++) in ca0132_mmio_init_sbz()
9313 for (i = 0; i < count; i++) in ca0132_mmio_init_sbz()
9328 writel(0x00000680, spec->mem_base + 0x1c); in ca0132_mmio_init_ae5()
9329 writel(0x00880680, spec->mem_base + 0x1c); in ca0132_mmio_init_ae5()
9332 for (i = 0; i < count; i++) { in ca0132_mmio_init_ae5()
9335 * a different value to 0x20c. in ca0132_mmio_init_ae5()
9338 writel(0x00800001, spec->mem_base + addr[i]); in ca0132_mmio_init_ae5()
9346 writel(0x00880680, spec->mem_base + 0x1c); in ca0132_mmio_init_ae5()
9368 0x304, 0x304, 0x304, 0x304, 0x100, 0x304, 0x100, 0x304, 0x100, 0x304,
9369 0x100, 0x304, 0x86c, 0x800, 0x86c, 0x800, 0x804
9373 0x0f, 0x0e, 0x1f, 0x0c, 0x3f, 0x08, 0x7f, 0x00, 0xff, 0x00, 0x6b,
9374 0x01, 0x6b, 0x57
9379 * eventually resets the codec with the 0x7ff verb. Not quite sure why it does
9392 chipio_8051_write_pll_pmu(codec, 0x41, 0xc8); in ae5_register_set()
9394 chipio_8051_write_direct(codec, 0x93, 0x10); in ae5_register_set()
9395 chipio_8051_write_pll_pmu(codec, 0x44, 0xc2); in ae5_register_set()
9398 tmp[0] = 0x03; in ae5_register_set()
9399 tmp[1] = 0x03; in ae5_register_set()
9400 tmp[2] = 0x07; in ae5_register_set()
9402 tmp[0] = 0x0f; in ae5_register_set()
9403 tmp[1] = 0x0f; in ae5_register_set()
9404 tmp[2] = 0x0f; in ae5_register_set()
9407 for (i = cur_addr = 0; i < 3; i++, cur_addr++) in ae5_register_set()
9414 for (i = 0; cur_addr < 12; i++, cur_addr++) in ae5_register_set()
9420 writel(0x00800001, spec->mem_base + 0x20c); in ae5_register_set()
9423 ca0113_mmio_command_set_type2(codec, 0x48, 0x07, 0x83); in ae5_register_set()
9424 ca0113_mmio_command_set(codec, 0x30, 0x2e, 0x3f); in ae5_register_set()
9426 ca0113_mmio_command_set(codec, 0x30, 0x2d, 0x3f); in ae5_register_set()
9429 chipio_8051_write_direct(codec, 0x90, 0x00); in ae5_register_set()
9430 chipio_8051_write_direct(codec, 0x90, 0x10); in ae5_register_set()
9433 ca0113_mmio_command_set(codec, 0x48, 0x07, 0x83); in ae5_register_set()
9462 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 0x6FF, 0xC4); in ca0132_alt_init()
9471 chipio_8051_write_pll_pmu(codec, 0x49, 0x88); in ca0132_alt_init()
9472 chipio_write(codec, 0x18b030, 0x00000020); in ca0132_alt_init()
9475 ca0113_mmio_command_set(codec, 0x30, 0x32, 0x3f); in ca0132_alt_init()
9479 chipio_8051_write_pll_pmu(codec, 0x49, 0x88); in ca0132_alt_init()
9482 chipio_write(codec, 0x18b008, 0x000000f8); in ca0132_alt_init()
9483 chipio_write(codec, 0x18b008, 0x000000f0); in ca0132_alt_init()
9484 chipio_write(codec, 0x18b030, 0x00000020); in ca0132_alt_init()
9485 ca0113_mmio_command_set(codec, 0x30, 0x32, 0x3f); in ca0132_alt_init()
9488 chipio_8051_write_pll_pmu(codec, 0x49, 0x88); in ca0132_alt_init()
9523 return 0; in ca0132_init()
9573 for (i = 0; i < spec->num_outputs; i++) in ca0132_init()
9574 init_output(codec, spec->out_pins[i], spec->dacs[0]); in ca0132_init()
9576 init_output(codec, cfg->dig_out_pins[0], spec->dig_out); in ca0132_init()
9578 for (i = 0; i < spec->num_inputs; i++) in ca0132_init()
9585 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in ca0132_init()
9586 VENDOR_CHIPIO_PARAM_EX_ID_SET, 0x0D); in ca0132_init()
9587 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in ca0132_init()
9588 VENDOR_CHIPIO_PARAM_EX_VALUE_SET, 0x20); in ca0132_init()
9616 return 0; in ca0132_init()
9625 init_output(codec, cfg->dig_out_pins[0], spec->dig_out); in dbpro_init()
9628 for (i = 0; i < spec->num_inputs; i++) in dbpro_init()
9631 return 0; in dbpro_init()
9690 return 0; in ca0132_suspend()
9713 spec->dacs[0] = 0x2; in ca0132_config()
9714 spec->dacs[1] = 0x3; in ca0132_config()
9715 spec->dacs[2] = 0x4; in ca0132_config()
9761 spec->out_pins[0] = 0x0b; /* speaker out */ in ca0132_config()
9762 spec->out_pins[1] = 0x0f; in ca0132_config()
9763 spec->shared_out_nid = 0x2; in ca0132_config()
9764 spec->unsol_tag_hp = 0x0f; in ca0132_config()
9766 spec->adcs[0] = 0x7; /* digital mic / analog mic1 */ in ca0132_config()
9767 spec->adcs[1] = 0x8; /* analog mic2 */ in ca0132_config()
9768 spec->adcs[2] = 0xa; /* what u hear */ in ca0132_config()
9771 spec->input_pins[0] = 0x12; in ca0132_config()
9772 spec->input_pins[1] = 0x11; in ca0132_config()
9773 spec->input_pins[2] = 0x13; in ca0132_config()
9774 spec->shared_mic_nid = 0x7; in ca0132_config()
9775 spec->unsol_tag_amic1 = 0x11; in ca0132_config()
9780 spec->out_pins[0] = 0x0B; /* Line out */ in ca0132_config()
9781 spec->out_pins[1] = 0x0F; /* Rear headphone out */ in ca0132_config()
9782 spec->out_pins[2] = 0x10; /* Front Headphone / Center/LFE*/ in ca0132_config()
9783 spec->out_pins[3] = 0x11; /* Rear surround */ in ca0132_config()
9784 spec->shared_out_nid = 0x2; in ca0132_config()
9788 spec->adcs[0] = 0x7; /* Rear Mic / Line-in */ in ca0132_config()
9789 spec->adcs[1] = 0x8; /* Front Mic, but only if no DSP */ in ca0132_config()
9790 spec->adcs[2] = 0xa; /* what u hear */ in ca0132_config()
9793 spec->input_pins[0] = 0x12; /* Rear Mic / Line-in */ in ca0132_config()
9794 spec->input_pins[1] = 0x13; /* What U Hear */ in ca0132_config()
9795 spec->shared_mic_nid = 0x7; in ca0132_config()
9796 spec->unsol_tag_amic1 = spec->input_pins[0]; in ca0132_config()
9799 spec->dig_out = 0x05; in ca0132_config()
9801 spec->dig_in = 0x09; in ca0132_config()
9805 spec->out_pins[0] = 0x0B; /* Line out */ in ca0132_config()
9806 spec->out_pins[1] = 0x0F; /* Rear headphone out */ in ca0132_config()
9807 spec->out_pins[2] = 0x10; /* Center/LFE */ in ca0132_config()
9808 spec->out_pins[3] = 0x11; /* Rear surround */ in ca0132_config()
9809 spec->shared_out_nid = 0x2; in ca0132_config()
9813 spec->adcs[0] = 0x7; /* Rear Mic / Line-in */ in ca0132_config()
9814 spec->adcs[1] = 0x8; /* Not connected, no front mic */ in ca0132_config()
9815 spec->adcs[2] = 0xa; /* what u hear */ in ca0132_config()
9818 spec->input_pins[0] = 0x12; /* Rear Mic / Line-in */ in ca0132_config()
9819 spec->input_pins[1] = 0x13; /* What U Hear */ in ca0132_config()
9820 spec->shared_mic_nid = 0x7; in ca0132_config()
9821 spec->unsol_tag_amic1 = spec->input_pins[0]; in ca0132_config()
9824 spec->adcs[0] = 0x8; /* ZxR DBPro Aux In */ in ca0132_config()
9827 spec->input_pins[0] = 0x11; /* RCA Line-in */ in ca0132_config()
9829 spec->dig_out = 0x05; in ca0132_config()
9832 spec->dig_in = 0x09; in ca0132_config()
9837 spec->out_pins[0] = 0x0B; /* Line out */ in ca0132_config()
9838 spec->out_pins[1] = 0x11; /* Rear headphone out */ in ca0132_config()
9839 spec->out_pins[2] = 0x10; /* Front Headphone / Center/LFE*/ in ca0132_config()
9840 spec->out_pins[3] = 0x0F; /* Rear surround */ in ca0132_config()
9841 spec->shared_out_nid = 0x2; in ca0132_config()
9845 spec->adcs[0] = 0x7; /* Rear Mic / Line-in */ in ca0132_config()
9846 spec->adcs[1] = 0x8; /* Front Mic, but only if no DSP */ in ca0132_config()
9847 spec->adcs[2] = 0xa; /* what u hear */ in ca0132_config()
9850 spec->input_pins[0] = 0x12; /* Rear Mic / Line-in */ in ca0132_config()
9851 spec->input_pins[1] = 0x13; /* What U Hear */ in ca0132_config()
9852 spec->shared_mic_nid = 0x7; in ca0132_config()
9853 spec->unsol_tag_amic1 = spec->input_pins[0]; in ca0132_config()
9856 spec->dig_out = 0x05; in ca0132_config()
9861 spec->out_pins[0] = 0x0B; /* Line out */ in ca0132_config()
9862 spec->out_pins[1] = 0x0F; /* Rear headphone out */ in ca0132_config()
9863 spec->out_pins[2] = 0x10; /* Front Headphone / Center/LFE*/ in ca0132_config()
9864 spec->out_pins[3] = 0x11; /* Rear surround */ in ca0132_config()
9865 spec->shared_out_nid = 0x2; in ca0132_config()
9869 spec->adcs[0] = 0x07; /* Rear Mic / Line-in */ in ca0132_config()
9870 spec->adcs[1] = 0x08; /* Front Mic, but only if no DSP */ in ca0132_config()
9871 spec->adcs[2] = 0x0a; /* what u hear */ in ca0132_config()
9874 spec->input_pins[0] = 0x12; /* Rear Mic / Line-in */ in ca0132_config()
9875 spec->input_pins[1] = 0x13; /* What U Hear */ in ca0132_config()
9876 spec->shared_mic_nid = 0x7; in ca0132_config()
9877 spec->unsol_tag_amic1 = spec->input_pins[0]; in ca0132_config()
9880 spec->dig_out = 0x05; in ca0132_config()
9885 spec->out_pins[0] = 0x0b; /* speaker out */ in ca0132_config()
9886 spec->out_pins[1] = 0x10; /* headphone out */ in ca0132_config()
9887 spec->shared_out_nid = 0x2; in ca0132_config()
9890 spec->adcs[0] = 0x7; /* digital mic / analog mic1 */ in ca0132_config()
9891 spec->adcs[1] = 0x8; /* analog mic2 */ in ca0132_config()
9892 spec->adcs[2] = 0xa; /* what u hear */ in ca0132_config()
9895 spec->input_pins[0] = 0x12; in ca0132_config()
9896 spec->input_pins[1] = 0x11; in ca0132_config()
9897 spec->input_pins[2] = 0x13; in ca0132_config()
9898 spec->shared_mic_nid = 0x7; in ca0132_config()
9899 spec->unsol_tag_amic1 = spec->input_pins[0]; in ca0132_config()
9902 spec->dig_out = 0x05; in ca0132_config()
9904 spec->dig_in = 0x09; in ca0132_config()
9929 spec->spec_init_verbs[0].nid = 0x0b; in ca0132_prepare_verbs()
9930 spec->spec_init_verbs[0].param = 0x78D; in ca0132_prepare_verbs()
9931 spec->spec_init_verbs[0].verb = 0x00; in ca0132_prepare_verbs()
9935 spec->spec_init_verbs[2].nid = 0x0b; in ca0132_prepare_verbs()
9937 spec->spec_init_verbs[2].verb = 0x02; in ca0132_prepare_verbs()
9939 spec->spec_init_verbs[3].nid = 0x10; in ca0132_prepare_verbs()
9940 spec->spec_init_verbs[3].param = 0x78D; in ca0132_prepare_verbs()
9941 spec->spec_init_verbs[3].verb = 0x02; in ca0132_prepare_verbs()
9943 spec->spec_init_verbs[4].nid = 0x10; in ca0132_prepare_verbs()
9945 spec->spec_init_verbs[4].verb = 0x02; in ca0132_prepare_verbs()
9949 return 0; in ca0132_prepare_verbs()
9963 case 0x11020033: in sbz_detect_quirk()
9966 case 0x1102003f: in sbz_detect_quirk()
10013 spec->mixers[0] = desktop_mixer; in patch_ca0132()
10017 spec->mixers[0] = desktop_mixer; in patch_ca0132()
10023 spec->mixers[0] = desktop_mixer; in patch_ca0132()
10027 spec->mixers[0] = r3di_mixer; in patch_ca0132()
10031 spec->mixers[0] = desktop_mixer; in patch_ca0132()
10035 spec->mixers[0] = desktop_mixer; in patch_ca0132()
10039 spec->mixers[0] = ca0132_mixer; in patch_ca0132()
10068 spec->mem_base = pci_iomap(codec->bus->pci, 2, 0xC20); in patch_ca0132()
10086 if (err < 0) in patch_ca0132()
10090 if (err < 0) in patch_ca0132()
10095 return 0; in patch_ca0132()
10106 HDA_CODEC_ENTRY(0x11020011, "CA0132", patch_ca0132),