Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2713593pxv; Sun, 11 Jul 2021 23:33:33 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyQ8xPMeRU3UmrphDkdmN0vDREC1UJYl+dn7khKTGIRwMK4qswyYpnew+5RmlbaLDn1ZXax X-Received: by 2002:a17:906:d977:: with SMTP id rp23mr7138963ejb.512.1626071613273; Sun, 11 Jul 2021 23:33:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626071613; cv=none; d=google.com; s=arc-20160816; b=KXiH0Em/WtcM9KeoCY7k/mh5JDU/qnxYXh6EsVv99NcR1AQSE1ZSE8WBW+XFLDcgVy pM7N6p6Be5e8z9qtyuLXDjHysiM7s1nD/T/lms51qige6ssVJg/GlSsQZz1hpSYbvV8T GKrS/H/rHnGn3vFu3YTzDFrzV9rYim6IgqadUFeJgj6MCQAoeY4r85PxVaWEIdJUwCdT y8ZNj8fgFjytLB1HtuYPgu+bXoZuA8qNTwW31jVe/AU8fS1MD7lQ7sX54vVm8DyuX4nl 6proqJIFtBw8fe49NM7rbF/UiZT+CnPXhhdEUWFTODXa3WHiu+Oc1KJ5aS5gj+i3hpOF X+Hw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=KTd0mmKqZs3fpaC0AmaenNwjsR3fOc+e0qcINAck8p4=; b=enq8E/REcqyP4HmBi2GbKIlXKjRRVpYBn/v3thjwEuXacFfZSChJgzvWF3uBFaQvSo AZe/XVvvqSAJEf7euUwdi2OLOMridvKjMlRbauYwOtVm0J8deakuisUPCvvYayK/dkMN K//kjEFjy6J+LMLyJnanIiF1Xw8zFZybNyjiiTt+oupddcmRf7O+HNjSJtDz3+hdjt/o 18uy5UFI41e0XHwXpbUu0npSxyNd19ltLMGZN+4DCB/T+NZr2mYJDnXpkDEJU8JJW/Wh K6wvo+Ag6FyUgbV4LqKubyXdLMNgNiOgqbqo1zFDXkr2GTPu+ueL9xuEe/Bp1BqPvFeu cv0A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=V+u75XOT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id dc24si2559527edb.193.2021.07.11.23.33.10; Sun, 11 Jul 2021 23:33:33 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=V+u75XOT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237606AbhGLGel (ORCPT + 99 others); Mon, 12 Jul 2021 02:34:41 -0400 Received: from mail.kernel.org ([198.145.29.99]:52840 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237083AbhGLGad (ORCPT ); Mon, 12 Jul 2021 02:30:33 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 2F6E160238; Mon, 12 Jul 2021 06:27:45 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626071265; bh=zxJW2rIiAo0jd+NdZYeI3reLelKmXIiJfeRrFb4xA6Q=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=V+u75XOTHd9PmoflCKbwZs5KNMKlyWme7PKTh1kywTIu3Ka/0azxBb5zNDQrXVK7c DGypg5ByhnHXLnxaSM2BSK3R7yg0q3NxkECX+fKs7edaWkMF6vsOvbR5XAc1EZGjJT 6+Zh6pcuxuM76JkUDepnQyqy+6G/693vVht2WRrE= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Christophe JAILLET , Mark Brown , Sasha Levin Subject: [PATCH 5.4 303/348] ASoC: mediatek: mtk-btcvsd: Fix an error handling path in mtk_btcvsd_snd_probe() Date: Mon, 12 Jul 2021 08:11:27 +0200 Message-Id: <20210712060743.909953098@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210712060659.886176320@linuxfoundation.org> References: <20210712060659.886176320@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Christophe JAILLET [ Upstream commit b6052c3c7a78f5e2b9756c92ef77c0b56435f107 ] If an error occurs after a successful 'of_iomap()' call, it must be undone by a corresponding 'iounmap()' call, as already done in the remove function. While at it, remove the useless initialization of 'ret' at the beginning of the function. Fixes: 4bd8597dc36c ("ASoC: mediatek: add btcvsd driver") Signed-off-by: Christophe JAILLET Link: https://lore.kernel.org/r/0c2ba562c3364e61bfbd5b3013a99dfa0d9045d7.1622989685.git.christophe.jaillet@wanadoo.fr Signed-off-by: Mark Brown Signed-off-by: Sasha Levin --- sound/soc/mediatek/common/mtk-btcvsd.c | 24 ++++++++++++++++++------ 1 file changed, 18 insertions(+), 6 deletions(-) diff --git a/sound/soc/mediatek/common/mtk-btcvsd.c b/sound/soc/mediatek/common/mtk-btcvsd.c index d00608c73c6e..b66f7dee1e14 100644 --- a/sound/soc/mediatek/common/mtk-btcvsd.c +++ b/sound/soc/mediatek/common/mtk-btcvsd.c @@ -1302,7 +1302,7 @@ static const struct snd_soc_component_driver mtk_btcvsd_snd_platform = { static int mtk_btcvsd_snd_probe(struct platform_device *pdev) { - int ret = 0; + int ret; int irq_id; u32 offset[5] = {0, 0, 0, 0, 0}; struct mtk_btcvsd_snd *btcvsd; @@ -1358,7 +1358,8 @@ static int mtk_btcvsd_snd_probe(struct platform_device *pdev) btcvsd->bt_sram_bank2_base = of_iomap(dev->of_node, 1); if (!btcvsd->bt_sram_bank2_base) { dev_err(dev, "iomap bt_sram_bank2_base fail\n"); - return -EIO; + ret = -EIO; + goto unmap_pkv_err; } btcvsd->infra = syscon_regmap_lookup_by_phandle(dev->of_node, @@ -1366,7 +1367,8 @@ static int mtk_btcvsd_snd_probe(struct platform_device *pdev) if (IS_ERR(btcvsd->infra)) { dev_err(dev, "cannot find infra controller: %ld\n", PTR_ERR(btcvsd->infra)); - return PTR_ERR(btcvsd->infra); + ret = PTR_ERR(btcvsd->infra); + goto unmap_bank2_err; } /* get offset */ @@ -1375,7 +1377,7 @@ static int mtk_btcvsd_snd_probe(struct platform_device *pdev) ARRAY_SIZE(offset)); if (ret) { dev_warn(dev, "%s(), get offset fail, ret %d\n", __func__, ret); - return ret; + goto unmap_bank2_err; } btcvsd->infra_misc_offset = offset[0]; btcvsd->conn_bt_cvsd_mask = offset[1]; @@ -1394,8 +1396,18 @@ static int mtk_btcvsd_snd_probe(struct platform_device *pdev) mtk_btcvsd_snd_set_state(btcvsd, btcvsd->tx, BT_SCO_STATE_IDLE); mtk_btcvsd_snd_set_state(btcvsd, btcvsd->rx, BT_SCO_STATE_IDLE); - return devm_snd_soc_register_component(dev, &mtk_btcvsd_snd_platform, - NULL, 0); + ret = devm_snd_soc_register_component(dev, &mtk_btcvsd_snd_platform, + NULL, 0); + if (ret) + goto unmap_bank2_err; + + return 0; + +unmap_bank2_err: + iounmap(btcvsd->bt_sram_bank2_base); +unmap_pkv_err: + iounmap(btcvsd->bt_pkv_base); + return ret; } static int mtk_btcvsd_snd_remove(struct platform_device *pdev) -- 2.30.2