]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
ASoC: qcom: lpass-platform: fix memory leak
authorRohit kumar <rohitkr@codeaurora.org>
Fri, 14 Aug 2020 10:53:00 +0000 (16:23 +0530)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 29 Oct 2020 09:07:29 +0000 (10:07 +0100)
[ Upstream commit 5fd188215d4eb52703600d8986b22311099a5940 ]

lpass_pcm_data is never freed. Free it in close
ops to avoid memory leak.

Fixes: 022d00ee0b55 ("ASoC: lpass-platform: Fix broken pcm data usage")
Signed-off-by: Rohit kumar <rohitkr@codeaurora.org>
Reviewed-by: Srinivas Kandagatla <srinivas.kandagatla@linaro.org>
Link: https://lore.kernel.org/r/1597402388-14112-5-git-send-email-rohitkr@codeaurora.org
Signed-off-by: Mark Brown <broonie@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
sound/soc/qcom/lpass-platform.c

index 34f7fd1bab1cfbffdc88c9d3c202eab65771010b..693839deebfe8406d11175389053bd43cd5b45d2 100644 (file)
@@ -61,7 +61,7 @@ static int lpass_platform_pcmops_open(struct snd_soc_component *component,
        int ret, dma_ch, dir = substream->stream;
        struct lpass_pcm_data *data;
 
-       data = devm_kzalloc(soc_runtime->dev, sizeof(*data), GFP_KERNEL);
+       data = kzalloc(sizeof(*data), GFP_KERNEL);
        if (!data)
                return -ENOMEM;
 
@@ -118,6 +118,7 @@ static int lpass_platform_pcmops_close(struct snd_soc_component *component,
        if (v->free_dma_channel)
                v->free_dma_channel(drvdata, data->dma_ch);
 
+       kfree(data);
        return 0;
 }