On Wed, 2011-06-01 at 19:10 +0200, Julia Lawall wrote: > From: Julia Lawall <julia@xxxxxxx> > > Jump to the end of the function for the clk_disable and clk_put rather than > returning directly. > > A simplified version of the semantic match that finds this problem is as > follows: (http://coccinelle.lip6.fr/) > > // <smpl> > @r exists@ > expression e1,e2; > statement S; > @@ > > e1 = clk_get@p1(...); > ... when != e1 = e2 > when != clk_put(e1) > when any > if (...) { ... when != clk_put(e1) > when != if (...) { ... clk_put(e1) ... } > * return@p3 ...; > } else S > // </smpl> > > Signed-off-by: Julia Lawall <julia@xxxxxxx> This one also looks good to me. Signed-off-by: Matt Mackall <mpm@xxxxxxxxxxx> > --- > drivers/char/hw_random/nomadik-rng.c | 3 ++- > 1 file changed, 2 insertions(+), 1 deletion(-) > > diff --git a/drivers/char/hw_random/nomadik-rng.c b/drivers/char/hw_random/nomadik-rng.c > index dd1d143..52e08ca 100644 > --- a/drivers/char/hw_random/nomadik-rng.c > +++ b/drivers/char/hw_random/nomadik-rng.c > @@ -55,7 +55,7 @@ static int nmk_rng_probe(struct amba_device *dev, const struct amba_id *id) > > ret = amba_request_regions(dev, dev->dev.init_name); > if (ret) > - return ret; > + goto out_clk; > ret = -ENOMEM; > base = ioremap(dev->res.start, resource_size(&dev->res)); > if (!base) > @@ -70,6 +70,7 @@ out_unmap: > iounmap(base); > out_release: > amba_release_regions(dev); > +out_clk: > clk_disable(rng_clk); > clk_put(rng_clk); > return ret; > > -- > To unsubscribe from this list: send the line "unsubscribe linux-kernel" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html > Please read the FAQ at http://www.tux.org/lkml/ -- Mathematics is the supreme nostalgia of our time. -- To unsubscribe from this list: send the line "unsubscribe kernel-janitors" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html