diff options
author | Julia Lawall <julia@diku.dk> | 2008-01-01 19:30:30 -0800 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-01-04 00:47:02 -0800 |
commit | 76975f8a3186dae501584d0155ea410464f62815 (patch) | |
tree | 265ed11c16755560e27f81a8e7ff2562031cfb58 /mm | |
parent | 304b46996ca1a989fe0fe99831ed38c79e855245 (diff) | |
download | lwn-76975f8a3186dae501584d0155ea410464f62815.tar.gz lwn-76975f8a3186dae501584d0155ea410464f62815.zip |
[X25]: Add missing x25_neigh_put
The function x25_get_neigh increments a reference count. At the point of
the second goto out, the result of calling x25_get_neigh is only stored in
a local variable, and thus no one outside the function will be able to
decrease the reference count. Thus, x25_neigh_put should be called before
the return in this case.
The problem was found using the following semantic match.
(http://www.emn.fr/x-info/coccinelle/)
// <smpl>
@@
type T,T1,T2;
identifier E;
statement S;
expression x1,x2,x3;
int ret;
@@
T E;
...
* if ((E = x25_get_neigh(...)) == NULL)
S
... when != x25_neigh_put(...,(T1)E,...)
when != if (E != NULL) { ... x25_neigh_put(...,(T1)E,...); ...}
when != x1 = (T1)E
when != E = x3;
when any
if (...) {
... when != x25_neigh_put(...,(T2)E,...)
when != if (E != NULL) { ... x25_neigh_put(...,(T2)E,...); ...}
when != x2 = (T2)E
(
* return;
|
* return ret;
)
}
// </smpl>
Signed-off-by: Julia Lawall <julia@diku.dk>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'mm')
0 files changed, 0 insertions, 0 deletions