ALSA: hda - Add prefer_hp_amp flag to hda_gen_spec
authorTakashi Iwai <tiwai@suse.de>
Tue, 15 Jan 2013 17:45:53 +0000 (18:45 +0100)
committerTakashi Iwai <tiwai@suse.de>
Tue, 15 Jan 2013 17:45:53 +0000 (18:45 +0100)
Add a new flag to indicate whether HP amp is turned on as default for
speaker or line-outs, and enable this for ALC260 codec, as many
machines with this codec require the HP amp even for speakers.

Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/pci/hda/hda_generic.c
sound/pci/hda/hda_generic.h
sound/pci/hda/patch_realtek.c

index 932e6a133f3d5e0947c9efda457eb2a04fb06c0c..e878a9effc962b3dfd4a9355baf4aa6c1c01cc23 100644 (file)
@@ -1284,6 +1284,7 @@ static int fill_and_eval_dacs(struct hda_codec *codec,
        struct hda_gen_spec *spec = codec->spec;
        struct auto_pin_cfg *cfg = &spec->autocfg;
        int i, err, badness;
+       unsigned int val;
 
        /* set num_dacs once to full for look_for_dac() */
        spec->multiout.num_dacs = cfg->line_outs;
@@ -1421,13 +1422,18 @@ static int fill_and_eval_dacs(struct hda_codec *codec,
                                   spec->speaker_paths);
 
        /* set initial pinctl targets */
-       set_pin_targets(codec, cfg->line_outs, cfg->line_out_pins,
-                       cfg->line_out_type == AUTO_PIN_HP_OUT ? PIN_HP : PIN_OUT);
+       if (spec->prefer_hp_amp || cfg->line_out_type == AUTO_PIN_HP_OUT)
+               val = PIN_HP;
+       else
+               val = PIN_OUT;
+       set_pin_targets(codec, cfg->line_outs, cfg->line_out_pins, val);
        if (cfg->line_out_type != AUTO_PIN_HP_OUT)
                set_pin_targets(codec, cfg->hp_outs, cfg->hp_pins, PIN_HP);
-       if (cfg->line_out_type != AUTO_PIN_SPEAKER_OUT)
+       if (cfg->line_out_type != AUTO_PIN_SPEAKER_OUT) {
+               val = spec->prefer_hp_amp ? PIN_HP : PIN_OUT;
                set_pin_targets(codec, cfg->speaker_outs,
-                               cfg->speaker_pins, PIN_OUT);
+                               cfg->speaker_pins, val);
+       }
 
        return badness;
 }
index 1ceaacd1b7752113d3ef266848f35e8e779c25cb..6ba580540081dd41b8a3f3e9b74cb477839c3479 100644 (file)
@@ -190,6 +190,7 @@ struct hda_gen_spec {
        unsigned int vmaster_mute_enum:1; /* add vmaster mute mode enum */
        unsigned int indep_hp:1; /* independent HP supported */
        unsigned int indep_hp_enabled:1; /* independent HP enabled */
+       unsigned int prefer_hp_amp:1; /* enable HP amp for speaker if any */
        unsigned int add_stereo_mix_input:1; /* add aamix as a capture src */
        unsigned int add_out_jack_modes:1; /* add output jack mode enum ctls */
 
index fab31d29fa23b62a5e19d92acc42bbaa907b6ff5..71a8894438abc7254065c2896f772e0ead88f27c 100644 (file)
@@ -1506,8 +1506,6 @@ static void alc260_fixup_fsc_s7020(struct hda_codec *codec,
 
        if (action == HDA_FIXUP_ACT_PRE_PROBE)
                spec->gen.add_out_jack_modes = 1;
-       else if (action == HDA_FIXUP_ACT_PROBE)
-               snd_hda_set_pin_ctl_cache(codec, 0x10, PIN_HP);
 }
 
 static const struct hda_fixup alc260_fixups[] = {
@@ -1597,6 +1595,11 @@ static int patch_alc260(struct hda_codec *codec)
                return err;
 
        spec = codec->spec;
+       /* as quite a few machines require HP amp for speaker outputs,
+        * it's easier to enable it unconditionally; even if it's unneeded,
+        * it's almost harmless.
+        */
+       spec->gen.prefer_hp_amp = 1;
 
        snd_hda_pick_fixup(codec, NULL, alc260_fixup_tbl, alc260_fixups);
        snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE);