Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp3150099pxb; Mon, 9 Nov 2020 04:06:30 -0800 (PST) X-Google-Smtp-Source: ABdhPJwwME0uf5bXYh0E/dOPOOo/7U9kbQT1UygBzDwfaWx1SsUYz04n87H/XIGwf527FpdfaFAz X-Received: by 2002:a50:e443:: with SMTP id e3mr15415353edm.160.1604923590609; Mon, 09 Nov 2020 04:06:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604923590; cv=none; d=google.com; s=arc-20160816; b=CTexjX9l1dx0kckHeLIy7w07EMxJ7qH3Ldo4czyVj5vFKbD04N/Oh1ywWLwoTN1TMi FG7bD0/BUy6uxuJ5aIfJ/J9+9/K6MOCsUQecp/lfYiUSCdpivzMPk1/9Ot1XH8s5BU38 vvweC/FaS7t8BbQUrQF1Xv3YmSCveRscbCLvI+SGyiCGG5n7Bb8EEBOBJJyOtmuv1U93 XveyDUwDD/xrKiyOY3HqgYDCVJwyBYviwYL3JZGRzHacgea/Chb7LRVANHI9yik0E01A Mqf18SDj+zD1BQWALl5x70HPskUHPSGs10qUpzniwq/p8xbSR7U2+DWqkWahebgoEaIJ B17A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :to:subject; bh=e/7Rpkbj+FAmnAl3uFoRtwGieAXJtN0TVmR8iT4FRHU=; b=auv2yDIMBwr1ghz40wrwuASwft2Y6EEoQrlp9czsHxnZ9sFWpR8AqD9NlY0Ae14fWg XK0q99mkUPCMC8nEtrZVxJANEwk1HU1yrfVsMkpG6b8Eaae5rkMF1XSJtavoF3/rRTsR jV+pLD6CUmEMiDFN+FBDZPirUJXREFGSELQVCqn9No2qKuE21ZfOUv6uPeKyY/uGGmDl CXdnildjAIyIzD09JgnGFIAZf3mG8gK5tM6n9nxxbi4RMYQ8p7hcVndcSniY2gii7HeI uOtgGsI+KXA++Ma9iw8OBFIRhSGvdF5Qurh17lBq3e27BLdH0RMuyaN/c6vJCvvInh5K 7Z0A== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id 18si6945890ejv.717.2020.11.09.04.06.06; Mon, 09 Nov 2020 04:06:30 -0800 (PST) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729520AbgKIMCe (ORCPT + 99 others); Mon, 9 Nov 2020 07:02:34 -0500 Received: from szxga03-in.huawei.com ([45.249.212.189]:2366 "EHLO szxga03-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726410AbgKIMCd (ORCPT ); Mon, 9 Nov 2020 07:02:33 -0500 Received: from dggeme755-chm.china.huawei.com (unknown [172.30.72.56]) by szxga03-in.huawei.com (SkyGuard) with ESMTP id 4CV8kN5hRxz52X9; Mon, 9 Nov 2020 20:02:20 +0800 (CST) Received: from [10.140.157.68] (10.140.157.68) by dggeme755-chm.china.huawei.com (10.3.19.101) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1913.5; Mon, 9 Nov 2020 20:02:30 +0800 Subject: Re: [PATCH V2] clk: hisilicon: Free clk_data and unmap region obtained by of_iomap To: , , , , Markus Elfring References: <20201109180920.43193-1-gengdongjiu@huawei.com> From: Dongjiu Geng Message-ID: Date: Mon, 9 Nov 2020 20:02:28 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: <20201109180920.43193-1-gengdongjiu@huawei.com> Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.140.157.68] X-ClientProxiedBy: dggeme710-chm.china.huawei.com (10.1.199.106) To dggeme755-chm.china.huawei.com (10.3.19.101) X-CFilter-Loop: Reflected Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org add Markus On 2020/11/10 2:09, Dongjiu Geng wrote: > Free memory mapping and free clk_data, if clock initialization > is not successful. > > Fixes: 75af25f581b1 ("clk: hisi: remove static variable") > Fixes: 62ac983b6141 ("clk: hisilicon: add hi3620_mmc_clks") > Signed-off-by: Dongjiu Geng > --- > drivers/clk/hisilicon/clk-hi3620.c | 8 ++++++-- > drivers/clk/hisilicon/clk.c | 11 ++++++----- > 2 files changed, 12 insertions(+), 7 deletions(-) > > diff --git a/drivers/clk/hisilicon/clk-hi3620.c b/drivers/clk/hisilicon/clk-hi3620.c > index a3d04c7c3da8..864d2ddfc73c 100644 > --- a/drivers/clk/hisilicon/clk-hi3620.c > +++ b/drivers/clk/hisilicon/clk-hi3620.c > @@ -464,11 +464,11 @@ static void __init hi3620_mmc_clk_init(struct device_node *node) > > clk_data = kzalloc(sizeof(*clk_data), GFP_KERNEL); > if (WARN_ON(!clk_data)) > - return; > + goto unmap_io; > > clk_data->clks = kcalloc(num, sizeof(*clk_data->clks), GFP_KERNEL); > if (!clk_data->clks) > - return; > + goto free_clk_data; > > for (i = 0; i < num; i++) { > struct hisi_mmc_clock *mmc_clk = &hi3620_mmc_clks[i]; > @@ -478,6 +478,10 @@ static void __init hi3620_mmc_clk_init(struct device_node *node) > > clk_data->clk_num = num; > of_clk_add_provider(node, of_clk_src_onecell_get, clk_data); > +free_clk_data: > + kfree(clk_data); > +unmap_io: > + iounmap(base); > } > > CLK_OF_DECLARE(hi3620_mmc_clk, "hisilicon,hi3620-mmc-clock", hi3620_mmc_clk_init); > diff --git a/drivers/clk/hisilicon/clk.c b/drivers/clk/hisilicon/clk.c > index 54d9fdc93599..da655683710f 100644 > --- a/drivers/clk/hisilicon/clk.c > +++ b/drivers/clk/hisilicon/clk.c > @@ -65,25 +65,26 @@ struct hisi_clock_data *hisi_clk_init(struct device_node *np, > base = of_iomap(np, 0); > if (!base) { > pr_err("%s: failed to map clock registers\n", __func__); > - goto err; > + return NULL; > } > > clk_data = kzalloc(sizeof(*clk_data), GFP_KERNEL); > if (!clk_data) > - goto err; > + goto unmap_io; > > clk_data->base = base; > clk_table = kcalloc(nr_clks, sizeof(*clk_table), GFP_KERNEL); > if (!clk_table) > - goto err_data; > + goto free_clk_data; > > clk_data->clk_data.clks = clk_table; > clk_data->clk_data.clk_num = nr_clks; > of_clk_add_provider(np, of_clk_src_onecell_get, &clk_data->clk_data); > return clk_data; > -err_data: > +free_clk_data: > kfree(clk_data); > -err: > +unmap_io: > + iounmap(base); > return NULL; > } > EXPORT_SYMBOL_GPL(hisi_clk_init); >