diff options
author | Alexander Duyck <aduyck@mirantis.com> | 2016-02-06 00:27:55 +0100 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2016-02-11 14:55:34 +0100 |
commit | ddff00d420432d54eb420bb33034bb8e22dd2543 (patch) | |
tree | fa2c13ae3708f32259da676c3b2c750e7ead8572 /net/core/skbuff.c | |
parent | net: Store checksum result for offloaded GSO checksums (diff) | |
download | linux-ddff00d420432d54eb420bb33034bb8e22dd2543.tar.xz linux-ddff00d420432d54eb420bb33034bb8e22dd2543.zip |
net: Move skb_has_shared_frag check out of GRE code and into segmentation
The call skb_has_shared_frag is used in the GRE path and skb_checksum_help
to verify that no frags can be modified by an external entity. This check
really doesn't belong in the GRE path but in the skb_segment function
itself. This way any protocol that might be segmented will be performing
this check before attempting to offload a checksum to software.
Signed-off-by: Alexander Duyck <aduyck@mirantis.com>
Acked-by: Tom Herbert <tom@herbertland.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/core/skbuff.c')
-rw-r--r-- | net/core/skbuff.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/net/core/skbuff.c b/net/core/skbuff.c index 9c065ac72e87..88262c82b96a 100644 --- a/net/core/skbuff.c +++ b/net/core/skbuff.c @@ -3173,6 +3173,11 @@ skip_fraglist: perform_csum_check: if (!csum) { + if (skb_has_shared_frag(nskb)) { + err = __skb_linearize(nskb); + if (err) + goto err; + } if (!nskb->remcsum_offload) nskb->ip_summed = CHECKSUM_NONE; SKB_GSO_CB(nskb)->csum = |