ip_tunnel: fix possible rtable leak
ip_rt_put(rt) is always called in "error" branches above, but was missed in skb_cow_head branch. As rt is not yet bound to skb here we have to release it by hand. Signed-off-by: Dmitry Popov <ixaphire@qrator.net> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
0dcceabb0c
commit
586d5fc867
1 changed files with 1 additions and 0 deletions
|
@ -668,6 +668,7 @@ void ip_tunnel_xmit(struct sk_buff *skb, struct net_device *dev,
|
||||||
dev->needed_headroom = max_headroom;
|
dev->needed_headroom = max_headroom;
|
||||||
|
|
||||||
if (skb_cow_head(skb, dev->needed_headroom)) {
|
if (skb_cow_head(skb, dev->needed_headroom)) {
|
||||||
|
ip_rt_put(rt);
|
||||||
dev->stats.tx_dropped++;
|
dev->stats.tx_dropped++;
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return;
|
return;
|
||||||
|
|
Loading…
Add table
Reference in a new issue