]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
ASoC: Intel: catpt: Do not wake DSP just for volume setup
authorCezary Rojewski <cezary.rojewski@intel.com>
Mon, 9 Mar 2026 09:16:04 +0000 (10:16 +0100)
committerMark Brown <broonie@kernel.org>
Wed, 11 Mar 2026 13:34:12 +0000 (13:34 +0000)
With the new control-operations in place, the controls no longer wake
the DSP just for the sake of updating volume (or mute) settings on the
firmware side. The values are cached and actual update occurs only when
streams are being opened for streaming or are already running. In those
cases the DSP must already be woken up and we avoid unnecessary power
consumption.

Signed-off-by: Cezary Rojewski <cezary.rojewski@intel.com>
Link: https://patch.msgid.link/20260309091605.896307-5-cezary.rojewski@intel.com
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/intel/catpt/pcm.c

index 3074b6c958fa77100afc0f26942707c91bd3c5f1..2ed9df7bc43494cdcf4baefe083207b75e61a91d 100644 (file)
@@ -388,6 +388,15 @@ static int catpt_apply_mute(struct catpt_dev *cdev, struct snd_soc_card *card)
 static int catpt_apply_controls(struct catpt_dev *cdev, struct snd_soc_card *card,
                                struct catpt_stream_runtime *stream)
 {
+       int ret;
+
+       /* Update the master volume when the first stream is opened. */
+       if (list_empty(&cdev->stream_list)) {
+               ret = catpt_apply_volume(cdev, card, "Master Playback Volume");
+               if (ret)
+                       return ret;
+       }
+
        /* Only selected streams have individual controls. */
        switch (stream->info.stream_hw_id) {
        case CATPT_PIN_ID_OFFLOAD1: