]> git.baikalelectronics.ru Git - kernel.git/commit
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)
commite5aae933a50d4bec16dd7a3da8257a33f6cb008c
tree0d8900698a3eae84fa7a4441c8e817ccc53c4924
parente9cf4fb2c977e177026a39c95ca1a91f4cde093c
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: ee93d7c69bb5 ("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