[U-Boot] [PATCH] pinctrl: imx: fix memory leak

Peng Fan peng.fan at nxp.com
Thu May 11 09:19:23 UTC 2017



> -----Original Message-----
> From: Jagan Teki [mailto:jagannadh.teki at gmail.com]
> Sent: Thursday, May 11, 2017 5:18 PM
> To: Peng Fan <peng.fan at nxp.com>
> Cc: Simon Glass <sjg at chromium.org>; u-boot at lists.denx.de; Stefan Agner
> <stefan.agner at toradex.com>
> Subject: Re: [U-Boot] [PATCH] pinctrl: imx: fix memory leak
> 
> On Thu, May 11, 2017 at 8:13 AM, Peng Fan <peng.fan at nxp.com> wrote:
> > Each time set_state is called, a new piece memory will be allocated
> > for pin_data, but not freed, this will incur memory leak.
> >
> > When error, the devm API could not free memory automatically.
> > So need call devm_kfree when error.
> >
> > Issue reported by Coverity
> >
> > Signed-off-by: Peng Fan <peng.fan at nxp.com>
> > Cc: Simon Glass <sjg at chromium.org>
> > Cc: Stefan Agner <stefan.agner at toradex.com>
> > Cc: Stefano Babic <sbabic at denx.de>
> > ---
> >  drivers/pinctrl/nxp/pinctrl-imx.c | 4 ++++
> >  1 file changed, 4 insertions(+)
> >
> > diff --git a/drivers/pinctrl/nxp/pinctrl-imx.c
> > b/drivers/pinctrl/nxp/pinctrl-imx.c
> > index f0321c4..31a28e1 100644
> > --- a/drivers/pinctrl/nxp/pinctrl-imx.c
> > +++ b/drivers/pinctrl/nxp/pinctrl-imx.c
> > @@ -53,6 +53,7 @@ static int imx_pinctrl_set_state(struct udevice *dev,
> struct udevice *config)
> >         if (fdtdec_get_int_array(gd->fdt_blob, node, "fsl,pins",
> >                                  pin_data, size >> 2)) {
> >                 dev_err(dev, "Error reading pin data.\n");
> > +               devm_kfree(pin_data);
> 
> we need to specify the pointer from where to free?

Oh. Missed to add dev pointer here.

Thanks,
Peng.

> 
> thanks!
> --
> Jagan Teki
> Free Software Engineer | www.openedev.com U-Boot, Linux | Upstream
> Maintainer Hyderabad, India.


More information about the U-Boot mailing list