Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp9410273ybi; Wed, 10 Jul 2019 09:47:11 -0700 (PDT) X-Google-Smtp-Source: APXvYqwlLNX78kMtYtbbp/tNLvBFMgVoi43oYaGFV28PLIH8LNmSu8I2isoVY3slV6dazRtp02HZ X-Received: by 2002:a17:902:2a26:: with SMTP id i35mr39463064plb.315.1562777231043; Wed, 10 Jul 2019 09:47:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1562777231; cv=none; d=google.com; s=arc-20160816; b=oppnM1BQ+MKiaqXB8sXSMLJIh1K4vEdW8np/1vB3Oqi13UwfKE8A5S4MwmdPSRKH4G ugV4Y6sQcw9q8VUrqNfF/lgnbBHeSmRn+CdqG+pMkd6ro9KN/coUZLg13cEdxPNDJB/B Q7HD7s0eSn749F9q1kwTk4ddwKOAYdw+YdaRnQ82EcBLHm+MMANQALGMJjnCvwe27VaR deQo7OT+sVkriyHuX90FruHBO+XrikX2pH7B+UmIjSxZ1i2TDUJLagtIsfby6oVWcn4x tXQsdworZvKM+aazqy62Sb0i94LJQypahU11oh5LNAQNiE2e/p1E2ORucr1mWmu3KbSy ksgA== 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; bh=V91pmBsf6kxdFHew84eBND8S52MilJzfqdSmspUhTJo=; b=zmjZalJ+b9ZMLBWG2h8rYbZwwEuMHKss2iUh7Dprm8ftke1eMxQGjyGzkLolX/24ux MOe1ffWThZbZpRW9ImAx1A3U8dHusKNN7OGfp8o8UU2YGlCmW52nEXPt8BSSzPMvIMnL Qlb+I8DqrtN6Vv7U93M6scXaToAxGPAvFVjkMNngaTcjAcglVnyDjSfek/TDTAJrz2C2 9VPknGfAeXUH4iqn9YH/9ME530+oUcJ9JTr/s26DKn6rUStROHhwtMSkLSSPrNo7BCeD Pxiu4IbJlqfq4IdgEFZvlMjTdmzx6WqD3PdTF4Glcif/wnQ1PKmLlJXkul3fMeipaSGS GiPA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@sirena.org.uk header.s=20170815-heliosphere header.b="jAd/Ps0/"; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id u16si2709065pjb.15.2019.07.10.09.46.55; Wed, 10 Jul 2019 09:47:11 -0700 (PDT) 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="jAd/Ps0/"; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727479AbfGJPey (ORCPT + 99 others); Wed, 10 Jul 2019 11:34:54 -0400 Received: from heliosphere.sirena.org.uk ([172.104.155.198]:45652 "EHLO heliosphere.sirena.org.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727063AbfGJPew (ORCPT ); Wed, 10 Jul 2019 11:34:52 -0400 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=V91pmBsf6kxdFHew84eBND8S52MilJzfqdSmspUhTJo=; b=jAd/Ps0/iZHi BE2144LdPYYIb3qiC4sqEAcaUL+ip753Mlxb04YZrQxVAXbKuAmAkhgAg/qlYuHUR9EF01UFhlwci LbgX+a/lK5m4Be37ykGiwQPiUjTxAFeOhKtjiLhry1bFf9wnD6sUMy2QYao5G2YDUOc0k65HQv0Gn D/Cj0=; Received: from [217.140.106.53] (helo=fitzroy.sirena.org.uk) by heliosphere.sirena.org.uk with esmtpsa (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1hlEcB-00082j-6P; Wed, 10 Jul 2019 15:34:39 +0000 Received: by fitzroy.sirena.org.uk (Postfix, from userid 1000) id 99AAED02D7C; Wed, 10 Jul 2019 16:34:38 +0100 (BST) From: Mark Brown To: Wen Yang Cc: alsa-devel@alsa-project.org, broonie@kernel.org, cheng.shengyu@zte.com.cn, jonathanh@nvidia.com, kuninori.morimoto.gx@renesas.com, Kuninori Morimoto , lgirdwood@gmail.com, linux-kernel@vger.kernel.org, Mark Brown , tiwai@suse.com, wang.yi59@zte.com.cn, xue.zhihong@zte.com.cn Subject: Applied "ASoC: audio-graph-card: fix an use-after-free in graph_get_dai_id()" to the asoc tree In-Reply-To: <1562743509-30496-5-git-send-email-wen.yang99@zte.com.cn> X-Patchwork-Hint: ignore Message-Id: <20190710153438.99AAED02D7C@fitzroy.sirena.org.uk> Date: Wed, 10 Jul 2019 16:34:38 +0100 (BST) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The patch ASoC: audio-graph-card: fix an use-after-free in graph_get_dai_id() 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 c152f8491a8d9a4b25afd65a86eb5e55e2a8c380 Mon Sep 17 00:00:00 2001 From: Wen Yang Date: Wed, 10 Jul 2019 15:25:09 +0800 Subject: [PATCH] ASoC: audio-graph-card: fix an use-after-free in graph_get_dai_id() After calling of_node_put() on the node variable, it is still being used, which may result in use-after-free. Fix this issue by calling of_node_put() after the last usage. Fixes: a0c426fe1433 ("ASoC: simple-card-utils: check "reg" property on asoc_simple_card_get_dai_id()") Link: https://lore.kernel.org/r/1562743509-30496-5-git-send-email-wen.yang99@zte.com.cn Signed-off-by: Wen Yang Acked-by: Kuninori Morimoto Signed-off-by: Mark Brown --- sound/soc/generic/audio-graph-card.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/sound/soc/generic/audio-graph-card.c b/sound/soc/generic/audio-graph-card.c index bddfcfd7bedf..343ede8042c3 100644 --- a/sound/soc/generic/audio-graph-card.c +++ b/sound/soc/generic/audio-graph-card.c @@ -63,6 +63,7 @@ static int graph_get_dai_id(struct device_node *ep) struct device_node *endpoint; struct of_endpoint info; int i, id; + u32 *reg; int ret; /* use driver specified DAI ID if exist */ @@ -83,8 +84,9 @@ static int graph_get_dai_id(struct device_node *ep) return info.id; node = of_get_parent(ep); + reg = of_get_property(node, "reg", NULL); of_node_put(node); - if (of_get_property(node, "reg", NULL)) + if (reg) return info.port; } node = of_graph_get_port_parent(ep); -- 2.20.1