diff options
| -rw-r--r-- | net/core/filter.c | 13 | 
1 files changed, 10 insertions, 3 deletions
| diff --git a/net/core/filter.c b/net/core/filter.c index 5708999f8a79..c46244f83a8f 100644 --- a/net/core/filter.c +++ b/net/core/filter.c @@ -1365,6 +1365,12 @@ static inline int bpf_try_make_writable(struct sk_buff *skb,  	return err;  } +static inline void bpf_push_mac_rcsum(struct sk_buff *skb) +{ +	if (skb_at_tc_ingress(skb)) +		skb_postpush_rcsum(skb, skb_mac_header(skb), skb->mac_len); +} +  static u64 bpf_skb_store_bytes(u64 r1, u64 r2, u64 r3, u64 r4, u64 flags)  {  	struct bpf_scratchpad *sp = this_cpu_ptr(&bpf_sp); @@ -1607,9 +1613,6 @@ static const struct bpf_func_proto bpf_csum_diff_proto = {  static inline int __bpf_rx_skb(struct net_device *dev, struct sk_buff *skb)  { -	if (skb_at_tc_ingress(skb)) -		skb_postpush_rcsum(skb, skb_mac_header(skb), skb->mac_len); -  	return dev_forward_skb(dev, skb);  } @@ -1648,6 +1651,8 @@ static u64 bpf_clone_redirect(u64 r1, u64 ifindex, u64 flags, u64 r4, u64 r5)  	if (unlikely(!skb))  		return -ENOMEM; +	bpf_push_mac_rcsum(skb); +  	return flags & BPF_F_INGRESS ?  	       __bpf_rx_skb(dev, skb) : __bpf_tx_skb(dev, skb);  } @@ -1693,6 +1698,8 @@ int skb_do_redirect(struct sk_buff *skb)  		return -EINVAL;  	} +	bpf_push_mac_rcsum(skb); +  	return ri->flags & BPF_F_INGRESS ?  	       __bpf_rx_skb(dev, skb) : __bpf_tx_skb(dev, skb);  } | 
