Lines Matching refs:spec

56 static int set_beep_amp(struct conexant_spec *spec, hda_nid_t nid,  in set_beep_amp()  argument
63 spec->gen.beep_nid = nid; in set_beep_amp()
65 knew = snd_hda_gen_add_kctl(&spec->gen, NULL, in set_beep_amp()
76 struct conexant_spec *spec = codec->spec; in cx_auto_parse_beep() local
81 return set_beep_amp(spec, nid, 0, HDA_OUTPUT); in cx_auto_parse_beep()
95 struct conexant_spec *spec = codec->spec; in cx_auto_parse_eapd() local
103 spec->eapds[spec->num_eapds++] = nid; in cx_auto_parse_eapd()
104 if (spec->num_eapds >= ARRAY_SIZE(spec->eapds)) in cx_auto_parse_eapd()
114 if (spec->num_eapds > 2) in cx_auto_parse_eapd()
115 spec->dynamic_eapd = 1; in cx_auto_parse_eapd()
134 struct conexant_spec *spec = codec->spec; in cx_auto_vmaster_hook() local
136 cx_auto_turn_eapd(codec, spec->num_eapds, spec->eapds, enabled); in cx_auto_vmaster_hook()
144 struct conexant_spec *spec = codec->spec; in cx_auto_vmaster_mute_led() local
146 snd_hda_codec_write(codec, spec->mute_led_eapd, 0, in cx_auto_vmaster_mute_led()
154 struct conexant_spec *spec = codec->spec; in cxt_init_gpio_led() local
155 unsigned int mask = spec->gpio_mute_led_mask | spec->gpio_mic_led_mask; in cxt_init_gpio_led()
163 spec->gpio_led); in cxt_init_gpio_led()
190 struct conexant_spec *spec = codec->spec; in cx_auto_init() local
192 if (!spec->dynamic_eapd) in cx_auto_init()
193 cx_auto_turn_eapd(codec, spec->num_eapds, spec->eapds, true); in cx_auto_init()
198 if (spec->is_cx8070_sn6140) in cx_auto_init()
206 struct conexant_spec *spec = codec->spec; in cx_auto_shutdown() local
210 cx_auto_turn_eapd(codec, spec->num_eapds, spec->eapds, false); in cx_auto_shutdown()
318 struct conexant_spec *spec = codec->spec; in cxt_fixup_stereo_dmic() local
319 spec->gen.inv_dmic_split = 1; in cxt_fixup_stereo_dmic()
353 struct conexant_spec *spec = codec->spec; in cxt_update_headset_mode() local
354 struct auto_pin_cfg *cfg = &spec->gen.autocfg; in cxt_update_headset_mode()
356 hda_nid_t mux_pin = spec->gen.imux_pins[spec->gen.cur_mux[0]]; in cxt_update_headset_mode()
366 spec->gen.hp_jack_present = false; in cxt_update_headset_mode()
369 spec->gen.hp_jack_present = snd_hda_jack_detect(codec, spec->gen.autocfg.hp_pins[0]); in cxt_update_headset_mode()
385 struct conexant_spec *spec = codec->spec; in cxt_fixup_headphone_mic() local
389 spec->parse_flags |= HDA_PINCFG_HEADPHONE_MIC; in cxt_fixup_headphone_mic()
393 WARN_ON(spec->gen.cap_sync_hook); in cxt_fixup_headphone_mic()
394 spec->gen.cap_sync_hook = cxt_update_headset_mode_hook; in cxt_fixup_headphone_mic()
395 spec->gen.automute_hook = cxt_update_headset_mode; in cxt_fixup_headphone_mic()
406 struct conexant_spec *spec = codec->spec; in cxt_fixup_headset_mic() local
410 spec->parse_flags |= HDA_PINCFG_HEADSET_MIC; in cxt_fixup_headset_mic()
439 struct conexant_spec *spec = codec->spec; in olpc_xo_update_mic_boost() local
445 if (!spec->dc_enable) in olpc_xo_update_mic_boost()
454 struct conexant_spec *spec = codec->spec; in olpc_xo_update_mic_pins() local
458 cur_input = spec->gen.input_paths[0][spec->gen.cur_mux[0]]; in olpc_xo_update_mic_pins()
463 if (!spec->dc_enable) { in olpc_xo_update_mic_pins()
466 snd_hda_activate_path(codec, spec->dc_mode_path, false, false); in olpc_xo_update_mic_pins()
475 update_mic_pin(codec, 0x1a, spec->recording ? in olpc_xo_update_mic_pins()
477 update_mic_pin(codec, 0x1b, spec->recording ? in olpc_xo_update_mic_pins()
494 if (spec->recording) in olpc_xo_update_mic_pins()
495 val = olpc_xo_dc_bias.items[spec->dc_input_bias].index; in olpc_xo_update_mic_pins()
501 update_mic_pin(codec, 0x1e, spec->recording ? PIN_IN : 0); in olpc_xo_update_mic_pins()
502 snd_hda_activate_path(codec, spec->dc_mode_path, true, false); in olpc_xo_update_mic_pins()
510 struct conexant_spec *spec = codec->spec; in olpc_xo_automic() local
513 if (!spec->dc_enable) in olpc_xo_automic()
516 if (spec->dc_enable) in olpc_xo_automic()
526 struct conexant_spec *spec = codec->spec; in olpc_xo_capture_hook() local
533 spec->recording = 1; in olpc_xo_capture_hook()
537 spec->recording = 0; in olpc_xo_capture_hook()
547 struct conexant_spec *spec = codec->spec; in olpc_xo_dc_mode_get() local
548 ucontrol->value.integer.value[0] = spec->dc_enable; in olpc_xo_dc_mode_get()
556 struct conexant_spec *spec = codec->spec; in olpc_xo_dc_mode_put() local
559 if (dc_enable == spec->dc_enable) in olpc_xo_dc_mode_put()
562 spec->dc_enable = dc_enable; in olpc_xo_dc_mode_put()
572 struct conexant_spec *spec = codec->spec; in olpc_xo_dc_bias_enum_get() local
573 ucontrol->value.enumerated.item[0] = spec->dc_input_bias; in olpc_xo_dc_bias_enum_get()
587 struct conexant_spec *spec = codec->spec; in olpc_xo_dc_bias_enum_put() local
594 if (spec->dc_input_bias == idx) in olpc_xo_dc_bias_enum_put()
597 spec->dc_input_bias = idx; in olpc_xo_dc_bias_enum_put()
598 if (spec->dc_enable) in olpc_xo_dc_bias_enum_put()
628 struct conexant_spec *spec = codec->spec; in olpc_xo_mic_boost_put() local
630 if (ret > 0 && spec->dc_enable) in olpc_xo_mic_boost_put()
638 struct conexant_spec *spec = codec->spec; in cxt_fixup_olpc_xo() local
645 spec->gen.mic_autoswitch_hook = olpc_xo_automic; in cxt_fixup_olpc_xo()
646 spec->gen.pcm_capture_hook = olpc_xo_capture_hook; in cxt_fixup_olpc_xo()
647 spec->dc_mode_path = snd_hda_add_new_path(codec, 0x1e, 0x14, 0); in cxt_fixup_olpc_xo()
658 snd_array_for_each(&spec->gen.kctls, i, kctl) { in cxt_fixup_olpc_xo()
669 struct conexant_spec *spec = codec->spec; in cxt_fixup_mute_led_eapd() local
672 spec->mute_led_eapd = 0x1b; in cxt_fixup_mute_led_eapd()
673 spec->dynamic_eapd = true; in cxt_fixup_mute_led_eapd()
721 struct conexant_spec *spec = codec->spec; in cxt_update_gpio_led() local
722 unsigned int oldval = spec->gpio_led; in cxt_update_gpio_led()
724 if (spec->mute_led_polarity) in cxt_update_gpio_led()
728 spec->gpio_led |= mask; in cxt_update_gpio_led()
730 spec->gpio_led &= ~mask; in cxt_update_gpio_led()
732 mask, led_on, spec->gpio_led); in cxt_update_gpio_led()
733 if (spec->gpio_led != oldval) in cxt_update_gpio_led()
735 spec->gpio_led); in cxt_update_gpio_led()
743 struct conexant_spec *spec = codec->spec; in cxt_gpio_mute_update() local
745 cxt_update_gpio_led(codec, spec->gpio_mute_led_mask, brightness); in cxt_gpio_mute_update()
754 struct conexant_spec *spec = codec->spec; in cxt_gpio_micmute_update() local
756 cxt_update_gpio_led(codec, spec->gpio_mic_led_mask, brightness); in cxt_gpio_micmute_update()
763 struct conexant_spec *spec = codec->spec; in cxt_setup_mute_led() local
765 spec->gpio_led = 0; in cxt_setup_mute_led()
766 spec->mute_led_polarity = 0; in cxt_setup_mute_led()
769 spec->gpio_mute_led_mask = mute; in cxt_setup_mute_led()
773 spec->gpio_mic_led_mask = mic_mute; in cxt_setup_mute_led()
1142 struct conexant_spec *spec = codec->spec; in add_cx5051_fake_mutes() local
1152 spec->gen.dac_min_mute = true; in add_cx5051_fake_mutes()
1157 struct conexant_spec *spec; in patch_conexant_auto() local
1162 spec = kzalloc(sizeof(*spec), GFP_KERNEL); in patch_conexant_auto()
1163 if (!spec) in patch_conexant_auto()
1165 snd_hda_gen_spec_init(&spec->gen); in patch_conexant_auto()
1166 codec->spec = spec; in patch_conexant_auto()
1173 spec->is_cx8070_sn6140 = true; in patch_conexant_auto()
1179 spec->gen.own_eapd_ctl = 1; in patch_conexant_auto()
1184 spec->gen.mixer_nid = 0x17; in patch_conexant_auto()
1185 spec->gen.add_stereo_mix_input = HDA_HINT_STEREO_MIX_AUTO; in patch_conexant_auto()
1191 spec->gen.mixer_nid = 0x19; in patch_conexant_auto()
1192 spec->gen.add_stereo_mix_input = HDA_HINT_STEREO_MIX_AUTO; in patch_conexant_auto()
1204 spec->gen.mixer_nid = 0x22; in patch_conexant_auto()
1205 spec->gen.add_stereo_mix_input = HDA_HINT_STEREO_MIX_AUTO; in patch_conexant_auto()
1219 if (!spec->gen.vmaster_mute.hook && spec->dynamic_eapd) in patch_conexant_auto()
1220 spec->gen.vmaster_mute.hook = cx_auto_vmaster_hook; in patch_conexant_auto()
1224 err = snd_hda_parse_pin_defcfg(codec, &spec->gen.autocfg, NULL, in patch_conexant_auto()
1225 spec->parse_flags); in patch_conexant_auto()
1233 err = snd_hda_gen_parse_auto_config(codec, &spec->gen.autocfg); in patch_conexant_auto()