]> git.proxmox.com Git - mirror_ubuntu-focal-kernel.git/commitdiff
ASoC: dmaengine: do not use a NULL prepare_slave_config() callback
authorCodrin Ciubotariu <codrin.ciubotariu@microchip.com>
Mon, 7 Mar 2022 12:21:57 +0000 (14:21 +0200)
committerStefan Bader <stefan.bader@canonical.com>
Fri, 20 May 2022 13:18:46 +0000 (15:18 +0200)
BugLink: https://bugs.launchpad.net/bugs/1971497
[ Upstream commit 9a1e13440a4f2e7566fd4c5eae6a53e6400e08a4 ]

Even if struct snd_dmaengine_pcm_config is used, prepare_slave_config()
callback might not be set. Check if this callback is set before using it.

Fixes: fa654e085300 ("ASoC: dmaengine-pcm: Provide default config")
Signed-off-by: Codrin Ciubotariu <codrin.ciubotariu@microchip.com>
Link: https://lore.kernel.org/r/20220307122202.2251639-2-codrin.ciubotariu@microchip.com
Signed-off-by: Mark Brown <broonie@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
Signed-off-by: Kamal Mostafa <kamal@canonical.com>
Signed-off-by: Stefan Bader <stefan.bader@canonical.com>
sound/soc/soc-generic-dmaengine-pcm.c

index 5552c66ca64220eb14dea16fe42d24cb22aea460..ca4b17bd95d14c1b5b373d94b1e6c54c8edc6320 100644 (file)
@@ -91,10 +91,10 @@ static int dmaengine_pcm_hw_params(struct snd_pcm_substream *substream,
 
        memset(&slave_config, 0, sizeof(slave_config));
 
-       if (!pcm->config)
-               prepare_slave_config = snd_dmaengine_pcm_prepare_slave_config;
-       else
+       if (pcm->config && pcm->config->prepare_slave_config)
                prepare_slave_config = pcm->config->prepare_slave_config;
+       else
+               prepare_slave_config = snd_dmaengine_pcm_prepare_slave_config;
 
        if (prepare_slave_config) {
                ret = prepare_slave_config(substream, params, &slave_config);