Lines Matching refs:spec

1181 #define ca0132_quirk(spec)		((spec)->codec->fixup_id)  argument
1182 #define ca0132_use_pci_mmio(spec) ((spec)->use_pci_mmio) argument
1183 #define ca0132_use_alt_functions(spec) ((spec)->use_alt_functions) argument
1184 #define ca0132_use_alt_controls(spec) ((spec)->use_alt_controls) argument
1186 #define ca0132_quirk(spec) ({ (void)(spec); QUIRK_NONE; }) argument
1187 #define ca0132_use_alt_functions(spec) ({ (void)(spec); false; }) argument
1188 #define ca0132_use_pci_mmio(spec) ({ (void)(spec); false; }) argument
1189 #define ca0132_use_alt_controls(spec) ({ (void)(spec); false; }) argument
1581 struct ca0132_spec *spec = codec->spec; in chipio_write_address() local
1584 if (spec->curr_chip_addx == chip_addx) in chipio_write_address()
1597 spec->curr_chip_addx = (res < 0) ? ~0U : chip_addx; in chipio_write_address()
1607 struct ca0132_spec *spec = codec->spec; in chipio_write_data() local
1621 spec->curr_chip_addx = (res != -EIO) ? in chipio_write_data()
1622 (spec->curr_chip_addx + 4) : ~0U; in chipio_write_data()
1652 struct ca0132_spec *spec = codec->spec; in chipio_read_data() local
1672 spec->curr_chip_addx = (res != -EIO) ? in chipio_read_data()
1673 (spec->curr_chip_addx + 4) : ~0U; in chipio_read_data()
1684 struct ca0132_spec *spec = codec->spec; in chipio_write() local
1687 mutex_lock(&spec->chipio_mutex); in chipio_write()
1699 mutex_unlock(&spec->chipio_mutex); in chipio_write()
1735 struct ca0132_spec *spec = codec->spec; in chipio_write_multiple() local
1738 mutex_lock(&spec->chipio_mutex); in chipio_write_multiple()
1745 mutex_unlock(&spec->chipio_mutex); in chipio_write_multiple()
1757 struct ca0132_spec *spec = codec->spec; in chipio_read() local
1760 mutex_lock(&spec->chipio_mutex); in chipio_read()
1772 mutex_unlock(&spec->chipio_mutex); in chipio_read()
1798 struct ca0132_spec *spec = codec->spec; in chipio_set_control_param() local
1806 mutex_lock(&spec->chipio_mutex); in chipio_set_control_param()
1815 mutex_unlock(&spec->chipio_mutex); in chipio_set_control_param()
1978 struct ca0132_spec *spec = codec->spec; in chipio_8051_write_exram() local
1980 mutex_lock(&spec->chipio_mutex); in chipio_8051_write_exram()
1985 mutex_unlock(&spec->chipio_mutex); in chipio_8051_write_exram()
2006 struct ca0132_spec *spec = codec->spec; in chipio_8051_write_pll_pmu() local
2008 mutex_lock(&spec->chipio_mutex); in chipio_8051_write_pll_pmu()
2013 mutex_unlock(&spec->chipio_mutex); in chipio_8051_write_pll_pmu()
2028 struct ca0132_spec *spec = codec->spec; in chipio_enable_clocks() local
2030 mutex_lock(&spec->chipio_mutex); in chipio_enable_clocks()
2036 mutex_unlock(&spec->chipio_mutex); in chipio_enable_clocks()
2082 struct ca0132_spec *spec = codec->spec; in dspio_write() local
2087 mutex_lock(&spec->chipio_mutex); in dspio_write()
2102 mutex_unlock(&spec->chipio_mutex); in dspio_write()
2257 struct ca0132_spec *spec = codec->spec; in dspio_get_response_data() local
2264 if ((data & 0x00ffffff) == spec->wait_scp_header) { in dspio_get_response_data()
2265 spec->scp_resp_header = data; in dspio_get_response_data()
2266 spec->scp_resp_count = data >> 27; in dspio_get_response_data()
2267 count = spec->wait_num_data; in dspio_get_response_data()
2268 dspio_read_multiple(codec, spec->scp_resp_data, in dspio_get_response_data()
2269 &spec->scp_resp_count, count); in dspio_get_response_data()
2286 struct ca0132_spec *spec = codec->spec; in dspio_send_scp_message() local
2313 spec->wait_scp_header = *((unsigned int *)send_buf); in dspio_send_scp_message()
2318 spec->wait_scp_header &= 0xffff0000; in dspio_send_scp_message()
2319 spec->wait_scp_header |= (resp_src_id << 8) | (resp_target_id); in dspio_send_scp_message()
2320 spec->wait_num_data = return_buf_size/sizeof(unsigned int) - 1; in dspio_send_scp_message()
2321 spec->wait_scp = 1; in dspio_send_scp_message()
2328 spec->wait_scp = 0; in dspio_send_scp_message()
2337 } while (spec->wait_scp && time_before(jiffies, timeout)); in dspio_send_scp_message()
2339 if (!spec->wait_scp) { in dspio_send_scp_message()
2341 memcpy(&ret_msg->hdr, &spec->scp_resp_header, 4); in dspio_send_scp_message()
2342 memcpy(&ret_msg->data, spec->scp_resp_data, in dspio_send_scp_message()
2343 spec->wait_num_data); in dspio_send_scp_message()
2344 *bytes_returned = (spec->scp_resp_count + 1) * 4; in dspio_send_scp_message()
2349 spec->wait_scp = 0; in dspio_send_scp_message()
3051 struct ca0132_spec *spec = codec->spec; in dma_reset() local
3063 spec->dsp_stream_id = status; in dma_reset()
3114 struct ca0132_spec *spec = dma->codec->spec; in dma_get_stream_id() local
3116 return spec->dsp_stream_id; in dma_get_stream_id()
3408 struct ca0132_spec *spec = codec->spec; in dspxfr_image() local
3452 spec->dsp_stream_id = status; in dspxfr_image()
3524 struct ca0132_spec *spec = codec->spec; in dspload_post_setup() local
3526 if (!ca0132_use_alt_functions(spec)) { in dspload_post_setup()
3658 struct ca0132_spec *spec = codec->spec; in ca0113_mmio_gpio_set() local
3664 writew(gpio_data, spec->mem_base + 0x320); in ca0113_mmio_gpio_set()
3678 struct ca0132_spec *spec = codec->spec; in ca0113_mmio_command_set() local
3681 writel(0x0000007e, spec->mem_base + 0x210); in ca0113_mmio_command_set()
3682 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set()
3683 writel(0x0000005a, spec->mem_base + 0x210); in ca0113_mmio_command_set()
3684 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set()
3685 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set()
3687 writel(0x00800005, spec->mem_base + 0x20c); in ca0113_mmio_command_set()
3688 writel(group, spec->mem_base + 0x804); in ca0113_mmio_command_set()
3690 writel(0x00800005, spec->mem_base + 0x20c); in ca0113_mmio_command_set()
3695 writel(write_val, spec->mem_base + 0x204); in ca0113_mmio_command_set()
3701 readl(spec->mem_base + 0x860); in ca0113_mmio_command_set()
3702 readl(spec->mem_base + 0x854); in ca0113_mmio_command_set()
3703 readl(spec->mem_base + 0x840); in ca0113_mmio_command_set()
3705 writel(0x00800004, spec->mem_base + 0x20c); in ca0113_mmio_command_set()
3706 writel(0x00000000, spec->mem_base + 0x210); in ca0113_mmio_command_set()
3707 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set()
3708 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set()
3717 struct ca0132_spec *spec = codec->spec; in ca0113_mmio_command_set_type2() local
3720 writel(0x0000007e, spec->mem_base + 0x210); in ca0113_mmio_command_set_type2()
3721 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set_type2()
3722 writel(0x0000005a, spec->mem_base + 0x210); in ca0113_mmio_command_set_type2()
3723 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set_type2()
3724 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set_type2()
3726 writel(0x00800003, spec->mem_base + 0x20c); in ca0113_mmio_command_set_type2()
3727 writel(group, spec->mem_base + 0x804); in ca0113_mmio_command_set_type2()
3729 writel(0x00800005, spec->mem_base + 0x20c); in ca0113_mmio_command_set_type2()
3734 writel(write_val, spec->mem_base + 0x204); in ca0113_mmio_command_set_type2()
3736 readl(spec->mem_base + 0x860); in ca0113_mmio_command_set_type2()
3737 readl(spec->mem_base + 0x854); in ca0113_mmio_command_set_type2()
3738 readl(spec->mem_base + 0x840); in ca0113_mmio_command_set_type2()
3740 writel(0x00800004, spec->mem_base + 0x20c); in ca0113_mmio_command_set_type2()
3741 writel(0x00000000, spec->mem_base + 0x210); in ca0113_mmio_command_set_type2()
3742 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set_type2()
3743 readl(spec->mem_base + 0x210); in ca0113_mmio_command_set_type2()
3756 struct ca0132_spec *spec = codec->spec; in ca0132_gpio_init() local
3758 switch (ca0132_quirk(spec)) { in ca0132_gpio_init()
3779 struct ca0132_spec *spec = codec->spec; in ca0132_gpio_setup() local
3781 switch (ca0132_quirk(spec)) { in ca0132_gpio_setup()
3905 struct ca0132_spec *spec = codec->spec; in ca0132_playback_pcm_prepare() local
3907 snd_hda_codec_setup_stream(codec, spec->dacs[0], stream_tag, 0, format); in ca0132_playback_pcm_prepare()
3916 struct ca0132_spec *spec = codec->spec; in ca0132_playback_pcm_cleanup() local
3918 if (spec->dsp_state == DSP_DOWNLOADING) in ca0132_playback_pcm_cleanup()
3923 if (spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID]) in ca0132_playback_pcm_cleanup()
3926 snd_hda_codec_cleanup_stream(codec, spec->dacs[0]); in ca0132_playback_pcm_cleanup()
3935 struct ca0132_spec *spec = codec->spec; in ca0132_playback_pcm_delay() local
3939 if (spec->dsp_state != DSP_DOWNLOADED) in ca0132_playback_pcm_delay()
3943 if (spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID]) { in ca0132_playback_pcm_delay()
3944 if ((spec->effects_switch[SURROUND - EFFECT_START_NID]) || in ca0132_playback_pcm_delay()
3945 (spec->effects_switch[DIALOG_PLUS - EFFECT_START_NID])) in ca0132_playback_pcm_delay()
3950 if (spec->cur_out_type == SPEAKER_OUT) in ca0132_playback_pcm_delay()
3963 struct ca0132_spec *spec = codec->spec; in ca0132_dig_playback_pcm_open() local
3964 return snd_hda_multi_out_dig_open(codec, &spec->multiout); in ca0132_dig_playback_pcm_open()
3973 struct ca0132_spec *spec = codec->spec; in ca0132_dig_playback_pcm_prepare() local
3974 return snd_hda_multi_out_dig_prepare(codec, &spec->multiout, in ca0132_dig_playback_pcm_prepare()
3982 struct ca0132_spec *spec = codec->spec; in ca0132_dig_playback_pcm_cleanup() local
3983 return snd_hda_multi_out_dig_cleanup(codec, &spec->multiout); in ca0132_dig_playback_pcm_cleanup()
3990 struct ca0132_spec *spec = codec->spec; in ca0132_dig_playback_pcm_close() local
3991 return snd_hda_multi_out_dig_close(codec, &spec->multiout); in ca0132_dig_playback_pcm_close()
4013 struct ca0132_spec *spec = codec->spec; in ca0132_capture_pcm_cleanup() local
4015 if (spec->dsp_state == DSP_DOWNLOADING) in ca0132_capture_pcm_cleanup()
4026 struct ca0132_spec *spec = codec->spec; in ca0132_capture_pcm_delay() local
4030 if (spec->dsp_state != DSP_DOWNLOADED) in ca0132_capture_pcm_delay()
4033 if (spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID]) in ca0132_capture_pcm_delay()
4260 struct ca0132_spec *spec = codec->spec; in tuning_ctl_get() local
4265 *valp = spec->cur_ctl_vals[idx]; in tuning_ctl_get()
4286 struct ca0132_spec *spec = codec->spec; in voice_focus_ctl_put() local
4293 if (spec->cur_ctl_vals[idx] == *valp) in voice_focus_ctl_put()
4296 spec->cur_ctl_vals[idx] = *valp; in voice_focus_ctl_put()
4321 struct ca0132_spec *spec = codec->spec; in mic_svm_ctl_put() local
4328 if (spec->cur_ctl_vals[idx] == *valp) in mic_svm_ctl_put()
4331 spec->cur_ctl_vals[idx] = *valp; in mic_svm_ctl_put()
4356 struct ca0132_spec *spec = codec->spec; in equalizer_ctl_put() local
4363 if (spec->cur_ctl_vals[idx] == *valp) in equalizer_ctl_put()
4366 spec->cur_ctl_vals[idx] = *valp; in equalizer_ctl_put()
4437 struct ca0132_spec *spec = codec->spec; in ca0132_init_tuning_defaults() local
4441 spec->cur_ctl_vals[WEDGE_ANGLE - TUNING_CTL_START_NID] = 10; in ca0132_init_tuning_defaults()
4443 spec->cur_ctl_vals[SVM_LEVEL - TUNING_CTL_START_NID] = 74; in ca0132_init_tuning_defaults()
4447 spec->cur_ctl_vals[i] = 24; in ca0132_init_tuning_defaults()
4459 struct ca0132_spec *spec = codec->spec; in ca0132_select_out() local
4470 auto_jack = spec->vnode_lswitch[VNID_HP_ASEL - VNODE_START_NID]; in ca0132_select_out()
4473 jack_present = snd_hda_jack_detect(codec, spec->unsol_tag_hp); in ca0132_select_out()
4476 spec->vnode_lswitch[VNID_HP_SEL - VNODE_START_NID]; in ca0132_select_out()
4479 spec->cur_out_type = HEADPHONE_OUT; in ca0132_select_out()
4481 spec->cur_out_type = SPEAKER_OUT; in ca0132_select_out()
4483 if (spec->cur_out_type == SPEAKER_OUT) { in ca0132_select_out()
4497 snd_hda_codec_write(codec, spec->out_pins[1], 0, in ca0132_select_out()
4499 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4501 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4503 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4507 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[1], 0, in ca0132_select_out()
4509 snd_hda_set_pin_ctl(codec, spec->out_pins[1], in ca0132_select_out()
4512 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[0], 0, in ca0132_select_out()
4514 snd_hda_set_pin_ctl(codec, spec->out_pins[0], in ca0132_select_out()
4530 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4532 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4534 snd_hda_codec_write(codec, spec->out_pins[1], 0, in ca0132_select_out()
4536 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4540 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[0], 0, in ca0132_select_out()
4542 snd_hda_set_pin_ctl(codec, spec->out_pins[0], in ca0132_select_out()
4545 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[1], 0, in ca0132_select_out()
4547 snd_hda_set_pin_ctl(codec, spec->out_pins[1], in ca0132_select_out()
4563 struct ca0132_spec *spec = codec->spec; in ae5_mmio_select_out() local
4567 if (ca0132_quirk(spec) == QUIRK_AE5) in ae5_mmio_select_out()
4575 out_cmds->vals[spec->cur_out_type][i]); in ae5_mmio_select_out()
4580 struct ca0132_spec *spec = codec->spec; in ca0132_alt_set_full_range_speaker() local
4581 int quirk = ca0132_quirk(spec); in ca0132_alt_set_full_range_speaker()
4586 if (spec->channel_cfg_val == SPEAKER_CHANNELS_4_0 in ca0132_alt_set_full_range_speaker()
4587 || spec->channel_cfg_val == SPEAKER_CHANNELS_2_0) in ca0132_alt_set_full_range_speaker()
4591 tmp = spec->speaker_range_val[0] ? FLOAT_ZERO : FLOAT_ONE; in ca0132_alt_set_full_range_speaker()
4598 tmp = spec->speaker_range_val[1] ? FLOAT_ZERO : FLOAT_ONE; in ca0132_alt_set_full_range_speaker()
4626 struct ca0132_spec *spec = codec->spec; in ca0132_alt_surround_set_bass_redirection() local
4630 if (val && spec->channel_cfg_val != SPEAKER_CHANNELS_4_0 && in ca0132_alt_surround_set_bass_redirection()
4631 spec->channel_cfg_val != SPEAKER_CHANNELS_2_0) in ca0132_alt_surround_set_bass_redirection()
4642 tmp = float_xbass_xover_lookup[spec->xbass_xover_freq]; in ca0132_alt_surround_set_bass_redirection()
4659 struct ca0132_spec *spec = codec->spec; in ca0132_alt_select_out_get_quirk_data() local
4660 int quirk = ca0132_quirk(spec); in ca0132_alt_select_out_get_quirk_data()
4676 struct ca0132_spec *spec = codec->spec; in ca0132_alt_select_out_quirk_set() local
4684 out_info = &quirk_data->out_set_info[spec->cur_out_type]; in ca0132_alt_select_out_quirk_set()
4727 if (spec->cur_out_type != HEADPHONE_OUT) { in ca0132_alt_select_out_quirk_set()
4735 spec->ae5_headphone_gain_val); in ca0132_alt_select_out_quirk_set()
4738 spec->zxr_gain_set); in ca0132_alt_select_out_quirk_set()
4768 struct ca0132_spec *spec = codec->spec; in ca0132_alt_select_out() local
4774 hda_nid_t headphone_nid = spec->out_pins[1]; in ca0132_alt_select_out()
4780 auto_jack = spec->vnode_lswitch[VNID_HP_ASEL - VNODE_START_NID]; in ca0132_alt_select_out()
4788 jack_present = snd_hda_jack_detect(codec, spec->unsol_tag_hp) || in ca0132_alt_select_out()
4789 snd_hda_jack_detect(codec, spec->unsol_tag_front_hp); in ca0132_alt_select_out()
4792 spec->cur_out_type = HEADPHONE_OUT; in ca0132_alt_select_out()
4794 spec->cur_out_type = SPEAKER_OUT; in ca0132_alt_select_out()
4796 spec->cur_out_type = spec->out_enum_val; in ca0132_alt_select_out()
4798 outfx_set = spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID]; in ca0132_alt_select_out()
4808 switch (spec->cur_out_type) { in ca0132_alt_select_out()
4813 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_alt_select_out()
4817 ca0132_set_out_node_pincfg(codec, spec->out_pins[1], 0, 0); in ca0132_alt_select_out()
4819 ca0132_set_out_node_pincfg(codec, spec->out_pins[0], 1, 0); in ca0132_alt_select_out()
4821 ca0132_set_out_node_pincfg(codec, spec->out_pins[2], 1, 0); in ca0132_alt_select_out()
4823 ca0132_set_out_node_pincfg(codec, spec->out_pins[3], 1, 0); in ca0132_alt_select_out()
4830 if (!outfx_set && spec->channel_cfg_val == SPEAKER_CHANNELS_2_0) in ca0132_alt_select_out()
4833 tmp = speaker_channel_cfgs[spec->channel_cfg_val].val; in ca0132_alt_select_out()
4842 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_alt_select_out()
4846 ca0132_set_out_node_pincfg(codec, spec->out_pins[0], 0, 0); in ca0132_alt_select_out()
4847 ca0132_set_out_node_pincfg(codec, spec->out_pins[2], 0, 0); in ca0132_alt_select_out()
4848 ca0132_set_out_node_pincfg(codec, spec->out_pins[3], 0, 0); in ca0132_alt_select_out()
4851 if (snd_hda_jack_detect(codec, spec->unsol_tag_front_hp)) in ca0132_alt_select_out()
4852 headphone_nid = spec->out_pins[2]; in ca0132_alt_select_out()
4853 else if (snd_hda_jack_detect(codec, spec->unsol_tag_hp)) in ca0132_alt_select_out()
4854 headphone_nid = spec->out_pins[1]; in ca0132_alt_select_out()
4874 spec->effects_switch[X_BASS - EFFECT_START_NID]); in ca0132_alt_select_out()
4890 if (spec->cur_out_type == SPEAKER_OUT) in ca0132_alt_select_out()
4892 spec->bass_redirection_val); in ca0132_alt_select_out()
4902 if (spec->cur_out_type == SPEAKER_OUT) { in ca0132_alt_select_out()
4916 struct ca0132_spec *spec = container_of( in ca0132_unsol_hp_delayed() local
4920 if (ca0132_use_alt_functions(spec)) in ca0132_unsol_hp_delayed()
4921 ca0132_alt_select_out(spec->codec); in ca0132_unsol_hp_delayed()
4923 ca0132_select_out(spec->codec); in ca0132_unsol_hp_delayed()
4925 jack = snd_hda_jack_tbl_get(spec->codec, spec->unsol_tag_hp); in ca0132_unsol_hp_delayed()
4928 snd_hda_jack_report_sync(spec->codec); in ca0132_unsol_hp_delayed()
4944 struct ca0132_spec *spec = codec->spec; in ca0132_set_vipsource() local
4947 if (spec->dsp_state != DSP_DOWNLOADED) in ca0132_set_vipsource()
4951 if (!spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID] || in ca0132_set_vipsource()
4956 if (spec->cur_mic_type == DIGITAL_MIC) in ca0132_set_vipsource()
4966 if (spec->cur_mic_type == DIGITAL_MIC) in ca0132_set_vipsource()
4982 struct ca0132_spec *spec = codec->spec; in ca0132_alt_set_vipsource() local
4985 if (spec->dsp_state != DSP_DOWNLOADED) in ca0132_alt_set_vipsource()
4994 if (!spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID] || in ca0132_alt_set_vipsource()
4995 (val == 0) || spec->in_enum_val == REAR_LINE_IN) { in ca0132_alt_set_vipsource()
5004 if (ca0132_quirk(spec) == QUIRK_R3DI) in ca0132_alt_set_vipsource()
5008 if (spec->in_enum_val == REAR_LINE_IN) in ca0132_alt_set_vipsource()
5011 if (ca0132_quirk(spec) == QUIRK_SBZ) in ca0132_alt_set_vipsource()
5023 if (ca0132_quirk(spec) == QUIRK_R3DI) in ca0132_alt_set_vipsource()
5026 if (spec->effects_switch[VOICE_FOCUS - EFFECT_START_NID]) in ca0132_alt_set_vipsource()
5053 struct ca0132_spec *spec = codec->spec; in ca0132_select_mic() local
5061 auto_jack = spec->vnode_lswitch[VNID_AMIC1_ASEL - VNODE_START_NID]; in ca0132_select_mic()
5064 jack_present = snd_hda_jack_detect(codec, spec->unsol_tag_amic1); in ca0132_select_mic()
5067 spec->vnode_lswitch[VNID_AMIC1_SEL - VNODE_START_NID]; in ca0132_select_mic()
5070 spec->cur_mic_type = LINE_MIC_IN; in ca0132_select_mic()
5072 spec->cur_mic_type = DIGITAL_MIC; in ca0132_select_mic()
5074 if (spec->cur_mic_type == DIGITAL_MIC) { in ca0132_select_mic()
5081 spec->effects_switch in ca0132_select_mic()
5087 ca0132_mic_boost_set(codec, spec->cur_mic_boost); in ca0132_select_mic()
5105 struct ca0132_spec *spec = codec->spec; in ca0132_alt_select_in() local
5115 spec->cur_mic_type = spec->in_enum_val; in ca0132_alt_select_in()
5117 switch (spec->cur_mic_type) { in ca0132_alt_select_in()
5119 switch (ca0132_quirk(spec)) { in ca0132_alt_select_in()
5152 if (ca0132_quirk(spec) == QUIRK_R3DI) in ca0132_alt_select_in()
5159 switch (ca0132_quirk(spec)) { in ca0132_alt_select_in()
5175 ca0132_alt_mic_boost_set(codec, spec->mic_boost_enum_val); in ca0132_alt_select_in()
5179 switch (ca0132_quirk(spec)) { in ca0132_alt_select_in()
5204 if (ca0132_quirk(spec) == QUIRK_R3DI) in ca0132_alt_select_in()
5207 if (ca0132_quirk(spec) == QUIRK_AE7) in ca0132_alt_select_in()
5213 switch (ca0132_quirk(spec)) { in ca0132_alt_select_in()
5226 switch (ca0132_quirk(spec)) { in ca0132_alt_select_in()
5248 if (ca0132_quirk(spec) == QUIRK_R3DI) in ca0132_alt_select_in()
5256 switch (ca0132_quirk(spec)) { in ca0132_alt_select_in()
5268 ca0132_alt_mic_boost_set(codec, spec->mic_boost_enum_val); in ca0132_alt_select_in()
5284 struct ca0132_spec *spec = codec->spec; in ca0132_is_vnode_effective() local
5289 nid = spec->shared_out_nid; in ca0132_is_vnode_effective()
5292 nid = spec->shared_mic_nid; in ca0132_is_vnode_effective()
5310 struct ca0132_spec *spec = codec->spec; in ca0132_voicefx_set() local
5315 tmp = spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID] ? in ca0132_voicefx_set()
5332 struct ca0132_spec *spec = codec->spec; in ca0132_effects_set() local
5344 if (!spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID]) in ca0132_effects_set()
5346 if (spec->cur_out_type == SPEAKER_OUT && nid == X_BASS) { in ca0132_effects_set()
5347 channel_cfg = spec->channel_cfg_val; in ca0132_effects_set()
5357 if (!spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID]) in ca0132_effects_set()
5361 if ((nid == VOICE_FOCUS) && (spec->cur_mic_type != DIGITAL_MIC)) in ca0132_effects_set()
5365 if ((nid == VOICE_FOCUS) && ca0132_use_pci_mmio(spec) in ca0132_effects_set()
5366 && (spec->cur_mic_type != REAR_LINE_IN)) { in ca0132_effects_set()
5367 if (spec->effects_switch[CRYSTAL_VOICE - in ca0132_effects_set()
5370 if (spec->effects_switch[VOICE_FOCUS - in ca0132_effects_set()
5384 if ((nid == NOISE_REDUCTION) && ca0132_use_pci_mmio(spec) in ca0132_effects_set()
5385 && (spec->cur_mic_type != REAR_LINE_IN)) { in ca0132_effects_set()
5386 if (spec->effects_switch[CRYSTAL_VOICE - in ca0132_effects_set()
5388 if (spec->effects_switch[NOISE_REDUCTION - in ca0132_effects_set()
5400 if (ca0132_use_alt_functions(spec) && in ca0132_effects_set()
5401 spec->in_enum_val == REAR_LINE_IN) in ca0132_effects_set()
5423 struct ca0132_spec *spec = codec->spec; in ca0132_pe_switch_set() local
5428 spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID]); in ca0132_pe_switch_set()
5430 if (ca0132_use_alt_functions(spec)) in ca0132_pe_switch_set()
5437 ret |= ca0132_effects_set(codec, nid, spec->effects_switch[i]); in ca0132_pe_switch_set()
5445 struct ca0132_spec *spec = codec->spec; in stop_mic1() local
5446 unsigned int oldval = snd_hda_codec_read(codec, spec->adcs[0], 0, in stop_mic1()
5449 snd_hda_codec_write(codec, spec->adcs[0], 0, in stop_mic1()
5458 struct ca0132_spec *spec = codec->spec; in resume_mic1() local
5461 snd_hda_codec_write(codec, spec->adcs[0], 0, in resume_mic1()
5471 struct ca0132_spec *spec = codec->spec; in ca0132_cvoice_switch_set() local
5477 spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID]); in ca0132_cvoice_switch_set()
5483 ret |= ca0132_effects_set(codec, nid, spec->effects_switch[i]); in ca0132_cvoice_switch_set()
5486 ret |= ca0132_voicefx_set(codec, (spec->voicefx_val ? 1 : 0)); in ca0132_cvoice_switch_set()
5490 if (ca0132_use_alt_functions(spec)) in ca0132_cvoice_switch_set()
5500 struct ca0132_spec *spec = codec->spec; in ca0132_mic_boost_set() local
5504 ret = snd_hda_codec_amp_update(codec, spec->input_pins[0], 0, in ca0132_mic_boost_set()
5507 ret = snd_hda_codec_amp_update(codec, spec->input_pins[0], 0, in ca0132_mic_boost_set()
5515 struct ca0132_spec *spec = codec->spec; in ca0132_alt_mic_boost_set() local
5518 ret = snd_hda_codec_amp_update(codec, spec->input_pins[0], 0, in ca0132_alt_mic_boost_set()
5552 struct ca0132_spec *spec = codec->spec; in ca0132_vnode_switch_set() local
5557 spec->vnode_lswitch[VNID_HP_ASEL - VNODE_START_NID]; in ca0132_vnode_switch_set()
5559 if (ca0132_use_alt_functions(spec)) in ca0132_vnode_switch_set()
5569 spec->vnode_lswitch[VNID_AMIC1_ASEL - VNODE_START_NID]; in ca0132_vnode_switch_set()
5576 if (ca0132_use_alt_functions(spec)) in ca0132_vnode_switch_set()
5671 struct ca0132_spec *spec = codec->spec; in ca0132_alt_xbass_xover_slider_ctl_get() local
5676 *valp = spec->bass_redirect_xover_freq; in ca0132_alt_xbass_xover_slider_ctl_get()
5678 *valp = spec->xbass_xover_freq; in ca0132_alt_xbass_xover_slider_ctl_get()
5687 struct ca0132_spec *spec = codec->spec; in ca0132_alt_slider_ctl_get() local
5692 *valp = spec->fx_ctl_val[idx]; in ca0132_alt_slider_ctl_get()
5730 struct ca0132_spec *spec = codec->spec; in ca0132_alt_xbass_xover_slider_put() local
5737 cur_val = &spec->bass_redirect_xover_freq; in ca0132_alt_xbass_xover_slider_put()
5739 cur_val = &spec->xbass_xover_freq; in ca0132_alt_xbass_xover_slider_put()
5760 struct ca0132_spec *spec = codec->spec; in ca0132_alt_effect_slider_put() local
5767 if (spec->fx_ctl_val[idx] == *valp) in ca0132_alt_effect_slider_put()
5770 spec->fx_ctl_val[idx] = *valp; in ca0132_alt_effect_slider_put()
5807 struct ca0132_spec *spec = codec->spec; in ca0132_alt_mic_boost_get() local
5809 ucontrol->value.enumerated.item[0] = spec->mic_boost_enum_val; in ca0132_alt_mic_boost_get()
5817 struct ca0132_spec *spec = codec->spec; in ca0132_alt_mic_boost_put() local
5827 spec->mic_boost_enum_val = sel; in ca0132_alt_mic_boost_put()
5829 if (spec->in_enum_val != REAR_LINE_IN) in ca0132_alt_mic_boost_put()
5830 ca0132_alt_mic_boost_set(codec, spec->mic_boost_enum_val); in ca0132_alt_mic_boost_put()
5861 struct ca0132_spec *spec = codec->spec; in ae5_headphone_gain_get() local
5863 ucontrol->value.enumerated.item[0] = spec->ae5_headphone_gain_val; in ae5_headphone_gain_get()
5871 struct ca0132_spec *spec = codec->spec; in ae5_headphone_gain_put() local
5881 spec->ae5_headphone_gain_val = sel; in ae5_headphone_gain_put()
5883 if (spec->out_enum_val == HEADPHONE_OUT) in ae5_headphone_gain_put()
5884 ae5_headphone_gain_set(codec, spec->ae5_headphone_gain_val); in ae5_headphone_gain_put()
5914 struct ca0132_spec *spec = codec->spec; in ae5_sound_filter_get() local
5916 ucontrol->value.enumerated.item[0] = spec->ae5_filter_val; in ae5_sound_filter_get()
5924 struct ca0132_spec *spec = codec->spec; in ae5_sound_filter_put() local
5934 spec->ae5_filter_val = sel; in ae5_sound_filter_put()
5964 struct ca0132_spec *spec = codec->spec; in ca0132_alt_input_source_get() local
5966 ucontrol->value.enumerated.item[0] = spec->in_enum_val; in ca0132_alt_input_source_get()
5974 struct ca0132_spec *spec = codec->spec; in ca0132_alt_input_source_put() local
5982 if (ca0132_quirk(spec) == QUIRK_AE7) in ca0132_alt_input_source_put()
5991 spec->in_enum_val = sel; in ca0132_alt_input_source_put()
6016 struct ca0132_spec *spec = codec->spec; in ca0132_alt_output_select_get() local
6018 ucontrol->value.enumerated.item[0] = spec->out_enum_val; in ca0132_alt_output_select_get()
6026 struct ca0132_spec *spec = codec->spec; in ca0132_alt_output_select_put() local
6037 spec->out_enum_val = sel; in ca0132_alt_output_select_put()
6039 auto_jack = spec->vnode_lswitch[VNID_HP_ASEL - VNODE_START_NID]; in ca0132_alt_output_select_put()
6067 struct ca0132_spec *spec = codec->spec; in ca0132_alt_speaker_channel_cfg_get() local
6069 ucontrol->value.enumerated.item[0] = spec->channel_cfg_val; in ca0132_alt_speaker_channel_cfg_get()
6077 struct ca0132_spec *spec = codec->spec; in ca0132_alt_speaker_channel_cfg_put() local
6087 spec->channel_cfg_val = sel; in ca0132_alt_speaker_channel_cfg_put()
6089 if (spec->out_enum_val == SPEAKER_OUT) in ca0132_alt_speaker_channel_cfg_put()
6120 struct ca0132_spec *spec = codec->spec; in ca0132_alt_svm_setting_get() local
6122 ucontrol->value.enumerated.item[0] = spec->smart_volume_setting; in ca0132_alt_svm_setting_get()
6130 struct ca0132_spec *spec = codec->spec; in ca0132_alt_svm_setting_put() local
6142 spec->smart_volume_setting = sel; in ca0132_alt_svm_setting_put()
6184 struct ca0132_spec *spec = codec->spec; in ca0132_alt_eq_preset_get() local
6186 ucontrol->value.enumerated.item[0] = spec->eq_preset_val; in ca0132_alt_eq_preset_get()
6194 struct ca0132_spec *spec = codec->spec; in ca0132_alt_eq_preset_put() local
6217 spec->eq_preset_val = sel; in ca0132_alt_eq_preset_put()
6241 struct ca0132_spec *spec = codec->spec; in ca0132_voicefx_get() local
6243 ucontrol->value.enumerated.item[0] = spec->voicefx_val; in ca0132_voicefx_get()
6251 struct ca0132_spec *spec = codec->spec; in ca0132_voicefx_put() local
6274 spec->voicefx_val = sel; in ca0132_voicefx_put()
6286 struct ca0132_spec *spec = codec->spec; in ca0132_switch_get() local
6294 *valp = spec->vnode_lswitch[nid - VNODE_START_NID]; in ca0132_switch_get()
6298 *valp = spec->vnode_rswitch[nid - VNODE_START_NID]; in ca0132_switch_get()
6306 *valp = spec->effects_switch[nid - EFFECT_START_NID]; in ca0132_switch_get()
6311 if (nid == spec->input_pins[0]) { in ca0132_switch_get()
6312 *valp = spec->cur_mic_boost; in ca0132_switch_get()
6317 *valp = spec->zxr_gain_set; in ca0132_switch_get()
6322 *valp = spec->speaker_range_val[nid - SPEAKER_FULL_RANGE_FRONT]; in ca0132_switch_get()
6327 *valp = spec->bass_redirection_val; in ca0132_switch_get()
6338 struct ca0132_spec *spec = codec->spec; in ca0132_switch_put() local
6351 spec->vnode_lswitch[nid - VNODE_START_NID] = *valp; in ca0132_switch_put()
6355 spec->vnode_rswitch[nid - VNODE_START_NID] = *valp; in ca0132_switch_put()
6364 spec->effects_switch[nid - EFFECT_START_NID] = *valp; in ca0132_switch_put()
6371 spec->effects_switch[nid - EFFECT_START_NID] = *valp; in ca0132_switch_put()
6379 spec->effects_switch[nid - EFFECT_START_NID] = *valp; in ca0132_switch_put()
6385 if (nid == spec->input_pins[0]) { in ca0132_switch_put()
6386 spec->cur_mic_boost = *valp; in ca0132_switch_put()
6387 if (ca0132_use_alt_functions(spec)) { in ca0132_switch_put()
6388 if (spec->in_enum_val != REAR_LINE_IN) in ca0132_switch_put()
6392 if (spec->cur_mic_type != DIGITAL_MIC) in ca0132_switch_put()
6400 spec->zxr_gain_set = *valp; in ca0132_switch_put()
6401 if (spec->cur_out_type == HEADPHONE_OUT) in ca0132_switch_put()
6410 spec->speaker_range_val[nid - SPEAKER_FULL_RANGE_FRONT] = *valp; in ca0132_switch_put()
6411 if (spec->cur_out_type == SPEAKER_OUT) in ca0132_switch_put()
6418 spec->bass_redirection_val = *valp; in ca0132_switch_put()
6419 if (spec->cur_out_type == SPEAKER_OUT) in ca0132_switch_put()
6440 struct ca0132_spec *spec = codec->spec; in ca0132_alt_dsp_volume_put() local
6449 lookup_val = spec->vnode_lvol[nid - VNODE_START_NID]; in ca0132_alt_dsp_volume_put()
6456 lookup_val = spec->vnode_rvol[nid - VNODE_START_NID]; in ca0132_alt_dsp_volume_put()
6472 struct ca0132_spec *spec = codec->spec; in ca0132_volume_info() local
6482 nid = spec->shared_out_nid; in ca0132_volume_info()
6492 nid = spec->shared_mic_nid; in ca0132_volume_info()
6510 struct ca0132_spec *spec = codec->spec; in ca0132_volume_get() local
6517 *valp = spec->vnode_lvol[nid - VNODE_START_NID]; in ca0132_volume_get()
6521 *valp = spec->vnode_rvol[nid - VNODE_START_NID]; in ca0132_volume_get()
6531 struct ca0132_spec *spec = codec->spec; in ca0132_volume_put() local
6541 spec->vnode_lvol[nid - VNODE_START_NID] = *valp; in ca0132_volume_put()
6545 spec->vnode_rvol[nid - VNODE_START_NID] = *valp; in ca0132_volume_put()
6578 struct ca0132_spec *spec = codec->spec; in ca0132_alt_volume_put() local
6596 spec->vnode_lvol[vnid - VNODE_START_NID] = *valp; in ca0132_alt_volume_put()
6600 spec->vnode_rvol[vnid - VNODE_START_NID] = *valp; in ca0132_alt_volume_put()
6618 struct ca0132_spec *spec = codec->spec; in ca0132_volume_tlv() local
6628 nid = spec->shared_out_nid; in ca0132_volume_tlv()
6638 nid = spec->shared_mic_nid; in ca0132_volume_tlv()
6691 struct ca0132_spec *spec = codec->spec; in add_fx_switch() local
6699 if (ca0132_use_alt_controls(spec) && (nid <= IN_EFFECT_END_NID)) in add_fx_switch()
7040 struct ca0132_spec *spec = codec->spec; in ca0132_build_controls() local
7045 for (i = 0; i < spec->num_mixers; i++) { in ca0132_build_controls()
7046 err = snd_hda_add_new_ctls(codec, spec->mixers[i]); in ca0132_build_controls()
7051 if (ca0132_use_alt_functions(spec)) { in ca0132_build_controls()
7052 snd_hda_set_vmaster_tlv(codec, spec->dacs[0], HDA_OUTPUT, in ca0132_build_controls()
7053 spec->tlv); in ca0132_build_controls()
7055 spec->tlv, ca0132_alt_follower_pfxs, in ca0132_build_controls()
7060 true, 0, &spec->vmaster_mute.sw_kctl); in ca0132_build_controls()
7071 if (ca0132_use_pci_mmio(spec)) { in ca0132_build_controls()
7088 if (ca0132_use_alt_controls(spec)) { in ca0132_build_controls()
7142 if (ca0132_use_alt_functions(spec)) { in ca0132_build_controls()
7168 if (ca0132_quirk(spec) != QUIRK_ZXR) { in ca0132_build_controls()
7175 switch (ca0132_quirk(spec)) { in ca0132_build_controls()
7198 err = snd_hda_jack_add_kctls(codec, &spec->autocfg); in ca0132_build_controls()
7202 if (spec->dig_out) { in ca0132_build_controls()
7203 err = snd_hda_create_spdif_out_ctls(codec, spec->dig_out, in ca0132_build_controls()
7204 spec->dig_out); in ca0132_build_controls()
7207 err = snd_hda_create_spdif_share_sw(codec, &spec->multiout); in ca0132_build_controls()
7213 if (spec->dig_in) { in ca0132_build_controls()
7214 err = snd_hda_create_spdif_in_ctls(codec, spec->dig_in); in ca0132_build_controls()
7219 if (ca0132_use_alt_functions(spec)) in ca0132_build_controls()
7227 struct ca0132_spec *spec = codec->spec; in dbpro_build_controls() local
7230 if (spec->dig_out) { in dbpro_build_controls()
7231 err = snd_hda_create_spdif_out_ctls(codec, spec->dig_out, in dbpro_build_controls()
7232 spec->dig_out); in dbpro_build_controls()
7237 if (spec->dig_in) { in dbpro_build_controls()
7238 err = snd_hda_create_spdif_in_ctls(codec, spec->dig_in); in dbpro_build_controls()
7291 struct ca0132_spec *spec = codec->spec; in ca0132_build_pcms() local
7297 if (ca0132_use_alt_functions(spec)) { in ca0132_build_pcms()
7303 info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid = spec->dacs[0]; in ca0132_build_pcms()
7305 spec->multiout.max_channels; in ca0132_build_pcms()
7308 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adcs[0]; in ca0132_build_pcms()
7311 if (!ca0132_use_alt_functions(spec)) { in ca0132_build_pcms()
7318 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adcs[1]; in ca0132_build_pcms()
7326 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adcs[2]; in ca0132_build_pcms()
7328 if (!spec->dig_out && !spec->dig_in) in ca0132_build_pcms()
7335 if (spec->dig_out) { in ca0132_build_pcms()
7338 info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid = spec->dig_out; in ca0132_build_pcms()
7340 if (spec->dig_in) { in ca0132_build_pcms()
7343 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->dig_in; in ca0132_build_pcms()
7351 struct ca0132_spec *spec = codec->spec; in dbpro_build_pcms() local
7359 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adcs[0]; in dbpro_build_pcms()
7362 if (!spec->dig_out && !spec->dig_in) in dbpro_build_pcms()
7369 if (spec->dig_out) { in dbpro_build_pcms()
7372 info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid = spec->dig_out; in dbpro_build_pcms()
7374 if (spec->dig_in) { in dbpro_build_pcms()
7377 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->dig_in; in dbpro_build_pcms()
7432 struct ca0132_spec *spec = codec->spec; in ca0132_set_dmic() local
7446 val = spec->dmic_ctl; in ca0132_set_dmic()
7448 snd_hda_codec_write(codec, spec->input_pins[0], 0, in ca0132_set_dmic()
7451 if (!(spec->dmic_ctl & 0x20)) in ca0132_set_dmic()
7458 val = spec->dmic_ctl; in ca0132_set_dmic()
7461 snd_hda_codec_write(codec, spec->input_pins[0], 0, in ca0132_set_dmic()
7464 if (!(spec->dmic_ctl & 0x20)) in ca0132_set_dmic()
7476 struct ca0132_spec *spec = codec->spec; in ca0132_init_dmic() local
7489 snd_hda_codec_write(codec, spec->input_pins[0], 0, in ca0132_init_dmic()
7499 snd_hda_codec_write(codec, spec->input_pins[0], 0, in ca0132_init_dmic()
7509 if (ca0132_quirk(spec) == QUIRK_ALIENWARE_M17XR4) in ca0132_init_dmic()
7514 spec->dmic_ctl = val; in ca0132_init_dmic()
7515 snd_hda_codec_write(codec, spec->input_pins[0], 0, in ca0132_init_dmic()
7524 struct ca0132_spec *spec = codec->spec; in ca0132_init_analog_mic2() local
7526 mutex_lock(&spec->chipio_mutex); in ca0132_init_analog_mic2()
7531 mutex_unlock(&spec->chipio_mutex); in ca0132_init_analog_mic2()
7536 struct ca0132_spec *spec = codec->spec; in ca0132_refresh_widget_caps() local
7542 for (i = 0; i < spec->multiout.num_dacs; i++) in ca0132_refresh_widget_caps()
7543 refresh_amp_caps(codec, spec->dacs[i], HDA_OUTPUT); in ca0132_refresh_widget_caps()
7545 for (i = 0; i < spec->num_outputs; i++) in ca0132_refresh_widget_caps()
7546 refresh_amp_caps(codec, spec->out_pins[i], HDA_OUTPUT); in ca0132_refresh_widget_caps()
7548 for (i = 0; i < spec->num_inputs; i++) { in ca0132_refresh_widget_caps()
7549 refresh_amp_caps(codec, spec->adcs[i], HDA_INPUT); in ca0132_refresh_widget_caps()
7550 refresh_amp_caps(codec, spec->input_pins[i], HDA_INPUT); in ca0132_refresh_widget_caps()
7614 struct ca0132_spec *spec = codec->spec; in ca0132_alt_start_dsp_audio_streams() local
7621 mutex_lock(&spec->chipio_mutex); in ca0132_alt_start_dsp_audio_streams()
7632 mutex_unlock(&spec->chipio_mutex); in ca0132_alt_start_dsp_audio_streams()
7641 mutex_lock(&spec->chipio_mutex); in ca0132_alt_start_dsp_audio_streams()
7654 mutex_unlock(&spec->chipio_mutex); in ca0132_alt_start_dsp_audio_streams()
7770 struct ca0132_spec *spec = codec->spec; in ca0132_alt_init_speaker_tuning() local
7774 switch (ca0132_quirk(spec)) { in ca0132_alt_init_speaker_tuning()
7814 struct ca0132_spec *spec = codec->spec; in ca0132_alt_init_analog_mics() local
7820 if (ca0132_quirk(spec) == QUIRK_R3DI) { in ca0132_alt_init_analog_mics()
7830 if (ca0132_quirk(spec) == QUIRK_R3DI) in ca0132_alt_init_analog_mics()
7844 struct ca0132_spec *spec = codec->spec; in sbz_connect_streams() local
7846 mutex_lock(&spec->chipio_mutex); in sbz_connect_streams()
7862 mutex_unlock(&spec->chipio_mutex); in sbz_connect_streams()
7874 struct ca0132_spec *spec = codec->spec; in sbz_chipio_startup_data() local
7876 mutex_lock(&spec->chipio_mutex); in sbz_chipio_startup_data()
7883 switch (ca0132_quirk(spec)) { in sbz_chipio_startup_data()
7901 mutex_unlock(&spec->chipio_mutex); in sbz_chipio_startup_data()
7906 struct ca0132_spec *spec = codec->spec; in ca0132_alt_dsp_initial_mic_setup() local
7921 switch (ca0132_quirk(spec)) { in ca0132_alt_dsp_initial_mic_setup()
7937 struct ca0132_spec *spec = codec->spec; in ae5_post_dsp_register_set() local
7942 writeb(0xff, spec->mem_base + 0x304); in ae5_post_dsp_register_set()
7943 writeb(0xff, spec->mem_base + 0x304); in ae5_post_dsp_register_set()
7944 writeb(0xff, spec->mem_base + 0x304); in ae5_post_dsp_register_set()
7945 writeb(0xff, spec->mem_base + 0x304); in ae5_post_dsp_register_set()
7946 writeb(0x00, spec->mem_base + 0x100); in ae5_post_dsp_register_set()
7947 writeb(0xff, spec->mem_base + 0x304); in ae5_post_dsp_register_set()
7948 writeb(0x00, spec->mem_base + 0x100); in ae5_post_dsp_register_set()
7949 writeb(0xff, spec->mem_base + 0x304); in ae5_post_dsp_register_set()
7950 writeb(0x00, spec->mem_base + 0x100); in ae5_post_dsp_register_set()
7951 writeb(0xff, spec->mem_base + 0x304); in ae5_post_dsp_register_set()
7952 writeb(0x00, spec->mem_base + 0x100); in ae5_post_dsp_register_set()
7953 writeb(0xff, spec->mem_base + 0x304); in ae5_post_dsp_register_set()
7991 struct ca0132_spec *spec = codec->spec; in ae5_post_dsp_stream_setup() local
7993 mutex_lock(&spec->chipio_mutex); in ae5_post_dsp_stream_setup()
8012 mutex_unlock(&spec->chipio_mutex); in ae5_post_dsp_stream_setup()
8017 struct ca0132_spec *spec = codec->spec; in ae5_post_dsp_startup_data() local
8019 mutex_lock(&spec->chipio_mutex); in ae5_post_dsp_startup_data()
8044 mutex_unlock(&spec->chipio_mutex); in ae5_post_dsp_startup_data()
8049 struct ca0132_spec *spec = codec->spec; in ae7_post_dsp_setup_ports() local
8051 mutex_lock(&spec->chipio_mutex); in ae7_post_dsp_setup_ports()
8065 mutex_unlock(&spec->chipio_mutex); in ae7_post_dsp_setup_ports()
8070 struct ca0132_spec *spec = codec->spec; in ae7_post_dsp_asi_stream_setup() local
8072 mutex_lock(&spec->chipio_mutex); in ae7_post_dsp_asi_stream_setup()
8088 mutex_unlock(&spec->chipio_mutex); in ae7_post_dsp_asi_stream_setup()
8107 struct ca0132_spec *spec = codec->spec; in ae7_post_dsp_asi_setup_ports() local
8116 mutex_lock(&spec->chipio_mutex); in ae7_post_dsp_asi_setup_ports()
8179 mutex_unlock(&spec->chipio_mutex); in ae7_post_dsp_asi_setup_ports()
8218 struct ca0132_spec *spec = codec->spec; in ca0132_setup_defaults() local
8223 if (spec->dsp_state != DSP_DOWNLOADED) in ca0132_setup_defaults()
8263 struct ca0132_spec *spec = codec->spec; in r3d_setup_defaults() local
8268 if (spec->dsp_state != DSP_DOWNLOADED) in r3d_setup_defaults()
8286 if (ca0132_quirk(spec) == QUIRK_R3DI) in r3d_setup_defaults()
8290 if (ca0132_quirk(spec) == QUIRK_R3D) { in r3d_setup_defaults()
8313 struct ca0132_spec *spec = codec->spec; in sbz_setup_defaults() local
8318 if (spec->dsp_state != DSP_DOWNLOADED) in sbz_setup_defaults()
8367 struct ca0132_spec *spec = codec->spec; in ae5_setup_defaults() local
8372 if (spec->dsp_state != DSP_DOWNLOADED) in ae5_setup_defaults()
8432 struct ca0132_spec *spec = codec->spec; in ae7_setup_defaults() local
8437 if (spec->dsp_state != DSP_DOWNLOADED) in ae7_setup_defaults()
8515 struct ca0132_spec *spec = codec->spec; in ca0132_init_flags() local
8517 if (ca0132_use_alt_functions(spec)) { in ca0132_init_flags()
8548 struct ca0132_spec *spec = codec->spec; in ca0132_init_params() local
8550 if (ca0132_use_alt_functions(spec)) { in ca0132_init_params()
8579 struct ca0132_spec *spec = codec->spec; in ca0132_download_dsp_images() local
8587 switch (ca0132_quirk(spec)) { in ca0132_download_dsp_images()
8634 struct ca0132_spec *spec = codec->spec; in ca0132_download_dsp() local
8640 if (spec->dsp_state == DSP_DOWNLOAD_FAILED) in ca0132_download_dsp()
8644 if (spec->dsp_state != DSP_DOWNLOADED) { in ca0132_download_dsp()
8645 spec->dsp_state = DSP_DOWNLOADING; in ca0132_download_dsp()
8648 spec->dsp_state = DSP_DOWNLOAD_FAILED; in ca0132_download_dsp()
8650 spec->dsp_state = DSP_DOWNLOADED; in ca0132_download_dsp()
8654 if (spec->dsp_state == DSP_DOWNLOADED && !ca0132_use_alt_functions(spec)) in ca0132_download_dsp()
8661 struct ca0132_spec *spec = codec->spec; in ca0132_process_dsp_response() local
8665 if (spec->wait_scp) { in ca0132_process_dsp_response()
8667 spec->wait_scp = 0; in ca0132_process_dsp_response()
8676 struct ca0132_spec *spec = codec->spec; in hp_callback() local
8685 schedule_delayed_work(&spec->unsol_hp_work, msecs_to_jiffies(500)); in hp_callback()
8690 struct ca0132_spec *spec = codec->spec; in amic_callback() local
8692 if (ca0132_use_alt_functions(spec)) in amic_callback()
8700 struct ca0132_spec *spec = codec->spec; in ca0132_setup_unsol() local
8701 snd_hda_jack_detect_enable_callback(codec, spec->unsol_tag_hp, hp_callback); in ca0132_setup_unsol()
8702 snd_hda_jack_detect_enable_callback(codec, spec->unsol_tag_amic1, in ca0132_setup_unsol()
8707 if (ca0132_use_alt_functions(spec)) in ca0132_setup_unsol()
8709 spec->unsol_tag_front_hp, hp_callback); in ca0132_setup_unsol()
8789 struct ca0132_spec *spec = codec->spec; in ca0132_init_chip() local
8794 mutex_init(&spec->chipio_mutex); in ca0132_init_chip()
8802 if (ca0132_use_alt_functions(spec)) { in ca0132_init_chip()
8812 spec->cur_out_type = SPEAKER_OUT; in ca0132_init_chip()
8813 if (!ca0132_use_alt_functions(spec)) in ca0132_init_chip()
8814 spec->cur_mic_type = DIGITAL_MIC; in ca0132_init_chip()
8816 spec->cur_mic_type = REAR_MIC; in ca0132_init_chip()
8818 spec->cur_mic_boost = 0; in ca0132_init_chip()
8821 spec->vnode_lvol[i] = 0x5a; in ca0132_init_chip()
8822 spec->vnode_rvol[i] = 0x5a; in ca0132_init_chip()
8823 spec->vnode_lswitch[i] = 0; in ca0132_init_chip()
8824 spec->vnode_rswitch[i] = 0; in ca0132_init_chip()
8833 spec->effects_switch[i] = on ? 1 : 0; in ca0132_init_chip()
8839 if (ca0132_use_alt_controls(spec)) { in ca0132_init_chip()
8841 spec->speaker_range_val[0] = 1; in ca0132_init_chip()
8842 spec->speaker_range_val[1] = 1; in ca0132_init_chip()
8844 spec->xbass_xover_freq = 8; in ca0132_init_chip()
8846 spec->fx_ctl_val[i] = effect_slider_defaults[i]; in ca0132_init_chip()
8848 spec->bass_redirect_xover_freq = 8; in ca0132_init_chip()
8851 spec->voicefx_val = 0; in ca0132_init_chip()
8852 spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID] = 1; in ca0132_init_chip()
8853 spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID] = 0; in ca0132_init_chip()
8860 if (ca0132_quirk(spec) == QUIRK_ZXR) in ca0132_init_chip()
8861 spec->in_enum_val = REAR_MIC; in ca0132_init_chip()
8882 struct ca0132_spec *spec = codec->spec; in sbz_region2_exit() local
8886 writeb(0x0, spec->mem_base + 0x100); in sbz_region2_exit()
8888 writeb(0xb3, spec->mem_base + 0x304); in sbz_region2_exit()
9088 struct ca0132_spec *spec = codec->spec; in sbz_dsp_startup_check() local
9095 if (spec->startup_check_entered) in sbz_dsp_startup_check()
9098 spec->startup_check_entered = true; in sbz_dsp_startup_check()
9120 spec->dsp_state = DSP_DOWNLOAD_INIT; in sbz_dsp_startup_check()
9168 struct ca0132_spec *spec = codec->spec; in sbz_pre_dsp_setup() local
9170 writel(0x00820680, spec->mem_base + 0x01C); in sbz_pre_dsp_setup()
9171 writel(0x00820680, spec->mem_base + 0x01C); in sbz_pre_dsp_setup()
9281 struct ca0132_spec *spec = codec->spec; in ca0132_mmio_init_sbz() local
9287 writel(0x00000000, spec->mem_base + addr[i]); in ca0132_mmio_init_sbz()
9290 switch (ca0132_quirk(spec)) { in ca0132_mmio_init_sbz()
9310 writel(tmp[i], spec->mem_base + addr[cur_addr + i]); in ca0132_mmio_init_sbz()
9314 switch (ca0132_quirk(spec)) { in ca0132_mmio_init_sbz()
9326 writel(data[i], spec->mem_base + addr[cur_addr + i]); in ca0132_mmio_init_sbz()
9331 struct ca0132_spec *spec = codec->spec; in ca0132_mmio_init_ae5() local
9339 if (ca0132_quirk(spec) == QUIRK_AE7) { in ca0132_mmio_init_ae5()
9340 writel(0x00000680, spec->mem_base + 0x1c); in ca0132_mmio_init_ae5()
9341 writel(0x00880680, spec->mem_base + 0x1c); in ca0132_mmio_init_ae5()
9349 if (i == 21 && ca0132_quirk(spec) == QUIRK_AE7) { in ca0132_mmio_init_ae5()
9350 writel(0x00800001, spec->mem_base + addr[i]); in ca0132_mmio_init_ae5()
9354 writel(data[i], spec->mem_base + addr[i]); in ca0132_mmio_init_ae5()
9357 if (ca0132_quirk(spec) == QUIRK_AE5) in ca0132_mmio_init_ae5()
9358 writel(0x00880680, spec->mem_base + 0x1c); in ca0132_mmio_init_ae5()
9363 struct ca0132_spec *spec = codec->spec; in ca0132_mmio_init() local
9365 switch (ca0132_quirk(spec)) { in ca0132_mmio_init()
9396 struct ca0132_spec *spec = codec->spec; in ae5_register_set() local
9403 if (ca0132_quirk(spec) == QUIRK_AE7) in ae5_register_set()
9409 if (ca0132_quirk(spec) == QUIRK_AE7) { in ae5_register_set()
9420 writeb(tmp[i], spec->mem_base + addr[cur_addr]); in ae5_register_set()
9427 writeb(data[i], spec->mem_base + addr[cur_addr]); in ae5_register_set()
9430 writel(data[i], spec->mem_base + addr[cur_addr]); in ae5_register_set()
9432 writel(0x00800001, spec->mem_base + 0x20c); in ae5_register_set()
9434 if (ca0132_quirk(spec) == QUIRK_AE7) { in ae5_register_set()
9444 if (ca0132_quirk(spec) == QUIRK_AE5) in ae5_register_set()
9455 struct ca0132_spec *spec = codec->spec; in ca0132_alt_init() local
9459 switch (ca0132_quirk(spec)) { in ca0132_alt_init()
9464 snd_hda_sequence_write(codec, spec->chip_init_verbs); in ca0132_alt_init()
9465 snd_hda_sequence_write(codec, spec->desktop_init_verbs); in ca0132_alt_init()
9473 snd_hda_sequence_write(codec, spec->chip_init_verbs); in ca0132_alt_init()
9478 snd_hda_sequence_write(codec, spec->chip_init_verbs); in ca0132_alt_init()
9479 snd_hda_sequence_write(codec, spec->desktop_init_verbs); in ca0132_alt_init()
9485 snd_hda_sequence_write(codec, spec->chip_init_verbs); in ca0132_alt_init()
9486 snd_hda_sequence_write(codec, spec->desktop_init_verbs); in ca0132_alt_init()
9492 snd_hda_sequence_write(codec, spec->chip_init_verbs); in ca0132_alt_init()
9493 snd_hda_sequence_write(codec, spec->desktop_init_verbs); in ca0132_alt_init()
9501 snd_hda_sequence_write(codec, spec->chip_init_verbs); in ca0132_alt_init()
9502 snd_hda_sequence_write(codec, spec->desktop_init_verbs); in ca0132_alt_init()
9512 struct ca0132_spec *spec = codec->spec; in ca0132_init() local
9513 struct auto_pin_cfg *cfg = &spec->autocfg; in ca0132_init()
9527 if (spec->dsp_state == DSP_DOWNLOADED) { in ca0132_init()
9530 spec->dsp_reload = true; in ca0132_init()
9531 spec->dsp_state = DSP_DOWNLOAD_INIT; in ca0132_init()
9533 if (ca0132_quirk(spec) == QUIRK_SBZ) in ca0132_init()
9539 if (spec->dsp_state != DSP_DOWNLOAD_FAILED) in ca0132_init()
9540 spec->dsp_state = DSP_DOWNLOAD_INIT; in ca0132_init()
9541 spec->curr_chip_addx = INVALID_CHIP_ADDRESS; in ca0132_init()
9543 if (ca0132_use_pci_mmio(spec)) in ca0132_init()
9548 if (ca0132_quirk(spec) == QUIRK_AE5 || ca0132_quirk(spec) == QUIRK_AE7) in ca0132_init()
9554 snd_hda_sequence_write(codec, spec->base_init_verbs); in ca0132_init()
9556 if (ca0132_use_alt_functions(spec)) in ca0132_init()
9563 switch (ca0132_quirk(spec)) { in ca0132_init()
9585 for (i = 0; i < spec->num_outputs; i++) in ca0132_init()
9586 init_output(codec, spec->out_pins[i], spec->dacs[0]); in ca0132_init()
9588 init_output(codec, cfg->dig_out_pins[0], spec->dig_out); in ca0132_init()
9590 for (i = 0; i < spec->num_inputs; i++) in ca0132_init()
9591 init_input(codec, spec->input_pins[i], spec->adcs[i]); in ca0132_init()
9593 init_input(codec, cfg->dig_in_pin, spec->dig_in); in ca0132_init()
9595 if (!ca0132_use_alt_functions(spec)) { in ca0132_init()
9596 snd_hda_sequence_write(codec, spec->chip_init_verbs); in ca0132_init()
9603 if (ca0132_quirk(spec) == QUIRK_SBZ) in ca0132_init()
9606 snd_hda_sequence_write(codec, spec->spec_init_verbs); in ca0132_init()
9607 if (ca0132_use_alt_functions(spec)) { in ca0132_init()
9621 if (spec->dsp_reload) { in ca0132_init()
9622 spec->dsp_reload = false; in ca0132_init()
9633 struct ca0132_spec *spec = codec->spec; in dbpro_init() local
9634 struct auto_pin_cfg *cfg = &spec->autocfg; in dbpro_init()
9637 init_output(codec, cfg->dig_out_pins[0], spec->dig_out); in dbpro_init()
9638 init_input(codec, cfg->dig_in_pin, spec->dig_in); in dbpro_init()
9640 for (i = 0; i < spec->num_inputs; i++) in dbpro_init()
9641 init_input(codec, spec->input_pins[i], spec->adcs[i]); in dbpro_init()
9648 struct ca0132_spec *spec = codec->spec; in ca0132_free() local
9650 cancel_delayed_work_sync(&spec->unsol_hp_work); in ca0132_free()
9652 switch (ca0132_quirk(spec)) { in ca0132_free()
9675 snd_hda_sequence_write(codec, spec->base_exit_verbs); in ca0132_free()
9680 if (spec->mem_base) in ca0132_free()
9681 pci_iounmap(codec->bus->pci, spec->mem_base); in ca0132_free()
9683 kfree(spec->spec_init_verbs); in ca0132_free()
9684 kfree(codec->spec); in ca0132_free()
9689 struct ca0132_spec *spec = codec->spec; in dbpro_free() local
9693 kfree(spec->spec_init_verbs); in dbpro_free()
9694 kfree(codec->spec); in dbpro_free()
9699 struct ca0132_spec *spec = codec->spec; in ca0132_suspend() local
9701 cancel_delayed_work_sync(&spec->unsol_hp_work); in ca0132_suspend()
9723 struct ca0132_spec *spec = codec->spec; in ca0132_config() local
9725 spec->dacs[0] = 0x2; in ca0132_config()
9726 spec->dacs[1] = 0x3; in ca0132_config()
9727 spec->dacs[2] = 0x4; in ca0132_config()
9729 spec->multiout.dac_nids = spec->dacs; in ca0132_config()
9730 spec->multiout.num_dacs = 3; in ca0132_config()
9732 if (!ca0132_use_alt_functions(spec)) in ca0132_config()
9733 spec->multiout.max_channels = 2; in ca0132_config()
9735 spec->multiout.max_channels = 6; in ca0132_config()
9737 switch (ca0132_quirk(spec)) { in ca0132_config()
9770 switch (ca0132_quirk(spec)) { in ca0132_config()
9772 spec->num_outputs = 2; in ca0132_config()
9773 spec->out_pins[0] = 0x0b; /* speaker out */ in ca0132_config()
9774 spec->out_pins[1] = 0x0f; in ca0132_config()
9775 spec->shared_out_nid = 0x2; in ca0132_config()
9776 spec->unsol_tag_hp = 0x0f; in ca0132_config()
9778 spec->adcs[0] = 0x7; /* digital mic / analog mic1 */ in ca0132_config()
9779 spec->adcs[1] = 0x8; /* analog mic2 */ in ca0132_config()
9780 spec->adcs[2] = 0xa; /* what u hear */ in ca0132_config()
9782 spec->num_inputs = 3; in ca0132_config()
9783 spec->input_pins[0] = 0x12; in ca0132_config()
9784 spec->input_pins[1] = 0x11; in ca0132_config()
9785 spec->input_pins[2] = 0x13; in ca0132_config()
9786 spec->shared_mic_nid = 0x7; in ca0132_config()
9787 spec->unsol_tag_amic1 = 0x11; in ca0132_config()
9791 spec->num_outputs = 2; in ca0132_config()
9792 spec->out_pins[0] = 0x0B; /* Line out */ in ca0132_config()
9793 spec->out_pins[1] = 0x0F; /* Rear headphone out */ in ca0132_config()
9794 spec->out_pins[2] = 0x10; /* Front Headphone / Center/LFE*/ in ca0132_config()
9795 spec->out_pins[3] = 0x11; /* Rear surround */ in ca0132_config()
9796 spec->shared_out_nid = 0x2; in ca0132_config()
9797 spec->unsol_tag_hp = spec->out_pins[1]; in ca0132_config()
9798 spec->unsol_tag_front_hp = spec->out_pins[2]; in ca0132_config()
9800 spec->adcs[0] = 0x7; /* Rear Mic / Line-in */ in ca0132_config()
9801 spec->adcs[1] = 0x8; /* Front Mic, but only if no DSP */ in ca0132_config()
9802 spec->adcs[2] = 0xa; /* what u hear */ in ca0132_config()
9804 spec->num_inputs = 2; in ca0132_config()
9805 spec->input_pins[0] = 0x12; /* Rear Mic / Line-in */ in ca0132_config()
9806 spec->input_pins[1] = 0x13; /* What U Hear */ in ca0132_config()
9807 spec->shared_mic_nid = 0x7; in ca0132_config()
9808 spec->unsol_tag_amic1 = spec->input_pins[0]; in ca0132_config()
9811 spec->dig_out = 0x05; in ca0132_config()
9812 spec->multiout.dig_out_nid = spec->dig_out; in ca0132_config()
9813 spec->dig_in = 0x09; in ca0132_config()
9816 spec->num_outputs = 2; in ca0132_config()
9817 spec->out_pins[0] = 0x0B; /* Line out */ in ca0132_config()
9818 spec->out_pins[1] = 0x0F; /* Rear headphone out */ in ca0132_config()
9819 spec->out_pins[2] = 0x10; /* Center/LFE */ in ca0132_config()
9820 spec->out_pins[3] = 0x11; /* Rear surround */ in ca0132_config()
9821 spec->shared_out_nid = 0x2; in ca0132_config()
9822 spec->unsol_tag_hp = spec->out_pins[1]; in ca0132_config()
9823 spec->unsol_tag_front_hp = spec->out_pins[2]; in ca0132_config()
9825 spec->adcs[0] = 0x7; /* Rear Mic / Line-in */ in ca0132_config()
9826 spec->adcs[1] = 0x8; /* Not connected, no front mic */ in ca0132_config()
9827 spec->adcs[2] = 0xa; /* what u hear */ in ca0132_config()
9829 spec->num_inputs = 2; in ca0132_config()
9830 spec->input_pins[0] = 0x12; /* Rear Mic / Line-in */ in ca0132_config()
9831 spec->input_pins[1] = 0x13; /* What U Hear */ in ca0132_config()
9832 spec->shared_mic_nid = 0x7; in ca0132_config()
9833 spec->unsol_tag_amic1 = spec->input_pins[0]; in ca0132_config()
9836 spec->adcs[0] = 0x8; /* ZxR DBPro Aux In */ in ca0132_config()
9838 spec->num_inputs = 1; in ca0132_config()
9839 spec->input_pins[0] = 0x11; /* RCA Line-in */ in ca0132_config()
9841 spec->dig_out = 0x05; in ca0132_config()
9842 spec->multiout.dig_out_nid = spec->dig_out; in ca0132_config()
9844 spec->dig_in = 0x09; in ca0132_config()
9848 spec->num_outputs = 2; in ca0132_config()
9849 spec->out_pins[0] = 0x0B; /* Line out */ in ca0132_config()
9850 spec->out_pins[1] = 0x11; /* Rear headphone out */ in ca0132_config()
9851 spec->out_pins[2] = 0x10; /* Front Headphone / Center/LFE*/ in ca0132_config()
9852 spec->out_pins[3] = 0x0F; /* Rear surround */ in ca0132_config()
9853 spec->shared_out_nid = 0x2; in ca0132_config()
9854 spec->unsol_tag_hp = spec->out_pins[1]; in ca0132_config()
9855 spec->unsol_tag_front_hp = spec->out_pins[2]; in ca0132_config()
9857 spec->adcs[0] = 0x7; /* Rear Mic / Line-in */ in ca0132_config()
9858 spec->adcs[1] = 0x8; /* Front Mic, but only if no DSP */ in ca0132_config()
9859 spec->adcs[2] = 0xa; /* what u hear */ in ca0132_config()
9861 spec->num_inputs = 2; in ca0132_config()
9862 spec->input_pins[0] = 0x12; /* Rear Mic / Line-in */ in ca0132_config()
9863 spec->input_pins[1] = 0x13; /* What U Hear */ in ca0132_config()
9864 spec->shared_mic_nid = 0x7; in ca0132_config()
9865 spec->unsol_tag_amic1 = spec->input_pins[0]; in ca0132_config()
9868 spec->dig_out = 0x05; in ca0132_config()
9869 spec->multiout.dig_out_nid = spec->dig_out; in ca0132_config()
9872 spec->num_outputs = 2; in ca0132_config()
9873 spec->out_pins[0] = 0x0B; /* Line out */ in ca0132_config()
9874 spec->out_pins[1] = 0x0F; /* Rear headphone out */ in ca0132_config()
9875 spec->out_pins[2] = 0x10; /* Front Headphone / Center/LFE*/ in ca0132_config()
9876 spec->out_pins[3] = 0x11; /* Rear surround */ in ca0132_config()
9877 spec->shared_out_nid = 0x2; in ca0132_config()
9878 spec->unsol_tag_hp = spec->out_pins[1]; in ca0132_config()
9879 spec->unsol_tag_front_hp = spec->out_pins[2]; in ca0132_config()
9881 spec->adcs[0] = 0x07; /* Rear Mic / Line-in */ in ca0132_config()
9882 spec->adcs[1] = 0x08; /* Front Mic, but only if no DSP */ in ca0132_config()
9883 spec->adcs[2] = 0x0a; /* what u hear */ in ca0132_config()
9885 spec->num_inputs = 2; in ca0132_config()
9886 spec->input_pins[0] = 0x12; /* Rear Mic / Line-in */ in ca0132_config()
9887 spec->input_pins[1] = 0x13; /* What U Hear */ in ca0132_config()
9888 spec->shared_mic_nid = 0x7; in ca0132_config()
9889 spec->unsol_tag_amic1 = spec->input_pins[0]; in ca0132_config()
9892 spec->dig_out = 0x05; in ca0132_config()
9893 spec->multiout.dig_out_nid = spec->dig_out; in ca0132_config()
9896 spec->num_outputs = 2; in ca0132_config()
9897 spec->out_pins[0] = 0x0b; /* speaker out */ in ca0132_config()
9898 spec->out_pins[1] = 0x10; /* headphone out */ in ca0132_config()
9899 spec->shared_out_nid = 0x2; in ca0132_config()
9900 spec->unsol_tag_hp = spec->out_pins[1]; in ca0132_config()
9902 spec->adcs[0] = 0x7; /* digital mic / analog mic1 */ in ca0132_config()
9903 spec->adcs[1] = 0x8; /* analog mic2 */ in ca0132_config()
9904 spec->adcs[2] = 0xa; /* what u hear */ in ca0132_config()
9906 spec->num_inputs = 3; in ca0132_config()
9907 spec->input_pins[0] = 0x12; in ca0132_config()
9908 spec->input_pins[1] = 0x11; in ca0132_config()
9909 spec->input_pins[2] = 0x13; in ca0132_config()
9910 spec->shared_mic_nid = 0x7; in ca0132_config()
9911 spec->unsol_tag_amic1 = spec->input_pins[0]; in ca0132_config()
9914 spec->dig_out = 0x05; in ca0132_config()
9915 spec->multiout.dig_out_nid = spec->dig_out; in ca0132_config()
9916 spec->dig_in = 0x09; in ca0132_config()
9925 struct ca0132_spec *spec = codec->spec; in ca0132_prepare_verbs() local
9927 spec->chip_init_verbs = ca0132_init_verbs0; in ca0132_prepare_verbs()
9932 if (ca0132_use_pci_mmio(spec)) in ca0132_prepare_verbs()
9933 spec->desktop_init_verbs = ca0132_init_verbs1; in ca0132_prepare_verbs()
9934 spec->spec_init_verbs = kcalloc(NUM_SPEC_VERBS, in ca0132_prepare_verbs()
9937 if (!spec->spec_init_verbs) in ca0132_prepare_verbs()
9941 spec->spec_init_verbs[0].nid = 0x0b; in ca0132_prepare_verbs()
9942 spec->spec_init_verbs[0].param = 0x78D; in ca0132_prepare_verbs()
9943 spec->spec_init_verbs[0].verb = 0x00; in ca0132_prepare_verbs()
9987 struct ca0132_spec *spec; in patch_ca0132() local
9992 spec = kzalloc(sizeof(*spec), GFP_KERNEL); in patch_ca0132()
9993 if (!spec) in patch_ca0132()
9995 codec->spec = spec; in patch_ca0132()
9996 spec->codec = codec; in patch_ca0132()
10000 if (ca0132_quirk(spec) == QUIRK_SBZ) in patch_ca0132()
10003 if (ca0132_quirk(spec) == QUIRK_ZXR_DBPRO) in patch_ca0132()
10012 spec->dsp_state = DSP_DOWNLOAD_INIT; in patch_ca0132()
10013 spec->num_mixers = 1; in patch_ca0132()
10016 switch (ca0132_quirk(spec)) { in patch_ca0132()
10018 spec->mixers[0] = desktop_mixer; in patch_ca0132()
10022 spec->mixers[0] = desktop_mixer; in patch_ca0132()
10028 spec->mixers[0] = desktop_mixer; in patch_ca0132()
10032 spec->mixers[0] = r3di_mixer; in patch_ca0132()
10036 spec->mixers[0] = desktop_mixer; in patch_ca0132()
10040 spec->mixers[0] = desktop_mixer; in patch_ca0132()
10044 spec->mixers[0] = ca0132_mixer; in patch_ca0132()
10049 switch (ca0132_quirk(spec)) { in patch_ca0132()
10055 spec->use_alt_controls = true; in patch_ca0132()
10056 spec->use_alt_functions = true; in patch_ca0132()
10057 spec->use_pci_mmio = true; in patch_ca0132()
10060 spec->use_alt_controls = true; in patch_ca0132()
10061 spec->use_alt_functions = true; in patch_ca0132()
10062 spec->use_pci_mmio = false; in patch_ca0132()
10065 spec->use_alt_controls = false; in patch_ca0132()
10066 spec->use_alt_functions = false; in patch_ca0132()
10067 spec->use_pci_mmio = false; in patch_ca0132()
10072 if (spec->use_pci_mmio) { in patch_ca0132()
10073 spec->mem_base = pci_iomap(codec->bus->pci, 2, 0xC20); in patch_ca0132()
10074 if (spec->mem_base == NULL) { in patch_ca0132()
10081 spec->base_init_verbs = ca0132_base_init_verbs; in patch_ca0132()
10082 spec->base_exit_verbs = ca0132_base_exit_verbs; in patch_ca0132()
10084 INIT_DELAYED_WORK(&spec->unsol_hp_work, ca0132_unsol_hp_delayed); in patch_ca0132()
10094 err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, NULL); in patch_ca0132()