}
EXPORT_SYMBOL_HDA(snd_hda_activate_path);
+/* turn on/off EAPD on the given pin */
+static void set_pin_eapd(struct hda_codec *codec, hda_nid_t pin, bool enable)
+{
+ struct hda_gen_spec *spec = codec->spec;
+ if (spec->own_eapd_ctl ||
+ !(snd_hda_query_pin_caps(codec, pin) & AC_PINCAP_EAPD))
+ return;
+ snd_hda_codec_update_cache(codec, pin, 0,
+ AC_VERB_SET_EAPD_BTLENABLE,
+ enable ? 0x02 : 0x00);
+}
+
/*
* Helper functions for creating mixer ctl elements
if (output) {
snd_hda_set_pin_ctl_cache(codec, nid, PIN_OUT);
snd_hda_activate_path(codec, path, true, true);
+ set_pin_eapd(codec, nid, true);
} else {
+ set_pin_eapd(codec, nid, false);
snd_hda_activate_path(codec, path, false, true);
snd_hda_set_pin_ctl_cache(codec, nid,
spec->multi_io[idx].ctl_in);
val = 0;
val |= pin_bits;
snd_hda_set_pin_ctl(codec, nid, val);
+ set_pin_eapd(codec, nid, !mute);
}
}
static void set_output_and_unmute(struct hda_codec *codec, hda_nid_t pin,
int pin_type, hda_nid_t dac)
{
- struct hda_gen_spec *spec = codec->spec;
struct nid_path *path;
snd_hda_set_pin_ctl_cache(codec, pin, pin_type);
if (path->active)
return;
snd_hda_activate_path(codec, path, true, true);
-
- if (!spec->own_eapd_ctl &&
- (snd_hda_query_pin_caps(codec, pin) & AC_PINCAP_EAPD))
- snd_hda_codec_update_cache(codec, pin, 0,
- AC_VERB_SET_EAPD_BTLENABLE, 0x02);
+ set_pin_eapd(codec, pin, true);
}
/* initialize primary output paths */