From: Sabrina Dubroca Date: Mon, 16 Nov 2015 21:54:20 +0000 (+0100) Subject: macvlan: fix leak in macvlan_handle_frame X-Git-Tag: v3.16.35~911 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=9d21c8322280613cfb27a583205045d70b2941b2;p=thirdparty%2Fkernel%2Fstable.git macvlan: fix leak in macvlan_handle_frame commit e639b8d8a7a728f0b05ef2df6cb6b45dc3d4e556 upstream. Reset pskb in macvlan_handle_frame in case skb_share_check returned a clone. Fixes: 8a4eb5734e8d ("net: introduce rx_handler results and logic around that") Signed-off-by: Sabrina Dubroca Signed-off-by: David S. Miller Signed-off-by: Luis Henriques --- diff --git a/drivers/net/macvlan.c b/drivers/net/macvlan.c index d4404e4cad41a..bb33b0410a228 100644 --- a/drivers/net/macvlan.c +++ b/drivers/net/macvlan.c @@ -284,6 +284,7 @@ static rx_handler_result_t macvlan_handle_frame(struct sk_buff **pskb) skb = ip_check_defrag(skb, IP_DEFRAG_MACVLAN); if (!skb) return RX_HANDLER_CONSUMED; + *pskb = skb; eth = eth_hdr(skb); src = macvlan_hash_lookup(port, eth->h_source); if (src && src->mode != MACVLAN_MODE_VEPA && @@ -319,6 +320,7 @@ static rx_handler_result_t macvlan_handle_frame(struct sk_buff **pskb) if (!skb) goto out; + *pskb = skb; skb->dev = dev; skb->pkt_type = PACKET_HOST;