diff options
author | Tom Herbert <therbert@google.com> | 2014-08-31 18:12:42 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-09-02 00:36:27 -0400 |
commit | d96535a17dbbafd567961d14c08c0984ddda9c3c (patch) | |
tree | aa07db9a2ef6ea095f7b38ec3be18c92d4f55506 /include/linux | |
parent | 5a21232983aa7acfe7fd26170832a9e0a4a7b4ae (diff) |
net: Infrastructure for checksum unnecessary conversions
For normal path, added skb_checksum_try_convert which is called
to attempt to convert CHECKSUM_UNNECESSARY to CHECKSUM_COMPLETE. The
primary condition to allow this is that ip_summed is CHECKSUM_NONE
and csum_valid is true, which will be the state after consuming
a CHECKSUM_UNNECESSARY.
For GRO path, added skb_gro_checksum_try_convert which is the GRO
analogue of skb_checksum_try_convert. The primary condition to allow
this is that NAPI_GRO_CB(skb)->csum_cnt == 0 and
NAPI_GRO_CB(skb)->csum_valid is set. This implies that we have consumed
all available CHECKSUM_UNNECESSARY checksums in the GRO path.
Signed-off-by: Tom Herbert <therbert@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/linux')
-rw-r--r-- | include/linux/netdevice.h | 20 | ||||
-rw-r--r-- | include/linux/skbuff.h | 20 |
2 files changed, 40 insertions, 0 deletions
diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h index a0ab6d9d400a..5be20a7bbb0d 100644 --- a/include/linux/netdevice.h +++ b/include/linux/netdevice.h | |||
@@ -2233,6 +2233,26 @@ static inline void skb_gro_incr_csum_unnecessary(struct sk_buff *skb) | |||
2233 | #define skb_gro_checksum_simple_validate(skb) \ | 2233 | #define skb_gro_checksum_simple_validate(skb) \ |
2234 | __skb_gro_checksum_validate(skb, 0, false, 0, null_compute_pseudo) | 2234 | __skb_gro_checksum_validate(skb, 0, false, 0, null_compute_pseudo) |
2235 | 2235 | ||
2236 | static inline bool __skb_gro_checksum_convert_check(struct sk_buff *skb) | ||
2237 | { | ||
2238 | return (NAPI_GRO_CB(skb)->csum_cnt == 0 && | ||
2239 | !NAPI_GRO_CB(skb)->csum_valid); | ||
2240 | } | ||
2241 | |||
2242 | static inline void __skb_gro_checksum_convert(struct sk_buff *skb, | ||
2243 | __sum16 check, __wsum pseudo) | ||
2244 | { | ||
2245 | NAPI_GRO_CB(skb)->csum = ~pseudo; | ||
2246 | NAPI_GRO_CB(skb)->csum_valid = 1; | ||
2247 | } | ||
2248 | |||
2249 | #define skb_gro_checksum_try_convert(skb, proto, check, compute_pseudo) \ | ||
2250 | do { \ | ||
2251 | if (__skb_gro_checksum_convert_check(skb)) \ | ||
2252 | __skb_gro_checksum_convert(skb, check, \ | ||
2253 | compute_pseudo(skb, proto)); \ | ||
2254 | } while (0) | ||
2255 | |||
2236 | static inline int dev_hard_header(struct sk_buff *skb, struct net_device *dev, | 2256 | static inline int dev_hard_header(struct sk_buff *skb, struct net_device *dev, |
2237 | unsigned short type, | 2257 | unsigned short type, |
2238 | const void *daddr, const void *saddr, | 2258 | const void *daddr, const void *saddr, |
diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h index 23710a243439..02529fcad1ac 100644 --- a/include/linux/skbuff.h +++ b/include/linux/skbuff.h | |||
@@ -2942,6 +2942,26 @@ static inline __wsum null_compute_pseudo(struct sk_buff *skb, int proto) | |||
2942 | #define skb_checksum_simple_validate(skb) \ | 2942 | #define skb_checksum_simple_validate(skb) \ |
2943 | __skb_checksum_validate(skb, 0, true, false, 0, null_compute_pseudo) | 2943 | __skb_checksum_validate(skb, 0, true, false, 0, null_compute_pseudo) |
2944 | 2944 | ||
2945 | static inline bool __skb_checksum_convert_check(struct sk_buff *skb) | ||
2946 | { | ||
2947 | return (skb->ip_summed == CHECKSUM_NONE && | ||
2948 | skb->csum_valid && !skb->csum_bad); | ||
2949 | } | ||
2950 | |||
2951 | static inline void __skb_checksum_convert(struct sk_buff *skb, | ||
2952 | __sum16 check, __wsum pseudo) | ||
2953 | { | ||
2954 | skb->csum = ~pseudo; | ||
2955 | skb->ip_summed = CHECKSUM_COMPLETE; | ||
2956 | } | ||
2957 | |||
2958 | #define skb_checksum_try_convert(skb, proto, check, compute_pseudo) \ | ||
2959 | do { \ | ||
2960 | if (__skb_checksum_convert_check(skb)) \ | ||
2961 | __skb_checksum_convert(skb, check, \ | ||
2962 | compute_pseudo(skb, proto)); \ | ||
2963 | } while (0) | ||
2964 | |||
2945 | #if defined(CONFIG_NF_CONNTRACK) || defined(CONFIG_NF_CONNTRACK_MODULE) | 2965 | #if defined(CONFIG_NF_CONNTRACK) || defined(CONFIG_NF_CONNTRACK_MODULE) |
2946 | void nf_conntrack_destroy(struct nf_conntrack *nfct); | 2966 | void nf_conntrack_destroy(struct nf_conntrack *nfct); |
2947 | static inline void nf_conntrack_put(struct nf_conntrack *nfct) | 2967 | static inline void nf_conntrack_put(struct nf_conntrack *nfct) |