浏览代码

xfrm: Verify MAC header exists before overwriting eth_hdr(skb)->h_proto

Artem Savkov reported that commit 5efec5c655dd leads to a packet loss under
IPSec configuration. It appears that his setup consists of a TUN device,
which does not have a MAC header.

Make sure MAC header exists.

Note: TUN device sets a MAC header pointer, although it does not have one.

Fixes: 5efec5c655dd ("xfrm: Fix eth_hdr(skb)->h_proto to reflect inner IP version")
Reported-by: Artem Savkov <artem.savkov@gmail.com>
Tested-by: Artem Savkov <artem.savkov@gmail.com>
Signed-off-by: Yossi Kuperman <yossiku@mellanox.com>
Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com>
Yossi Kuperman 7 年之前
父节点
当前提交
87cdf3148b
共有 2 个文件被更改,包括 4 次插入2 次删除
  1. 2 1
      net/ipv4/xfrm4_mode_tunnel.c
  2. 2 1
      net/ipv6/xfrm6_mode_tunnel.c

+ 2 - 1
net/ipv4/xfrm4_mode_tunnel.c

@@ -92,7 +92,8 @@ static int xfrm4_mode_tunnel_input(struct xfrm_state *x, struct sk_buff *skb)
 
 
 	skb_reset_network_header(skb);
 	skb_reset_network_header(skb);
 	skb_mac_header_rebuild(skb);
 	skb_mac_header_rebuild(skb);
-	eth_hdr(skb)->h_proto = skb->protocol;
+	if (skb->mac_len)
+		eth_hdr(skb)->h_proto = skb->protocol;
 
 
 	err = 0;
 	err = 0;
 
 

+ 2 - 1
net/ipv6/xfrm6_mode_tunnel.c

@@ -92,7 +92,8 @@ static int xfrm6_mode_tunnel_input(struct xfrm_state *x, struct sk_buff *skb)
 
 
 	skb_reset_network_header(skb);
 	skb_reset_network_header(skb);
 	skb_mac_header_rebuild(skb);
 	skb_mac_header_rebuild(skb);
-	eth_hdr(skb)->h_proto = skb->protocol;
+	if (skb->mac_len)
+		eth_hdr(skb)->h_proto = skb->protocol;
 
 
 	err = 0;
 	err = 0;