From: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
To: Arvind Yadav <arvind.yadav.cs@gmail.com>
Cc: mturquette@baylibre.com, sboyd@codeaurora.org,
geert+renesas@glider.be, horms+renesas@verge.net.au,
ulf.hansson@linaro.org, linux-clk@vger.kernel.org,
linux-kernel@vger.kernel.org
Subject: Re: [PATCH] clk: renesas: clk-mstp: Free memory and Unmap region obtained by kzalloc and of_iomap
Date: Tue, 20 Sep 2016 15:49:03 +0300 [thread overview]
Message-ID: <21075147.gpvqaLID3A@avalon> (raw)
In-Reply-To: <1474375159-16568-1-git-send-email-arvind.yadav.cs@gmail.com>
HI Arvind,
Thank you for the patch.
On Tuesday 20 Sep 2016 18:09:19 Arvind Yadav wrote:
> From: Arvind Yadav <arvind.yadav.cs@gmail.com>
>
> Free memory and memory mapping , if cpg_mstp_clocks_init is not successful.
>
> Signed-off-by: Arvind Yadav <arvind.yadav.cs@gmail.com>
> ---
> drivers/clk/renesas/clk-mstp.c | 14 ++++++++++++--
> 1 file changed, 12 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/clk/renesas/clk-mstp.c b/drivers/clk/renesas/clk-mstp.c
> index 5093a25..19e73c8 100644
> --- a/drivers/clk/renesas/clk-mstp.c
> +++ b/drivers/clk/renesas/clk-mstp.c
> @@ -179,14 +179,20 @@ static void __init cpg_mstp_clocks_init(struct
> device_node *np) group->data.clks = clks;
>
> group->smstpcr = of_iomap(np, 0);
> - group->mstpsr = of_iomap(np, 1);
> -
> if (group->smstpcr == NULL) {
> pr_err("%s: failed to remap SMSTPCR\n", __func__);
> kfree(group);
> kfree(clks);
> return;
> }
> + group->mstpsr = of_iomap(np, 1);
> + if (group->mstpsr == NULL) {
> + pr_err("%s: failed to remap MSTPCR\n", __func__);
> + iounmap(group->smstpcr);
> + kfree(group);
> + kfree(clks);
> + return;
If you really want to do this (and I don't think that's worth it, an error
here will render the system completely unbootable anyway, I'd rather remove
the kfree() calls), you can test both group->smstpcr and group->mstpsr in a
single go, with a single error path. You can then call iounmap() on both
variables in the error path, either unconditionally if iounmap() is safe to be
called on NULL pointers (to be checked, I haven't verified that personally),
or conditionally based on the pointer value.
> + }
>
> for (i = 0; i < MSTP_MAX_CLOCKS; ++i)
> clks[i] = ERR_PTR(-ENOENT);
> @@ -236,6 +242,10 @@ static void __init cpg_mstp_clocks_init(struct
> device_node *np) } else {
> pr_err("%s: failed to register %s %s clock (%ld)\n",
> __func__, np->name, name,
PTR_ERR(clks[clkidx]));
> + iounmap(group->smstpcr);
> + iounmap(group->mstpsr);
> + kfree(group);
> + kfree(clks);
This is wrong, a single clock failing to be registered is not a fatal error,
and should not free resources used by all other clocks in the group.
> }
> }
--
Regards,
Laurent Pinchart
prev parent reply other threads:[~2016-09-20 12:49 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-09-20 12:39 [PATCH] clk: renesas: clk-mstp: Free memory and Unmap region obtained by kzalloc and of_iomap Arvind Yadav
2016-09-20 12:49 ` Laurent Pinchart [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=21075147.gpvqaLID3A@avalon \
--to=laurent.pinchart@ideasonboard.com \
--cc=arvind.yadav.cs@gmail.com \
--cc=geert+renesas@glider.be \
--cc=horms+renesas@verge.net.au \
--cc=linux-clk@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mturquette@baylibre.com \
--cc=sboyd@codeaurora.org \
--cc=ulf.hansson@linaro.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.