diff options
author | Wei Yongjun <yongjun_wei@trendmicro.com.cn> | 2011-12-28 04:32:41 +0100 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2011-12-28 04:32:41 +0100 |
commit | aef950b4ba3196622a5bd5e21ab1d63f30658285 (patch) | |
tree | f4cb91f4517a041ef95c28ad50039b0b2ae6b137 /net/packet/af_packet.c | |
parent | Merge branch 'nf' of git://1984.lsi.us.es/net (diff) | |
download | linux-aef950b4ba3196622a5bd5e21ab1d63f30658285.tar.xz linux-aef950b4ba3196622a5bd5e21ab1d63f30658285.zip |
packet: fix possible dev refcnt leak when bind fail
If bind is fail when bind is called after set PACKET_FANOUT
sock option, the dev refcnt will leak.
Signed-off-by: Wei Yongjun <yongjun_wei@trendmicro.com.cn>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to '')
-rw-r--r-- | net/packet/af_packet.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c index 3891702b81df..d9d4970b9b07 100644 --- a/net/packet/af_packet.c +++ b/net/packet/af_packet.c @@ -2448,8 +2448,12 @@ static int packet_do_bind(struct sock *sk, struct net_device *dev, __be16 protoc { struct packet_sock *po = pkt_sk(sk); - if (po->fanout) + if (po->fanout) { + if (dev) + dev_put(dev); + return -EINVAL; + } lock_sock(sk); |