diff options
| author | Julia Lawall <julia@diku.dk> | 2010-08-28 06:31:56 +0400 | 
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2010-08-28 06:31:56 +0400 | 
| commit | c34186ed008229e7f7e3f1de8e6acf6374995358 (patch) | |
| tree | b8d24a6503fc847d7dd1fa55b73aa9ca45781730 /tools/perf/scripts/python/check-perf-trace.py | |
| parent | 7e368739e3b3f1d7944794c178a15f05829b56bc (diff) | |
| download | linux-c34186ed008229e7f7e3f1de8e6acf6374995358.tar.xz | |
net/ipv4: Eliminate kstrdup memory leak
The string clone is only used as a temporary copy of the argument val
within the while loop, and so it should be freed before leaving the
function.  The call to strsep, however, modifies clone, so a pointer to the
front of the string is kept in saved_clone, to make it possible to free it.
The sematic match that finds this problem is as follows:
(http://coccinelle.lip6.fr/)
// <smpl>
@r exists@
local idexpression x;
expression E;
identifier l;
statement S;
@@
*x= \(kasprintf\|kstrdup\)(...);
...
if (x == NULL) S
... when != kfree(x)
    when != E = x
if (...) {
  <... when != kfree(x)
* goto l;
  ...>
* return ...;
}
// </smpl>
Signed-off-by: Julia Lawall <julia@diku.dk>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'tools/perf/scripts/python/check-perf-trace.py')
0 files changed, 0 insertions, 0 deletions
