Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp492808ybl; Tue, 28 Jan 2020 06:49:06 -0800 (PST) X-Google-Smtp-Source: APXvYqyK90GcNTkWPiekfB8WxrcpsrwU2Yepood0MbtJJvsvFbXiG9A0zfTMzILbPpIDu0xF/jND X-Received: by 2002:aca:5188:: with SMTP id f130mr3195735oib.47.1580222946004; Tue, 28 Jan 2020 06:49:06 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1580222945; cv=none; d=google.com; s=arc-20160816; b=j4DsnNEkGLQhS61C+7lkjerymThftAUJWNdVjqeOr2XYFp0FKMyUzTOQfG3IyFxrjn Tx1NfFoCM0TPVJ3IWIgja7EQkJiTf+EribgjkoO5If2LGY22mdDTadqPaq4dPIs6lceS yzZo8+3wI1KHQSY8LiG6E3oqsFzUYdiawmBROqXg9JBRkYnFxfUSmXuQk3BvRBqwxc8f zc5dTgsgLuUVjFGfBmrHuwcaqi8eVgD89ur8wWaOxYsUwuEbgUUd+zTFTpTZ7n0LinnF 77slpOe/zz0HlIu4g/nno5NbmrZPt9e4gH3/335mAbPZIjqphy0dEFhP+b+RGaOmMqRa Ajgg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=GZSsZusnJH4kV1HTPsyidNTMbeqKYERw+YY6eXbwv2Q=; b=0sX0Sjs4ddCS9G63YG3ulpdatmY5m/NuoiZlVp+AdctBuSodMcnDFTnLpb54QgTwPC IX+hKYDPUdvBT2HevHf/6UnKO+WtffZfeqeFmNiw0n5CEPfnFzuW+MOK/RLko/r1LQoc m9WqYMnWHVnBqZWCQw4vLe+ID+BAjQn8JXKiy4cefm28X592KgC5wCHdAmr9BCRZgSk/ kIsBK3whuR1I62kLYppQ7VJqMrAzajAMlCSz1/IMM87/fJECnMgbKUuLg1F9oi1Le5Q2 0c2DFxqzRP+skJl0mJeGzydM3BU/iKwlKfV2WjEHrrZXVhViCCSUZaINDU9EveZ+d7wl GGTg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=NNNrJWw9; 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 y127si5662960oiy.250.2020.01.28.06.48.53; Tue, 28 Jan 2020 06:49:05 -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=pass header.i=@kernel.org header.s=default header.b=NNNrJWw9; 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 S1726363AbgA1Oq0 (ORCPT + 99 others); Tue, 28 Jan 2020 09:46:26 -0500 Received: from mail.kernel.org ([198.145.29.99]:57516 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727789AbgA1OJM (ORCPT ); Tue, 28 Jan 2020 09:09:12 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 6B56924688; Tue, 28 Jan 2020 14:09:11 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1580220551; bh=qeubVtjGPkxwmdUo+kI9xbarZDGPcg0nVGIze15XR4g=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=NNNrJWw9KO2Om5lQzn0d2Xje9IC1QPMUGFrd7Hfq8txPn659WNfZI+zdWIoldIIQZ vAPgnFS7+uFDPg6wUF3yO0AzKIgQnokyc356gGlNx76Kr7THzY36IVWobwNGffBm6K 8TF/2jHnwh3qF0tsvR9P5DZF1NnqXttUpUzPaDNY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Patrick Lai , Banajit Goswami , Takashi Iwai , Mark Brown , Sasha Levin Subject: [PATCH 4.4 052/183] ASoC: qcom: Fix of-node refcount unbalance in apq8016_sbc_parse_of() Date: Tue, 28 Jan 2020 15:04:31 +0100 Message-Id: <20200128135835.112688114@linuxfoundation.org> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200128135829.486060649@linuxfoundation.org> References: <20200128135829.486060649@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Takashi Iwai [ Upstream commit 8d1667200850f8753c0265fa4bd25c9a6e5f94ce ] The apq8016 driver leaves the of-node refcount at aborting from the loop of for_each_child_of_node() in the error path. Not only the iterator node of for_each_child_of_node(), the children nodes referred from it for codec and cpu have to be properly unreferenced. Fixes: bdb052e81f62 ("ASoC: qcom: add apq8016 sound card support") Cc: Patrick Lai Cc: Banajit Goswami Signed-off-by: Takashi Iwai Signed-off-by: Mark Brown Signed-off-by: Sasha Levin --- sound/soc/qcom/apq8016_sbc.c | 21 ++++++++++++++++----- 1 file changed, 16 insertions(+), 5 deletions(-) diff --git a/sound/soc/qcom/apq8016_sbc.c b/sound/soc/qcom/apq8016_sbc.c index 1efdf0088ecdf..886f2027e6712 100644 --- a/sound/soc/qcom/apq8016_sbc.c +++ b/sound/soc/qcom/apq8016_sbc.c @@ -98,13 +98,15 @@ static struct apq8016_sbc_data *apq8016_sbc_parse_of(struct snd_soc_card *card) if (!cpu || !codec) { dev_err(dev, "Can't find cpu/codec DT node\n"); - return ERR_PTR(-EINVAL); + ret = -EINVAL; + goto error; } link->cpu_of_node = of_parse_phandle(cpu, "sound-dai", 0); if (!link->cpu_of_node) { dev_err(card->dev, "error getting cpu phandle\n"); - return ERR_PTR(-EINVAL); + ret = -EINVAL; + goto error; } link->codec_of_node = of_parse_phandle(codec, "sound-dai", 0); @@ -116,13 +118,13 @@ static struct apq8016_sbc_data *apq8016_sbc_parse_of(struct snd_soc_card *card) ret = snd_soc_of_get_dai_name(cpu, &link->cpu_dai_name); if (ret) { dev_err(card->dev, "error getting cpu dai name\n"); - return ERR_PTR(ret); + goto error; } ret = snd_soc_of_get_dai_name(codec, &link->codec_dai_name); if (ret) { dev_err(card->dev, "error getting codec dai name\n"); - return ERR_PTR(ret); + goto error; } link->platform_of_node = link->cpu_of_node; @@ -132,15 +134,24 @@ static struct apq8016_sbc_data *apq8016_sbc_parse_of(struct snd_soc_card *card) ret = of_property_read_string(np, "link-name", &link->name); if (ret) { dev_err(card->dev, "error getting codec dai_link name\n"); - return ERR_PTR(ret); + goto error; } link->stream_name = link->name; link->init = apq8016_sbc_dai_init; link++; + + of_node_put(cpu); + of_node_put(codec); } return data; + + error: + of_node_put(np); + of_node_put(cpu); + of_node_put(codec); + return ERR_PTR(ret); } static int apq8016_sbc_platform_probe(struct platform_device *pdev) -- 2.20.1