]> git.itanic.dy.fi Git - linux-stable/commitdiff
ALSA: hda - Fix regression of monitor_present flag in eld proc file
authorHyungwon Hwang <hyungwon.hwang7@gmail.com>
Wed, 13 Apr 2016 00:27:39 +0000 (09:27 +0900)
committerSasha Levin <sasha.levin@oracle.com>
Mon, 18 Apr 2016 12:49:41 +0000 (08:49 -0400)
[ Upstream commit 023d8218ec0dfc30e11d4ec54f640e8f127d1fbe ]

The commit [bd48128539ab: ALSA: hda - Fix forgotten HDMI
monitor_present update] covered the missing update of monitor_present
flag, but this caused a regression for devices without the i915 eld
notifier.  Since the old code supposed that pin_eld->monitor_present
was updated by the caller side, the hdmi_present_sense_via_verbs()
doesn't update the temporary eld->monitor_present but only
pin_eld->monitor_present, which is now overridden in update_eld().

The fix is to update pin_eld->monitor_present as well before calling
update_eld().

Note that this may still leave monitor_present flag in an inconsistent
state when the driver repolls, but this is at least the old behavior.
More proper fix will follow in the later patch.

Fixes: bd48128539ab ('ALSA: hda - Fix forgotten HDMI monitor_present update')
Signed-off-by: Hyungwon Hwang <hyungwon.hwang7@gmail.com>
Cc: <stable@vger.kernel.org>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Signed-off-by: Sasha Levin <sasha.levin@oracle.com>
sound/pci/hda/patch_hdmi.c

index 691b138987003bd5710add428a88d5ca4a5af54f..f6c5cbbbcfeace5f38ec24876db7f922d409e662 100644 (file)
@@ -1555,6 +1555,8 @@ static bool hdmi_present_sense(struct hdmi_spec_per_pin *per_pin, int repoll)
 
        mutex_lock(&per_pin->lock);
        pin_eld->monitor_present = !!(present & AC_PINSENSE_PRESENCE);
+       eld->monitor_present = pin_eld->monitor_present;
+
        if (pin_eld->monitor_present)
                eld->eld_valid  = !!(present & AC_PINSENSE_ELDV);
        else