diff options
author | Daniel Lezcano <dlezcano@fr.ibm.com> | 2008-01-10 05:56:03 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-01-28 18:01:18 -0500 |
commit | e71e0349eb32bc438fa80d8990c6f3592967d111 (patch) | |
tree | 1fc9565c1b8c36e5fe9ecfde20bd989f6475324f /net/ipv6/reassembly.c | |
parent | 99bc9c4e45e7e783cf0b0a25cc03a103c038f254 (diff) |
[NETNS][IPV6]: Make ip6_frags per namespace.
The ip6_frags is moved to the network namespace structure. Because
there can be multiple instances of the network namespaces, and the
ip6_frags is no longer a global static variable, a helper function has
been added to facilitate the initialization of the variables.
Until the ipv6 protocol is not per namespace, the variables are
accessed relatively from the initial network namespace.
Signed-off-by: Daniel Lezcano <dlezcano@fr.ibm.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv6/reassembly.c')
-rw-r--r-- | net/ipv6/reassembly.c | 16 |
1 files changed, 7 insertions, 9 deletions
diff --git a/net/ipv6/reassembly.c b/net/ipv6/reassembly.c index bf4173daecbb..5cd0bc693a5f 100644 --- a/net/ipv6/reassembly.c +++ b/net/ipv6/reassembly.c | |||
@@ -82,13 +82,6 @@ struct frag_queue | |||
82 | __u16 nhoffset; | 82 | __u16 nhoffset; |
83 | }; | 83 | }; |
84 | 84 | ||
85 | struct inet_frags_ctl ip6_frags_ctl __read_mostly = { | ||
86 | .high_thresh = 256 * 1024, | ||
87 | .low_thresh = 192 * 1024, | ||
88 | .timeout = IPV6_FRAG_TIMEOUT, | ||
89 | .secret_interval = 10 * 60 * HZ, | ||
90 | }; | ||
91 | |||
92 | static struct inet_frags ip6_frags; | 85 | static struct inet_frags ip6_frags; |
93 | 86 | ||
94 | int ip6_frag_nqueues(void) | 87 | int ip6_frag_nqueues(void) |
@@ -605,7 +598,7 @@ static int ipv6_frag_rcv(struct sk_buff *skb) | |||
605 | return 1; | 598 | return 1; |
606 | } | 599 | } |
607 | 600 | ||
608 | if (atomic_read(&ip6_frags.mem) > ip6_frags_ctl.high_thresh) | 601 | if (atomic_read(&ip6_frags.mem) > init_net.ipv6.sysctl.frags.high_thresh) |
609 | ip6_evictor(ip6_dst_idev(skb->dst)); | 602 | ip6_evictor(ip6_dst_idev(skb->dst)); |
610 | 603 | ||
611 | if ((fq = fq_find(fhdr->identification, &hdr->saddr, &hdr->daddr, | 604 | if ((fq = fq_find(fhdr->identification, &hdr->saddr, &hdr->daddr, |
@@ -632,6 +625,11 @@ static struct inet6_protocol frag_protocol = | |||
632 | .flags = INET6_PROTO_NOPOLICY, | 625 | .flags = INET6_PROTO_NOPOLICY, |
633 | }; | 626 | }; |
634 | 627 | ||
628 | void ipv6_frag_sysctl_init(struct net *net) | ||
629 | { | ||
630 | ip6_frags.ctl = &net->ipv6.sysctl.frags; | ||
631 | } | ||
632 | |||
635 | int __init ipv6_frag_init(void) | 633 | int __init ipv6_frag_init(void) |
636 | { | 634 | { |
637 | int ret; | 635 | int ret; |
@@ -639,7 +637,7 @@ int __init ipv6_frag_init(void) | |||
639 | ret = inet6_add_protocol(&frag_protocol, IPPROTO_FRAGMENT); | 637 | ret = inet6_add_protocol(&frag_protocol, IPPROTO_FRAGMENT); |
640 | if (ret) | 638 | if (ret) |
641 | goto out; | 639 | goto out; |
642 | ip6_frags.ctl = &ip6_frags_ctl; | 640 | |
643 | ip6_frags.hashfn = ip6_hashfn; | 641 | ip6_frags.hashfn = ip6_hashfn; |
644 | ip6_frags.constructor = ip6_frag_init; | 642 | ip6_frags.constructor = ip6_frag_init; |
645 | ip6_frags.destructor = NULL; | 643 | ip6_frags.destructor = NULL; |