• Home
  • Raw
  • Download

Lines Matching +full:pdm +full:- +full:mute

23  *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
44 /* extra amp-initialization sequence types */
95 /* mute LED for HP laptops, see alc269_fixup_mic_mute_hook() */
165 if (val != -1) in alc_update_coefex_idx()
176 struct alc_spec *spec = codec->spec; in alc_get_coef0()
178 if (!spec->coef0) in alc_get_coef0()
179 spec->coef0 = alc_read_coef_idx(codec, 0); in alc_get_coef0()
180 return spec->coef0; in alc_get_coef0()
193 #define WRITE_COEFEX(_nid, _idx, _val) UPDATE_COEFEX(_nid, _idx, -1, _val)
200 for (; fw->nid; fw++) { in alc_process_coef_fw()
201 if (fw->mask == (unsigned short)-1) in alc_process_coef_fw()
202 alc_write_coefex_idx(codec, fw->nid, fw->idx, fw->val); in alc_process_coef_fw()
204 alc_update_coefex_idx(codec, fw->nid, fw->idx, in alc_process_coef_fw()
205 fw->mask, fw->val); in alc_process_coef_fw()
216 struct alc_spec *spec = codec->spec; in alc_setup_gpio()
218 spec->gpio_mask |= mask; in alc_setup_gpio()
219 spec->gpio_dir |= mask; in alc_setup_gpio()
220 spec->gpio_data |= mask; in alc_setup_gpio()
225 struct alc_spec *spec = codec->spec; in alc_write_gpio_data()
228 spec->gpio_data); in alc_write_gpio_data()
234 struct alc_spec *spec = codec->spec; in alc_update_gpio_data()
235 unsigned int oldval = spec->gpio_data; in alc_update_gpio_data()
238 spec->gpio_data |= mask; in alc_update_gpio_data()
240 spec->gpio_data &= ~mask; in alc_update_gpio_data()
241 if (oldval != spec->gpio_data) in alc_update_gpio_data()
247 struct alc_spec *spec = codec->spec; in alc_write_gpio()
249 if (!spec->gpio_mask) in alc_write_gpio()
252 snd_hda_codec_write(codec, codec->core.afg, 0, in alc_write_gpio()
253 AC_VERB_SET_GPIO_MASK, spec->gpio_mask); in alc_write_gpio()
254 snd_hda_codec_write(codec, codec->core.afg, 0, in alc_write_gpio()
255 AC_VERB_SET_GPIO_DIRECTION, spec->gpio_dir); in alc_write_gpio()
256 if (spec->gpio_write_delay) in alc_write_gpio()
299 struct alc_spec *spec = codec->spec; in alc_fix_pll()
301 if (spec->pll_nid) in alc_fix_pll()
302 alc_update_coefex_idx(codec, spec->pll_nid, spec->pll_coef_idx, in alc_fix_pll()
303 1 << spec->pll_coef_bit, 0); in alc_fix_pll()
309 struct alc_spec *spec = codec->spec; in alc_fix_pll_init()
310 spec->pll_nid = nid; in alc_fix_pll_init()
311 spec->pll_coef_idx = coef_idx; in alc_fix_pll_init()
312 spec->pll_coef_bit = coef_bit; in alc_fix_pll_init()
316 /* update the master volume per volume-knob's unsol event */
330 val = snd_hda_codec_read(codec, jack->nid, 0, in alc_update_knob_master()
333 uctl->value.integer.value[0] = val; in alc_update_knob_master()
334 uctl->value.integer.value[1] = val; in alc_update_knob_master()
335 kctl->put(kctl, uctl); in alc_update_knob_master()
353 switch (codec->core.vendor_id) { in alc_fill_eapd_coef()
458 /* alc888-VA */ in alc888_coef_init()
460 /* alc888-VB */ in alc888_coef_init()
500 if (codec->bus->shutdown) in alc_headset_mic_no_shutup()
503 snd_array_for_each(&codec->init_pins, i, pin) { in alc_headset_mic_no_shutup()
505 if (pin->nid != mic_pin) in alc_headset_mic_no_shutup()
506 snd_hda_codec_read(codec, pin->nid, 0, in alc_headset_mic_no_shutup()
510 codec->pins_shutup = 1; in alc_headset_mic_no_shutup()
515 struct alc_spec *spec = codec->spec; in alc_shutup_pins()
517 switch (codec->core.vendor_id) { in alc_shutup_pins()
525 if (!spec->no_shutup_pins) in alc_shutup_pins()
532 * just turning off EAPD and a little pause for avoiding pop-noise
536 struct alc_spec *spec = codec->spec; in alc_eapd_shutup()
539 if (!spec->no_depop_delay) in alc_eapd_shutup()
552 switch (codec->core.vendor_id) { in alc_auto_init_amp()
573 if (spec->gen.autocfg.hp_pins[0]) in alc_get_hp_pin()
574 return spec->gen.autocfg.hp_pins[0]; in alc_get_hp_pin()
575 if (spec->gen.autocfg.line_out_type == AC_JACK_HP_OUT) in alc_get_hp_pin()
576 return spec->gen.autocfg.line_out_pins[0]; in alc_get_hp_pin()
584 /* Could be any non-zero and even value. When used as fixup, tells
592 struct alc_spec *spec = codec->spec; in alc_fixup_sku_ignore()
594 spec->cdefine.fixup = 1; in alc_fixup_sku_ignore()
595 spec->cdefine.sku_cfg = ALC_FIXUP_SKU_IGNORE; in alc_fixup_sku_ignore()
602 struct alc_spec *spec = codec->spec; in alc_fixup_no_depop_delay()
605 spec->no_depop_delay = 1; in alc_fixup_no_depop_delay()
606 codec->depop_delay = 0; in alc_fixup_no_depop_delay()
614 struct alc_spec *spec = codec->spec; in alc_auto_parse_customize_define()
616 spec->cdefine.enable_pcbeep = 1; /* assume always enabled */ in alc_auto_parse_customize_define()
618 if (spec->cdefine.fixup) { in alc_auto_parse_customize_define()
619 ass = spec->cdefine.sku_cfg; in alc_auto_parse_customize_define()
621 return -1; in alc_auto_parse_customize_define()
625 if (!codec->bus->pci) in alc_auto_parse_customize_define()
626 return -1; in alc_auto_parse_customize_define()
627 ass = codec->core.subsystem_id & 0xffff; in alc_auto_parse_customize_define()
628 if (ass != codec->bus->pci->subsystem_device && (ass & 1)) in alc_auto_parse_customize_define()
632 if (codec->core.vendor_id == 0x10ec0260) in alc_auto_parse_customize_define()
638 codec->core.chip_name, ass); in alc_auto_parse_customize_define()
639 return -1; in alc_auto_parse_customize_define()
649 return -1; in alc_auto_parse_customize_define()
651 spec->cdefine.port_connectivity = ass >> 30; in alc_auto_parse_customize_define()
652 spec->cdefine.enable_pcbeep = (ass & 0x100000) >> 20; in alc_auto_parse_customize_define()
653 spec->cdefine.check_sum = (ass >> 16) & 0xf; in alc_auto_parse_customize_define()
654 spec->cdefine.customization = ass >> 8; in alc_auto_parse_customize_define()
656 spec->cdefine.sku_cfg = ass; in alc_auto_parse_customize_define()
657 spec->cdefine.external_amp = (ass & 0x38) >> 3; in alc_auto_parse_customize_define()
658 spec->cdefine.platform_type = (ass & 0x4) >> 2; in alc_auto_parse_customize_define()
659 spec->cdefine.swap = (ass & 0x2) >> 1; in alc_auto_parse_customize_define()
660 spec->cdefine.override = ass & 0x1; in alc_auto_parse_customize_define()
663 nid, spec->cdefine.sku_cfg); in alc_auto_parse_customize_define()
665 spec->cdefine.port_connectivity); in alc_auto_parse_customize_define()
666 codec_dbg(codec, "SKU: enable_pcbeep=0x%x\n", spec->cdefine.enable_pcbeep); in alc_auto_parse_customize_define()
667 codec_dbg(codec, "SKU: check_sum=0x%08x\n", spec->cdefine.check_sum); in alc_auto_parse_customize_define()
668 codec_dbg(codec, "SKU: customization=0x%08x\n", spec->cdefine.customization); in alc_auto_parse_customize_define()
669 codec_dbg(codec, "SKU: external_amp=0x%x\n", spec->cdefine.external_amp); in alc_auto_parse_customize_define()
670 codec_dbg(codec, "SKU: platform_type=0x%x\n", spec->cdefine.platform_type); in alc_auto_parse_customize_define()
671 codec_dbg(codec, "SKU: swap=0x%x\n", spec->cdefine.swap); in alc_auto_parse_customize_define()
672 codec_dbg(codec, "SKU: override=0x%x\n", spec->cdefine.override); in alc_auto_parse_customize_define()
677 /* return the position of NID in the list, or -1 if not found */
684 return -1; in find_idx_in_nid_list()
692 /* check subsystem ID and set up device-specific initialization;
695 /* 32-bit subsystem ID for BIOS loading in HD Audio codec.
699 * port-A --> pin 39/41, port-E --> pin 14/15, port-D --> pin 35/36
705 struct alc_spec *spec = codec->spec; in alc_subsystem_id()
707 if (spec->cdefine.fixup) { in alc_subsystem_id()
708 ass = spec->cdefine.sku_cfg; in alc_subsystem_id()
714 ass = codec->core.subsystem_id & 0xffff; in alc_subsystem_id()
715 if (codec->bus->pci && in alc_subsystem_id()
716 ass != codec->bus->pci->subsystem_device && (ass & 1)) in alc_subsystem_id()
729 if (codec->core.vendor_id == 0x10ec0260) in alc_subsystem_id()
750 ass & 0xffff, codec->core.vendor_id); in alc_subsystem_id()
754 * 2 : 0 --> Desktop, 1 --> Laptop in alc_subsystem_id()
759 if (spec->init_amp == ALC_INIT_UNDEFINED) { in alc_subsystem_id()
772 spec->init_amp = ALC_INIT_DEFAULT; in alc_subsystem_id()
777 /* is laptop or Desktop and enable the function "Mute internal speaker in alc_subsystem_id()
784 * 12~11: Headphone out -> 00: PortA, 01: PortE, 02: PortD, 03: Resvered in alc_subsystem_id()
786 * 15 : 1 --> enable the function "Mute internal speaker in alc_subsystem_id()
793 if (found_in_nid_list(nid, spec->gen.autocfg.line_out_pins, in alc_subsystem_id()
794 spec->gen.autocfg.line_outs)) in alc_subsystem_id()
796 spec->gen.autocfg.hp_pins[0] = nid; in alc_subsystem_id()
801 /* Check the validity of ALC subsystem-id
802 * ports contains an array of 4 pin NIDs for port-A, E, D and I */
806 struct alc_spec *spec = codec->spec; in alc_ssid_check()
807 if (spec->init_amp == ALC_INIT_UNDEFINED) { in alc_ssid_check()
810 spec->init_amp = ALC_INIT_DEFAULT; in alc_ssid_check()
821 struct alc_spec *spec = codec->spec; in alc_fixup_inv_dmic()
823 spec->gen.inv_dmic_split = 1; in alc_fixup_inv_dmic()
846 struct alc_spec *spec = codec->spec; in alc_init()
848 if (spec->init_hook) in alc_init()
849 spec->init_hook(codec); in alc_init()
851 spec->gen.skip_verbs = 1; /* applied in below */ in alc_init()
854 alc_auto_init_amp(codec, spec->init_amp); in alc_init()
864 struct alc_spec *spec = codec->spec; in alc_shutup()
869 if (spec && spec->shutup) in alc_shutup()
870 spec->shutup(codec); in alc_shutup()
877 struct alc_spec *spec = codec->spec; in alc_reboot_notify()
879 if (spec && spec->reboot_notify) in alc_reboot_notify()
880 spec->reboot_notify(codec); in alc_reboot_notify()
895 struct alc_spec *spec = codec->spec; in alc_suspend()
897 if (spec && spec->power_hook) in alc_suspend()
898 spec->power_hook(codec); in alc_suspend()
906 struct alc_spec *spec = codec->spec; in alc_resume()
908 if (!spec->no_depop_delay) in alc_resume()
910 codec->patch_ops.init(codec); in alc_resume()
911 regcache_sync(codec->core.regmap); in alc_resume()
964 { 0x10ec0887, 0x00f0, 0x0030, "ALC887-VD" },
965 { 0x10ec0888, 0x00f0, 0x0030, "ALC888-VD" },
1010 for (p = rename_tbl; p->vendor_id; p++) { in alc_codec_rename_from_preset()
1011 if (p->vendor_id != codec->core.vendor_id) in alc_codec_rename_from_preset()
1013 if ((alc_get_coef0(codec) & p->coef_mask) == p->coef_bits) in alc_codec_rename_from_preset()
1014 return alc_codec_rename(codec, p->name); in alc_codec_rename_from_preset()
1017 if (!codec->bus->pci) in alc_codec_rename_from_preset()
1019 for (q = rename_pci_tbl; q->codec_vendor_id; q++) { in alc_codec_rename_from_preset()
1020 if (q->codec_vendor_id != codec->core.vendor_id) in alc_codec_rename_from_preset()
1022 if (q->pci_subvendor != codec->bus->pci->subsystem_vendor) in alc_codec_rename_from_preset()
1024 if (!q->pci_subdevice || in alc_codec_rename_from_preset()
1025 q->pci_subdevice == codec->bus->pci->subsystem_device) in alc_codec_rename_from_preset()
1026 return alc_codec_rename(codec, q->name); in alc_codec_rename_from_preset()
1034 * Digital-beep handlers
1053 knew = snd_hda_gen_add_kctl(&spec->gen, NULL, in set_beep_amp()
1056 return -ENOMEM; in set_beep_amp()
1057 knew->private_value = beep_amp; in set_beep_amp()
1070 SND_PCI_QUIRK(0x1458, 0xa002, "GA-MA790X", 1),
1072 /* blacklist -- no beep available */
1080 struct alc_spec *spec = codec->spec; in has_cdefine_beep()
1082 q = snd_pci_quirk_lookup(codec->bus->pci, beep_white_list); in has_cdefine_beep()
1084 return q->value; in has_cdefine_beep()
1085 return spec->cdefine.enable_pcbeep; in has_cdefine_beep()
1100 struct alc_spec *spec = codec->spec; in alc_parse_auto_config()
1101 struct auto_pin_cfg *cfg = &spec->gen.autocfg; in alc_parse_auto_config()
1105 spec->parse_flags); in alc_parse_auto_config()
1126 return -ENOMEM; in alc_alloc_spec()
1127 codec->spec = spec; in alc_alloc_spec()
1128 snd_hda_gen_spec_init(&spec->gen); in alc_alloc_spec()
1129 spec->gen.mixer_nid = mixer_nid; in alc_alloc_spec()
1130 spec->gen.own_eapd_ctl = 1; in alc_alloc_spec()
1131 codec->single_adc_amp = 1; in alc_alloc_spec()
1133 codec->spdif_status_reset = 1; in alc_alloc_spec()
1134 codec->patch_ops = alc_patch_ops; in alc_alloc_spec()
1152 * ALC880 fix-ups
1182 /* enable the volume-knob widget support on NID 0x21 */
1223 { 0x1a, 0x0181344f }, /* line-in */
1271 { 0x19, 0x01a19950 }, /* mic-in */
1291 { 0x19, 0x01a19950 }, /* mic-in */
1331 { 0x18, 0x01a19950 }, /* mic-in */
1333 { 0x1a, 0x01813031 }, /* line-in */
1364 { 0x14, 0x01014010 }, /* line-out */
1368 { 0x18, 0x01a19c30 }, /* mic-in */
1370 { 0x1a, 0x01813031 }, /* line-in */
1371 { 0x1b, 0x02a19c40 }, /* front-mic */
1404 { 0x18, 0x01a19c30 }, /* mic-in */
1406 { 0x1a, 0x01813031 }, /* line-in */
1407 { 0x1b, 0x02a19c40 }, /* front-mic */
1440 { 0x18, 0x01a19c30 }, /* mic-in */
1441 { 0x19, 0x02a19c40 }, /* front-mic */
1442 { 0x1a, 0x01813031 }, /* line-in */
1506 * It's not quite sure whether BIOS sets the correct pin-config table
1531 SND_PCI_QUIRK(0x1695, 0x4012, "EPox EP-5LDA", ALC880_FIXUP_5ST_DIG),
1546 SND_PCI_QUIRK(0xa0a0, 0x0560, "AOpen i915GMm-HFS", ALC880_FIXUP_5ST_DIG),
1553 {.id = ALC880_FIXUP_3ST_DIG, .name = "3stack-digout"},
1555 {.id = ALC880_FIXUP_5ST_DIG, .name = "5stack-digout"},
1557 {.id = ALC880_FIXUP_6ST_DIG, .name = "6stack-digout"},
1558 {.id = ALC880_FIXUP_6ST_AUTOMUTE, .name = "6stack-automute"},
1575 spec = codec->spec; in patch_alc880()
1576 spec->gen.need_dac_fix = 1; in patch_alc880()
1577 spec->gen.beep_nid = 0x01; in patch_alc880()
1579 codec->patch_ops.unsol_event = alc880_unsol_event; in patch_alc880()
1590 if (!spec->gen.no_analog) { in patch_alc880()
1635 struct alc_spec *spec = codec->spec; in alc260_gpio1_automute()
1637 alc_update_gpio_data(codec, 0x01, spec->gen.hp_jack_present); in alc260_gpio1_automute()
1643 struct alc_spec *spec = codec->spec; in alc260_fixup_gpio1_toggle()
1648 spec->gen.automute_hook = alc260_gpio1_automute; in alc260_fixup_gpio1_toggle()
1649 spec->gen.detect_hp = 1; in alc260_fixup_gpio1_toggle()
1650 spec->gen.automute_speaker = 1; in alc260_fixup_gpio1_toggle()
1651 spec->gen.autocfg.hp_pins[0] = 0x0f; /* copy it for automute */ in alc260_fixup_gpio1_toggle()
1661 struct alc_spec *spec = codec->spec; in alc260_fixup_kn1()
1681 spec->init_amp = ALC_INIT_NONE; in alc260_fixup_kn1()
1689 struct alc_spec *spec = codec->spec; in alc260_fixup_fsc_s7020()
1691 spec->init_amp = ALC_INIT_NONE; in alc260_fixup_fsc_s7020()
1697 struct alc_spec *spec = codec->spec; in alc260_fixup_fsc_s7020_jwse()
1699 spec->gen.add_jack_modes = 1; in alc260_fixup_fsc_s7020_jwse()
1700 spec->gen.hp_mic = 1; in alc260_fixup_fsc_s7020_jwse()
1807 {.id = ALC260_FIXUP_FSC_S7020_JWSE, .name = "fujitsu-jwse"},
1822 spec = codec->spec; in patch_alc260()
1827 spec->gen.prefer_hp_amp = 1; in patch_alc260()
1828 spec->gen.beep_nid = 0x01; in patch_alc260()
1830 spec->shutup = alc_eapd_shutup; in patch_alc260()
1841 if (!spec->gen.no_analog) { in patch_alc260()
1863 * 6-channel independent captures.
1865 * In addition, an independent DAC for the multi-playback (not used in this
1925 struct alc_spec *spec = codec->spec; in alc885_fixup_macpro_gpio()
1927 spec->gpio_write_delay = true; in alc885_fixup_macpro_gpio()
1960 struct alc_spec *spec = codec->spec; in alc889_fixup_mbp_vref()
1973 spec->gen.keep_vref_in_automute = 1; in alc889_fixup_mbp_vref()
1981 struct alc_spec *spec = codec->spec; in alc889_fixup_mac_pins()
1990 spec->gen.keep_vref_in_automute = 1; in alc889_fixup_mac_pins()
2025 * all-in-one desktop PCs (for example VGC-LN51JGB) through DAC 0x05
2030 struct alc_spec *spec = codec->spec; in alc882_fixup_no_primary_hp()
2032 spec->gen.no_primary_hp = 1; in alc882_fixup_no_primary_hp()
2033 spec->gen.no_multi_io = 1; in alc882_fixup_no_primary_hp()
2040 /* For dual-codec configuration, we need to disable some features to avoid
2046 struct alc_spec *spec = codec->spec; in alc_fixup_dual_codecs()
2051 spec->gen.suppress_vmaster = 1; in alc_fixup_dual_codecs()
2052 /* auto-mute and auto-mic switch don't work with multiple codecs */ in alc_fixup_dual_codecs()
2053 spec->gen.suppress_auto_mute = 1; in alc_fixup_dual_codecs()
2054 spec->gen.suppress_auto_mic = 1; in alc_fixup_dual_codecs()
2056 spec->gen.mixer_nid = 0; in alc_fixup_dual_codecs()
2058 codec->force_pin_prefix = 1; in alc_fixup_dual_codecs()
2068 strcpy(kctl->id.name, newname); in rename_ctl()
2079 strcpy(codec->card->longname, "HDAudio-Gigabyte-ALC1220DualCodecs"); in alc1220_fixup_gb_dual_codecs()
2084 codec->addr == 0 ? in alc1220_fixup_gb_dual_codecs()
2085 "Rear-Panel Capture Volume" : in alc1220_fixup_gb_dual_codecs()
2086 "Front-Panel Capture Volume"); in alc1220_fixup_gb_dual_codecs()
2088 codec->addr == 0 ? in alc1220_fixup_gb_dual_codecs()
2089 "Rear-Panel Capture Switch" : in alc1220_fixup_gb_dual_codecs()
2090 "Front-Panel Capture Switch"); in alc1220_fixup_gb_dual_codecs()
2126 struct alc_spec *spec = codec->spec; in alc887_asus_hp_automute_hook()
2131 if (spec->gen.hp_jack_present) in alc887_asus_hp_automute_hook()
2141 struct alc_spec *spec = codec->spec; in alc887_fixup_asus_jack()
2145 spec->gen.hp_automute_hook = alc887_asus_hp_automute_hook; in alc887_fixup_asus_jack()
2289 /* DAC DISABLE/MUTE 1? */
2290 /* setting bits 1-5 disables DAC nids 0x02-0x06
2294 /* DAC DISABLE/MUTE 2? */
2443 SND_PCI_QUIRK(0x1025, 0x0155, "Packard-Bell M5120", ALC882_FIXUP_PB_M5210),
2459 SND_PCI_QUIRK(0x104d, 0x9043, "Sony Vaio VGC-LN51JGB", ALC882_FIXUP_NO_PRIMARY_HP),
2487 SND_PCI_QUIRK(0x1458, 0xa002, "Gigabyte EP45-DS3/Z87X-UD3H", ALC889_FIXUP_FRONT_HP_NO_PRESENCE),
2488 SND_PCI_QUIRK(0x1458, 0xa0b8, "Gigabyte AZ370-Gaming", ALC1220_FIXUP_GB_DUAL_CODECS),
2491 SND_PCI_QUIRK(0x1462, 0x11f7, "MSI-GE63", ALC1220_FIXUP_CLEVO_P950),
2492 SND_PCI_QUIRK(0x1462, 0x1228, "MSI-GP63", ALC1220_FIXUP_CLEVO_P950),
2493 SND_PCI_QUIRK(0x1462, 0x1275, "MSI-GL63", ALC1220_FIXUP_CLEVO_P950),
2494 SND_PCI_QUIRK(0x1462, 0x1276, "MSI-GL73", ALC1220_FIXUP_CLEVO_P950),
2495 SND_PCI_QUIRK(0x1462, 0x1293, "MSI-GP65", ALC1220_FIXUP_CLEVO_P950),
2496 SND_PCI_QUIRK(0x1462, 0x7350, "MSI-7350", ALC889_FIXUP_CD),
2497 SND_PCI_QUIRK(0x1462, 0xda57, "MSI Z270-Gaming", ALC1220_FIXUP_GB_DUAL_CODECS),
2499 SND_PCI_QUIRK(0x147b, 0x107a, "Abit AW9D-MAX", ALC882_FIXUP_ABIT_AW9D_MAX),
2503 SND_PCI_QUIRK(0x1558, 0x96e1, "Clevo P960[ER][CDFN]-K", ALC1220_FIXUP_CLEVO_P950),
2518 {.id = ALC882_FIXUP_ABIT_AW9D_MAX, .name = "abit-aw9d"},
2519 {.id = ALC882_FIXUP_LENOVO_Y530, .name = "lenovo-y530"},
2520 {.id = ALC882_FIXUP_ACER_ASPIRE_7736, .name = "acer-aspire-7736"},
2521 {.id = ALC882_FIXUP_ASUS_W90V, .name = "asus-w90v"},
2523 {.id = ALC889_FIXUP_FRONT_HP_NO_PRESENCE, .name = "no-front-hp"},
2524 {.id = ALC889_FIXUP_VAIO_TT, .name = "vaio-tt"},
2526 {.id = ALC882_FIXUP_EAPD, .name = "alc882-eapd"},
2527 {.id = ALC883_FIXUP_EAPD, .name = "alc883-eapd"},
2531 {.id = ALC889_FIXUP_COEF, .name = "alc889-coef"},
2532 {.id = ALC882_FIXUP_ASUS_W2JC, .name = "asus-w2jc"},
2533 {.id = ALC882_FIXUP_ACER_ASPIRE_4930G, .name = "acer-aspire-4930g"},
2534 {.id = ALC882_FIXUP_ACER_ASPIRE_8930G, .name = "acer-aspire-8930g"},
2535 {.id = ALC883_FIXUP_ACER_EAPD, .name = "acer-aspire"},
2536 {.id = ALC885_FIXUP_MACPRO_GPIO, .name = "macpro-gpio"},
2537 {.id = ALC889_FIXUP_DAC_ROUTE, .name = "dac-route"},
2538 {.id = ALC889_FIXUP_MBP_VREF, .name = "mbp-vref"},
2539 {.id = ALC889_FIXUP_IMAC91_VREF, .name = "imac91-vref"},
2540 {.id = ALC889_FIXUP_MBA11_VREF, .name = "mba11-vref"},
2541 {.id = ALC889_FIXUP_MBA21_VREF, .name = "mba21-vref"},
2542 {.id = ALC889_FIXUP_MP11_VREF, .name = "mp11-vref"},
2543 {.id = ALC889_FIXUP_MP41_VREF, .name = "mp41-vref"},
2544 {.id = ALC882_FIXUP_INV_DMIC, .name = "inv-dmic"},
2545 {.id = ALC882_FIXUP_NO_PRIMARY_HP, .name = "no-primary-hp"},
2546 {.id = ALC887_FIXUP_ASUS_BASS, .name = "asus-bass"},
2547 {.id = ALC1220_FIXUP_GB_DUAL_CODECS, .name = "dual-codecs"},
2548 {.id = ALC1220_FIXUP_CLEVO_P950, .name = "clevo-p950"},
2574 spec = codec->spec; in patch_alc882()
2576 switch (codec->core.vendor_id) { in patch_alc882()
2596 spec->gen.beep_nid = 0x01; in patch_alc882()
2603 if (!spec->gen.no_analog && spec->gen.beep_nid) { in patch_alc882()
2721 SND_PCI_QUIRK(0x17ff, 0x058d, "Benq T31-16", ALC262_FIXUP_BENQ_T31),
2727 {.id = ALC262_FIXUP_INV_DMIC, .name = "inv-dmic"},
2728 {.id = ALC262_FIXUP_FSC_H270, .name = "fsc-h270"},
2729 {.id = ALC262_FIXUP_FSC_S7110, .name = "fsc-s7110"},
2730 {.id = ALC262_FIXUP_HP_Z200, .name = "hp-z200"},
2732 {.id = ALC262_FIXUP_LENOVO_3000, .name = "lenovo-3000"},
2734 {.id = ALC262_FIXUP_BENQ_T31, .name = "benq-t31"},
2750 spec = codec->spec; in patch_alc262()
2751 spec->gen.shared_mic_vref_pin = 0x18; in patch_alc262()
2753 spec->shutup = alc_eapd_shutup; in patch_alc262()
2757 * under-run in patch_alc262()
2770 spec->gen.beep_nid = 0x01; in patch_alc262()
2777 if (!spec->gen.no_analog && spec->gen.beep_nid) { in patch_alc262()
2803 mutex_lock(&codec->control_mutex); in alc268_beep_switch_put()
2804 pval = kcontrol->private_value; in alc268_beep_switch_put()
2805 kcontrol->private_value = (pval & ~0xff) | 0x0f; in alc268_beep_switch_put()
2808 kcontrol->private_value = (pval & ~0xff) | 0x10; in alc268_beep_switch_put()
2811 kcontrol->private_value = pval; in alc268_beep_switch_put()
2812 mutex_unlock(&codec->control_mutex); in alc268_beep_switch_put()
2829 /* set PCBEEP vol = 0, mute connections */
2865 {.id = ALC268_FIXUP_INV_DMIC, .name = "inv-dmic"},
2866 {.id = ALC268_FIXUP_HP_EAPD, .name = "hp-eapd"},
2897 /* ALC268 has no aa-loopback mixer */ in patch_alc268()
2902 spec = codec->spec; in patch_alc268()
2903 spec->gen.beep_nid = 0x01; in patch_alc268()
2905 spec->shutup = alc_eapd_shutup; in patch_alc268()
2915 if (err > 0 && !spec->gen.no_analog && in patch_alc268()
2916 spec->gen.autocfg.speaker_pins[0] != 0x1d) { in patch_alc268()
2918 if (!snd_hda_gen_add_kctl(&spec->gen, NULL, in patch_alc268()
2920 err = -ENOMEM; in patch_alc268()
2955 /* different alc269-variants */
2987 struct alc_spec *spec = codec->spec; in alc269_parse_auto_config()
2990 switch (spec->codec_variant) { in alc269_parse_auto_config()
3030 struct alc_spec *spec = codec->spec; in alc269_shutup()
3032 if (spec->codec_variant == ALC269_TYPE_ALC269VB) in alc269_shutup()
3034 if (spec->codec_variant == ALC269_TYPE_ALC269VB && in alc269_shutup()
3081 struct alc_spec *spec = codec->spec; in alc282_init()
3118 struct alc_spec *spec = codec->spec; in alc282_shutup()
3141 if (!spec->no_shutup_pins) in alc282_shutup()
3197 struct alc_spec *spec = codec->spec; in alc283_init()
3233 struct alc_spec *spec = codec->spec; in alc283_shutup()
3255 if (!spec->no_shutup_pins) in alc283_shutup()
3270 struct alc_spec *spec = codec->spec; in alc256_init()
3305 * Documentation/sound/hd-audio/realtek-pc-beep.rst for details of in alc256_init()
3313 struct alc_spec *spec = codec->spec; in alc256_shutup()
3338 if (codec->core.vendor_id != 0x10ec0257) in alc256_shutup()
3341 if (!spec->no_shutup_pins) in alc256_shutup()
3354 struct alc_spec *spec = codec->spec; in alc225_init()
3397 struct alc_spec *spec = codec->spec; in alc225_shutup()
3441 struct alc_spec *spec = codec->spec; in alc_default_init()
3470 struct alc_spec *spec = codec->spec; in alc_default_shutup()
3490 if (!spec->no_shutup_pins) in alc_default_shutup()
3503 struct alc_spec *spec = codec->spec; in alc294_hp_init()
3515 if (!spec->no_shutup_pins) in alc294_hp_init()
3535 struct alc_spec *spec = codec->spec; in alc294_init()
3538 if (!spec->done_hp_init || in alc294_init()
3539 codec->core.dev.power.power_state.event == PM_EVENT_RESTORE) { in alc294_init()
3541 spec->done_hp_init = true; in alc294_init()
3641 struct alc_spec *spec = codec->spec; in alc269_suspend()
3643 if (spec->has_alc5505_dsp) in alc269_suspend()
3650 struct alc_spec *spec = codec->spec; in alc269_resume()
3652 if (spec->codec_variant == ALC269_TYPE_ALC269VB) in alc269_resume()
3654 if (spec->codec_variant == ALC269_TYPE_ALC269VB && in alc269_resume()
3659 codec->patch_ops.init(codec); in alc269_resume()
3661 if (spec->codec_variant == ALC269_TYPE_ALC269VB) in alc269_resume()
3663 if (spec->codec_variant == ALC269_TYPE_ALC269VB && in alc269_resume()
3668 regcache_sync(codec->core.regmap); in alc269_resume()
3675 if (spec->gpio_data) in alc269_resume()
3678 if (spec->has_alc5505_dsp) in alc269_resume()
3688 struct alc_spec *spec = codec->spec; in alc269_fixup_pincfg_no_hp_to_lineout()
3691 spec->parse_flags = HDA_PINCFG_NO_HP_FIXUP; in alc269_fixup_pincfg_no_hp_to_lineout()
3717 struct alc_spec *spec = codec->spec; in alc269_fixup_headset_mic()
3720 spec->parse_flags |= HDA_PINCFG_HEADSET_MIC; in alc269_fixup_headset_mic()
3733 if (strcmp(codec->core.chip_name, "ALC271X") && in alc271_fixup_dmic()
3734 strcmp(codec->core.chip_name, "ALC269VB")) in alc271_fixup_dmic()
3744 struct alc_spec *spec = codec->spec; in alc269_fixup_pcm_44k()
3752 spec->gen.stream_analog_playback = &alc269_44k_pcm_analog_playback; in alc269_fixup_pcm_44k()
3753 spec->gen.stream_analog_capture = &alc269_44k_pcm_analog_capture; in alc269_fixup_pcm_44k()
3759 /* The digital-mic unit sends PDM (differential signal) instead of in alc269_fixup_stereo_dmic()
3779 struct alc_spec *spec = codec->spec; in alc269_fixup_quanta_mute()
3782 spec->gen.automute_hook = alc269_quanta_automute; in alc269_fixup_quanta_mute()
3788 struct alc_spec *spec = codec->spec; in alc269_x101_hp_automute_hook()
3793 vref = spec->gen.hp_jack_present ? PIN_VREF80 : 0; in alc269_x101_hp_automute_hook()
3805 struct alc_spec *spec = codec->spec; in alc269_fixup_x101_headset_mic()
3807 spec->parse_flags |= HDA_PINCFG_HEADSET_MIC; in alc269_fixup_x101_headset_mic()
3808 spec->gen.hp_automute_hook = alc269_x101_hp_automute_hook; in alc269_fixup_x101_headset_mic()
3813 /* update mute-LED according to the speaker mute state via mic VREF pin */
3817 struct alc_spec *spec = codec->spec; in alc269_fixup_mic_mute_hook()
3820 if (spec->mute_led_polarity) in alc269_fixup_mic_mute_hook()
3822 pinval = snd_hda_codec_get_pin_target(codec, spec->mute_led_nid); in alc269_fixup_mic_mute_hook()
3825 if (spec->mute_led_nid) { in alc269_fixup_mic_mute_hook()
3828 snd_hda_set_pin_ctl_cache(codec, spec->mute_led_nid, pinval); in alc269_fixup_mic_mute_hook()
3838 struct alc_spec *spec = codec->spec; in led_power_filter()
3841 (nid != spec->mute_led_nid && nid != spec->cap_mute_led_nid)) in led_power_filter()
3854 struct alc_spec *spec = codec->spec; in alc269_fixup_hp_mute_led()
3862 if (sscanf(dev->name, "HP_Mute_LED_%d_%x", &pol, &pin) != 2) in alc269_fixup_hp_mute_led()
3866 spec->mute_led_polarity = pol; in alc269_fixup_hp_mute_led()
3867 spec->mute_led_nid = pin - 0x0a + 0x18; in alc269_fixup_hp_mute_led()
3868 spec->gen.vmaster_mute.hook = alc269_fixup_mic_mute_hook; in alc269_fixup_hp_mute_led()
3869 spec->gen.vmaster_mute_enum = 1; in alc269_fixup_hp_mute_led()
3870 codec->power_filter = led_power_filter; in alc269_fixup_hp_mute_led()
3872 "Detected mute LED for %x:%d\n", spec->mute_led_nid, in alc269_fixup_hp_mute_led()
3873 spec->mute_led_polarity); in alc269_fixup_hp_mute_led()
3882 struct alc_spec *spec = codec->spec; in alc269_fixup_hp_mute_led_micx()
3885 spec->mute_led_polarity = 0; in alc269_fixup_hp_mute_led_micx()
3886 spec->mute_led_nid = pin; in alc269_fixup_hp_mute_led_micx()
3887 spec->gen.vmaster_mute.hook = alc269_fixup_mic_mute_hook; in alc269_fixup_hp_mute_led_micx()
3888 spec->gen.vmaster_mute_enum = 1; in alc269_fixup_hp_mute_led_micx()
3889 codec->power_filter = led_power_filter; in alc269_fixup_hp_mute_led_micx()
3917 alc_update_gpio_data(codec, mask, !enabled); /* muted -> LED on */ in alc_update_gpio_led()
3920 /* turn on/off mute LED via GPIO per vmaster hook */
3924 struct alc_spec *spec = codec->spec; in alc_fixup_gpio_mute_hook()
3926 alc_update_gpio_led(codec, spec->gpio_mute_led_mask, in alc_fixup_gpio_mute_hook()
3927 spec->mute_led_polarity, enabled); in alc_fixup_gpio_mute_hook()
3930 /* turn on/off mic-mute LED via GPIO per capture hook */
3933 struct alc_spec *spec = codec->spec; in alc_gpio_micmute_update()
3935 alc_update_gpio_led(codec, spec->gpio_mic_led_mask, in alc_gpio_micmute_update()
3936 spec->micmute_led_polarity, in alc_gpio_micmute_update()
3937 spec->gen.micmute_led.led_value); in alc_gpio_micmute_update()
3940 /* setup mute and mic-mute GPIO bits, add hooks appropriately */
3946 struct alc_spec *spec = codec->spec; in alc_fixup_hp_gpio_led()
3953 spec->gpio_mute_led_mask = mute_mask; in alc_fixup_hp_gpio_led()
3954 spec->gen.vmaster_mute.hook = alc_fixup_gpio_mute_hook; in alc_fixup_hp_gpio_led()
3957 spec->gpio_mic_led_mask = micmute_mask; in alc_fixup_hp_gpio_led()
3971 struct alc_spec *spec = codec->spec; in alc285_fixup_hp_gpio_led()
3973 spec->micmute_led_polarity = 1; in alc285_fixup_hp_gpio_led()
3984 /* turn on/off mic-mute LED per capture hook */
3987 struct alc_spec *spec = codec->spec; in alc_cap_micmute_update()
3990 if (!spec->cap_mute_led_nid) in alc_cap_micmute_update()
3992 pinval = snd_hda_codec_get_pin_target(codec, spec->cap_mute_led_nid); in alc_cap_micmute_update()
3994 if (spec->gen.micmute_led.led_value) in alc_cap_micmute_update()
3998 snd_hda_set_pin_ctl_cache(codec, spec->cap_mute_led_nid, pinval); in alc_cap_micmute_update()
4004 struct alc_spec *spec = codec->spec; in alc269_fixup_hp_gpio_mic1_led()
4011 spec->gpio_mask |= 0x10; in alc269_fixup_hp_gpio_mic1_led()
4012 spec->gpio_dir |= 0x10; in alc269_fixup_hp_gpio_mic1_led()
4013 spec->cap_mute_led_nid = 0x18; in alc269_fixup_hp_gpio_mic1_led()
4015 codec->power_filter = led_power_filter; in alc269_fixup_hp_gpio_mic1_led()
4022 struct alc_spec *spec = codec->spec; in alc280_fixup_hp_gpio4()
4026 spec->cap_mute_led_nid = 0x18; in alc280_fixup_hp_gpio4()
4028 codec->power_filter = led_power_filter; in alc280_fixup_hp_gpio4()
4036 struct alc_spec *spec = codec->spec; in gpio2_mic_hotkey_event()
4040 input_report_key(spec->kb_dev, spec->alc_mute_keycode_map[ALC_KEY_MICMUTE_INDEX], 1); in gpio2_mic_hotkey_event()
4041 input_sync(spec->kb_dev); in gpio2_mic_hotkey_event()
4042 input_report_key(spec->kb_dev, spec->alc_mute_keycode_map[ALC_KEY_MICMUTE_INDEX], 0); in gpio2_mic_hotkey_event()
4043 input_sync(spec->kb_dev); in gpio2_mic_hotkey_event()
4048 struct alc_spec *spec = codec->spec; in alc_register_micmute_input_device()
4051 spec->kb_dev = input_allocate_device(); in alc_register_micmute_input_device()
4052 if (!spec->kb_dev) { in alc_register_micmute_input_device()
4054 return -ENOMEM; in alc_register_micmute_input_device()
4057 spec->alc_mute_keycode_map[ALC_KEY_MICMUTE_INDEX] = KEY_MICMUTE; in alc_register_micmute_input_device()
4059 spec->kb_dev->name = "Microphone Mute Button"; in alc_register_micmute_input_device()
4060 spec->kb_dev->evbit[0] = BIT_MASK(EV_KEY); in alc_register_micmute_input_device()
4061 spec->kb_dev->keycodesize = sizeof(spec->alc_mute_keycode_map[0]); in alc_register_micmute_input_device()
4062 spec->kb_dev->keycodemax = ARRAY_SIZE(spec->alc_mute_keycode_map); in alc_register_micmute_input_device()
4063 spec->kb_dev->keycode = spec->alc_mute_keycode_map; in alc_register_micmute_input_device()
4064 for (i = 0; i < ARRAY_SIZE(spec->alc_mute_keycode_map); i++) in alc_register_micmute_input_device()
4065 set_bit(spec->alc_mute_keycode_map[i], spec->kb_dev->keybit); in alc_register_micmute_input_device()
4067 if (input_register_device(spec->kb_dev)) { in alc_register_micmute_input_device()
4069 input_free_device(spec->kb_dev); in alc_register_micmute_input_device()
4070 spec->kb_dev = NULL; in alc_register_micmute_input_device()
4071 return -ENOMEM; in alc_register_micmute_input_device()
4078 * GPIO2 = mic mute hotkey
4079 * GPIO3 = mute LED
4080 * GPIO4 = mic mute LED
4085 struct alc_spec *spec = codec->spec; in alc280_fixup_hp_gpio2_mic_hotkey()
4089 spec->init_amp = ALC_INIT_DEFAULT; in alc280_fixup_hp_gpio2_mic_hotkey()
4093 spec->gpio_mask |= 0x06; in alc280_fixup_hp_gpio2_mic_hotkey()
4094 spec->gpio_dir |= 0x02; in alc280_fixup_hp_gpio2_mic_hotkey()
4095 spec->gpio_data |= 0x02; in alc280_fixup_hp_gpio2_mic_hotkey()
4096 snd_hda_codec_write_cache(codec, codec->core.afg, 0, in alc280_fixup_hp_gpio2_mic_hotkey()
4098 snd_hda_jack_detect_enable_callback(codec, codec->core.afg, in alc280_fixup_hp_gpio2_mic_hotkey()
4103 if (!spec->kb_dev) in alc280_fixup_hp_gpio2_mic_hotkey()
4108 input_unregister_device(spec->kb_dev); in alc280_fixup_hp_gpio2_mic_hotkey()
4109 spec->kb_dev = NULL; in alc280_fixup_hp_gpio2_mic_hotkey()
4113 /* Line2 = mic mute hotkey
4114 * GPIO2 = mic mute LED
4119 struct alc_spec *spec = codec->spec; in alc233_fixup_lenovo_line2_mic_hotkey()
4121 spec->micmute_led_polarity = 1; in alc233_fixup_lenovo_line2_mic_hotkey()
4124 spec->init_amp = ALC_INIT_DEFAULT; in alc233_fixup_lenovo_line2_mic_hotkey()
4133 if (!spec->kb_dev) in alc233_fixup_lenovo_line2_mic_hotkey()
4138 input_unregister_device(spec->kb_dev); in alc233_fixup_lenovo_line2_mic_hotkey()
4139 spec->kb_dev = NULL; in alc233_fixup_lenovo_line2_mic_hotkey()
4150 struct alc_spec *spec = codec->spec; in alc269_fixup_hp_line1_mic1_led()
4154 spec->cap_mute_led_nid = 0x18; in alc269_fixup_hp_line1_mic1_led()
4221 UPDATE_COEF(0x1a, 1<<3, 1<<3), /* Combo JD gating with LINE1-VREFO */ in alc_headset_mode_unplugged()
4246 switch (codec->core.vendor_id) { in alc_headset_mode_unplugged()
4335 UPDATE_COEF(0x1a, 1<<3, 0), /* Combo JD gating without LINE1-VREFO */ in alc_headset_mode_mic_in()
4357 switch (codec->core.vendor_id) { in alc_headset_mode_mic_in()
4431 codec_dbg(codec, "Headset jack set to mic-in mode.\n"); in alc_headset_mode_mic_in()
4483 UPDATE_COEF(0x1a, 1<<3, 0), /* Combo JD gating without LINE1-VREFO */ in alc_headset_mode_default()
4500 switch (codec->core.vendor_id) { in alc_headset_mode_default()
4607 switch (codec->core.vendor_id) { in alc_headset_mode_ctia()
4667 codec_dbg(codec, "Headset jack set to iPhone-style headset mode.\n"); in alc_headset_mode_ctia()
4720 switch (codec->core.vendor_id) { in alc_headset_mode_omtp()
4766 codec_dbg(codec, "Headset jack set to Nokia-style headset mode.\n"); in alc_headset_mode_omtp()
4773 struct alc_spec *spec = codec->spec; in alc_determine_headset_type()
4812 switch (codec->core.vendor_id) { in alc_determine_headset_type()
4957 codec_dbg(codec, "Headset jack detected iPhone-style headset: %s\n", in alc_determine_headset_type()
4959 spec->current_headset_type = is_ctia ? ALC_HEADSET_TYPE_CTIA : ALC_HEADSET_TYPE_OMTP; in alc_determine_headset_type()
4964 struct alc_spec *spec = codec->spec; in alc_update_headset_mode()
4966 hda_nid_t mux_pin = spec->gen.imux_pins[spec->gen.cur_mux[0]]; in alc_update_headset_mode()
4973 else if (mux_pin == spec->headset_mic_pin) in alc_update_headset_mode()
4975 else if (mux_pin == spec->headphone_mic_pin) in alc_update_headset_mode()
4980 if (new_headset_mode == spec->current_headset_mode) { in alc_update_headset_mode()
4988 spec->gen.hp_jack_present = false; in alc_update_headset_mode()
4991 if (spec->current_headset_type == ALC_HEADSET_TYPE_UNKNOWN) in alc_update_headset_mode()
4993 if (spec->current_headset_type == ALC_HEADSET_TYPE_CTIA) in alc_update_headset_mode()
4995 else if (spec->current_headset_type == ALC_HEADSET_TYPE_OMTP) in alc_update_headset_mode()
4997 spec->gen.hp_jack_present = true; in alc_update_headset_mode()
5000 alc_headset_mode_mic_in(codec, hp_pin, spec->headphone_mic_pin); in alc_update_headset_mode()
5001 spec->gen.hp_jack_present = false; in alc_update_headset_mode()
5005 spec->gen.hp_jack_present = true; in alc_update_headset_mode()
5011 if (spec->headphone_mic_pin && spec->headphone_mic_pin != hp_pin) in alc_update_headset_mode()
5012 snd_hda_set_pin_ctl_cache(codec, spec->headphone_mic_pin, in alc_update_headset_mode()
5015 spec->current_headset_mode = new_headset_mode; in alc_update_headset_mode()
5030 struct alc_spec *spec = codec->spec; in alc_update_headset_jack_cb()
5031 spec->current_headset_type = ALC_HEADSET_TYPE_UNKNOWN; in alc_update_headset_jack_cb()
5038 struct alc_spec *spec = codec->spec; in alc_probe_headset_mode()
5039 struct auto_pin_cfg *cfg = &spec->gen.autocfg; in alc_probe_headset_mode()
5042 for (i = 0; i < cfg->num_inputs; i++) { in alc_probe_headset_mode()
5043 if (cfg->inputs[i].is_headset_mic && !spec->headset_mic_pin) in alc_probe_headset_mode()
5044 spec->headset_mic_pin = cfg->inputs[i].pin; in alc_probe_headset_mode()
5045 if (cfg->inputs[i].is_headphone_mic && !spec->headphone_mic_pin) in alc_probe_headset_mode()
5046 spec->headphone_mic_pin = cfg->inputs[i].pin; in alc_probe_headset_mode()
5049 WARN_ON(spec->gen.cap_sync_hook); in alc_probe_headset_mode()
5050 spec->gen.cap_sync_hook = alc_update_headset_mode_hook; in alc_probe_headset_mode()
5051 spec->gen.automute_hook = alc_update_headset_mode; in alc_probe_headset_mode()
5052 spec->gen.hp_automute_hook = alc_update_headset_jack_cb; in alc_probe_headset_mode()
5058 struct alc_spec *spec = codec->spec; in alc_fixup_headset_mode()
5062 spec->parse_flags |= HDA_PINCFG_HEADSET_MIC | HDA_PINCFG_HEADPHONE_MIC; in alc_fixup_headset_mode()
5068 spec->current_headset_mode = 0; in alc_fixup_headset_mode()
5078 struct alc_spec *spec = codec->spec; in alc_fixup_headset_mode_no_hp_mic()
5079 spec->parse_flags |= HDA_PINCFG_HEADSET_MIC; in alc_fixup_headset_mode_no_hp_mic()
5104 switch (codec->core.vendor_id) { in alc255_set_default_jack_type()
5129 struct alc_spec *spec = codec->spec; in alc_fixup_headset_mode_alc255_no_hp_mic()
5130 spec->parse_flags |= HDA_PINCFG_HEADSET_MIC; in alc_fixup_headset_mode_alc255_no_hp_mic()
5140 struct alc_spec *spec = codec->spec; in alc288_update_headset_jack_cb()
5144 alc_update_gpio_data(codec, 0x40, spec->gen.hp_jack_present); in alc288_update_headset_jack_cb()
5152 struct alc_spec *spec = codec->spec; in alc_fixup_headset_mode_dell_alc288()
5154 spec->gpio_mask |= 0x40; in alc_fixup_headset_mode_dell_alc288()
5155 spec->gpio_dir |= 0x40; in alc_fixup_headset_mode_dell_alc288()
5156 spec->gen.hp_automute_hook = alc288_update_headset_jack_cb; in alc_fixup_headset_mode_dell_alc288()
5164 struct alc_spec *spec = codec->spec; in alc_fixup_auto_mute_via_amp()
5165 spec->gen.auto_mute_via_amp = 1; in alc_fixup_auto_mute_via_amp()
5173 struct alc_spec *spec = codec->spec; in alc_fixup_no_shutup()
5174 spec->no_shutup_pins = 1; in alc_fixup_no_shutup()
5182 struct alc_spec *spec = codec->spec; in alc_fixup_disable_aamix()
5183 /* Disable AA-loopback as it causes white noise */ in alc_fixup_disable_aamix()
5184 spec->gen.mixer_nid = 0; in alc_fixup_disable_aamix()
5197 struct alc_spec *spec = codec->spec; in alc_fixup_tpt440_dock()
5200 spec->reboot_notify = snd_hda_gen_reboot_notify; /* reduce noise */ in alc_fixup_tpt440_dock()
5201 spec->parse_flags = HDA_PINCFG_NO_HP_FIXUP; in alc_fixup_tpt440_dock()
5202 codec->power_save_node = 0; /* avoid click noises */ in alc_fixup_tpt440_dock()
5215 struct alc_spec *spec = codec->spec; in alc_fixup_tpt470_dock()
5218 spec->parse_flags = HDA_PINCFG_NO_HP_FIXUP; in alc_fixup_tpt470_dock()
5241 struct alc_spec *spec = codec->spec; in alc_fixup_tpt470_dacs()
5244 spec->gen.preferred_dacs = preferred_pairs; in alc_fixup_tpt470_dacs()
5249 struct alc_spec *spec = codec->spec; in alc_shutup_dell_xps13()
5261 struct alc_spec *spec = codec->spec; in alc_fixup_dell_xps13()
5262 struct hda_input_mux *imux = &spec->gen.input_mux; in alc_fixup_dell_xps13()
5267 /* mic pin 0x19 must be initialized with Vref Hi-Z, otherwise in alc_fixup_dell_xps13()
5271 spec->shutup = alc_shutup_dell_xps13; in alc_fixup_dell_xps13()
5275 for (i = 0; i < imux->num_items; i++) { in alc_fixup_dell_xps13()
5276 if (spec->gen.imux_pins[i] == 0x12) { in alc_fixup_dell_xps13()
5277 spec->gen.cur_mux[0] = i; in alc_fixup_dell_xps13()
5288 struct alc_spec *spec = codec->spec; in alc_fixup_headset_mode_alc662()
5291 spec->parse_flags |= HDA_PINCFG_HEADSET_MIC; in alc_fixup_headset_mode_alc662()
5292 spec->gen.hp_mic = 1; /* Mic-in is same pin as headphone */ in alc_fixup_headset_mode_alc662()
5294 /* Disable boost for mic-in permanently. (This code is only called in alc_fixup_headset_mode_alc662()
5316 struct alc_spec *spec = codec->spec; in find_ext_mic_pin()
5317 struct auto_pin_cfg *cfg = &spec->gen.autocfg; in find_ext_mic_pin()
5322 for (i = 0; i < cfg->num_inputs; i++) { in find_ext_mic_pin()
5323 if (cfg->inputs[i].type != AUTO_PIN_MIC) in find_ext_mic_pin()
5325 nid = cfg->inputs[i].pin; in find_ext_mic_pin()
5339 struct alc_spec *spec = codec->spec; in alc271_hp_gate_mic_jack()
5355 struct alc_spec *spec = codec->spec; in alc269_fixup_limit_int_mic_boost()
5356 struct auto_pin_cfg *cfg = &spec->gen.autocfg; in alc269_fixup_limit_int_mic_boost()
5366 for (i = 0; i < cfg->num_inputs; i++) { in alc269_fixup_limit_int_mic_boost()
5367 hda_nid_t nid = cfg->inputs[i].pin; in alc269_fixup_limit_int_mic_boost()
5369 if (cfg->inputs[i].type != AUTO_PIN_MIC) in alc269_fixup_limit_int_mic_boost()
5386 struct alc_spec *spec = codec->spec; in alc283_hp_automute_hook()
5392 vref = spec->gen.hp_jack_present ? PIN_VREF80 : 0; in alc283_hp_automute_hook()
5402 struct alc_spec *spec = codec->spec; in alc283_fixup_chromebook()
5407 /* Disable AA-loopback as it causes white noise */ in alc283_fixup_chromebook()
5408 spec->gen.mixer_nid = 0; in alc283_fixup_chromebook()
5411 /* MIC2-VREF control */ in alc283_fixup_chromebook()
5423 struct alc_spec *spec = codec->spec; in alc283_fixup_sense_combo_jack()
5427 spec->gen.hp_automute_hook = alc283_hp_automute_hook; in alc283_fixup_sense_combo_jack()
5430 /* MIC2-VREF control */ in alc283_fixup_sense_combo_jack()
5437 /* mute tablet speaker pin (0x14) via dock plugging in addition */
5440 struct alc_spec *spec = codec->spec; in asus_tx300_automute()
5443 spec->gen.mute_bits |= (1ULL << 0x14); in asus_tx300_automute()
5449 struct alc_spec *spec = codec->spec; in alc282_fixup_asus_tx300()
5457 spec->init_amp = ALC_INIT_DEFAULT; in alc282_fixup_asus_tx300()
5461 spec->gen.auto_mute_via_amp = 1; in alc282_fixup_asus_tx300()
5462 spec->gen.automute_hook = asus_tx300_automute; in alc282_fixup_asus_tx300()
5467 spec->init_amp = ALC_INIT_DEFAULT; in alc282_fixup_asus_tx300()
5500 Amp-out capability. we change the speaker's route to: in alc298_fixup_speaker_volume()
5501 Node 0x02 (Audio Output) -> Node 0x0c (Audio Mixer) -> Node 0x17 ( in alc298_fixup_speaker_volume()
5502 Pin Complex), since Node 0x02 has Amp-out caps, we can adjust in alc298_fixup_speaker_volume()
5534 struct alc_spec *spec = codec->spec; in alc280_hp_gpio4_automute_hook()
5538 alc_update_gpio_led(codec, 0x10, spec->mute_led_polarity, in alc280_hp_gpio4_automute_hook()
5539 !spec->gen.hp_jack_present); in alc280_hp_gpio4_automute_hook()
5545 * GPIO3 is the audio output mute indicator LED
5552 struct alc_spec *spec = codec->spec; in alc280_fixup_hp_9480m()
5557 spec->gpio_mask |= 0x10; in alc280_fixup_hp_9480m()
5558 spec->gpio_dir |= 0x10; in alc280_fixup_hp_9480m()
5559 spec->gen.hp_automute_hook = alc280_hp_gpio4_automute_hook; in alc280_fixup_hp_9480m()
5567 struct alc_spec *spec = codec->spec; in alc275_fixup_gpio4_off()
5570 spec->gpio_mask |= 0x04; in alc275_fixup_gpio4_off()
5571 spec->gpio_dir |= 0x04; in alc275_fixup_gpio4_off()
5584 strcpy(codec->card->longname, "HDAudio-Lenovo-DualCodecs"); in alc233_alc662_fixup_lenovo_dual_codecs()
5589 codec->addr == 0 ? in alc233_alc662_fixup_lenovo_dual_codecs()
5590 "Rear-Panel Capture Volume" : in alc233_alc662_fixup_lenovo_dual_codecs()
5591 "Front-Panel Capture Volume"); in alc233_alc662_fixup_lenovo_dual_codecs()
5593 codec->addr == 0 ? in alc233_alc662_fixup_lenovo_dual_codecs()
5594 "Rear-Panel Capture Switch" : in alc233_alc662_fixup_lenovo_dual_codecs()
5595 "Front-Panel Capture Switch"); in alc233_alc662_fixup_lenovo_dual_codecs()
5606 codec->power_save_node = 1; in alc225_fixup_s3_pop_noise()
5613 struct alc_spec *spec = codec->spec; in alc274_fixup_bind_dacs()
5622 spec->gen.preferred_dacs = preferred_pairs; in alc274_fixup_bind_dacs()
5623 spec->gen.auto_mute_via_amp = 1; in alc274_fixup_bind_dacs()
5624 codec->power_save_node = 0; in alc274_fixup_bind_dacs()
5654 /* for dell wmi mic mute led */
5895 { 0x1a, 0x2101103f }, /* dock line-out */
5896 { 0x1b, 0x23a11040 }, /* dock mic-in */
5930 { 0x19, 0x99a3092f }, /* int-mic */
5937 { 0x12, 0x99a3092f }, /* int-mic */
5949 { 0x19, 0x99a3092f }, /* int-mic */
5957 { 0x12, 0x99a3092f }, /* int-mic */
6137 { 0x1b, 0x99a7012f }, /* int-mic */
6157 { 0x12, 0x99a3092f }, /* int-mic */
6182 /* class-D output amp +5dB */
6199 { 0x12, 0x99a3092f }, /* int-mic */
6380 { 0x1b, 0x21011020 }, /* line-out */
6382 { 0x18, 0x2181103f }, /* line-in */
6391 { 0x1b, 0x21011020 }, /* line-out */
6392 { 0x18, 0x2181103f }, /* line-in */
6503 /* Disable pass-through path for FRONT 14h */
6794 /* Disable PCBEEP-IN passthrough */
6929 SND_PCI_QUIRK(0x1025, 0x072d, "Acer Aspire V5-571G", ALC269_FIXUP_ASPIRE_HEADSET_MIC),
6930 SND_PCI_QUIRK(0x1025, 0x080d, "Acer Aspire V5-122P", ALC269_FIXUP_ASPIRE_HEADSET_MIC),
6933 SND_PCI_QUIRK(0x1025, 0x0762, "Acer Aspire E1-472", ALC271_FIXUP_HP_GATE_MIC_JACK_E1_572),
6934 SND_PCI_QUIRK(0x1025, 0x0775, "Acer Aspire E1-572", ALC271_FIXUP_HP_GATE_MIC_JACK_E1_572),
6935 SND_PCI_QUIRK(0x1025, 0x079b, "Acer Aspire V5-573G", ALC282_FIXUP_ASPIRE_V5_PINS),
6936 SND_PCI_QUIRK(0x1025, 0x102b, "Acer Aspire C24-860", ALC286_FIXUP_ACER_AIO_MIC_NO_PRESENCE),
6938 SND_PCI_QUIRK(0x1025, 0x1099, "Acer Aspire E5-523G", ALC255_FIXUP_ACER_MIC_NO_PRESENCE),
6939 SND_PCI_QUIRK(0x1025, 0x110e, "Acer Aspire ES1-432", ALC255_FIXUP_ACER_MIC_NO_PRESENCE),
6944 SND_PCI_QUIRK(0x1025, 0x1308, "Acer Aspire Z24-890", ALC286_FIXUP_ACER_AIO_HEADSET_MIC),
6945 SND_PCI_QUIRK(0x1025, 0x132a, "Acer TravelMate B114-21", ALC233_FIXUP_ACER_HEADSET_MIC),
6946 SND_PCI_QUIRK(0x1025, 0x1330, "Acer TravelMate X514-51T", ALC255_FIXUP_ACER_HEADSET_MIC),
7111 SND_PCI_QUIRK(0x10f7, 0x8338, "Panasonic CF-SZ6", ALC269_FIXUP_HEADSET_MODE),
7114 SND_PCI_QUIRK(0x1458, 0xfa53, "Gigabyte BXBT-2807", ALC283_FIXUP_HEADSET_MIC),
7115 SND_PCI_QUIRK(0x1462, 0xb120, "MSI Cubi MS-B120", ALC283_FIXUP_HEADSET_MIC),
7116 SND_PCI_QUIRK(0x1462, 0xb171, "Cubi N 8GL (MS-B171)", ALC283_FIXUP_HEADSET_MIC),
7169 SND_PCI_QUIRK(0x17aa, 0x3902, "Lenovo E50-80", ALC269_FIXUP_DMIC_THINKPAD_ACPI),
7171 SND_PCI_QUIRK(0x17aa, 0x3978, "Lenovo B50-70", ALC269_FIXUP_DMIC_THINKPAD_ACPI),
7193 …b7d, 0xa831, "Ordissimo EVE2 ", ALC269VB_FIXUP_ORDISSIMO_EVE2), /* Also known as Malata PC-B1303 */
7257 {.id = ALC269_FIXUP_AMIC, .name = "laptop-amic"},
7258 {.id = ALC269_FIXUP_DMIC, .name = "laptop-dmic"},
7259 {.id = ALC269_FIXUP_STEREO_DMIC, .name = "alc269-dmic"},
7260 {.id = ALC271_FIXUP_DMIC, .name = "alc271-dmic"},
7261 {.id = ALC269_FIXUP_INV_DMIC, .name = "inv-dmic"},
7262 {.id = ALC269_FIXUP_HEADSET_MIC, .name = "headset-mic"},
7263 {.id = ALC269_FIXUP_HEADSET_MODE, .name = "headset-mode"},
7264 {.id = ALC269_FIXUP_HEADSET_MODE_NO_HP_MIC, .name = "headset-mode-no-hp-mic"},
7265 {.id = ALC269_FIXUP_LENOVO_DOCK, .name = "lenovo-dock"},
7266 {.id = ALC269_FIXUP_LENOVO_DOCK_LIMIT_BOOST, .name = "lenovo-dock-limit-boost"},
7267 {.id = ALC269_FIXUP_HP_GPIO_LED, .name = "hp-gpio-led"},
7268 {.id = ALC269_FIXUP_HP_DOCK_GPIO_MIC1_LED, .name = "hp-dock-gpio-mic1-led"},
7269 {.id = ALC269_FIXUP_DELL1_MIC_NO_PRESENCE, .name = "dell-headset-multi"},
7270 {.id = ALC269_FIXUP_DELL2_MIC_NO_PRESENCE, .name = "dell-headset-dock"},
7271 {.id = ALC269_FIXUP_DELL3_MIC_NO_PRESENCE, .name = "dell-headset3"},
7272 {.id = ALC269_FIXUP_DELL4_MIC_NO_PRESENCE, .name = "dell-headset4"},
7273 {.id = ALC283_FIXUP_CHROME_BOOK, .name = "alc283-dac-wcaps"},
7274 {.id = ALC283_FIXUP_SENSE_COMBO_JACK, .name = "alc283-sense-combo"},
7275 {.id = ALC292_FIXUP_TPT440_DOCK, .name = "tpt440-dock"},
7278 {.id = ALC298_FIXUP_TPT470_DOCK_FIX, .name = "tpt470-dock-fix"},
7279 {.id = ALC298_FIXUP_TPT470_DOCK, .name = "tpt470-dock"},
7280 {.id = ALC233_FIXUP_LENOVO_MULTI_CODECS, .name = "dual-codecs"},
7281 {.id = ALC700_FIXUP_INTEL_REFERENCE, .name = "alc700-ref"},
7283 {.id = ALC269_FIXUP_DELL_M101Z, .name = "dell-m101z"},
7284 {.id = ALC269_FIXUP_ASUS_G73JW, .name = "asus-g73jw"},
7285 {.id = ALC269_FIXUP_LENOVO_EAPD, .name = "lenovo-eapd"},
7286 {.id = ALC275_FIXUP_SONY_HWEQ, .name = "sony-hweq"},
7289 {.id = ALC269_FIXUP_LIFEBOOK_EXTMIC, .name = "lifebook-extmic"},
7290 {.id = ALC269_FIXUP_LIFEBOOK_HP_PIN, .name = "lifebook-hp-pin"},
7291 {.id = ALC255_FIXUP_LIFEBOOK_U7x7_HEADSET_MIC, .name = "lifebook-u7x7"},
7292 {.id = ALC269VB_FIXUP_AMIC, .name = "alc269vb-amic"},
7293 {.id = ALC269VB_FIXUP_DMIC, .name = "alc269vb-dmic"},
7294 {.id = ALC269_FIXUP_HP_MUTE_LED_MIC1, .name = "hp-mute-led-mic1"},
7295 {.id = ALC269_FIXUP_HP_MUTE_LED_MIC2, .name = "hp-mute-led-mic2"},
7296 {.id = ALC269_FIXUP_HP_MUTE_LED_MIC3, .name = "hp-mute-led-mic3"},
7297 {.id = ALC269_FIXUP_HP_GPIO_MIC1_LED, .name = "hp-gpio-mic1"},
7298 {.id = ALC269_FIXUP_HP_LINE1_MIC1_LED, .name = "hp-line1-mic1"},
7300 {.id = ALC286_FIXUP_SONY_MIC_NO_PRESENCE, .name = "sony-nomic"},
7301 {.id = ALC269_FIXUP_ASPIRE_HEADSET_MIC, .name = "aspire-headset-mic"},
7302 {.id = ALC269_FIXUP_ASUS_X101, .name = "asus-x101"},
7303 {.id = ALC271_FIXUP_HP_GATE_MIC_JACK, .name = "acer-ao7xx"},
7304 {.id = ALC271_FIXUP_HP_GATE_MIC_JACK_E1_572, .name = "acer-aspire-e1"},
7305 {.id = ALC269_FIXUP_ACER_AC700, .name = "acer-ac700"},
7306 {.id = ALC269_FIXUP_LIMIT_INT_MIC_BOOST, .name = "limit-mic-boost"},
7307 {.id = ALC269VB_FIXUP_ASUS_ZENBOOK, .name = "asus-zenbook"},
7308 {.id = ALC269VB_FIXUP_ASUS_ZENBOOK_UX31A, .name = "asus-zenbook-ux31a"},
7310 {.id = ALC282_FIXUP_ASUS_TX300, .name = "asus-tx300"},
7311 {.id = ALC283_FIXUP_INT_MIC, .name = "alc283-int-mic"},
7312 {.id = ALC290_FIXUP_MONO_SPEAKERS_HSJACK, .name = "mono-speakers"},
7313 {.id = ALC290_FIXUP_SUBWOOFER_HSJACK, .name = "alc290-subwoofer"},
7315 {.id = ALC269_FIXUP_DMIC_THINKPAD_ACPI, .name = "dmic-thinkpad"},
7316 {.id = ALC255_FIXUP_ACER_MIC_NO_PRESENCE, .name = "alc255-acer"},
7317 {.id = ALC255_FIXUP_ASUS_MIC_NO_PRESENCE, .name = "alc255-asus"},
7318 {.id = ALC255_FIXUP_DELL1_MIC_NO_PRESENCE, .name = "alc255-dell1"},
7319 {.id = ALC255_FIXUP_DELL2_MIC_NO_PRESENCE, .name = "alc255-dell2"},
7320 {.id = ALC293_FIXUP_DELL1_MIC_NO_PRESENCE, .name = "alc293-dell1"},
7321 {.id = ALC283_FIXUP_HEADSET_MIC, .name = "alc283-headset"},
7322 {.id = ALC255_FIXUP_DELL_WMI_MIC_MUTE_LED, .name = "alc255-dell-mute"},
7323 {.id = ALC282_FIXUP_ASPIRE_V5_PINS, .name = "aspire-v5"},
7324 {.id = ALC280_FIXUP_HP_GPIO4, .name = "hp-gpio4"},
7325 {.id = ALC286_FIXUP_HP_GPIO_LED, .name = "hp-gpio-led"},
7326 {.id = ALC280_FIXUP_HP_GPIO2_MIC_HOTKEY, .name = "hp-gpio2-hotkey"},
7327 {.id = ALC280_FIXUP_HP_DOCK_PINS, .name = "hp-dock-pins"},
7328 {.id = ALC269_FIXUP_HP_DOCK_GPIO_MIC1_LED, .name = "hp-dock-gpio-mic"},
7329 {.id = ALC280_FIXUP_HP_9480M, .name = "hp-9480m"},
7330 {.id = ALC288_FIXUP_DELL_HEADSET_MODE, .name = "alc288-dell-headset"},
7331 {.id = ALC288_FIXUP_DELL1_MIC_NO_PRESENCE, .name = "alc288-dell1"},
7332 {.id = ALC288_FIXUP_DELL_XPS_13, .name = "alc288-dell-xps13"},
7333 {.id = ALC292_FIXUP_DELL_E7X, .name = "dell-e7x"},
7334 {.id = ALC293_FIXUP_DISABLE_AAMIX_MULTIJACK, .name = "alc293-dell"},
7335 {.id = ALC298_FIXUP_DELL1_MIC_NO_PRESENCE, .name = "alc298-dell1"},
7336 {.id = ALC298_FIXUP_DELL_AIO_MIC_NO_PRESENCE, .name = "alc298-dell-aio"},
7337 {.id = ALC275_FIXUP_DELL_XPS, .name = "alc275-dell-xps"},
7338 {.id = ALC293_FIXUP_LENOVO_SPK_NOISE, .name = "lenovo-spk-noise"},
7339 {.id = ALC233_FIXUP_LENOVO_LINE2_MIC_HOTKEY, .name = "lenovo-hotkey"},
7340 {.id = ALC255_FIXUP_DELL_SPK_NOISE, .name = "dell-spk-noise"},
7341 {.id = ALC225_FIXUP_DELL1_MIC_NO_PRESENCE, .name = "alc225-dell1"},
7342 {.id = ALC295_FIXUP_DISABLE_DAC3, .name = "alc295-disable-dac3"},
7343 {.id = ALC285_FIXUP_SPEAKER2_TO_DAC1, .name = "alc285-speaker2-to-dac1"},
7344 {.id = ALC280_FIXUP_HP_HEADSET_MIC, .name = "alc280-hp-headset"},
7345 {.id = ALC221_FIXUP_HP_FRONT_MIC, .name = "alc221-hp-mic"},
7346 {.id = ALC298_FIXUP_SPK_VOLUME, .name = "alc298-spk-volume"},
7347 {.id = ALC256_FIXUP_DELL_INSPIRON_7559_SUBWOOFER, .name = "dell-inspiron-7559"},
7348 {.id = ALC269_FIXUP_ATIV_BOOK_8, .name = "ativ-book"},
7349 {.id = ALC221_FIXUP_HP_MIC_NO_PRESENCE, .name = "alc221-hp-mic"},
7350 {.id = ALC256_FIXUP_ASUS_HEADSET_MODE, .name = "alc256-asus-headset"},
7351 {.id = ALC256_FIXUP_ASUS_MIC, .name = "alc256-asus-mic"},
7352 {.id = ALC256_FIXUP_ASUS_AIO_GPIO2, .name = "alc256-asus-aio"},
7353 {.id = ALC233_FIXUP_ASUS_MIC_NO_PRESENCE, .name = "alc233-asus"},
7354 {.id = ALC233_FIXUP_EAPD_COEF_AND_MIC_NO_PRESENCE, .name = "alc233-eapd"},
7355 {.id = ALC294_FIXUP_LENOVO_MIC_LOCATION, .name = "alc294-lenovo-mic"},
7356 {.id = ALC225_FIXUP_DELL_WYSE_MIC_NO_PRESENCE, .name = "alc225-wyse"},
7357 {.id = ALC274_FIXUP_DELL_AIO_LINEOUT_VERB, .name = "alc274-dell-aio"},
7358 {.id = ALC255_FIXUP_DUMMY_LINEOUT_VERB, .name = "alc255-dummy-lineout"},
7359 {.id = ALC255_FIXUP_DELL_HEADSET_MIC, .name = "alc255-dell-headset"},
7360 {.id = ALC295_FIXUP_HP_X360, .name = "alc295-hp-x360"},
7361 {.id = ALC299_FIXUP_PREDATOR_SPK, .name = "predator-spk"},
7362 {.id = ALC256_FIXUP_MEDION_HEADSET_NO_PRESENCE, .name = "alc256-medion-headset"},
7794 struct alc_spec *spec = codec->spec; in alc269_fill_coef()
7797 if (spec->codec_variant != ALC269_TYPE_ALC269VB) in alc269_fill_coef()
7817 if (val != -1 && (val & 0x0c00) >> 10 != 0x1) { in alc269_fill_coef()
7822 if (val != -1 && (val & 0x01c0) >> 6 != 0x4) { in alc269_fill_coef()
7843 spec = codec->spec; in patch_alc269()
7844 spec->gen.shared_mic_vref_pin = 0x18; in patch_alc269()
7845 codec->power_save_node = 0; in patch_alc269()
7848 codec->patch_ops.suspend = alc269_suspend; in patch_alc269()
7849 codec->patch_ops.resume = alc269_resume; in patch_alc269()
7851 spec->shutup = alc_default_shutup; in patch_alc269()
7852 spec->init_hook = alc_default_init; in patch_alc269()
7854 switch (codec->core.vendor_id) { in patch_alc269()
7856 spec->codec_variant = ALC269_TYPE_ALC269VA; in patch_alc269()
7859 if (codec->bus->pci && in patch_alc269()
7860 codec->bus->pci->subsystem_vendor == 0x1025 && in patch_alc269()
7861 spec->cdefine.platform_type == 1) in patch_alc269()
7863 spec->codec_variant = ALC269_TYPE_ALC269VB; in patch_alc269()
7866 if (codec->bus->pci && in patch_alc269()
7867 codec->bus->pci->subsystem_vendor == 0x17aa && in patch_alc269()
7868 codec->bus->pci->subsystem_device == 0x21f3) in patch_alc269()
7870 spec->codec_variant = ALC269_TYPE_ALC269VC; in patch_alc269()
7873 spec->codec_variant = ALC269_TYPE_ALC269VD; in patch_alc269()
7880 spec->shutup = alc269_shutup; in patch_alc269()
7881 spec->init_hook = alc269_fill_coef; in patch_alc269()
7887 spec->codec_variant = ALC269_TYPE_ALC280; in patch_alc269()
7890 spec->codec_variant = ALC269_TYPE_ALC282; in patch_alc269()
7891 spec->shutup = alc282_shutup; in patch_alc269()
7892 spec->init_hook = alc282_init; in patch_alc269()
7896 spec->codec_variant = ALC269_TYPE_ALC283; in patch_alc269()
7897 spec->shutup = alc283_shutup; in patch_alc269()
7898 spec->init_hook = alc283_init; in patch_alc269()
7902 spec->codec_variant = ALC269_TYPE_ALC284; in patch_alc269()
7905 spec->codec_variant = ALC269_TYPE_ALC293; in patch_alc269()
7909 spec->codec_variant = ALC269_TYPE_ALC286; in patch_alc269()
7912 spec->codec_variant = ALC269_TYPE_ALC298; in patch_alc269()
7916 spec->codec_variant = ALC269_TYPE_ALC255; in patch_alc269()
7917 spec->shutup = alc256_shutup; in patch_alc269()
7918 spec->init_hook = alc256_init; in patch_alc269()
7922 spec->codec_variant = ALC269_TYPE_ALC256; in patch_alc269()
7923 spec->shutup = alc256_shutup; in patch_alc269()
7924 spec->init_hook = alc256_init; in patch_alc269()
7925 spec->gen.mixer_nid = 0; /* ALC256 does not have any loopback mixer path */ in patch_alc269()
7928 spec->codec_variant = ALC269_TYPE_ALC257; in patch_alc269()
7929 spec->shutup = alc256_shutup; in patch_alc269()
7930 spec->init_hook = alc256_init; in patch_alc269()
7931 spec->gen.mixer_nid = 0; in patch_alc269()
7938 spec->codec_variant = ALC269_TYPE_ALC215; in patch_alc269()
7939 spec->shutup = alc225_shutup; in patch_alc269()
7940 spec->init_hook = alc225_init; in patch_alc269()
7941 spec->gen.mixer_nid = 0; in patch_alc269()
7946 spec->codec_variant = ALC269_TYPE_ALC225; in patch_alc269()
7947 spec->shutup = alc225_shutup; in patch_alc269()
7948 spec->init_hook = alc225_init; in patch_alc269()
7949 spec->gen.mixer_nid = 0; /* no loopback on ALC225, ALC295 and ALC299 */ in patch_alc269()
7954 spec->codec_variant = ALC269_TYPE_ALC294; in patch_alc269()
7955 spec->gen.mixer_nid = 0; /* ALC2x4 does not have any loopback mixer path */ in patch_alc269()
7957 spec->init_hook = alc294_init; in patch_alc269()
7960 spec->codec_variant = ALC269_TYPE_ALC300; in patch_alc269()
7961 spec->gen.mixer_nid = 0; /* no loopback on ALC300 */ in patch_alc269()
7964 spec->codec_variant = ALC269_TYPE_ALC623; in patch_alc269()
7970 spec->codec_variant = ALC269_TYPE_ALC700; in patch_alc269()
7971 spec->gen.mixer_nid = 0; /* ALC700 does not have any loopback mixer path */ in patch_alc269()
7973 spec->init_hook = alc294_init; in patch_alc269()
7979 spec->has_alc5505_dsp = 1; in patch_alc269()
7980 spec->init_hook = alc5505_dsp_init; in patch_alc269()
7993 spec->gen.beep_nid = 0x01; in patch_alc269()
8000 if (!spec->gen.no_analog && spec->gen.beep_nid && spec->gen.mixer_nid) { in patch_alc269()
8001 err = set_beep_amp(spec, spec->gen.mixer_nid, 0x04, HDA_INPUT); in patch_alc269()
8039 struct alc_spec *spec = codec->spec; in alc861_fixup_asus_amp_vref_0f()
8049 spec->gen.keep_vref_in_automute = 1; in alc861_fixup_asus_amp_vref_0f()
8052 /* suppress the jack-detection */
8057 codec->no_jack_detect = 1; in alc_fixup_no_jack_detect()
8118 spec = codec->spec; in patch_alc861()
8119 spec->gen.beep_nid = 0x23; in patch_alc861()
8122 spec->power_hook = alc_power_eapd; in patch_alc861()
8133 if (!spec->gen.no_analog) { in patch_alc861()
8149 * ALC861-VD support
8181 struct alc_spec *spec = codec->spec; in alc660vd_fixup_asus_gpio1()
8184 spec->gpio_mask |= 0x02; in alc660vd_fixup_asus_gpio1()
8201 SND_PCI_QUIRK(0x1043, 0x1339, "ASUS A7-K", ALC660VD_FIX_ASUS_GPIO1),
8202 SND_PCI_QUIRK(0x1179, 0xff31, "Toshiba L30-149", ALC861VD_FIX_DALLAS),
8217 spec = codec->spec; in patch_alc861vd()
8218 spec->gen.beep_nid = 0x23; in patch_alc861vd()
8220 spec->shutup = alc_eapd_shutup; in patch_alc861vd()
8230 if (!spec->gen.no_analog) { in patch_alc861vd()
8251 * 6-channel independent captures.
8253 * In addition, an independent DAC for the multi-playback (not used in this
8268 if (codec->core.vendor_id == 0x10ec0272 || codec->core.vendor_id == 0x10ec0663 || in alc662_parse_auto_config()
8269 codec->core.vendor_id == 0x10ec0665 || codec->core.vendor_id == 0x10ec0670 || in alc662_parse_auto_config()
8270 codec->core.vendor_id == 0x10ec0671) in alc662_parse_auto_config()
8304 struct alc_spec *spec = codec->spec; in alc_fixup_bass_chmap()
8305 spec->gen.pcm_rec[0]->stream[0].chmap = asus_pcm_2_1_chmaps; in alc_fixup_bass_chmap()
8314 struct alc_spec *spec = codec->spec; in gpio_led_power_filter()
8315 if (nid == codec->core.afg && power_state == AC_PWRST_D3 && spec->gpio_data) in gpio_led_power_filter()
8323 struct alc_spec *spec = codec->spec; in alc662_fixup_led_gpio1()
8327 spec->mute_led_polarity = 1; in alc662_fixup_led_gpio1()
8328 codec->power_filter = gpio_led_power_filter; in alc662_fixup_led_gpio1()
8335 struct alc_spec *spec = codec->spec; in alc662_usi_automute_hook()
8340 vref = spec->gen.hp_jack_present ? PIN_VREF80 : 0; in alc662_usi_automute_hook()
8349 struct alc_spec *spec = codec->spec; in alc662_fixup_usi_headset_mic()
8351 spec->parse_flags |= HDA_PINCFG_HEADSET_MIC; in alc662_fixup_usi_headset_mic()
8352 spec->gen.hp_automute_hook = alc662_usi_automute_hook; in alc662_fixup_usi_headset_mic()
8479 { 0x19, 0x99a3092f }, /* int-mic */
8491 { 0x19, 0x99a3092f }, /* int-mic */
8504 { 0x19, 0x99a3094f }, /* int-mic */
8517 { 0x19, 0x99a3094f }, /* int-mic */
8531 { 0x19, 0x99a3094f }, /* int-mic */
8543 { 0x19, 0x99a3094f }, /* int-mic */
8556 { 0x19, 0x99a3094f }, /* int-mic */
8568 { 0x12, 0x99a30970 }, /* int-mic */
8863 {.id = ALC662_FIXUP_HP_RP5800, .name = "hp-rp5800"},
8864 {.id = ALC662_FIXUP_ASUS_MODE1, .name = "asus-mode1"},
8865 {.id = ALC662_FIXUP_ASUS_MODE2, .name = "asus-mode2"},
8866 {.id = ALC662_FIXUP_ASUS_MODE3, .name = "asus-mode3"},
8867 {.id = ALC662_FIXUP_ASUS_MODE4, .name = "asus-mode4"},
8868 {.id = ALC662_FIXUP_ASUS_MODE5, .name = "asus-mode5"},
8869 {.id = ALC662_FIXUP_ASUS_MODE6, .name = "asus-mode6"},
8870 {.id = ALC662_FIXUP_ASUS_MODE7, .name = "asus-mode7"},
8871 {.id = ALC662_FIXUP_ASUS_MODE8, .name = "asus-mode8"},
8872 {.id = ALC662_FIXUP_ZOTAC_Z68, .name = "zotac-z68"},
8873 {.id = ALC662_FIXUP_INV_DMIC, .name = "inv-dmic"},
8874 {.id = ALC662_FIXUP_DELL_MIC_NO_PRESENCE, .name = "alc662-headset-multi"},
8875 {.id = ALC668_FIXUP_DELL_MIC_NO_PRESENCE, .name = "dell-headset-multi"},
8876 {.id = ALC662_FIXUP_HEADSET_MODE, .name = "alc662-headset"},
8877 {.id = ALC668_FIXUP_HEADSET_MODE, .name = "alc668-headset"},
8881 {.id = ALC668_FIXUP_DELL_XPS13, .name = "dell-xps13"},
8882 {.id = ALC662_FIXUP_ASUS_Nx50, .name = "asus-nx50"},
8883 {.id = ALC668_FIXUP_ASUS_Nx51, .name = "asus-nx51"},
8884 {.id = ALC891_FIXUP_HEADSET_MODE, .name = "alc891-headset"},
8885 {.id = ALC891_FIXUP_DELL_MIC_NO_PRESENCE, .name = "alc891-headset-multi"},
8886 {.id = ALC662_FIXUP_ACER_VERITON, .name = "acer-veriton"},
8887 {.id = ALC892_FIXUP_ASROCK_MOBO, .name = "asrock-mobo"},
8888 {.id = ALC662_FIXUP_USI_HEADSET_MODE, .name = "usi-headset"},
8889 {.id = ALC662_FIXUP_LENOVO_MULTI_CODECS, .name = "dual-codecs"},
8946 spec = codec->spec; in patch_alc662()
8948 spec->shutup = alc_eapd_shutup; in patch_alc662()
8951 spec->parse_flags = HDA_PINCFG_NO_HP_FIXUP; in patch_alc662()
8955 switch (codec->core.vendor_id) { in patch_alc662()
8957 spec->init_hook = alc668_restore_default_value; in patch_alc662()
8969 spec->gen.beep_nid = 0x01; in patch_alc662()
8972 codec->bus->pci && codec->bus->pci->subsystem_vendor == 0x1025 && in patch_alc662()
8973 spec->cdefine.platform_type == 1) { in patch_alc662()
8984 if (!spec->gen.no_analog && spec->gen.beep_nid) { in patch_alc662()
8985 switch (codec->core.vendor_id) { in patch_alc662()
9027 /* ALC680 has no aa-loopback mixer */ in patch_alc680()
9088 HDA_CODEC_ENTRY(0x10ec0660, "ALC660-VD", patch_alc861vd),
9090 HDA_CODEC_ENTRY(0x10ec0862, "ALC861-VD", patch_alc861vd),
9127 MODULE_DESCRIPTION("Realtek HD-audio codec");