Commit a3de8ab8 authored by Takashi Iwai's avatar Takashi Iwai

ALSA: hda - Clean up cxt5066 port-D handling & co

Instead of hard-coded magic numbers, properly define and use macros
for improve the readability.  Also, dell_automute is handled samely
as thinkpad, since it also sets port_d_mode, too.
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent 4c98ec11
...@@ -2111,6 +2111,11 @@ static struct hda_channel_mode cxt5066_modes[1] = { ...@@ -2111,6 +2111,11 @@ static struct hda_channel_mode cxt5066_modes[1] = {
{ 2, NULL }, { 2, NULL },
}; };
#define HP_PRESENT_PORT_A (1 << 0)
#define HP_PRESENT_PORT_D (1 << 1)
#define hp_port_a_present(spec) ((spec)->hp_present & HP_PRESENT_PORT_A)
#define hp_port_d_present(spec) ((spec)->hp_present & HP_PRESENT_PORT_D)
static void cxt5066_update_speaker(struct hda_codec *codec) static void cxt5066_update_speaker(struct hda_codec *codec)
{ {
struct conexant_spec *spec = codec->spec; struct conexant_spec *spec = codec->spec;
...@@ -2120,24 +2125,20 @@ static void cxt5066_update_speaker(struct hda_codec *codec) ...@@ -2120,24 +2125,20 @@ static void cxt5066_update_speaker(struct hda_codec *codec)
spec->hp_present, spec->cur_eapd); spec->hp_present, spec->cur_eapd);
/* Port A (HP) */ /* Port A (HP) */
pinctl = ((spec->hp_present & 1) && spec->cur_eapd) ? PIN_HP : 0; pinctl = (hp_port_a_present(spec) && spec->cur_eapd) ? PIN_HP : 0;
snd_hda_codec_write(codec, 0x19, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, snd_hda_codec_write(codec, 0x19, 0, AC_VERB_SET_PIN_WIDGET_CONTROL,
pinctl); pinctl);
/* Port D (HP/LO) */ /* Port D (HP/LO) */
if (spec->dell_automute) { pinctl = spec->cur_eapd ? spec->port_d_mode : 0;
/* DELL AIO Port Rule: PortA> PortD> IntSpk */ if (spec->dell_automute || spec->thinkpad) {
pinctl = (!(spec->hp_present & 1) && spec->cur_eapd) /* Mute if Port A is connected */
? PIN_OUT : 0; if (hp_port_a_present(spec))
} else if (spec->thinkpad) {
if (spec->cur_eapd)
pinctl = spec->port_d_mode;
/* Mute dock line-out if Port A (laptop HP) is present */
if (spec->hp_present& 1)
pinctl = 0; pinctl = 0;
} else { } else {
pinctl = ((spec->hp_present & 2) && spec->cur_eapd) /* Thinkpad/Dell doesn't give pin-D status */
? spec->port_d_mode : 0; if (!hp_port_d_present(spec))
pinctl = 0;
} }
snd_hda_codec_write(codec, 0x1c, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, snd_hda_codec_write(codec, 0x1c, 0, AC_VERB_SET_PIN_WIDGET_CONTROL,
pinctl); pinctl);
...@@ -2379,8 +2380,8 @@ static void cxt5066_hp_automute(struct hda_codec *codec) ...@@ -2379,8 +2380,8 @@ static void cxt5066_hp_automute(struct hda_codec *codec)
/* Port D */ /* Port D */
portD = snd_hda_jack_detect(codec, 0x1c); portD = snd_hda_jack_detect(codec, 0x1c);
spec->hp_present = !!(portA); spec->hp_present = portA ? HP_PRESENT_PORT_A : 0;
spec->hp_present |= portD ? 2 : 0; spec->hp_present |= portD ? HP_PRESENT_PORT_D : 0;
snd_printdd("CXT5066: hp automute portA=%x portD=%x present=%d\n", snd_printdd("CXT5066: hp automute portA=%x portD=%x present=%d\n",
portA, portD, spec->hp_present); portA, portD, spec->hp_present);
cxt5066_update_speaker(codec); cxt5066_update_speaker(codec);
......
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