Skip to content

Commit bde7bc6

Browse files
Chih-Chung Changtiwai
authored andcommitted
ALSA: hda - Fix jack gating when auto_{mute,mic} is suppressed.
The snd_hda_jack_set_gating_jack() call didn't work when auto_{mute,mic} is suppressed because (1) am_entry is not filled with nid of the mic pin. (2) The jacks are not created (by snd_hda_jack_detect_enable_callback) before the snd_hda_jack_set_gating_jack call. Now we use the first input pin nid directly, and create the jack if it doesn't exist yet. Signed-off-by: Chih-Chung Chang <chihchung@chromium.org> Signed-off-by: Takashi Iwai <tiwai@suse.de>
1 parent da96fb5 commit bde7bc6

File tree

2 files changed

+29
-6
lines changed

2 files changed

+29
-6
lines changed

sound/pci/hda/hda_jack.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -253,8 +253,8 @@ EXPORT_SYMBOL_HDA(snd_hda_jack_detect_enable);
253253
int snd_hda_jack_set_gating_jack(struct hda_codec *codec, hda_nid_t gated_nid,
254254
hda_nid_t gating_nid)
255255
{
256-
struct hda_jack_tbl *gated = snd_hda_jack_tbl_get(codec, gated_nid);
257-
struct hda_jack_tbl *gating = snd_hda_jack_tbl_get(codec, gating_nid);
256+
struct hda_jack_tbl *gated = snd_hda_jack_tbl_new(codec, gated_nid);
257+
struct hda_jack_tbl *gating = snd_hda_jack_tbl_new(codec, gating_nid);
258258

259259
if (!gated || !gating)
260260
return -EINVAL;

sound/pci/hda/patch_realtek.c

Lines changed: 27 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -3260,18 +3260,41 @@ static void alc_fixup_headset_mode_alc668(struct hda_codec *codec,
32603260
alc_fixup_headset_mode(codec, fix, action);
32613261
}
32623262

3263+
/* Returns the nid of the external mic input pin, or 0 if it cannot be found. */
3264+
static int find_ext_mic_pin(struct hda_codec *codec)
3265+
{
3266+
struct alc_spec *spec = codec->spec;
3267+
struct auto_pin_cfg *cfg = &spec->gen.autocfg;
3268+
hda_nid_t nid;
3269+
unsigned int defcfg;
3270+
int i;
3271+
3272+
for (i = 0; i < cfg->num_inputs; i++) {
3273+
if (cfg->inputs[i].type != AUTO_PIN_MIC)
3274+
continue;
3275+
nid = cfg->inputs[i].pin;
3276+
defcfg = snd_hda_codec_get_pincfg(codec, nid);
3277+
if (snd_hda_get_input_pin_attr(defcfg) == INPUT_PIN_ATTR_INT)
3278+
continue;
3279+
return nid;
3280+
}
3281+
3282+
return 0;
3283+
}
3284+
32633285
static void alc271_hp_gate_mic_jack(struct hda_codec *codec,
32643286
const struct hda_fixup *fix,
32653287
int action)
32663288
{
32673289
struct alc_spec *spec = codec->spec;
32683290

32693291
if (action == HDA_FIXUP_ACT_PROBE) {
3270-
if (snd_BUG_ON(!spec->gen.am_entry[1].pin ||
3271-
!spec->gen.autocfg.hp_pins[0]))
3292+
int mic_pin = find_ext_mic_pin(codec);
3293+
int hp_pin = spec->gen.autocfg.hp_pins[0];
3294+
3295+
if (snd_BUG_ON(!mic_pin || !hp_pin))
32723296
return;
3273-
snd_hda_jack_set_gating_jack(codec, spec->gen.am_entry[1].pin,
3274-
spec->gen.autocfg.hp_pins[0]);
3297+
snd_hda_jack_set_gating_jack(codec, mic_pin, hp_pin);
32753298
}
32763299
}
32773300

0 commit comments

Comments
 (0)