OSDN Git Service

ALSA: hda/hdmi: Fix keep_power assignment for non-component devices
authorTakashi Iwai <tiwai@suse.de>
Tue, 28 Jul 2020 08:20:33 +0000 (10:20 +0200)
committerTakashi Iwai <tiwai@suse.de>
Tue, 28 Jul 2020 08:23:35 +0000 (10:23 +0200)
commitc2c3657f0aedb8736a0fb7b2b1985adfb86e7802
tree0d8900698a3eae84fa7a4441c8e817ccc53c4924
parenta6630529aecb5a3e84370c376ed658e892e6261e
ALSA: hda/hdmi: Fix keep_power assignment for non-component devices

It's been reported that, when neither nouveau nor Nvidia graphics
driver is used, the screen starts flickering.  And, after comparing
between the working case (stable 4.4.x) and the broken case, it turned
out that the problem comes from the audio component binding.  The
Nvidia and AMD audio binding code clears the bus->keep_power flag
whenever snd_hdac_acomp_init() succeeds.  But this doesn't mean that
the component is actually bound, but it merely indicates that it's
ready for binding.  So, when both nouveau and Nvidia are blacklisted
or not ready, the driver keeps running without the audio component but
also with bus->keep_power = false.  This made the driver runtime PM
kicked in and powering down when unused, which results in flickering
in the graphics side, as it seems.

For fixing the bug, this patch moves the bus->keep_power flag change
into generic_acomp_notifier_set() that is the function called from the
master_bind callback of component ops; i.e. it's guaranteed that the
binding succeeded.

BugLink: https://bugzilla.kernel.org/show_bug.cgi?id=208609
Fixes: 5a858e79c911 ("ALSA: hda - Disable audio component for legacy Nvidia HDMI codecs")
Cc: <stable@vger.kernel.org>
Link: https://lore.kernel.org/r/20200728082033.23933-1-tiwai@suse.de
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/pci/hda/patch_hdmi.c