aboutsummaryrefslogtreecommitdiffstats
path: root/net/ipv6/route.c
diff options
context:
space:
mode:
authorDaniel Lezcano <dlezcano@fr.ibm.com>2008-03-04 16:50:14 -0500
committerDavid S. Miller <davem@davemloft.net>2008-03-04 16:50:14 -0500
commit7019b78e1483fa724dcba56e8465376b8fd03ea8 (patch)
treedb1724c6a9e63257eb810b4e4d4ee744098c4f6c /net/ipv6/route.c
parent6891a346c387bd0a64afa50f4522f5fe8ba879d8 (diff)
[NETNS][IPV6] route6 - Make ip6_dst_gc simpler
This patches improves the readibility of the ip6_dst_gc() routine. It simplifies long lines which grow a lot due to the introduction of network namespaces support. Signed-off-by: Daniel Lezcano <dlezcano@fr.ibm.com> Acked-by: Benjamin Thery <benjamin.thery@bull.net> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv6/route.c')
-rw-r--r--net/ipv6/route.c22
1 files changed, 13 insertions, 9 deletions
diff --git a/net/ipv6/route.c b/net/ipv6/route.c
index 10a6cc0aca6c..ec1fedb339cc 100644
--- a/net/ipv6/route.c
+++ b/net/ipv6/route.c
@@ -992,22 +992,26 @@ int icmp6_dst_gc(int *more)
992 992
993static int ip6_dst_gc(struct dst_ops *ops) 993static int ip6_dst_gc(struct dst_ops *ops)
994{ 994{
995 struct net *net = ops->dst_net;
996 unsigned long now = jiffies; 995 unsigned long now = jiffies;
997 996 struct net *net = ops->dst_net;
998 if (time_after(net->ipv6.ip6_rt_last_gc + net->ipv6.sysctl.ip6_rt_gc_min_interval, now) && 997 int rt_min_interval = net->ipv6.sysctl.ip6_rt_gc_min_interval;
999 atomic_read(&net->ipv6.ip6_dst_ops->entries) <= net->ipv6.sysctl.ip6_rt_max_size) 998 int rt_max_size = net->ipv6.sysctl.ip6_rt_max_size;
999 int rt_elasticity = net->ipv6.sysctl.ip6_rt_gc_elasticity;
1000 int rt_gc_timeout = net->ipv6.sysctl.ip6_rt_gc_timeout;
1001 unsigned long rt_last_gc = net->ipv6.ip6_rt_last_gc;
1002
1003 if (time_after(rt_last_gc + rt_min_interval, now) &&
1004 atomic_read(&ops->entries) <= rt_max_size)
1000 goto out; 1005 goto out;
1001 1006
1002 net->ipv6.ip6_rt_gc_expire++; 1007 net->ipv6.ip6_rt_gc_expire++;
1003 fib6_run_gc(net->ipv6.ip6_rt_gc_expire, net); 1008 fib6_run_gc(net->ipv6.ip6_rt_gc_expire, net);
1004 net->ipv6.ip6_rt_last_gc = now; 1009 net->ipv6.ip6_rt_last_gc = now;
1005 if (atomic_read(&net->ipv6.ip6_dst_ops->entries) < net->ipv6.ip6_dst_ops->gc_thresh) 1010 if (atomic_read(&ops->entries) < ops->gc_thresh)
1006 net->ipv6.ip6_rt_gc_expire = net->ipv6.sysctl.ip6_rt_gc_timeout>>1; 1011 net->ipv6.ip6_rt_gc_expire = rt_gc_timeout>>1;
1007
1008out: 1012out:
1009 net->ipv6.ip6_rt_gc_expire -= net->ipv6.ip6_rt_gc_expire>>net->ipv6.sysctl.ip6_rt_gc_elasticity; 1013 net->ipv6.ip6_rt_gc_expire -= net->ipv6.ip6_rt_gc_expire>>rt_elasticity;
1010 return (atomic_read(&net->ipv6.ip6_dst_ops->entries) > net->ipv6.sysctl.ip6_rt_max_size); 1014 return (atomic_read(&ops->entries) > rt_max_size);
1011} 1015}
1012 1016
1013/* Clean host part of a prefix. Not necessary in radix tree, 1017/* Clean host part of a prefix. Not necessary in radix tree,