mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-04-02 12:34:06 +00: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:
parent
de213e5eed
commit
d19d56ddc8
7 changed files with 34 additions and 34 deletions
|
@ -226,6 +226,26 @@ static inline void skb_dst_force(struct sk_buff *skb)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* skb_tunnel_rx - prepare skb for rx reinsert
|
||||||
|
* @skb: buffer
|
||||||
|
* @dev: tunnel device
|
||||||
|
*
|
||||||
|
* After decapsulation, packet is going to re-enter (netif_rx()) our stack,
|
||||||
|
* so make some cleanups, and perform accounting.
|
||||||
|
*/
|
||||||
|
static inline void skb_tunnel_rx(struct sk_buff *skb, struct net_device *dev)
|
||||||
|
{
|
||||||
|
skb->dev = dev;
|
||||||
|
/* TODO : stats should be SMP safe */
|
||||||
|
dev->stats.rx_packets++;
|
||||||
|
dev->stats.rx_bytes += skb->len;
|
||||||
|
skb->rxhash = 0;
|
||||||
|
skb_dst_drop(skb);
|
||||||
|
nf_reset(skb);
|
||||||
|
}
|
||||||
|
|
||||||
/* Children define the path of the packet through the
|
/* Children define the path of the packet through the
|
||||||
* Linux networking. Thus, destinations are stackable.
|
* Linux networking. Thus, destinations are stackable.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -538,7 +538,6 @@ static int ipgre_rcv(struct sk_buff *skb)
|
||||||
struct ip_tunnel *tunnel;
|
struct ip_tunnel *tunnel;
|
||||||
int offset = 4;
|
int offset = 4;
|
||||||
__be16 gre_proto;
|
__be16 gre_proto;
|
||||||
unsigned int len;
|
|
||||||
|
|
||||||
if (!pskb_may_pull(skb, 16))
|
if (!pskb_may_pull(skb, 16))
|
||||||
goto drop_nolock;
|
goto drop_nolock;
|
||||||
|
@ -629,8 +628,6 @@ static int ipgre_rcv(struct sk_buff *skb)
|
||||||
tunnel->i_seqno = seqno + 1;
|
tunnel->i_seqno = seqno + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
len = skb->len;
|
|
||||||
|
|
||||||
/* Warning: All skb pointers will be invalidated! */
|
/* Warning: All skb pointers will be invalidated! */
|
||||||
if (tunnel->dev->type == ARPHRD_ETHER) {
|
if (tunnel->dev->type == ARPHRD_ETHER) {
|
||||||
if (!pskb_may_pull(skb, ETH_HLEN)) {
|
if (!pskb_may_pull(skb, ETH_HLEN)) {
|
||||||
|
@ -644,11 +641,7 @@ static int ipgre_rcv(struct sk_buff *skb)
|
||||||
skb_postpull_rcsum(skb, eth_hdr(skb), ETH_HLEN);
|
skb_postpull_rcsum(skb, eth_hdr(skb), ETH_HLEN);
|
||||||
}
|
}
|
||||||
|
|
||||||
stats->rx_packets++;
|
skb_tunnel_rx(skb, tunnel->dev);
|
||||||
stats->rx_bytes += len;
|
|
||||||
skb->dev = tunnel->dev;
|
|
||||||
skb_dst_drop(skb);
|
|
||||||
nf_reset(skb);
|
|
||||||
|
|
||||||
skb_reset_network_header(skb);
|
skb_reset_network_header(skb);
|
||||||
ipgre_ecn_decapsulate(iph, skb);
|
ipgre_ecn_decapsulate(iph, skb);
|
||||||
|
|
|
@ -374,11 +374,8 @@ static int ipip_rcv(struct sk_buff *skb)
|
||||||
skb->protocol = htons(ETH_P_IP);
|
skb->protocol = htons(ETH_P_IP);
|
||||||
skb->pkt_type = PACKET_HOST;
|
skb->pkt_type = PACKET_HOST;
|
||||||
|
|
||||||
tunnel->dev->stats.rx_packets++;
|
skb_tunnel_rx(skb, tunnel->dev);
|
||||||
tunnel->dev->stats.rx_bytes += skb->len;
|
|
||||||
skb->dev = tunnel->dev;
|
|
||||||
skb_dst_drop(skb);
|
|
||||||
nf_reset(skb);
|
|
||||||
ipip_ecn_decapsulate(iph, skb);
|
ipip_ecn_decapsulate(iph, skb);
|
||||||
netif_rx(skb);
|
netif_rx(skb);
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
|
|
|
@ -1831,14 +1831,12 @@ static int __pim_rcv(struct mr_table *mrt, struct sk_buff *skb,
|
||||||
skb->mac_header = skb->network_header;
|
skb->mac_header = skb->network_header;
|
||||||
skb_pull(skb, (u8*)encap - skb->data);
|
skb_pull(skb, (u8*)encap - skb->data);
|
||||||
skb_reset_network_header(skb);
|
skb_reset_network_header(skb);
|
||||||
skb->dev = reg_dev;
|
|
||||||
skb->protocol = htons(ETH_P_IP);
|
skb->protocol = htons(ETH_P_IP);
|
||||||
skb->ip_summed = 0;
|
skb->ip_summed = 0;
|
||||||
skb->pkt_type = PACKET_HOST;
|
skb->pkt_type = PACKET_HOST;
|
||||||
skb_dst_drop(skb);
|
|
||||||
reg_dev->stats.rx_bytes += skb->len;
|
skb_tunnel_rx(skb, reg_dev);
|
||||||
reg_dev->stats.rx_packets++;
|
|
||||||
nf_reset(skb);
|
|
||||||
netif_rx(skb);
|
netif_rx(skb);
|
||||||
dev_put(reg_dev);
|
dev_put(reg_dev);
|
||||||
|
|
||||||
|
|
|
@ -723,14 +723,10 @@ static int ip6_tnl_rcv(struct sk_buff *skb, __u16 protocol,
|
||||||
skb->protocol = htons(protocol);
|
skb->protocol = htons(protocol);
|
||||||
skb->pkt_type = PACKET_HOST;
|
skb->pkt_type = PACKET_HOST;
|
||||||
memset(skb->cb, 0, sizeof(struct inet6_skb_parm));
|
memset(skb->cb, 0, sizeof(struct inet6_skb_parm));
|
||||||
skb->dev = t->dev;
|
|
||||||
skb_dst_drop(skb);
|
skb_tunnel_rx(skb, t->dev);
|
||||||
nf_reset(skb);
|
|
||||||
|
|
||||||
dscp_ecn_decapsulate(t, ipv6h, skb);
|
dscp_ecn_decapsulate(t, ipv6h, skb);
|
||||||
|
|
||||||
t->dev->stats.rx_packets++;
|
|
||||||
t->dev->stats.rx_bytes += skb->len;
|
|
||||||
netif_rx(skb);
|
netif_rx(skb);
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -658,14 +658,12 @@ static int pim6_rcv(struct sk_buff *skb)
|
||||||
skb->mac_header = skb->network_header;
|
skb->mac_header = skb->network_header;
|
||||||
skb_pull(skb, (u8 *)encap - skb->data);
|
skb_pull(skb, (u8 *)encap - skb->data);
|
||||||
skb_reset_network_header(skb);
|
skb_reset_network_header(skb);
|
||||||
skb->dev = reg_dev;
|
|
||||||
skb->protocol = htons(ETH_P_IPV6);
|
skb->protocol = htons(ETH_P_IPV6);
|
||||||
skb->ip_summed = 0;
|
skb->ip_summed = 0;
|
||||||
skb->pkt_type = PACKET_HOST;
|
skb->pkt_type = PACKET_HOST;
|
||||||
skb_dst_drop(skb);
|
|
||||||
reg_dev->stats.rx_bytes += skb->len;
|
skb_tunnel_rx(skb, reg_dev);
|
||||||
reg_dev->stats.rx_packets++;
|
|
||||||
nf_reset(skb);
|
|
||||||
netif_rx(skb);
|
netif_rx(skb);
|
||||||
dev_put(reg_dev);
|
dev_put(reg_dev);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -566,11 +566,9 @@ static int ipip6_rcv(struct sk_buff *skb)
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
tunnel->dev->stats.rx_packets++;
|
|
||||||
tunnel->dev->stats.rx_bytes += skb->len;
|
skb_tunnel_rx(skb, tunnel->dev);
|
||||||
skb->dev = tunnel->dev;
|
|
||||||
skb_dst_drop(skb);
|
|
||||||
nf_reset(skb);
|
|
||||||
ipip6_ecn_decapsulate(iph, skb);
|
ipip6_ecn_decapsulate(iph, skb);
|
||||||
netif_rx(skb);
|
netif_rx(skb);
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
|
|
Loading…
Add table
Reference in a new issue