]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/commitdiff
mfd: Introduce missing kfree in 88pm860x probe routine
authorJulia Lawall <julia@diku.dk>
Fri, 23 Dec 2011 17:39:26 +0000 (18:39 +0100)
committerSamuel Ortiz <sameo@linux.intel.com>
Sun, 8 Jan 2012 23:37:47 +0000 (00:37 +0100)
Error handling code following a kzalloc should free the allocated data.  At
this point, chip has been allocated and some fields have been initialized,
but it has not been stored anywhere, so it should be freed before leaving
the function.

A simplified version of the semantic match that finds the problem is as
follows: (http://coccinelle.lip6.fr)

// <smpl>
@r exists@
local idexpression x;
statement S;
identifier f1;
position p1,p2;
expression *ptr != NULL;
@@

x@p1 = \(kmalloc\|kzalloc\|kcalloc\)(...);
...
if (x == NULL) S
<... when != x
     when != if (...) { <+...x...+> }
x->f1
...>
(
 return \(0\|<+...x...+>\|ptr\);
|
 return@p2 ...;
)

@script:python@
p1 << r.p1;
p2 << r.p2;
@@

print "* file: %s kmalloc %s return %s" % (p1[0].file,p1[0].line,p2[0].line)
// </smpl>

Signed-off-by: Julia Lawall <julia@diku.dk>
Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
drivers/mfd/88pm860x-i2c.c

index 630f1b545fc483322d37fd39feccecc338e418a6..f93dd9571c3c81e8b44f26dc51d54b0901039cd6 100644 (file)
@@ -286,6 +286,7 @@ static int __devinit pm860x_probe(struct i2c_client *client,
                ret = PTR_ERR(chip->regmap);
                dev_err(&client->dev, "Failed to allocate register map: %d\n",
                                ret);
+               kfree(chip);
                return ret;
        }
        chip->client = client;