]> git.karo-electronics.de Git - karo-tx-linux.git/commit
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)
commite3380333b8fdaad07d53953c1831b90d9cc23821
treef84d1c99bbdaff0e4f92d1bc260266d68933d5ca
parentc3d4d697346e36304a94942ad8ed3e28a0d38a44
mfd: Introduce missing kfree in 88pm860x probe routine

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