[alsa-devel] [PATCH] ALSA: hda/hdmi - Don't report Jack event if no need to do that
Hui Wang
hui.wang at canonical.com
Tue Apr 30 08:57:11 CEST 2019
On the machines with AMD GPU or Nvidia GPU, we often meet this issues:
after s3, there are 4 HDMI/DP audio devices in the gnome-sound-setting
even there is no any monitors plugged.
When this problem happens, we check the /proc/asound/cardX/eld#N.M, we
will find the monitor_present=1, eld_valid=0.
The root cause is somehow the pin_sense reports the monitor is present
and eld is valid when there is no monitor plugged.
The current driver will read the eld data if the pin_sense reports the
eld is valid, because of no monitor is plugged, there is no valid eld
data, then the eld->valid is set to 0.
If we don't let driver report Jack event when monitor_present=1 while
eld_valid=0, there will be no this issue.
After this change, the driver only reports Jack event with one of the
below 2 conditons:
eld->monitor_present=1 and eld->eld_valid=1 (a valid monitor detect)
eld->monitor_present=0 (a monitor is unplugged)
Signed-off-by: Hui Wang <hui.wang at canonical.com>
---
sound/pci/hda/patch_hdmi.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/sound/pci/hda/patch_hdmi.c b/sound/pci/hda/patch_hdmi.c
index 8b3ac690efa3..e5a34fa6f358 100644
--- a/sound/pci/hda/patch_hdmi.c
+++ b/sound/pci/hda/patch_hdmi.c
@@ -1548,7 +1548,7 @@ static bool hdmi_present_sense_via_verbs(struct hdmi_spec_per_pin *per_pin,
else
update_eld(codec, per_pin, eld);
- ret = !repoll || !eld->monitor_present || eld->eld_valid;
+ ret = !eld->monitor_present || eld->eld_valid;
jack = snd_hda_jack_tbl_get(codec, pin_nid);
if (jack)
--
2.17.1
More information about the Alsa-devel
mailing list