ALSA: hda: Suspend codec at shutdown
So far we have a few workarounds at shutdown for each codec, e.g. turning off the display power and setting the codec to D3. But all those are basically a part of the suspend procedure. Moreover, the streams are still active after that call, hence it might hit the update on the codec that has been already put to D3. In this patch, instead of calling each reboot_notify callback, simply put the codec into the runtime-suspended state after the manual suspend of all PCM streams. It makes the code and the behavior more consistent. The reboot_notify callback is no longer used after this patch, and will be cleaned up later. BugLink: https://bugzilla.kernel.org/show_bug.cgi?id=214045 Link: https://lore.kernel.org/r/20210813081230.4268-3-tiwai@suse.de Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
parent
95dc85dba0
commit
b98444ed59
@ -165,13 +165,7 @@ static int hda_codec_driver_remove(struct device *dev)
|
|||||||
|
|
||||||
static void hda_codec_driver_shutdown(struct device *dev)
|
static void hda_codec_driver_shutdown(struct device *dev)
|
||||||
{
|
{
|
||||||
struct hda_codec *codec = dev_to_hda_codec(dev);
|
snd_hda_codec_shutdown(dev_to_hda_codec(dev));
|
||||||
|
|
||||||
if (!pm_runtime_suspended(dev)) {
|
|
||||||
if (codec->patch_ops.reboot_notify)
|
|
||||||
codec->patch_ops.reboot_notify(codec);
|
|
||||||
snd_hda_codec_display_power(codec, false);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int __hda_codec_driver_register(struct hda_codec_driver *drv, const char *name,
|
int __hda_codec_driver_register(struct hda_codec_driver *drv, const char *name,
|
||||||
|
@ -2981,6 +2981,20 @@ const struct dev_pm_ops hda_codec_driver_pm = {
|
|||||||
NULL)
|
NULL)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* suspend the codec at shutdown; called from driver's shutdown callback */
|
||||||
|
void snd_hda_codec_shutdown(struct hda_codec *codec)
|
||||||
|
{
|
||||||
|
struct hda_pcm *cpcm;
|
||||||
|
|
||||||
|
if (pm_runtime_suspended(hda_codec_dev(codec)))
|
||||||
|
return;
|
||||||
|
|
||||||
|
list_for_each_entry(cpcm, &codec->pcm_list_head, list)
|
||||||
|
snd_pcm_suspend_all(cpcm->pcm);
|
||||||
|
|
||||||
|
pm_runtime_suspend(hda_codec_dev(codec));
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* add standard channel maps if not specified
|
* add standard channel maps if not specified
|
||||||
*/
|
*/
|
||||||
|
@ -615,6 +615,8 @@ unsigned int snd_hda_codec_eapd_power_filter(struct hda_codec *codec,
|
|||||||
hda_nid_t nid,
|
hda_nid_t nid,
|
||||||
unsigned int power_state);
|
unsigned int power_state);
|
||||||
|
|
||||||
|
void snd_hda_codec_shutdown(struct hda_codec *codec);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* AMP control callbacks
|
* AMP control callbacks
|
||||||
*/
|
*/
|
||||||
|
Loading…
Reference in New Issue
Block a user