Commit af6ee302 authored by Takashi Iwai's avatar Takashi Iwai

ALSA: hda - Set default GPIO for STAC/IDT codecs

IDT92HD73xx and STAC927x codecs use GPIO0 bit as EAPD on many machines.
However, currently we don't set it unless the model is specified just
for safety reason.  But, most machines do need this bit, so this safety
handling is rather annoying.

This patch enables GPIO0 setup as default for them.  Many HP / Dell
laptops should work even without model override with this change.
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent 3d3792cb
...@@ -5016,7 +5016,7 @@ static int patch_stac92hd73xx(struct hda_codec *codec) ...@@ -5016,7 +5016,7 @@ static int patch_stac92hd73xx(struct hda_codec *codec)
spec->eapd_switch = 1; spec->eapd_switch = 1;
break; break;
} }
if (spec->board_config > STAC_92HD73XX_REF) { if (spec->board_config != STAC_92HD73XX_REF) {
/* GPIO0 High = Enable EAPD */ /* GPIO0 High = Enable EAPD */
spec->eapd_mask = spec->gpio_mask = spec->gpio_dir = 0x1; spec->eapd_mask = spec->gpio_mask = spec->gpio_dir = 0x1;
spec->gpio_data = 0x01; spec->gpio_data = 0x01;
...@@ -5557,14 +5557,17 @@ static int patch_stac927x(struct hda_codec *codec) ...@@ -5557,14 +5557,17 @@ static int patch_stac927x(struct hda_codec *codec)
spec->dac_list = stac927x_dac_nids; spec->dac_list = stac927x_dac_nids;
spec->multiout.dac_nids = spec->dac_nids; spec->multiout.dac_nids = spec->dac_nids;
if (spec->board_config != STAC_D965_REF) {
/* GPIO0 High = Enable EAPD */
spec->eapd_mask = spec->gpio_mask = 0x01;
spec->gpio_dir = spec->gpio_data = 0x01;
}
switch (spec->board_config) { switch (spec->board_config) {
case STAC_D965_3ST: case STAC_D965_3ST:
case STAC_D965_5ST: case STAC_D965_5ST:
/* GPIO0 High = Enable EAPD */ /* GPIO0 High = Enable EAPD */
spec->eapd_mask = spec->gpio_mask = spec->gpio_dir = 0x01;
spec->gpio_data = 0x01;
spec->num_dmics = 0; spec->num_dmics = 0;
spec->init = d965_core_init; spec->init = d965_core_init;
break; break;
case STAC_DELL_BIOS: case STAC_DELL_BIOS:
...@@ -5583,16 +5586,11 @@ static int patch_stac927x(struct hda_codec *codec) ...@@ -5583,16 +5586,11 @@ static int patch_stac927x(struct hda_codec *codec)
snd_hda_codec_set_pincfg(codec, 0x0e, 0x02a79130); snd_hda_codec_set_pincfg(codec, 0x0e, 0x02a79130);
/* fallthru */ /* fallthru */
case STAC_DELL_3ST: case STAC_DELL_3ST:
/* GPIO2 High = Enable EAPD */ if (codec->subsystem_id != 0x1028022f) {
spec->eapd_mask = spec->gpio_mask = spec->gpio_dir = 0x04; /* GPIO2 High = Enable EAPD */
spec->gpio_data = 0x04; spec->eapd_mask = spec->gpio_mask = 0x04;
switch (codec->subsystem_id) { spec->gpio_dir = spec->gpio_data = 0x04;
case 0x1028022f: }
/* correct EAPD to be GPIO0 */
spec->eapd_mask = spec->gpio_mask = 0x01;
spec->gpio_dir = spec->gpio_data = 0x01;
break;
};
spec->dmic_nids = stac927x_dmic_nids; spec->dmic_nids = stac927x_dmic_nids;
spec->num_dmics = STAC927X_NUM_DMICS; spec->num_dmics = STAC927X_NUM_DMICS;
...@@ -5601,14 +5599,9 @@ static int patch_stac927x(struct hda_codec *codec) ...@@ -5601,14 +5599,9 @@ static int patch_stac927x(struct hda_codec *codec)
spec->num_dmuxes = ARRAY_SIZE(stac927x_dmux_nids); spec->num_dmuxes = ARRAY_SIZE(stac927x_dmux_nids);
break; break;
default: default:
if (spec->board_config > STAC_D965_REF) {
/* GPIO0 High = Enable EAPD */
spec->eapd_mask = spec->gpio_mask = 0x01;
spec->gpio_dir = spec->gpio_data = 0x01;
}
spec->num_dmics = 0; spec->num_dmics = 0;
spec->init = stac927x_core_init; spec->init = stac927x_core_init;
break;
} }
spec->num_caps = STAC927X_NUM_CAPS; spec->num_caps = STAC927X_NUM_CAPS;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment