Skip to content

Commit 2853af6

Browse files
congwang1986davem330
authored andcommitted
vxlan: use dev->needed_headroom instead of dev->hard_header_len
When we mirror packets from a vxlan tunnel to other device, the mirror device should see the same packets (that is, without outer header). Because vxlan tunnel sets dev->hard_header_len, tcf_mirred() resets mac header back to outer mac, the mirror device actually sees packets with outer headers Vxlan tunnel should set dev->needed_headroom instead of dev->hard_header_len, like what other ip tunnels do. This fixes the above problem. Cc: "David S. Miller" <davem@davemloft.net> Cc: stephen hemminger <stephen@networkplumber.org> Cc: Pravin B Shelar <pshelar@nicira.com> Signed-off-by: Cong Wang <cwang@twopensource.com> Signed-off-by: Cong Wang <xiyou.wangcong@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
1 parent 56f16c7 commit 2853af6

File tree

1 file changed

+3
-4
lines changed

1 file changed

+3
-4
lines changed

drivers/net/vxlan.c

Lines changed: 3 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -2247,9 +2247,9 @@ static void vxlan_setup(struct net_device *dev)
22472247
eth_hw_addr_random(dev);
22482248
ether_setup(dev);
22492249
if (vxlan->default_dst.remote_ip.sa.sa_family == AF_INET6)
2250-
dev->hard_header_len = ETH_HLEN + VXLAN6_HEADROOM;
2250+
dev->needed_headroom = ETH_HLEN + VXLAN6_HEADROOM;
22512251
else
2252-
dev->hard_header_len = ETH_HLEN + VXLAN_HEADROOM;
2252+
dev->needed_headroom = ETH_HLEN + VXLAN_HEADROOM;
22532253

22542254
dev->netdev_ops = &vxlan_netdev_ops;
22552255
dev->destructor = free_netdev;
@@ -2646,8 +2646,7 @@ static int vxlan_newlink(struct net *net, struct net_device *dev,
26462646
if (!tb[IFLA_MTU])
26472647
dev->mtu = lowerdev->mtu - (use_ipv6 ? VXLAN6_HEADROOM : VXLAN_HEADROOM);
26482648

2649-
/* update header length based on lower device */
2650-
dev->hard_header_len = lowerdev->hard_header_len +
2649+
dev->needed_headroom = lowerdev->hard_header_len +
26512650
(use_ipv6 ? VXLAN6_HEADROOM : VXLAN_HEADROOM);
26522651
} else if (use_ipv6)
26532652
vxlan->flags |= VXLAN_F_IPV6;

0 commit comments

Comments
 (0)