]> git.baikalelectronics.ru Git - kernel.git/commit
ALSA: hda - Fix runtime PM
authorLukas Wunner <lukas@wunner.de>
Thu, 24 May 2018 17:01:07 +0000 (19:01 +0200)
committerTakashi Iwai <tiwai@suse.de>
Thu, 24 May 2018 18:16:47 +0000 (20:16 +0200)
commit56e001229bac53d1ebba2e3881c2fe44798b5145
tree3f4272a78bc8703a5a18d895681d2c9c8b790b5f
parent0ca02b19a33abcfad86611f2b0f8645702a98265
ALSA: hda - Fix runtime PM

Before commit 28a0144f6615 ("ALSA: hda: Make use of core codec functions
to sync power state"), hda_set_power_state() returned the response to
the Get Power State verb, a 32-bit unsigned integer whose expected value
is 0x233 after transitioning a codec to D3, and 0x0 after transitioning
it to D0.

The response value is significant because hda_codec_runtime_suspend()
does not clear the codec's bit in the codec_powered bitmask unless the
AC_PWRST_CLK_STOP_OK bit (0x200) is set in the response value.  That in
turn prevents the HDA controller from runtime suspending because
azx_runtime_idle() checks that the codec_powered bitmask is zero.

Since commit 28a0144f6615, hda_set_power_state() only returns 0x0 or
0x1, thereby breaking runtime PM for any HDA controller.  That's because
an inline function introduced by the commit returns a bool instead of a
32-bit unsigned int.  The change was likely erroneous and resulted from
copying and pasting snd_hda_check_power_state(), which is immediately
preceding the newly introduced inline function.  Fix it.

Link: https://bugs.freedesktop.org/show_bug.cgi?id=106597
Fixes: 28a0144f6615 ("ALSA: hda: Make use of core codec functions to sync power state")
Cc: Alex Deucher <alexander.deucher@amd.com>
Cc: Abhijeet Kumar <abhijeet.kumar@intel.com>
Reported-and-tested-by: Gunnar Krüger <taijian@posteo.de>
Signed-off-by: Lukas Wunner <lukas@wunner.de>
Acked-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/pci/hda/hda_local.h