[alsa-devel] [PATCH] ALSA: hda - Fix runtime PM accounting
Lin, Mengdong
mengdong.lin at intel.com
Fri Aug 31 03:57:09 CEST 2012
> -----Original Message-----
> From: Takashi Iwai [mailto:tiwai at suse.de]
> Sent: Thursday, August 30, 2012 10:45 PM
>
> Yeah, the check seems slipped from my previous post by some reason.
> Maybe I cherry-picked a wrong branch.
> It should be
> if (codec->power_on)
> hda_call_pm_notify(codec->bus, false); and it should be called
> before module_put().
>
> It's not needed. In the case of snd_hda_codec_free(), the only interest is
> whether pm_notify down was already called for this this particular codec.
> And this can be checked by codec->power_on flag.
>
Yes, an extra power flag is not needed.
I think 'codec->d3_stop_clk_ok' flag is more suitable than 'codec->power_on' for this check:
if (!codec->d3_stop_clk_ok) ... either not suspended or d3_stop_clk_ok is not set for last suspending
hda_call_pm_notify(codec->bus, false);
It's because the codec will call pm_notify down only when PS-ClkStopOk is set on its last suspending to D3.
And PS-ClkStopOk is dynamic flag while CLKSTOP is static. It's possible that a codec supports CLKSTOP but
does not set PS-ClkStopOk on every transition to D3.
Thanks
Mengdong
More information about the Alsa-devel
mailing list