[alsa-devel] Query regarding possibility of PM QoS unvote/vote when substream Pause/Resume called
bgoswami at codeaurora.org
bgoswami at codeaurora.org
Wed Jun 21 19:58:24 CEST 2017
Hi,
Current ALSA core implementation has PM QoS vote/unvote calls in
snd_pcm_hw_params() and snd_pcm_hw_free().
However, this might have an implication in terms of power, as PM QoS
vote would still be valid for that substream, even when the substream is
paused. Especially for those cases, where, to avoid missing the QoS, one
or more CPU cores might be prevented from entering into lower power mode
(or power-collapse), as it might take longer to bring those cores out of
power collapse. This might be specially more prominent when the period
size is smaller.
So, in an effort to optimize power (by whatever smaller amount), I was
wondering, if it is better to remove the PM QoS vote
(pm_qos_remove_request) when Pause (SNDRV_PCM_TRIGGER_PAUSE_PUSH) is
called from user space (using IOCTL) for a particular substream.
Similarly, PM QoS vote can be added (pm_qos_add_request) back, when
user space (using IOCTL) calls Resume (SNDRV_PCM_TRIGGER_PAUSE_RELEASE)
for that same substream.
I am looking for opinions from subject matter experts, to see if the
proposed approach might have any unintended side-effects or any known
limitation that I might be missing.
Thanks and Regards,
Banajit Goswami
The Qualcomm Innovation Center, Inc. is a member of the Code Aurora
Forum,
a Linux Foundation Collaborative Project
More information about the Alsa-devel
mailing list