X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=net%2Fipv6%2Fnetfilter.c;h=580b1aba6722bd61438d4a52b3ed09bea2668f9f;hb=782237a2418e2561a87c86a4832726931adce737;hp=b63678328a3b2c97ce17a58fcbc4cfa8975c7b63;hpb=3e3850e989c5d2eb1aab6f0fd9257759f0f4cbc6;p=powerpc.git diff --git a/net/ipv6/netfilter.c b/net/ipv6/netfilter.c index b63678328a..580b1aba67 100644 --- a/net/ipv6/netfilter.c +++ b/net/ipv6/netfilter.c @@ -1,9 +1,5 @@ -#include -#include - -#ifdef CONFIG_NETFILTER - #include +#include #include #include #include @@ -11,6 +7,7 @@ #include #include #include +#include int ip6_route_me_harder(struct sk_buff *skb) { @@ -58,7 +55,7 @@ struct ip6_rt_info { struct in6_addr saddr; }; -static void save(const struct sk_buff *skb, struct nf_info *info) +static void nf_ip6_saveroute(const struct sk_buff *skb, struct nf_info *info) { struct ip6_rt_info *rt_info = nf_info_reroute(info); @@ -70,7 +67,7 @@ static void save(const struct sk_buff *skb, struct nf_info *info) } } -static int reroute(struct sk_buff **pskb, const struct nf_info *info) +static int nf_ip6_reroute(struct sk_buff **pskb, const struct nf_info *info) { struct ip6_rt_info *rt_info = nf_info_reroute(info); @@ -83,29 +80,56 @@ static int reroute(struct sk_buff **pskb, const struct nf_info *info) return 0; } -static struct nf_queue_rerouter ip6_reroute = { - .rer_size = sizeof(struct ip6_rt_info), - .save = &save, - .reroute = &reroute, -}; - -int __init ipv6_netfilter_init(void) +unsigned int nf_ip6_checksum(struct sk_buff *skb, unsigned int hook, + unsigned int dataoff, u_int8_t protocol) { - return nf_register_queue_rerouter(PF_INET6, &ip6_reroute); + struct ipv6hdr *ip6h = skb->nh.ipv6h; + unsigned int csum = 0; + + switch (skb->ip_summed) { + case CHECKSUM_COMPLETE: + if (hook != NF_IP6_PRE_ROUTING && hook != NF_IP6_LOCAL_IN) + break; + if (!csum_ipv6_magic(&ip6h->saddr, &ip6h->daddr, + skb->len - dataoff, protocol, + csum_sub(skb->csum, + skb_checksum(skb, 0, + dataoff, 0)))) { + skb->ip_summed = CHECKSUM_UNNECESSARY; + break; + } + /* fall through */ + case CHECKSUM_NONE: + skb->csum = ~csum_ipv6_magic(&ip6h->saddr, &ip6h->daddr, + skb->len - dataoff, + protocol, + csum_sub(0, + skb_checksum(skb, 0, + dataoff, 0))); + csum = __skb_checksum_complete(skb); + } + return csum; } -void ipv6_netfilter_fini(void) -{ - nf_unregister_queue_rerouter(PF_INET6); -} +EXPORT_SYMBOL(nf_ip6_checksum); + +static struct nf_afinfo nf_ip6_afinfo = { + .family = AF_INET6, + .checksum = nf_ip6_checksum, + .saveroute = nf_ip6_saveroute, + .reroute = nf_ip6_reroute, + .route_key_size = sizeof(struct ip6_rt_info), +}; -#else /* CONFIG_NETFILTER */ int __init ipv6_netfilter_init(void) { - return 0; + return nf_register_afinfo(&nf_ip6_afinfo); } +/* This can be called from inet6_init() on errors, so it cannot + * be marked __exit. -DaveM + */ void ipv6_netfilter_fini(void) { + nf_unregister_afinfo(&nf_ip6_afinfo); } -#endif /* CONFIG_NETFILTER */