提交 584c0c4c 编写于 作者: T Takashi Iwai

ALSA: hda - Initialize special cases for input src in init phase

Currently some special handling for the unusual case like dual-ADCs
or a single-input-src is done in the tree-parse time in
set_capture_mixer().  But this setup could be overwritten by static
init verbs.

This patch moves the initialization into the init phase so that
such input-src setup won't be lost.

Cc: <stable@kernel.org>
Signed-off-by: NTakashi Iwai <tiwai@suse.de>
上级 a09e89f6
...@@ -385,6 +385,7 @@ struct alc_spec { ...@@ -385,6 +385,7 @@ struct alc_spec {
/* other flags */ /* other flags */
unsigned int no_analog :1; /* digital I/O only */ unsigned int no_analog :1; /* digital I/O only */
unsigned int dual_adc_switch:1; /* switch ADCs (for ALC275) */ unsigned int dual_adc_switch:1; /* switch ADCs (for ALC275) */
unsigned int single_input_src:1;
int init_amp; int init_amp;
int codec_variant; /* flag for other variants */ int codec_variant; /* flag for other variants */
...@@ -3847,6 +3848,8 @@ static struct hda_amp_list alc880_lg_loopbacks[] = { ...@@ -3847,6 +3848,8 @@ static struct hda_amp_list alc880_lg_loopbacks[] = {
* Common callbacks * Common callbacks
*/ */
static void alc_init_special_input_src(struct hda_codec *codec);
static int alc_init(struct hda_codec *codec) static int alc_init(struct hda_codec *codec)
{ {
struct alc_spec *spec = codec->spec; struct alc_spec *spec = codec->spec;
...@@ -3857,6 +3860,7 @@ static int alc_init(struct hda_codec *codec) ...@@ -3857,6 +3860,7 @@ static int alc_init(struct hda_codec *codec)
for (i = 0; i < spec->num_init_verbs; i++) for (i = 0; i < spec->num_init_verbs; i++)
snd_hda_sequence_write(codec, spec->init_verbs[i]); snd_hda_sequence_write(codec, spec->init_verbs[i]);
alc_init_special_input_src(codec);
if (spec->init_hook) if (spec->init_hook)
spec->init_hook(codec); spec->init_hook(codec);
...@@ -5519,6 +5523,7 @@ static void fixup_single_adc(struct hda_codec *codec) ...@@ -5519,6 +5523,7 @@ static void fixup_single_adc(struct hda_codec *codec)
spec->capsrc_nids += i; spec->capsrc_nids += i;
spec->adc_nids += i; spec->adc_nids += i;
spec->num_adc_nids = 1; spec->num_adc_nids = 1;
spec->single_input_src = 1;
} }
} }
...@@ -5530,6 +5535,16 @@ static void fixup_dual_adc_switch(struct hda_codec *codec) ...@@ -5530,6 +5535,16 @@ static void fixup_dual_adc_switch(struct hda_codec *codec)
init_capsrc_for_pin(codec, spec->int_mic.pin); init_capsrc_for_pin(codec, spec->int_mic.pin);
} }
/* initialize some special cases for input sources */
static void alc_init_special_input_src(struct hda_codec *codec)
{
struct alc_spec *spec = codec->spec;
if (spec->dual_adc_switch)
fixup_dual_adc_switch(codec);
else if (spec->single_input_src)
init_capsrc_for_pin(codec, spec->autocfg.inputs[0].pin);
}
static void set_capture_mixer(struct hda_codec *codec) static void set_capture_mixer(struct hda_codec *codec)
{ {
struct alc_spec *spec = codec->spec; struct alc_spec *spec = codec->spec;
...@@ -5545,7 +5560,7 @@ static void set_capture_mixer(struct hda_codec *codec) ...@@ -5545,7 +5560,7 @@ static void set_capture_mixer(struct hda_codec *codec)
int mux = 0; int mux = 0;
int num_adcs = spec->num_adc_nids; int num_adcs = spec->num_adc_nids;
if (spec->dual_adc_switch) if (spec->dual_adc_switch)
fixup_dual_adc_switch(codec); num_adcs = 1;
else if (spec->auto_mic) else if (spec->auto_mic)
fixup_automic_adc(codec); fixup_automic_adc(codec);
else if (spec->input_mux) { else if (spec->input_mux) {
...@@ -5554,8 +5569,6 @@ static void set_capture_mixer(struct hda_codec *codec) ...@@ -5554,8 +5569,6 @@ static void set_capture_mixer(struct hda_codec *codec)
else if (spec->input_mux->num_items == 1) else if (spec->input_mux->num_items == 1)
fixup_single_adc(codec); fixup_single_adc(codec);
} }
if (spec->dual_adc_switch)
num_adcs = 1;
spec->cap_mixer = caps[mux][num_adcs - 1]; spec->cap_mixer = caps[mux][num_adcs - 1];
} }
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册