From: Kuninori Morimoto Date: Tue, 30 Mar 2021 05:26:38 +0000 (+0900) Subject: ASoC: soc-core: use device_unregister() if rtd allocation failed X-Git-Tag: nvme-5.14-2021-06-08~186^2~19^2^2~88^2 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=5fa7553dcd83c576c589fd3e617dc599e4fe15dc;p=nvme.git ASoC: soc-core: use device_unregister() if rtd allocation failed Because soc_free_pcm_runtime(rtd) checks rtd pointer and freeing rtd->xxx, it doesn't work correctly in case of rtd allocation failed. We need to use device_unregister(dev) in such case. This patch fixup it. Signed-off-by: Kuninori Morimoto Link: https://lore.kernel.org/r/87r1jxxldd.wl-kuninori.morimoto.gx@renesas.com Signed-off-by: Mark Brown --- diff --git a/sound/soc/soc-core.c b/sound/soc/soc-core.c index 88694746dc11..236e075b9e57 100644 --- a/sound/soc/soc-core.c +++ b/sound/soc/soc-core.c @@ -470,8 +470,10 @@ static struct snd_soc_pcm_runtime *soc_new_pcm_runtime( dai_link->num_codecs + dai_link->num_platforms), GFP_KERNEL); - if (!rtd) - goto free_rtd; + if (!rtd) { + device_unregister(dev); + return NULL; + } rtd->dev = dev; INIT_LIST_HEAD(&rtd->list);