You've already forked linux-apfs
mirror of
https://github.com/linux-apfs/linux-apfs.git
synced 2026-05-01 15:00:59 -07:00
net: Introduce skb_tunnel_rx() helper
skb rxhash should be cleared when a skb is handled by a tunnel before being delivered again, so that correct packet steering can take place. There are other cleanups and accounting that we can factorize in a new helper, skb_tunnel_rx() Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
de213e5eed
commit
d19d56ddc8
@@ -723,14 +723,10 @@ static int ip6_tnl_rcv(struct sk_buff *skb, __u16 protocol,
|
||||
skb->protocol = htons(protocol);
|
||||
skb->pkt_type = PACKET_HOST;
|
||||
memset(skb->cb, 0, sizeof(struct inet6_skb_parm));
|
||||
skb->dev = t->dev;
|
||||
skb_dst_drop(skb);
|
||||
nf_reset(skb);
|
||||
|
||||
skb_tunnel_rx(skb, t->dev);
|
||||
|
||||
dscp_ecn_decapsulate(t, ipv6h, skb);
|
||||
|
||||
t->dev->stats.rx_packets++;
|
||||
t->dev->stats.rx_bytes += skb->len;
|
||||
netif_rx(skb);
|
||||
rcu_read_unlock();
|
||||
return 0;
|
||||
|
||||
+3
-5
@@ -658,14 +658,12 @@ static int pim6_rcv(struct sk_buff *skb)
|
||||
skb->mac_header = skb->network_header;
|
||||
skb_pull(skb, (u8 *)encap - skb->data);
|
||||
skb_reset_network_header(skb);
|
||||
skb->dev = reg_dev;
|
||||
skb->protocol = htons(ETH_P_IPV6);
|
||||
skb->ip_summed = 0;
|
||||
skb->pkt_type = PACKET_HOST;
|
||||
skb_dst_drop(skb);
|
||||
reg_dev->stats.rx_bytes += skb->len;
|
||||
reg_dev->stats.rx_packets++;
|
||||
nf_reset(skb);
|
||||
|
||||
skb_tunnel_rx(skb, reg_dev);
|
||||
|
||||
netif_rx(skb);
|
||||
dev_put(reg_dev);
|
||||
return 0;
|
||||
|
||||
+3
-5
@@ -566,11 +566,9 @@ static int ipip6_rcv(struct sk_buff *skb)
|
||||
kfree_skb(skb);
|
||||
return 0;
|
||||
}
|
||||
tunnel->dev->stats.rx_packets++;
|
||||
tunnel->dev->stats.rx_bytes += skb->len;
|
||||
skb->dev = tunnel->dev;
|
||||
skb_dst_drop(skb);
|
||||
nf_reset(skb);
|
||||
|
||||
skb_tunnel_rx(skb, tunnel->dev);
|
||||
|
||||
ipip6_ecn_decapsulate(iph, skb);
|
||||
netif_rx(skb);
|
||||
rcu_read_unlock();
|
||||
|
||||
Reference in New Issue
Block a user