On Thu, Sep 27, 2007 at 03:16:48PM +0200, Patrick McHardy ([EMAIL PROTECTED]) wrote: > Evgeniy Polyakov wrote: > > +static inline void nf_proto_csum_replace4(__sum16 *sum, struct sk_buff > > *skb, > > + __be32 from, __be32 to, int pseudohdr) > > +{ > > + __be32 diff[] = { ~from, to }; > > + if (skb->ip_summed != CHECKSUM_PARTIAL) { > > + *sum = csum_fold(csum_partial(diff, sizeof(diff), > > + ~csum_unfold(*sum))); > > + if (skb->ip_summed == CHECKSUM_COMPLETE && pseudohdr) > > + skb->csum = ~csum_partial(diff, sizeof(diff), > > + ~skb->csum); > > + } else if (pseudohdr) > > + *sum = ~csum_fold(csum_partial(diff, sizeof(diff), > > + csum_unfold(*sum))); > > +} > > + > > +static inline void nf_proto_csum_replace2(__sum16 *sum, struct sk_buff > > *skb, > > + __be16 from, __be16 to, int pseudohdr) > > +{ > > + nf_proto_csum_replace4(sum, skb, (__force __be32)from, > > + (__force __be32)to, pseudohdr); > > +} > > > These are way too large to get inlined, please move somewhere below > net/core.
I knew that... :) I'm pretty sure new files called net/core/helpers.c which will host that helper is not a good solution too? diff --git a/include/linux/netfilter.h b/include/linux/netfilter.h index 1dd075e..624d78b 100644 --- a/include/linux/netfilter.h +++ b/include/linux/netfilter.h @@ -40,6 +40,29 @@ #endif #ifdef __KERNEL__ + +static inline void nf_csum_replace4(__sum16 *sum, __be32 from, __be32 to) +{ + __be32 diff[] = { ~from, to }; + + *sum = csum_fold(csum_partial((char *)diff, sizeof(diff), ~csum_unfold(*sum))); +} + +static inline void nf_csum_replace2(__sum16 *sum, __be16 from, __be16 to) +{ + nf_csum_replace4(sum, (__force __be32)from, (__force __be32)to); +} + +extern void nf_proto_csum_replace4(__sum16 *sum, struct sk_buff *skb, + __be32 from, __be32 to, int pseudohdr); + +static inline void nf_proto_csum_replace2(__sum16 *sum, struct sk_buff *skb, + __be16 from, __be16 to, int pseudohdr) +{ + nf_proto_csum_replace4(sum, skb, (__force __be32)from, + (__force __be32)to, pseudohdr); +} + #ifdef CONFIG_NETFILTER extern void netfilter_init(void); @@ -289,28 +312,6 @@ extern void nf_invalidate_cache(int pf); Returns true or false. */ extern int skb_make_writable(struct sk_buff **pskb, unsigned int writable_len); -static inline void nf_csum_replace4(__sum16 *sum, __be32 from, __be32 to) -{ - __be32 diff[] = { ~from, to }; - - *sum = csum_fold(csum_partial((char *)diff, sizeof(diff), ~csum_unfold(*sum))); -} - -static inline void nf_csum_replace2(__sum16 *sum, __be16 from, __be16 to) -{ - nf_csum_replace4(sum, (__force __be32)from, (__force __be32)to); -} - -extern void nf_proto_csum_replace4(__sum16 *sum, struct sk_buff *skb, - __be32 from, __be32 to, int pseudohdr); - -static inline void nf_proto_csum_replace2(__sum16 *sum, struct sk_buff *skb, - __be16 from, __be16 to, int pseudohdr) -{ - nf_proto_csum_replace4(sum, skb, (__force __be32)from, - (__force __be32)to, pseudohdr); -} - struct nf_afinfo { unsigned short family; __sum16 (*checksum)(struct sk_buff *skb, unsigned int hook, diff --git a/net/core/Makefile b/net/core/Makefile index 4751613..5757323 100644 --- a/net/core/Makefile +++ b/net/core/Makefile @@ -3,7 +3,7 @@ # obj-y := sock.o request_sock.o skbuff.o iovec.o datagram.o stream.o scm.o \ - gen_stats.o gen_estimator.o + gen_stats.o gen_estimator.o helpers.o obj-$(CONFIG_SYSCTL) += sysctl_net_core.o diff --git a/net/core/helpers.c b/net/core/helpers.c new file mode 100644 index 0000000..d3c8d97 --- /dev/null +++ b/net/core/helpers.c @@ -0,0 +1,23 @@ +/* + * Generic helper functions. + */ + +#include <linux/types.h> +#include <linux/skbuff.h> + +#include <net/checksum.h> + +void nf_proto_csum_replace4(__sum16 *sum, struct sk_buff *skb, + __be32 from, __be32 to, int pseudohdr) +{ + __be32 diff[] = { ~from, to }; + if (skb->ip_summed != CHECKSUM_PARTIAL) { + *sum = csum_fold(csum_partial(diff, sizeof(diff), + ~csum_unfold(*sum))); + if (skb->ip_summed == CHECKSUM_COMPLETE && pseudohdr) + skb->csum = ~csum_partial(diff, sizeof(diff), + ~skb->csum); + } else if (pseudohdr) + *sum = ~csum_fold(csum_partial(diff, sizeof(diff), + csum_unfold(*sum))); +} diff --git a/net/netfilter/core.c b/net/netfilter/core.c index 381a77c..9ffbbe2 100644 --- a/net/netfilter/core.c +++ b/net/netfilter/core.c @@ -226,22 +226,6 @@ copy_skb: } EXPORT_SYMBOL(skb_make_writable); -void nf_proto_csum_replace4(__sum16 *sum, struct sk_buff *skb, - __be32 from, __be32 to, int pseudohdr) -{ - __be32 diff[] = { ~from, to }; - if (skb->ip_summed != CHECKSUM_PARTIAL) { - *sum = csum_fold(csum_partial(diff, sizeof(diff), - ~csum_unfold(*sum))); - if (skb->ip_summed == CHECKSUM_COMPLETE && pseudohdr) - skb->csum = ~csum_partial(diff, sizeof(diff), - ~skb->csum); - } else if (pseudohdr) - *sum = ~csum_fold(csum_partial(diff, sizeof(diff), - csum_unfold(*sum))); -} -EXPORT_SYMBOL(nf_proto_csum_replace4); - #if defined(CONFIG_NF_CONNTRACK) || defined(CONFIG_NF_CONNTRACK_MODULE) /* This does not belong here, but locally generated errors need it if connection tracking in use: without this, connection may not be in hash table, and hence -- Evgeniy Polyakov - To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html