Lines Matching refs:codec

253 				   struct hda_codec *codec,  in stac_playback_pcm_hook()  argument
257 struct sigmatel_spec *spec = codec->spec; in stac_playback_pcm_hook()
263 struct hda_codec *codec, in stac_capture_pcm_hook() argument
267 struct sigmatel_spec *spec = codec->spec; in stac_capture_pcm_hook()
283 snd_hda_codec_write(codec, hinfo->nid, 0, in stac_capture_pcm_hook()
288 snd_hda_codec_write(codec, hinfo->nid, 0, in stac_capture_pcm_hook()
300 static void stac_gpio_set(struct hda_codec *codec, unsigned int mask, in stac_gpio_set() argument
304 hda_nid_t fg = codec->core.afg; in stac_gpio_set()
306 codec_dbg(codec, "%s msk %x dir %x gpio %x\n", __func__, mask, dir_mask, data); in stac_gpio_set()
308 gpiostate = snd_hda_codec_read(codec, fg, 0, in stac_gpio_set()
312 gpiomask = snd_hda_codec_read(codec, fg, 0, in stac_gpio_set()
316 gpiodir = snd_hda_codec_read(codec, fg, 0, in stac_gpio_set()
321 snd_hda_codec_write(codec, fg, 0, 0x7e7, 0); in stac_gpio_set()
323 snd_hda_codec_write(codec, fg, 0, in stac_gpio_set()
325 snd_hda_codec_read(codec, fg, 0, in stac_gpio_set()
330 snd_hda_codec_read(codec, fg, 0, in stac_gpio_set()
335 static void stac_capture_led_update(struct hda_codec *codec) in stac_capture_led_update() argument
337 struct sigmatel_spec *spec = codec->spec; in stac_capture_led_update()
343 stac_gpio_set(codec, spec->gpio_mask, spec->gpio_dir, spec->gpio_data); in stac_capture_led_update()
346 static int stac_vrefout_set(struct hda_codec *codec, in stac_vrefout_set() argument
351 codec_dbg(codec, "%s, nid %x ctl %x\n", __func__, nid, new_vref); in stac_vrefout_set()
352 pinctl = snd_hda_codec_read(codec, nid, 0, in stac_vrefout_set()
362 error = snd_hda_set_pin_ctl_cache(codec, nid, pinctl); in stac_vrefout_set()
371 static unsigned int stac_vref_led_power_filter(struct hda_codec *codec, in stac_vref_led_power_filter() argument
375 if (nid == codec->core.afg && power_state == AC_PWRST_D3) in stac_vref_led_power_filter()
377 return snd_hda_gen_path_power_filter(codec, nid, power_state); in stac_vref_led_power_filter()
381 static void stac_update_led_status(struct hda_codec *codec, int enabled) in stac_update_led_status() argument
383 struct sigmatel_spec *spec = codec->spec; in stac_update_led_status()
398 stac_gpio_set(codec, spec->gpio_mask, in stac_update_led_status()
402 stac_vrefout_set(codec, spec->vref_mute_led_nid, in stac_update_led_status()
414 static void stac_update_outputs(struct hda_codec *codec) in stac_update_outputs() argument
416 struct sigmatel_spec *spec = codec->spec; in stac_update_outputs()
420 !(snd_hda_codec_read(codec, codec->core.afg, 0, in stac_update_outputs()
423 snd_hda_gen_update_outputs(codec); in stac_update_outputs()
433 stac_gpio_set(codec, spec->gpio_mask, spec->gpio_dir, in stac_update_outputs()
439 static void stac_toggle_power_map(struct hda_codec *codec, hda_nid_t nid, in stac_toggle_power_map() argument
442 struct sigmatel_spec *spec = codec->spec; in stac_toggle_power_map()
464 snd_hda_codec_write(codec, codec->core.afg, 0, in stac_toggle_power_map()
470 static void jack_update_power(struct hda_codec *codec, in jack_update_power() argument
473 struct sigmatel_spec *spec = codec->spec; in jack_update_power()
480 stac_toggle_power_map(codec, jack->nid, in jack_update_power()
481 snd_hda_jack_detect(codec, jack->nid), in jack_update_power()
489 if (!snd_hda_jack_tbl_get(codec, nid)) in jack_update_power()
491 stac_toggle_power_map(codec, nid, in jack_update_power()
492 snd_hda_jack_detect(codec, nid), in jack_update_power()
496 snd_hda_codec_write(codec, codec->core.afg, 0, in jack_update_power()
501 static void stac_vref_event(struct hda_codec *codec, in stac_vref_event() argument
506 data = snd_hda_codec_read(codec, codec->core.afg, 0, in stac_vref_event()
509 snd_hda_codec_write(codec, codec->core.afg, 0, 0x7e0, in stac_vref_event()
516 static void stac_init_power_map(struct hda_codec *codec) in stac_init_power_map() argument
518 struct sigmatel_spec *spec = codec->spec; in stac_init_power_map()
523 unsigned int def_conf = snd_hda_codec_get_pincfg(codec, nid); in stac_init_power_map()
527 is_jack_detectable(codec, nid)) { in stac_init_power_map()
528 snd_hda_jack_detect_enable_callback(codec, nid, in stac_init_power_map()
532 stac_toggle_power_map(codec, nid, false, false); in stac_init_power_map()
534 stac_toggle_power_map(codec, nid, true, false); in stac_init_power_map()
542 static inline bool get_int_hint(struct hda_codec *codec, const char *key, in get_int_hint() argument
545 return !snd_hda_get_int_hint(codec, key, valp); in get_int_hint()
549 static void stac_store_hints(struct hda_codec *codec) in stac_store_hints() argument
551 struct sigmatel_spec *spec = codec->spec; in stac_store_hints()
554 if (get_int_hint(codec, "gpio_mask", &spec->gpio_mask)) { in stac_store_hints()
558 if (get_int_hint(codec, "gpio_dir", &spec->gpio_dir)) in stac_store_hints()
560 if (get_int_hint(codec, "gpio_data", &spec->gpio_data)) in stac_store_hints()
562 if (get_int_hint(codec, "eapd_mask", &spec->eapd_mask)) in stac_store_hints()
564 if (get_int_hint(codec, "gpio_mute", &spec->gpio_mute)) in stac_store_hints()
566 val = snd_hda_get_bool_hint(codec, "eapd_switch"); in stac_store_hints()
580 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in stac_aloopback_get() local
582 struct sigmatel_spec *spec = codec->spec; in stac_aloopback_get()
592 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in stac_aloopback_put() local
593 struct sigmatel_spec *spec = codec->spec; in stac_aloopback_put()
611 dac_mode = snd_hda_codec_read(codec, codec->core.afg, 0, in stac_aloopback_put()
616 snd_hda_power_up(codec); in stac_aloopback_put()
619 snd_hda_power_down(codec); in stac_aloopback_put()
623 snd_hda_codec_write_cache(codec, codec->core.afg, 0, in stac_aloopback_put()
645 static bool hp_bnb2011_with_dock(struct hda_codec *codec) in hp_bnb2011_with_dock() argument
647 if (codec->core.vendor_id != 0x111d7605 && in hp_bnb2011_with_dock()
648 codec->core.vendor_id != 0x111d76d1) in hp_bnb2011_with_dock()
651 switch (codec->core.subsystem_id) { in hp_bnb2011_with_dock()
715 static void set_hp_led_gpio(struct hda_codec *codec) in set_hp_led_gpio() argument
717 struct sigmatel_spec *spec = codec->spec; in set_hp_led_gpio()
723 gpio = snd_hda_param_read(codec, codec->core.afg, AC_PAR_GPIO_CAP); in set_hp_led_gpio()
751 static int find_mute_led_cfg(struct hda_codec *codec, int default_polarity) in find_mute_led_cfg() argument
753 struct sigmatel_spec *spec = codec->spec; in find_mute_led_cfg()
756 if (get_int_hint(codec, "gpio_led", &spec->gpio_led)) { in find_mute_led_cfg()
757 get_int_hint(codec, "gpio_led_polarity", in find_mute_led_cfg()
767 max_gpio = snd_hda_param_read(codec, codec->core.afg, in find_mute_led_cfg()
778 set_hp_led_gpio(codec); in find_mute_led_cfg()
783 set_hp_led_gpio(codec); in find_mute_led_cfg()
797 if (!hp_blike_system(codec->core.subsystem_id) && in find_mute_led_cfg()
799 set_hp_led_gpio(codec); in find_mute_led_cfg()
807 static bool has_builtin_speaker(struct hda_codec *codec) in has_builtin_speaker() argument
809 struct sigmatel_spec *spec = codec->spec; in has_builtin_speaker()
822 unsigned int def_conf = snd_hda_codec_get_pincfg(codec, nid_pin[i]); in has_builtin_speaker()
834 static int stac_auto_create_beep_ctls(struct hda_codec *codec, in stac_auto_create_beep_ctls() argument
837 struct sigmatel_spec *spec = codec->spec; in stac_auto_create_beep_ctls()
838 u32 caps = query_amp_caps(codec, nid, HDA_OUTPUT); in stac_auto_create_beep_ctls()
881 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in stac_dig_beep_switch_get() local
882 ucontrol->value.integer.value[0] = codec->beep->enabled; in stac_dig_beep_switch_get()
889 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in stac_dig_beep_switch_put() local
890 return snd_hda_enable_beep_device(codec, ucontrol->value.integer.value[0]); in stac_dig_beep_switch_put()
901 static int stac_beep_switch_ctl(struct hda_codec *codec) in stac_beep_switch_ctl() argument
903 struct sigmatel_spec *spec = codec->spec; in stac_beep_switch_ctl()
918 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in stac_smux_enum_info() local
919 struct sigmatel_spec *spec = codec->spec; in stac_smux_enum_info()
926 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in stac_smux_enum_get() local
927 struct sigmatel_spec *spec = codec->spec; in stac_smux_enum_get()
937 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in stac_smux_enum_put() local
938 struct sigmatel_spec *spec = codec->spec; in stac_smux_enum_put()
941 return snd_hda_input_mux_put(codec, &spec->spdif_mux, ucontrol, in stac_smux_enum_put()
959 static int stac_create_spdif_mux_ctls(struct hda_codec *codec) in stac_create_spdif_mux_ctls() argument
961 struct sigmatel_spec *spec = codec->spec; in stac_create_spdif_mux_ctls()
970 num_cons = snd_hda_get_num_conns(codec, cfg->dig_out_pins[0]); in stac_create_spdif_mux_ctls()
979 snd_hda_add_imux_item(codec, &spec->spdif_mux, labels[i], i, NULL); in stac_create_spdif_mux_ctls()
1368 static void stac9200_fixup_panasonic(struct hda_codec *codec, in stac9200_fixup_panasonic() argument
1371 struct sigmatel_spec *spec = codec->spec; in stac9200_fixup_panasonic()
1796 static void stac92hd73xx_fixup_ref(struct hda_codec *codec, in stac92hd73xx_fixup_ref() argument
1799 struct sigmatel_spec *spec = codec->spec; in stac92hd73xx_fixup_ref()
1804 snd_hda_apply_pincfgs(codec, ref92hd73xx_pin_configs); in stac92hd73xx_fixup_ref()
1808 static void stac92hd73xx_fixup_dell(struct hda_codec *codec) in stac92hd73xx_fixup_dell() argument
1810 struct sigmatel_spec *spec = codec->spec; in stac92hd73xx_fixup_dell()
1812 snd_hda_apply_pincfgs(codec, dell_m6_pin_configs); in stac92hd73xx_fixup_dell()
1816 static void stac92hd73xx_fixup_dell_eq(struct hda_codec *codec, in stac92hd73xx_fixup_dell_eq() argument
1819 struct sigmatel_spec *spec = codec->spec; in stac92hd73xx_fixup_dell_eq()
1824 stac92hd73xx_fixup_dell(codec); in stac92hd73xx_fixup_dell_eq()
1825 snd_hda_add_verbs(codec, dell_eq_core_init); in stac92hd73xx_fixup_dell_eq()
1830 static void stac92hd73xx_fixup_dell_m6_amic(struct hda_codec *codec, in stac92hd73xx_fixup_dell_m6_amic() argument
1836 stac92hd73xx_fixup_dell(codec); in stac92hd73xx_fixup_dell_m6_amic()
1837 snd_hda_codec_set_pincfg(codec, 0x0b, 0x90A70170); in stac92hd73xx_fixup_dell_m6_amic()
1841 static void stac92hd73xx_fixup_dell_m6_dmic(struct hda_codec *codec, in stac92hd73xx_fixup_dell_m6_dmic() argument
1847 stac92hd73xx_fixup_dell(codec); in stac92hd73xx_fixup_dell_m6_dmic()
1848 snd_hda_codec_set_pincfg(codec, 0x13, 0x90A60160); in stac92hd73xx_fixup_dell_m6_dmic()
1852 static void stac92hd73xx_fixup_dell_m6_both(struct hda_codec *codec, in stac92hd73xx_fixup_dell_m6_both() argument
1858 stac92hd73xx_fixup_dell(codec); in stac92hd73xx_fixup_dell_m6_both()
1859 snd_hda_codec_set_pincfg(codec, 0x0b, 0x90A70170); in stac92hd73xx_fixup_dell_m6_both()
1860 snd_hda_codec_set_pincfg(codec, 0x13, 0x90A60160); in stac92hd73xx_fixup_dell_m6_both()
1863 static void stac92hd73xx_fixup_alienware_m17x(struct hda_codec *codec, in stac92hd73xx_fixup_alienware_m17x() argument
1866 struct sigmatel_spec *spec = codec->spec; in stac92hd73xx_fixup_alienware_m17x()
1871 snd_hda_apply_pincfgs(codec, alienware_m17x_pin_configs); in stac92hd73xx_fixup_alienware_m17x()
1875 static void stac92hd73xx_fixup_no_jd(struct hda_codec *codec, in stac92hd73xx_fixup_no_jd() argument
1879 codec->no_jack_detect = 1; in stac92hd73xx_fixup_no_jd()
2085 static void stac92hd83xxx_fixup_hp(struct hda_codec *codec, in stac92hd83xxx_fixup_hp() argument
2088 struct sigmatel_spec *spec = codec->spec; in stac92hd83xxx_fixup_hp()
2093 if (hp_bnb2011_with_dock(codec)) { in stac92hd83xxx_fixup_hp()
2094 snd_hda_codec_set_pincfg(codec, 0xa, 0x2101201f); in stac92hd83xxx_fixup_hp()
2095 snd_hda_codec_set_pincfg(codec, 0xf, 0x2181205e); in stac92hd83xxx_fixup_hp()
2098 if (find_mute_led_cfg(codec, spec->default_polarity)) in stac92hd83xxx_fixup_hp()
2099 codec_dbg(codec, "mute LED gpio %d polarity %d\n", in stac92hd83xxx_fixup_hp()
2107 static void stac92hd83xxx_fixup_hp_zephyr(struct hda_codec *codec, in stac92hd83xxx_fixup_hp_zephyr() argument
2113 snd_hda_apply_pincfgs(codec, hp_zephyr_pin_configs); in stac92hd83xxx_fixup_hp_zephyr()
2114 snd_hda_add_verbs(codec, stac92hd83xxx_hp_zephyr_init); in stac92hd83xxx_fixup_hp_zephyr()
2117 static void stac92hd83xxx_fixup_hp_led(struct hda_codec *codec, in stac92hd83xxx_fixup_hp_led() argument
2120 struct sigmatel_spec *spec = codec->spec; in stac92hd83xxx_fixup_hp_led()
2126 static void stac92hd83xxx_fixup_hp_inv_led(struct hda_codec *codec, in stac92hd83xxx_fixup_hp_inv_led() argument
2129 struct sigmatel_spec *spec = codec->spec; in stac92hd83xxx_fixup_hp_inv_led()
2135 static void stac92hd83xxx_fixup_hp_mic_led(struct hda_codec *codec, in stac92hd83xxx_fixup_hp_mic_led() argument
2138 struct sigmatel_spec *spec = codec->spec; in stac92hd83xxx_fixup_hp_mic_led()
2144 codec->core.power_caps &= ~AC_PWRST_CLKSTOP; in stac92hd83xxx_fixup_hp_mic_led()
2149 static void stac92hd83xxx_fixup_hp_led_gpio10(struct hda_codec *codec, in stac92hd83xxx_fixup_hp_led_gpio10() argument
2152 struct sigmatel_spec *spec = codec->spec; in stac92hd83xxx_fixup_hp_led_gpio10()
2160 static void stac92hd83xxx_fixup_headset_jack(struct hda_codec *codec, in stac92hd83xxx_fixup_headset_jack() argument
2163 struct sigmatel_spec *spec = codec->spec; in stac92hd83xxx_fixup_headset_jack()
2169 static void stac92hd83xxx_fixup_gpio10_eapd(struct hda_codec *codec, in stac92hd83xxx_fixup_gpio10_eapd() argument
2173 struct sigmatel_spec *spec = codec->spec; in stac92hd83xxx_fixup_gpio10_eapd()
2182 static void hp_envy_ts_fixup_dac_bind(struct hda_codec *codec, in hp_envy_ts_fixup_dac_bind() argument
2186 struct sigmatel_spec *spec = codec->spec; in hp_envy_ts_fixup_dac_bind()
2941 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in stac_hp_bass_gpio_get() local
2942 struct sigmatel_spec *spec = codec->spec; in stac_hp_bass_gpio_get()
2950 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in stac_hp_bass_gpio_put() local
2951 struct sigmatel_spec *spec = codec->spec; in stac_hp_bass_gpio_put()
2959 stac_gpio_set(codec, spec->gpio_mask, spec->gpio_dir, spec->gpio_data); in stac_hp_bass_gpio_put()
2970 static int stac_add_hp_bass_switch(struct hda_codec *codec) in stac_add_hp_bass_switch() argument
2972 struct sigmatel_spec *spec = codec->spec; in stac_add_hp_bass_switch()
3044 static void stac92hd71bxx_fixup_ref(struct hda_codec *codec, in stac92hd71bxx_fixup_ref() argument
3047 struct sigmatel_spec *spec = codec->spec; in stac92hd71bxx_fixup_ref()
3052 snd_hda_apply_pincfgs(codec, ref92hd71bxx_pin_configs); in stac92hd71bxx_fixup_ref()
3056 static void stac92hd71bxx_fixup_hp_m4(struct hda_codec *codec, in stac92hd71bxx_fixup_hp_m4() argument
3059 struct sigmatel_spec *spec = codec->spec; in stac92hd71bxx_fixup_hp_m4()
3066 snd_hda_codec_write_cache(codec, codec->core.afg, 0, in stac92hd71bxx_fixup_hp_m4()
3068 jack = snd_hda_jack_detect_enable_callback(codec, codec->core.afg, in stac92hd71bxx_fixup_hp_m4()
3076 snd_hda_codec_set_pincfg(codec, 0x0e, 0x01813040); in stac92hd71bxx_fixup_hp_m4()
3079 static void stac92hd71bxx_fixup_hp_dv4(struct hda_codec *codec, in stac92hd71bxx_fixup_hp_dv4() argument
3082 struct sigmatel_spec *spec = codec->spec; in stac92hd71bxx_fixup_hp_dv4()
3089 static void stac92hd71bxx_fixup_hp_dv5(struct hda_codec *codec, in stac92hd71bxx_fixup_hp_dv5() argument
3096 snd_hda_codec_set_pincfg(codec, 0x0d, 0x90170010); in stac92hd71bxx_fixup_hp_dv5()
3101 cap = snd_hda_param_read(codec, 0x1, AC_PAR_GPIO_CAP); in stac92hd71bxx_fixup_hp_dv5()
3104 stac_add_hp_bass_switch(codec); in stac92hd71bxx_fixup_hp_dv5()
3109 static void stac92hd71bxx_fixup_hp_hdx(struct hda_codec *codec, in stac92hd71bxx_fixup_hp_hdx() argument
3112 struct sigmatel_spec *spec = codec->spec; in stac92hd71bxx_fixup_hp_hdx()
3119 static bool is_hp_output(struct hda_codec *codec, hda_nid_t pin) in is_hp_output() argument
3121 unsigned int pin_cfg = snd_hda_codec_get_pincfg(codec, pin); in is_hp_output()
3129 static void fixup_hp_headphone(struct hda_codec *codec, hda_nid_t pin) in fixup_hp_headphone() argument
3131 unsigned int pin_cfg = snd_hda_codec_get_pincfg(codec, pin); in fixup_hp_headphone()
3140 snd_hda_codec_set_pincfg(codec, pin, pin_cfg); in fixup_hp_headphone()
3143 static void stac92hd71bxx_fixup_hp(struct hda_codec *codec, in stac92hd71bxx_fixup_hp() argument
3146 struct sigmatel_spec *spec = codec->spec; in stac92hd71bxx_fixup_hp()
3154 if (is_hp_output(codec, 0x0a) && is_hp_output(codec, 0x0f)) { in stac92hd71bxx_fixup_hp()
3155 fixup_hp_headphone(codec, 0x0a); in stac92hd71bxx_fixup_hp()
3156 fixup_hp_headphone(codec, 0x0f); in stac92hd71bxx_fixup_hp()
3159 if (find_mute_led_cfg(codec, 1)) in stac92hd71bxx_fixup_hp()
3160 codec_dbg(codec, "mute LED gpio %d polarity %d\n", in stac92hd71bxx_fixup_hp()
3506 static void stac922x_fixup_intel_mac_auto(struct hda_codec *codec, in stac922x_fixup_intel_mac_auto() argument
3513 codec->fixup_id = HDA_FIXUP_ID_NOT_SET; in stac922x_fixup_intel_mac_auto()
3514 snd_hda_pick_fixup(codec, NULL, stac922x_intel_mac_fixup_tbl, in stac922x_fixup_intel_mac_auto()
3516 if (codec->fixup_id != HDA_FIXUP_ID_NOT_SET) in stac922x_fixup_intel_mac_auto()
3517 snd_hda_apply_fixup(codec, action); in stac922x_fixup_intel_mac_auto()
3520 static void stac922x_fixup_intel_mac_gpio(struct hda_codec *codec, in stac922x_fixup_intel_mac_gpio() argument
3524 struct sigmatel_spec *spec = codec->spec; in stac922x_fixup_intel_mac_gpio()
3812 static void stac927x_fixup_ref_no_jd(struct hda_codec *codec, in stac927x_fixup_ref_no_jd() argument
3817 codec->no_jack_detect = 1; in stac927x_fixup_ref_no_jd()
3820 static void stac927x_fixup_ref(struct hda_codec *codec, in stac927x_fixup_ref() argument
3823 struct sigmatel_spec *spec = codec->spec; in stac927x_fixup_ref()
3826 snd_hda_apply_pincfgs(codec, ref927x_pin_configs); in stac927x_fixup_ref()
3832 static void stac927x_fixup_dell_dmic(struct hda_codec *codec, in stac927x_fixup_dell_dmic() argument
3835 struct sigmatel_spec *spec = codec->spec; in stac927x_fixup_dell_dmic()
3840 if (codec->core.subsystem_id != 0x1028022f) { in stac927x_fixup_dell_dmic()
3846 snd_hda_add_verbs(codec, dell_3st_core_init); in stac927x_fixup_dell_dmic()
3850 static void stac927x_fixup_volknob(struct hda_codec *codec, in stac927x_fixup_volknob() argument
3853 struct sigmatel_spec *spec = codec->spec; in stac927x_fixup_volknob()
3856 snd_hda_add_verbs(codec, stac927x_volknob_core_init); in stac927x_fixup_volknob()
4086 static void stac9205_fixup_ref(struct hda_codec *codec, in stac9205_fixup_ref() argument
4089 struct sigmatel_spec *spec = codec->spec; in stac9205_fixup_ref()
4092 snd_hda_apply_pincfgs(codec, ref9205_pin_configs); in stac9205_fixup_ref()
4098 static void stac9205_fixup_dell_m43(struct hda_codec *codec, in stac9205_fixup_dell_m43() argument
4101 struct sigmatel_spec *spec = codec->spec; in stac9205_fixup_dell_m43()
4105 snd_hda_apply_pincfgs(codec, dell_9205_m43_pin_configs); in stac9205_fixup_dell_m43()
4108 snd_hda_codec_write_cache(codec, codec->core.afg, 0, in stac9205_fixup_dell_m43()
4110 jack = snd_hda_jack_detect_enable_callback(codec, codec->core.afg, in stac9205_fixup_dell_m43()
4126 static void stac9205_fixup_eapd(struct hda_codec *codec, in stac9205_fixup_eapd() argument
4129 struct sigmatel_spec *spec = codec->spec; in stac9205_fixup_eapd()
4215 static void stac92hd95_fixup_hp_led(struct hda_codec *codec, in stac92hd95_fixup_hp_led() argument
4218 struct sigmatel_spec *spec = codec->spec; in stac92hd95_fixup_hp_led()
4223 if (find_mute_led_cfg(codec, spec->default_polarity)) in stac92hd95_fixup_hp_led()
4224 codec_dbg(codec, "mute LED gpio %d polarity %d\n", in stac92hd95_fixup_hp_led()
4257 static int stac_parse_auto_config(struct hda_codec *codec) in stac_parse_auto_config() argument
4259 struct sigmatel_spec *spec = codec->spec; in stac_parse_auto_config()
4266 err = snd_hda_parse_pin_defcfg(codec, &spec->gen.autocfg, NULL, flags); in stac_parse_auto_config()
4276 err = snd_hda_gen_parse_auto_config(codec, &spec->gen.autocfg); in stac_parse_auto_config()
4281 err = snd_hda_gen_fix_pin_power(codec, spec->vref_mute_led_nid); in stac_parse_auto_config()
4288 err = stac_auto_create_beep_ctls(codec, in stac_parse_auto_config()
4300 err = stac_auto_create_beep_ctls(codec, nid); in stac_parse_auto_config()
4303 if (codec->beep) { in stac_parse_auto_config()
4305 codec->beep->linear_tone = spec->linear_tone_beep; in stac_parse_auto_config()
4307 caps = query_amp_caps(codec, nid, HDA_OUTPUT); in stac_parse_auto_config()
4309 err = stac_beep_switch_ctl(codec); in stac_parse_auto_config()
4321 snd_hda_get_bool_hint(codec, "loopback") == 1) { in stac_parse_auto_config()
4324 if (snd_hdac_regmap_add_vendor_verb(&codec->core, wr_verb)) in stac_parse_auto_config()
4331 err = stac_create_spdif_mux_ctls(codec); in stac_parse_auto_config()
4336 stac_init_power_map(codec); in stac_parse_auto_config()
4341 static int stac_init(struct hda_codec *codec) in stac_init() argument
4343 struct sigmatel_spec *spec = codec->spec; in stac_init()
4347 stac_store_hints(codec); in stac_init()
4355 stac_gpio_set(codec, spec->gpio_mask, spec->gpio_dir, spec->gpio_data); in stac_init()
4357 snd_hda_gen_init(codec); in stac_init()
4361 snd_hda_codec_write(codec, codec->core.afg, 0, in stac_init()
4370 snd_hda_codec_write(codec, spec->gen.all_adcs[i], 0, in stac_init()
4379 static void stac_shutup(struct hda_codec *codec) in stac_shutup() argument
4381 struct sigmatel_spec *spec = codec->spec; in stac_shutup()
4383 snd_hda_shutup_pins(codec); in stac_shutup()
4386 stac_gpio_set(codec, spec->gpio_mask, in stac_shutup()
4395 struct hda_codec *codec, hda_nid_t nid) in stac92hd_proc_hook() argument
4397 if (nid == codec->core.afg) in stac92hd_proc_hook()
4399 snd_hda_codec_read(codec, nid, 0, in stac92hd_proc_hook()
4404 struct hda_codec *codec, in analog_loop_proc_hook() argument
4408 snd_hda_codec_read(codec, codec->core.afg, 0, verb, 0)); in analog_loop_proc_hook()
4413 struct hda_codec *codec, hda_nid_t nid) in stac92hd7x_proc_hook() argument
4415 stac92hd_proc_hook(buffer, codec, nid); in stac92hd7x_proc_hook()
4416 if (nid == codec->core.afg) in stac92hd7x_proc_hook()
4417 analog_loop_proc_hook(buffer, codec, 0xfa0); in stac92hd7x_proc_hook()
4421 struct hda_codec *codec, hda_nid_t nid) in stac9205_proc_hook() argument
4423 if (nid == codec->core.afg) in stac9205_proc_hook()
4424 analog_loop_proc_hook(buffer, codec, 0xfe0); in stac9205_proc_hook()
4428 struct hda_codec *codec, hda_nid_t nid) in stac927x_proc_hook() argument
4430 if (nid == codec->core.afg) in stac927x_proc_hook()
4431 analog_loop_proc_hook(buffer, codec, 0xfeb); in stac927x_proc_hook()
4441 static int stac_suspend(struct hda_codec *codec) in stac_suspend() argument
4443 stac_shutup(codec); in stac_suspend()
4462 static int alloc_stac_spec(struct hda_codec *codec) in alloc_stac_spec() argument
4470 codec->spec = spec; in alloc_stac_spec()
4471 codec->no_trigger_sense = 1; /* seems common with STAC/IDT codecs */ in alloc_stac_spec()
4473 codec->patch_ops = stac_patch_ops; in alloc_stac_spec()
4477 static int patch_stac9200(struct hda_codec *codec) in patch_stac9200() argument
4482 err = alloc_stac_spec(codec); in patch_stac9200()
4486 spec = codec->spec; in patch_stac9200()
4490 codec->power_filter = snd_hda_codec_eapd_power_filter; in patch_stac9200()
4492 snd_hda_add_verbs(codec, stac9200_eapd_init); in patch_stac9200()
4494 snd_hda_pick_fixup(codec, stac9200_models, stac9200_fixup_tbl, in patch_stac9200()
4496 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE); in patch_stac9200()
4498 err = stac_parse_auto_config(codec); in patch_stac9200()
4500 stac_free(codec); in patch_stac9200()
4504 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE); in patch_stac9200()
4509 static int patch_stac925x(struct hda_codec *codec) in patch_stac925x() argument
4514 err = alloc_stac_spec(codec); in patch_stac925x()
4518 spec = codec->spec; in patch_stac925x()
4522 snd_hda_add_verbs(codec, stac925x_core_init); in patch_stac925x()
4524 snd_hda_pick_fixup(codec, stac925x_models, stac925x_fixup_tbl, in patch_stac925x()
4526 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE); in patch_stac925x()
4528 err = stac_parse_auto_config(codec); in patch_stac925x()
4530 stac_free(codec); in patch_stac925x()
4534 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE); in patch_stac925x()
4539 static int patch_stac92hd73xx(struct hda_codec *codec) in patch_stac92hd73xx() argument
4545 err = alloc_stac_spec(codec); in patch_stac92hd73xx()
4549 spec = codec->spec; in patch_stac92hd73xx()
4553 if ((codec->core.vendor_id & 0xfffffff0) != 0x111d7670) in patch_stac92hd73xx()
4554 codec->power_save_node = 1; in patch_stac92hd73xx()
4559 num_dacs = snd_hda_get_num_conns(codec, 0x0a) - 1; in patch_stac92hd73xx()
4561 codec_warn(codec, in patch_stac92hd73xx()
4595 snd_hda_pick_fixup(codec, stac92hd73xx_models, stac92hd73xx_fixup_tbl, in patch_stac92hd73xx()
4597 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE); in patch_stac92hd73xx()
4600 snd_hda_add_verbs(codec, stac92hd73xx_core_init); in patch_stac92hd73xx()
4602 err = stac_parse_auto_config(codec); in patch_stac92hd73xx()
4604 stac_free(codec); in patch_stac92hd73xx()
4611 if (spec->eapd_switch && !has_builtin_speaker(codec)) in patch_stac92hd73xx()
4614 codec->proc_widget_hook = stac92hd7x_proc_hook; in patch_stac92hd73xx()
4616 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE); in patch_stac92hd73xx()
4621 static void stac_setup_gpio(struct hda_codec *codec) in stac_setup_gpio() argument
4623 struct sigmatel_spec *spec = codec->spec; in stac_setup_gpio()
4632 codec->power_filter = stac_vref_led_power_filter; in stac_setup_gpio()
4641 snd_hda_gen_add_micmute_led(codec, stac_capture_led_update); in stac_setup_gpio()
4645 static int patch_stac92hd83xxx(struct hda_codec *codec) in patch_stac92hd83xxx() argument
4650 err = alloc_stac_spec(codec); in patch_stac92hd83xxx()
4655 codec->core.power_caps &= ~AC_PWRST_EPSS; in patch_stac92hd83xxx()
4657 spec = codec->spec; in patch_stac92hd83xxx()
4658 codec->power_save_node = 1; in patch_stac92hd83xxx()
4669 snd_hda_add_verbs(codec, stac92hd83xxx_core_init); in patch_stac92hd83xxx()
4671 snd_hda_pick_fixup(codec, stac92hd83xxx_models, stac92hd83xxx_fixup_tbl, in patch_stac92hd83xxx()
4673 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE); in patch_stac92hd83xxx()
4675 stac_setup_gpio(codec); in patch_stac92hd83xxx()
4677 err = stac_parse_auto_config(codec); in patch_stac92hd83xxx()
4679 stac_free(codec); in patch_stac92hd83xxx()
4683 codec->proc_widget_hook = stac92hd_proc_hook; in patch_stac92hd83xxx()
4685 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE); in patch_stac92hd83xxx()
4694 static int patch_stac92hd95(struct hda_codec *codec) in patch_stac92hd95() argument
4699 err = alloc_stac_spec(codec); in patch_stac92hd95()
4704 codec->core.power_caps &= ~AC_PWRST_EPSS; in patch_stac92hd95()
4706 spec = codec->spec; in patch_stac92hd95()
4707 codec->power_save_node = 1; in patch_stac92hd95()
4717 snd_hda_pick_fixup(codec, stac92hd95_models, stac92hd95_fixup_tbl, in patch_stac92hd95()
4719 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE); in patch_stac92hd95()
4721 stac_setup_gpio(codec); in patch_stac92hd95()
4723 err = stac_parse_auto_config(codec); in patch_stac92hd95()
4725 stac_free(codec); in patch_stac92hd95()
4729 codec->proc_widget_hook = stac92hd_proc_hook; in patch_stac92hd95()
4731 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE); in patch_stac92hd95()
4736 static int patch_stac92hd71bxx(struct hda_codec *codec) in patch_stac92hd71bxx() argument
4742 err = alloc_stac_spec(codec); in patch_stac92hd71bxx()
4746 spec = codec->spec; in patch_stac92hd71bxx()
4760 switch (codec->core.vendor_id) { in patch_stac92hd71bxx()
4766 if ((codec->core.revision_id & 0xf) == 0 || in patch_stac92hd71bxx()
4767 (codec->core.revision_id & 0xf) == 1) in patch_stac92hd71bxx()
4772 snd_hda_codec_set_pincfg(codec, 0x0f, 0x40f000f0); in patch_stac92hd71bxx()
4773 snd_hda_codec_set_pincfg(codec, 0x19, 0x40f000f3); in patch_stac92hd71bxx()
4776 if ((codec->core.revision_id & 0xf) == 1) in patch_stac92hd71bxx()
4782 if (get_wcaps_type(get_wcaps(codec, 0x28)) == AC_WID_VOL_KNB) in patch_stac92hd71bxx()
4783 snd_hda_add_verbs(codec, stac92hd71bxx_core_init); in patch_stac92hd71bxx()
4785 if (get_wcaps(codec, 0xa) & AC_WCAP_IN_AMP) { in patch_stac92hd71bxx()
4788 snd_hda_codec_amp_init_stereo(codec, *p, HDA_INPUT, 0, in patch_stac92hd71bxx()
4801 snd_hda_pick_fixup(codec, stac92hd71bxx_models, stac92hd71bxx_fixup_tbl, in patch_stac92hd71bxx()
4803 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE); in patch_stac92hd71bxx()
4805 stac_setup_gpio(codec); in patch_stac92hd71bxx()
4807 err = stac_parse_auto_config(codec); in patch_stac92hd71bxx()
4809 stac_free(codec); in patch_stac92hd71bxx()
4813 codec->proc_widget_hook = stac92hd7x_proc_hook; in patch_stac92hd71bxx()
4815 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE); in patch_stac92hd71bxx()
4820 static int patch_stac922x(struct hda_codec *codec) in patch_stac922x() argument
4825 err = alloc_stac_spec(codec); in patch_stac922x()
4829 spec = codec->spec; in patch_stac922x()
4833 snd_hda_add_verbs(codec, stac922x_core_init); in patch_stac922x()
4836 snd_hda_override_amp_caps(codec, 0x12, HDA_OUTPUT, in patch_stac922x()
4842 snd_hda_pick_fixup(codec, stac922x_models, stac922x_fixup_tbl, in patch_stac922x()
4844 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE); in patch_stac922x()
4846 err = stac_parse_auto_config(codec); in patch_stac922x()
4848 stac_free(codec); in patch_stac922x()
4852 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE); in patch_stac922x()
4862 static int patch_stac927x(struct hda_codec *codec) in patch_stac927x() argument
4867 err = alloc_stac_spec(codec); in patch_stac927x()
4871 spec = codec->spec; in patch_stac927x()
4888 snd_hda_pick_fixup(codec, stac927x_models, stac927x_fixup_tbl, in patch_stac927x()
4890 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE); in patch_stac927x()
4893 snd_hda_add_verbs(codec, stac927x_core_init); in patch_stac927x()
4895 err = stac_parse_auto_config(codec); in patch_stac927x()
4897 stac_free(codec); in patch_stac927x()
4901 codec->proc_widget_hook = stac927x_proc_hook; in patch_stac927x()
4913 codec->bus->needs_damn_long_delay = 1; in patch_stac927x()
4915 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE); in patch_stac927x()
4920 static int patch_stac9205(struct hda_codec *codec) in patch_stac9205() argument
4925 err = alloc_stac_spec(codec); in patch_stac9205()
4929 spec = codec->spec; in patch_stac9205()
4936 snd_hda_add_verbs(codec, stac9205_core_init); in patch_stac9205()
4949 snd_hda_pick_fixup(codec, stac9205_models, stac9205_fixup_tbl, in patch_stac9205()
4951 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE); in patch_stac9205()
4953 err = stac_parse_auto_config(codec); in patch_stac9205()
4955 stac_free(codec); in patch_stac9205()
4959 codec->proc_widget_hook = stac9205_proc_hook; in patch_stac9205()
4961 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE); in patch_stac9205()
5007 static int patch_stac9872(struct hda_codec *codec) in patch_stac9872() argument
5012 err = alloc_stac_spec(codec); in patch_stac9872()
5016 spec = codec->spec; in patch_stac9872()
5020 snd_hda_add_verbs(codec, stac9872_core_init); in patch_stac9872()
5022 snd_hda_pick_fixup(codec, stac9872_models, stac9872_fixup_tbl, in patch_stac9872()
5024 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE); in patch_stac9872()
5026 err = stac_parse_auto_config(codec); in patch_stac9872()
5028 stac_free(codec); in patch_stac9872()
5032 snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE); in patch_stac9872()