drivers/staging/ath6kl/os/linux/cfg80211.c: Add missing call to cfg80211_put_bss
commitd93089df1b752e4da048cd7f4749d29120b65e55
authorJulia Lawall <julia@diku.dk>
Mon, 16 May 2011 09:20:29 +0000 (16 11:20 +0200)
committerGreg Kroah-Hartman <gregkh@suse.de>
Tue, 17 May 2011 20:31:31 +0000 (17 13:31 -0700)
treecd9f5f0985a838fc61fb9192d5b5d6b632b7a0cd
parentaacd531df9b88f7419e22708f72a476030863efe
drivers/staging/ath6kl/os/linux/cfg80211.c: Add missing call to cfg80211_put_bss

A call to cfg80211_get_bss hould be accompanied by a call to
cfg80211_put_bss in error-handling code.

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

// <smpl>
@r exists@
local idexpression struct cfg80211_bss * x;
expression ra,rr;
position p1,p2;
@@

x = cfg80211_get_bss@p1(...)
...  when != x = rr
     when != cfg80211_put_bss(x,...)
     when != if (...) { ... cfg80211_put_bss(x,...) ...}
if(...) { ... when != x = ra
     when forall
     when != cfg80211_put_bss(x,...)
 \(return <+...x...+>; \| return@p2...; \) }

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

cocci.print_main("cfg80211_get_bss",p1)
cocci.print_secs("return",p2)

// </smpl>

Signed-off-by: Julia Lawall <julia@diku.dk>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/staging/ath6kl/os/linux/cfg80211.c