ipv6: icmp6_dst_gc return change
authorStephen Hemminger <shemminger@vyatta.com>
Tue, 22 Jul 2008 21:35:50 +0000 (14:35 -0700)
committerDavid S. Miller <davem@davemloft.net>
Tue, 22 Jul 2008 21:35:50 +0000 (14:35 -0700)
Change icmp6_dst_gc to return the one value the caller cares about rather
than using call by reference.

Signed-off-by: Stephen Hemminger <shemminger@vyatta.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/net/ip6_route.h
net/ipv6/ip6_fib.c
net/ipv6/route.c

index 9313491e3dad2212eb7a55126a07b2081e27bb6a..2f8b3c06a10198b7c51d1029965284c802a395b9 100644 (file)
@@ -68,7 +68,7 @@ extern struct rt6_info                *rt6_lookup(struct net *net,
 extern struct dst_entry *icmp6_dst_alloc(struct net_device *dev,
                                         struct neighbour *neigh,
                                         const struct in6_addr *addr);
-extern int icmp6_dst_gc(int *more);
+extern int icmp6_dst_gc(void);
 
 extern void fib6_force_start_gc(struct net *net);
 
index c72fd2461ca5b4aa8265881487da822de318ab6c..08ea2de28d63c358eeec0a3b59469914dd3fca4b 100644 (file)
@@ -1453,9 +1453,8 @@ void fib6_run_gc(unsigned long expires, struct net *net)
                }
                gc_args.timeout = net->ipv6.sysctl.ip6_rt_gc_interval;
        }
-       gc_args.more = 0;
 
-       icmp6_dst_gc(&gc_args.more);
+       gc_args.more = icmp6_dst_gc();
 
        fib6_clean_all(net, fib6_age, 0, NULL);
 
index 615b328de2516cbccdac54debb0cfb47abfb147a..86540b24b27c386454630ecd9143dc09b5fe2cc8 100644 (file)
@@ -978,13 +978,12 @@ out:
        return &rt->u.dst;
 }
 
-int icmp6_dst_gc(int *more)
+int icmp6_dst_gc(void)
 {
        struct dst_entry *dst, *next, **pprev;
-       int freed;
+       int more = 0;
 
        next = NULL;
-       freed = 0;
 
        spin_lock_bh(&icmp6_dst_lock);
        pprev = &icmp6_dst_gc_list;
@@ -993,16 +992,15 @@ int icmp6_dst_gc(int *more)
                if (!atomic_read(&dst->__refcnt)) {
                        *pprev = dst->next;
                        dst_free(dst);
-                       freed++;
                } else {
                        pprev = &dst->next;
-                       (*more)++;
+                       ++more;
                }
        }
 
        spin_unlock_bh(&icmp6_dst_lock);
 
-       return freed;
+       return more;
 }
 
 static int ip6_dst_gc(struct dst_ops *ops)