Received: by 10.223.176.46 with SMTP id f43csp2844213wra; Mon, 22 Jan 2018 04:27:25 -0800 (PST) X-Google-Smtp-Source: AH8x224iXd60DqSyvcta6ShKq6GB/blLeXuZ+3YrJ2zDEti06bRb2JZzSAkBl6KqzLmB3cTUTZZw X-Received: by 10.98.63.214 with SMTP id z83mr8206496pfj.95.1516624045818; Mon, 22 Jan 2018 04:27:25 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1516624045; cv=none; d=google.com; s=arc-20160816; b=AHXyl/3hJZCDnHSB3bWUsyE1gbU/vlBCnP9xMjsOGsH8Q/RkVzOmm8Ie1DawdV8feV RobgTFs1sGkr3uUx00QL2ydUf/1ubGRN0Z6sw+J9EpZr+GVFOfureu/CxrTjxzW9bXr1 UuRUoJAQD/lugxuFDgCEnrO3mocaCcTjdf9lY01IzEeDvtnuseSBUyv7WPrrJF+c6WlV redzvoX352C1lMCpgfactTPt8Q8/1/KA/augBt5iw2yj28D0lHHu2CbGkrSd7p1B71KD wL4ikkmSKVNnUqHuMACFnB1c19vcsyWfxjiJoaBR9UwgjZgX6gQCvc59SJXZCipa1exv 0Eqg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:date:message-id:in-reply-to:subject:cc:to :from:dkim-signature:arc-authentication-results; bh=kRT7Xhj/Vq6nzVdWhZnOYmf955ka/sx7ScFjEArcJCY=; b=k69PDfjeJXZjIM4KJ4ncqm6Y6oiOE6m2gN+KBVCWlR6dawFiV7mCl5XSzJNDtFzc8d NWsZtFKoYZpcEfpkKrUU1OoP1XU3As9DvOgAZ0Ixg6AVsT6wDIG/+Uws2F91JmPEK8+y 0v8fRBXvsA1EQINJO7shvw7WZ3j/71qFXr9JDlGjLR/btLn11zxQ5lpoMNo6FnK+uo0u BE9LFZuAWOhGjqqVs8BHnkdzQZ6i7qiySVOsDpyeqPtnRNvxmfscCm7t0dAR0lY5d3D/ ju5HCi95vEKEdiPCZ8uVw9J3ItKF5wIoyp6OxJ1doStpRoFWBY7oNVHaW/QlIxMhTIRv GkJQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@sirena.org.uk header.s=20170815-heliosphere header.b=BZfqsbnq; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p7si124874pfk.8.2018.01.22.04.27.12; Mon, 22 Jan 2018 04:27:25 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=fail header.i=@sirena.org.uk header.s=20170815-heliosphere header.b=BZfqsbnq; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751150AbeAVM0r (ORCPT + 99 others); Mon, 22 Jan 2018 07:26:47 -0500 Received: from heliosphere.sirena.org.uk ([172.104.155.198]:38454 "EHLO heliosphere.sirena.org.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751041AbeAVM0q (ORCPT ); Mon, 22 Jan 2018 07:26:46 -0500 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=sirena.org.uk; s=20170815-heliosphere; h=Date:Message-Id:In-Reply-To: Subject:Cc:To:From:Sender:Reply-To:MIME-Version:Content-Type: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:References: List-Id:List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner: List-Archive; bh=kRT7Xhj/Vq6nzVdWhZnOYmf955ka/sx7ScFjEArcJCY=; b=BZfqsbnq5wyr XTnQKnnuN44OXKi3O9F65g8pET9b0asF54qSaro6rP7GjPRcZDXt1vDU+X/0bjPnIO8vBGyIKI04k 8Dp7LV7C9S2GzA5cekA6F70TKVPG17X8JPTzcBA6yNmzuK67VujH5FWPEFnM11LPgZdoO3HNK0AVe T6Nmk=; Received: from debutante.sirena.org.uk ([2001:470:1f1d:6b5::3] helo=debutante) by heliosphere.sirena.org.uk with esmtpsa (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.89) (envelope-from ) id 1edbBL-0008Ho-3G; Mon, 22 Jan 2018 12:26:35 +0000 Received: from broonie by debutante with local (Exim 4.90) (envelope-from ) id 1edbBK-0004dh-Ku; Mon, 22 Jan 2018 12:26:34 +0000 From: Mark Brown To: Ryder Lee Cc: Dan Carpenter , Mark Brown , Mark Brown , alsa-devel@alsa-project.org, linux-mediatek@lists.infradead.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, alsa-devel@alsa-project.org Subject: Applied "ASoC: mediatek: fix double free in mt2701_afe_pcm_dev_probe()" to the asoc tree In-Reply-To: <2fd34b71f3c940186b99f799c3ed14a83ccc4bba.1516620578.git.ryder.lee@mediatek.com> Message-Id: Date: Mon, 22 Jan 2018 12:26:34 +0000 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The patch ASoC: mediatek: fix double free in mt2701_afe_pcm_dev_probe() has been applied to the asoc tree at https://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound.git All being well this means that it will be integrated into the linux-next tree (usually sometime in the next 24 hours) and sent to Linus during the next merge window (or sooner if it is a bug fix), however if problems are discovered then the patch may be dropped or reverted. You may get further e-mails resulting from automated or manual testing and review of the tree, please engage with people reporting problems and send followup patches addressing any issues that are reported if needed. If any updates are required or you are submitting further changes they should be sent as incremental updates against current git, existing patches will not be replaced. Please add any relevant lists and maintainers to the CCs when replying to this mail. Thanks, Mark From dc2a17f4f074c434757e2cef5026d4747fe22955 Mon Sep 17 00:00:00 2001 From: Ryder Lee Date: Mon, 22 Jan 2018 19:33:05 +0800 Subject: [PATCH] ASoC: mediatek: fix double free in mt2701_afe_pcm_dev_probe() The commit dfa3cbb8(ASoC: mediatek: modify MT2701 AFE driver to adapt mfd device) leads to the following static checker warning: sound/soc/mediatek/mt2701/mt2701-afe-pcm.c:1535 mt2701_afe_pcm_dev_probe() error: double free of 'component' This patch fixes that and adds a helper mt2701_afe_add_component() to setup component. Reported-by: Dan Carpenter Signed-off-by: Ryder Lee Signed-off-by: Mark Brown --- sound/soc/mediatek/mt2701/mt2701-afe-pcm.c | 32 +++++++++++++++++------------- 1 file changed, 18 insertions(+), 14 deletions(-) diff --git a/sound/soc/mediatek/mt2701/mt2701-afe-pcm.c b/sound/soc/mediatek/mt2701/mt2701-afe-pcm.c index 5bc4e00a4a29..d68b53f7cefe 100644 --- a/sound/soc/mediatek/mt2701/mt2701-afe-pcm.c +++ b/sound/soc/mediatek/mt2701/mt2701-afe-pcm.c @@ -1405,9 +1405,24 @@ static int mt2701_afe_runtime_resume(struct device *dev) return mt2701_afe_enable_clock(afe); } -static int mt2701_afe_pcm_dev_probe(struct platform_device *pdev) +static int mt2701_afe_add_component(struct mtk_base_afe *afe) { struct snd_soc_component *component; + + component = kzalloc(sizeof(*component), GFP_KERNEL); + if (!component) + return -ENOMEM; + + component->regmap = afe->regmap; + + return snd_soc_add_component(afe->dev, component, + &mt2701_afe_pcm_dai_component, + mt2701_afe_pcm_dais, + ARRAY_SIZE(mt2701_afe_pcm_dais)); +} + +static int mt2701_afe_pcm_dev_probe(struct platform_device *pdev) +{ struct mtk_base_afe *afe; struct mt2701_afe_private *afe_priv; struct device *dev; @@ -1477,12 +1492,6 @@ static int mt2701_afe_pcm_dev_probe(struct platform_device *pdev) = &mt2701_i2s_data[i][I2S_IN]; } - component = kzalloc(sizeof(*component), GFP_KERNEL); - if (!component) - return -ENOMEM; - - component->regmap = afe->regmap; - afe->mtk_afe_hardware = &mt2701_afe_hardware; afe->memif_fs = mt2701_memif_fs; afe->irq_fs = mt2701_irq_fs; @@ -1495,7 +1504,7 @@ static int mt2701_afe_pcm_dev_probe(struct platform_device *pdev) ret = mt2701_init_clock(afe); if (ret) { dev_err(dev, "init clock error\n"); - goto err_init_clock; + return ret; } platform_set_drvdata(pdev, afe); @@ -1514,10 +1523,7 @@ static int mt2701_afe_pcm_dev_probe(struct platform_device *pdev) goto err_platform; } - ret = snd_soc_add_component(dev, component, - &mt2701_afe_pcm_dai_component, - mt2701_afe_pcm_dais, - ARRAY_SIZE(mt2701_afe_pcm_dais)); + ret = mt2701_afe_add_component(afe); if (ret) { dev_warn(dev, "err_dai_component\n"); goto err_dai_component; @@ -1531,8 +1537,6 @@ static int mt2701_afe_pcm_dev_probe(struct platform_device *pdev) pm_runtime_put_sync(dev); err_pm_disable: pm_runtime_disable(dev); -err_init_clock: - kfree(component); return ret; } -- 2.15.1