[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <Pine.LNX.4.64.0909131749150.25903@ask.diku.dk>
Date: Sun, 13 Sep 2009 17:49:40 +0200 (CEST)
From: Julia Lawall <julia@...u.dk>
To: Atsushi Nemoto <anemo@....ocn.ne.jp>
Cc: ralf@...ux-mips.org, linux-mips@...ux-mips.org,
linux-kernel@...r.kernel.org, kernel-janitors@...r.kernel.org
Subject: Re: [PATCH 1/8] arch/mips/txx9: introduce missing kfree, iounmap
On Mon, 14 Sep 2009, Atsushi Nemoto wrote:
> On Sun, 13 Sep 2009 17:14:06 +0200 (CEST), Julia Lawall <julia@...u.dk> wrote:
> > > This patch add some correctness, but obviously incomplete: there are
> > > more error pathes without iounmap/kfree/etc. in this function.
> >
> > The only other error path that I see is:
> >
> > pdev = platform_device_alloc("leds-gpio", basenum);
> > if (!pdev)
> > return;
> >
> > But at that point the call gpiochip_add(&iocled->chip) has already
> > succeeded. From looking at this function, I have the impression that it
> > makes the iocled structure available from a global array, gpio_desc.
> > Since the function containing the above code doesn't return any error
> > code, perhaps the caller will not know whether this platform_device_alloc
> > error occurred or not. There would also be at least the problem of
> > getting the pointer out of the gpio_desc structure. I guess this could be
> > done with gpiochip_remove?
> >
> > I can certainly make a new patch using the goto style, but let me know
> > what to do about the above issue.
>
> Yes, this gpiochip is only used by leds-gpio driver. So
> gpiochip_remove() would be the right thing to do when something
> failed.
>
> Also there is one another error path: platform_device_add() failure at
> the end of this function.
OK, I see. I will submit an improved patch. Thanks for the explanations.
julia
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists