提交 181a4224 编写于 作者: J Jiri Benc 提交者: David S. Miller

ipv4: fix reply_dst leakage on arp reply

There are cases when the created metadata reply is not used. Ensure the
allocated memory is freed also in such cases.

Fixes: 63d008a4 ("ipv4: send arp replies to the correct tunnel")
Reported-by: NHannes Frederic Sowa <hannes@stressinduktion.org>
Signed-off-by: NJiri Benc <jbenc@redhat.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 2306c704
...@@ -312,7 +312,7 @@ static void arp_send_dst(int type, int ptype, __be32 dest_ip, ...@@ -312,7 +312,7 @@ static void arp_send_dst(int type, int ptype, __be32 dest_ip,
if (!skb) if (!skb)
return; return;
skb_dst_set(skb, dst); skb_dst_set(skb, dst_clone(dst));
arp_xmit(skb); arp_xmit(skb);
} }
...@@ -384,7 +384,7 @@ static void arp_solicit(struct neighbour *neigh, struct sk_buff *skb) ...@@ -384,7 +384,7 @@ static void arp_solicit(struct neighbour *neigh, struct sk_buff *skb)
} }
if (skb && !(dev->priv_flags & IFF_XMIT_DST_RELEASE)) if (skb && !(dev->priv_flags & IFF_XMIT_DST_RELEASE))
dst = dst_clone(skb_dst(skb)); dst = skb_dst(skb);
arp_send_dst(ARPOP_REQUEST, ETH_P_ARP, target, dev, saddr, arp_send_dst(ARPOP_REQUEST, ETH_P_ARP, target, dev, saddr,
dst_hw, dev->dev_addr, NULL, dst); dst_hw, dev->dev_addr, NULL, dst);
} }
...@@ -811,7 +811,7 @@ static int arp_process(struct sock *sk, struct sk_buff *skb) ...@@ -811,7 +811,7 @@ static int arp_process(struct sock *sk, struct sk_buff *skb)
} else { } else {
pneigh_enqueue(&arp_tbl, pneigh_enqueue(&arp_tbl,
in_dev->arp_parms, skb); in_dev->arp_parms, skb);
return 0; goto out_free_dst;
} }
goto out; goto out;
} }
...@@ -865,6 +865,8 @@ static int arp_process(struct sock *sk, struct sk_buff *skb) ...@@ -865,6 +865,8 @@ static int arp_process(struct sock *sk, struct sk_buff *skb)
out: out:
consume_skb(skb); consume_skb(skb);
out_free_dst:
dst_release(reply_dst);
return 0; return 0;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册