aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHannes Frederic Sowa <hannes@stressinduktion.org>2014-10-06 13:58:34 -0400
committerDavid S. Miller <davem@davemloft.net>2014-10-07 00:02:30 -0400
commit94b2cfe02bfe3f1918d91bd6f498e308c5605cbc (patch)
tree597dc0faf3ccd86acc74851f92e37bef3988973f
parent1ff0dc9499b25d016777f9b8d3ee486fd588ba59 (diff)
ipv6: minor fib6 cleanups like type safety, bool conversion, inline removal
Also renamed struct fib6_walker_t to fib6_walker and enum fib_walk_state_t to fib6_walk_state as recommended by Cong Wang. Cc: Cong Wang <cwang@twopensource.com> Cc: YOSHIFUJI Hideaki <hideaki@yoshifuji.org> Cc: Martin Lau <kafai@fb.com> Signed-off-by: Hannes Frederic Sowa <hannes@stressinduktion.org> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--include/net/ip6_fib.h18
-rw-r--r--net/ipv6/ip6_fib.c71
2 files changed, 45 insertions, 44 deletions
diff --git a/include/net/ip6_fib.h b/include/net/ip6_fib.h
index cf485f9aa563..9221bf4c64f7 100644
--- a/include/net/ip6_fib.h
+++ b/include/net/ip6_fib.h
@@ -202,15 +202,25 @@ static inline void ip6_rt_put(struct rt6_info *rt)
202 dst_release(&rt->dst); 202 dst_release(&rt->dst);
203} 203}
204 204
205struct fib6_walker_t { 205enum fib6_walk_state {
206#ifdef CONFIG_IPV6_SUBTREES
207 FWS_S,
208#endif
209 FWS_L,
210 FWS_R,
211 FWS_C,
212 FWS_U
213};
214
215struct fib6_walker {
206 struct list_head lh; 216 struct list_head lh;
207 struct fib6_node *root, *node; 217 struct fib6_node *root, *node;
208 struct rt6_info *leaf; 218 struct rt6_info *leaf;
209 unsigned char state; 219 enum fib6_walk_state state;
210 unsigned char prune; 220 bool prune;
211 unsigned int skip; 221 unsigned int skip;
212 unsigned int count; 222 unsigned int count;
213 int (*func)(struct fib6_walker_t *); 223 int (*func)(struct fib6_walker *);
214 void *args; 224 void *args;
215}; 225};
216 226
diff --git a/net/ipv6/ip6_fib.c b/net/ipv6/ip6_fib.c
index 97b9fa8de377..e8d7465b1597 100644
--- a/net/ipv6/ip6_fib.c
+++ b/net/ipv6/ip6_fib.c
@@ -46,18 +46,8 @@
46 46
47static struct kmem_cache *fib6_node_kmem __read_mostly; 47static struct kmem_cache *fib6_node_kmem __read_mostly;
48 48
49enum fib_walk_state_t { 49struct fib6_cleaner {
50#ifdef CONFIG_IPV6_SUBTREES 50 struct fib6_walker w;
51 FWS_S,
52#endif
53 FWS_L,
54 FWS_R,
55 FWS_C,
56 FWS_U
57};
58
59struct fib6_cleaner_t {
60 struct fib6_walker_t w;
61 struct net *net; 51 struct net *net;
62 int (*func)(struct rt6_info *, void *arg); 52 int (*func)(struct rt6_info *, void *arg);
63 void *arg; 53 void *arg;
@@ -74,8 +64,8 @@ static DEFINE_RWLOCK(fib6_walker_lock);
74static void fib6_prune_clones(struct net *net, struct fib6_node *fn); 64static void fib6_prune_clones(struct net *net, struct fib6_node *fn);
75static struct rt6_info *fib6_find_prefix(struct net *net, struct fib6_node *fn); 65static struct rt6_info *fib6_find_prefix(struct net *net, struct fib6_node *fn);
76static struct fib6_node *fib6_repair_tree(struct net *net, struct fib6_node *fn); 66static struct fib6_node *fib6_repair_tree(struct net *net, struct fib6_node *fn);
77static int fib6_walk(struct fib6_walker_t *w); 67static int fib6_walk(struct fib6_walker *w);
78static int fib6_walk_continue(struct fib6_walker_t *w); 68static int fib6_walk_continue(struct fib6_walker *w);
79 69
80/* 70/*
81 * A routing update causes an increase of the serial number on the 71 * A routing update causes an increase of the serial number on the
@@ -91,20 +81,21 @@ static void fib6_gc_timer_cb(unsigned long arg);
91static LIST_HEAD(fib6_walkers); 81static LIST_HEAD(fib6_walkers);
92#define FOR_WALKERS(w) list_for_each_entry(w, &fib6_walkers, lh) 82#define FOR_WALKERS(w) list_for_each_entry(w, &fib6_walkers, lh)
93 83
94static inline void fib6_walker_link(struct fib6_walker_t *w) 84static void fib6_walker_link(struct fib6_walker *w)
95{ 85{
96 write_lock_bh(&fib6_walker_lock); 86 write_lock_bh(&fib6_walker_lock);
97 list_add(&w->lh, &fib6_walkers); 87 list_add(&w->lh, &fib6_walkers);
98 write_unlock_bh(&fib6_walker_lock); 88 write_unlock_bh(&fib6_walker_lock);
99} 89}
100 90
101static inline void fib6_walker_unlink(struct fib6_walker_t *w) 91static void fib6_walker_unlink(struct fib6_walker *w)
102{ 92{
103 write_lock_bh(&fib6_walker_lock); 93 write_lock_bh(&fib6_walker_lock);
104 list_del(&w->lh); 94 list_del(&w->lh);
105 write_unlock_bh(&fib6_walker_lock); 95 write_unlock_bh(&fib6_walker_lock);
106} 96}
107static __inline__ u32 fib6_new_sernum(void) 97
98static u32 fib6_new_sernum(void)
108{ 99{
109 u32 n = ++rt_sernum; 100 u32 n = ++rt_sernum;
110 if ((__s32)n <= 0) 101 if ((__s32)n <= 0)
@@ -128,7 +119,7 @@ static __inline__ u32 fib6_new_sernum(void)
128# define BITOP_BE32_SWIZZLE 0 119# define BITOP_BE32_SWIZZLE 0
129#endif 120#endif
130 121
131static __inline__ __be32 addr_bit_set(const void *token, int fn_bit) 122static __be32 addr_bit_set(const void *token, int fn_bit)
132{ 123{
133 const __be32 *addr = token; 124 const __be32 *addr = token;
134 /* 125 /*
@@ -142,7 +133,7 @@ static __inline__ __be32 addr_bit_set(const void *token, int fn_bit)
142 addr[fn_bit >> 5]; 133 addr[fn_bit >> 5];
143} 134}
144 135
145static __inline__ struct fib6_node *node_alloc(void) 136static struct fib6_node *node_alloc(void)
146{ 137{
147 struct fib6_node *fn; 138 struct fib6_node *fn;
148 139
@@ -151,12 +142,12 @@ static __inline__ struct fib6_node *node_alloc(void)
151 return fn; 142 return fn;
152} 143}
153 144
154static __inline__ void node_free(struct fib6_node *fn) 145static void node_free(struct fib6_node *fn)
155{ 146{
156 kmem_cache_free(fib6_node_kmem, fn); 147 kmem_cache_free(fib6_node_kmem, fn);
157} 148}
158 149
159static __inline__ void rt6_release(struct rt6_info *rt) 150static void rt6_release(struct rt6_info *rt)
160{ 151{
161 if (atomic_dec_and_test(&rt->rt6i_ref)) 152 if (atomic_dec_and_test(&rt->rt6i_ref))
162 dst_free(&rt->dst); 153 dst_free(&rt->dst);
@@ -267,7 +258,7 @@ static void __net_init fib6_tables_init(struct net *net)
267 258
268#endif 259#endif
269 260
270static int fib6_dump_node(struct fib6_walker_t *w) 261static int fib6_dump_node(struct fib6_walker *w)
271{ 262{
272 int res; 263 int res;
273 struct rt6_info *rt; 264 struct rt6_info *rt;
@@ -287,7 +278,7 @@ static int fib6_dump_node(struct fib6_walker_t *w)
287 278
288static void fib6_dump_end(struct netlink_callback *cb) 279static void fib6_dump_end(struct netlink_callback *cb)
289{ 280{
290 struct fib6_walker_t *w = (void *)cb->args[2]; 281 struct fib6_walker *w = (void *)cb->args[2];
291 282
292 if (w) { 283 if (w) {
293 if (cb->args[4]) { 284 if (cb->args[4]) {
@@ -310,7 +301,7 @@ static int fib6_dump_done(struct netlink_callback *cb)
310static int fib6_dump_table(struct fib6_table *table, struct sk_buff *skb, 301static int fib6_dump_table(struct fib6_table *table, struct sk_buff *skb,
311 struct netlink_callback *cb) 302 struct netlink_callback *cb)
312{ 303{
313 struct fib6_walker_t *w; 304 struct fib6_walker *w;
314 int res; 305 int res;
315 306
316 w = (void *)cb->args[2]; 307 w = (void *)cb->args[2];
@@ -355,7 +346,7 @@ static int inet6_dump_fib(struct sk_buff *skb, struct netlink_callback *cb)
355 unsigned int h, s_h; 346 unsigned int h, s_h;
356 unsigned int e = 0, s_e; 347 unsigned int e = 0, s_e;
357 struct rt6_rtnl_dump_arg arg; 348 struct rt6_rtnl_dump_arg arg;
358 struct fib6_walker_t *w; 349 struct fib6_walker *w;
359 struct fib6_table *tb; 350 struct fib6_table *tb;
360 struct hlist_head *head; 351 struct hlist_head *head;
361 int res = 0; 352 int res = 0;
@@ -627,7 +618,7 @@ insert_above:
627 return ln; 618 return ln;
628} 619}
629 620
630static inline bool rt6_qualify_for_ecmp(struct rt6_info *rt) 621static bool rt6_qualify_for_ecmp(struct rt6_info *rt)
631{ 622{
632 return (rt->rt6i_flags & (RTF_GATEWAY|RTF_ADDRCONF|RTF_DYNAMIC)) == 623 return (rt->rt6i_flags & (RTF_GATEWAY|RTF_ADDRCONF|RTF_DYNAMIC)) ==
633 RTF_GATEWAY; 624 RTF_GATEWAY;
@@ -820,7 +811,7 @@ add:
820 return 0; 811 return 0;
821} 812}
822 813
823static __inline__ void fib6_start_gc(struct net *net, struct rt6_info *rt) 814static void fib6_start_gc(struct net *net, struct rt6_info *rt)
824{ 815{
825 if (!timer_pending(&net->ipv6.ip6_fib_timer) && 816 if (!timer_pending(&net->ipv6.ip6_fib_timer) &&
826 (rt->rt6i_flags & (RTF_EXPIRES | RTF_CACHE))) 817 (rt->rt6i_flags & (RTF_EXPIRES | RTF_CACHE)))
@@ -1174,7 +1165,7 @@ static struct fib6_node *fib6_repair_tree(struct net *net,
1174 int children; 1165 int children;
1175 int nstate; 1166 int nstate;
1176 struct fib6_node *child, *pn; 1167 struct fib6_node *child, *pn;
1177 struct fib6_walker_t *w; 1168 struct fib6_walker *w;
1178 int iter = 0; 1169 int iter = 0;
1179 1170
1180 for (;;) { 1171 for (;;) {
@@ -1276,7 +1267,7 @@ static struct fib6_node *fib6_repair_tree(struct net *net,
1276static void fib6_del_route(struct fib6_node *fn, struct rt6_info **rtp, 1267static void fib6_del_route(struct fib6_node *fn, struct rt6_info **rtp,
1277 struct nl_info *info) 1268 struct nl_info *info)
1278{ 1269{
1279 struct fib6_walker_t *w; 1270 struct fib6_walker *w;
1280 struct rt6_info *rt = *rtp; 1271 struct rt6_info *rt = *rtp;
1281 struct net *net = info->nl_net; 1272 struct net *net = info->nl_net;
1282 1273
@@ -1414,7 +1405,7 @@ int fib6_del(struct rt6_info *rt, struct nl_info *info)
1414 * <0 -> walk is terminated by an error. 1405 * <0 -> walk is terminated by an error.
1415 */ 1406 */
1416 1407
1417static int fib6_walk_continue(struct fib6_walker_t *w) 1408static int fib6_walk_continue(struct fib6_walker *w)
1418{ 1409{
1419 struct fib6_node *fn, *pn; 1410 struct fib6_node *fn, *pn;
1420 1411
@@ -1498,7 +1489,7 @@ skip:
1498 } 1489 }
1499} 1490}
1500 1491
1501static int fib6_walk(struct fib6_walker_t *w) 1492static int fib6_walk(struct fib6_walker *w)
1502{ 1493{
1503 int res; 1494 int res;
1504 1495
@@ -1512,11 +1503,11 @@ static int fib6_walk(struct fib6_walker_t *w)
1512 return res; 1503 return res;
1513} 1504}
1514 1505
1515static int fib6_clean_node(struct fib6_walker_t *w) 1506static int fib6_clean_node(struct fib6_walker *w)
1516{ 1507{
1517 int res; 1508 int res;
1518 struct rt6_info *rt; 1509 struct rt6_info *rt;
1519 struct fib6_cleaner_t *c = container_of(w, struct fib6_cleaner_t, w); 1510 struct fib6_cleaner *c = container_of(w, struct fib6_cleaner, w);
1520 struct nl_info info = { 1511 struct nl_info info = {
1521 .nl_net = c->net, 1512 .nl_net = c->net,
1522 }; 1513 };
@@ -1554,9 +1545,9 @@ static int fib6_clean_node(struct fib6_walker_t *w)
1554 1545
1555static void fib6_clean_tree(struct net *net, struct fib6_node *root, 1546static void fib6_clean_tree(struct net *net, struct fib6_node *root,
1556 int (*func)(struct rt6_info *, void *arg), 1547 int (*func)(struct rt6_info *, void *arg),
1557 int prune, void *arg) 1548 bool prune, void *arg)
1558{ 1549{
1559 struct fib6_cleaner_t c; 1550 struct fib6_cleaner c;
1560 1551
1561 c.w.root = root; 1552 c.w.root = root;
1562 c.w.func = fib6_clean_node; 1553 c.w.func = fib6_clean_node;
@@ -1583,7 +1574,7 @@ void fib6_clean_all(struct net *net, int (*func)(struct rt6_info *, void *arg),
1583 hlist_for_each_entry_rcu(table, head, tb6_hlist) { 1574 hlist_for_each_entry_rcu(table, head, tb6_hlist) {
1584 write_lock_bh(&table->tb6_lock); 1575 write_lock_bh(&table->tb6_lock);
1585 fib6_clean_tree(net, &table->tb6_root, 1576 fib6_clean_tree(net, &table->tb6_root,
1586 func, 0, arg); 1577 func, false, arg);
1587 write_unlock_bh(&table->tb6_lock); 1578 write_unlock_bh(&table->tb6_lock);
1588 } 1579 }
1589 } 1580 }
@@ -1602,7 +1593,7 @@ static int fib6_prune_clone(struct rt6_info *rt, void *arg)
1602 1593
1603static void fib6_prune_clones(struct net *net, struct fib6_node *fn) 1594static void fib6_prune_clones(struct net *net, struct fib6_node *fn)
1604{ 1595{
1605 fib6_clean_tree(net, fn, fib6_prune_clone, 1, NULL); 1596 fib6_clean_tree(net, fn, fib6_prune_clone, true, NULL);
1606} 1597}
1607 1598
1608static int fib6_update_sernum(struct rt6_info *rt, void *arg) 1599static int fib6_update_sernum(struct rt6_info *rt, void *arg)
@@ -1828,7 +1819,7 @@ void fib6_gc_cleanup(void)
1828 1819
1829struct ipv6_route_iter { 1820struct ipv6_route_iter {
1830 struct seq_net_private p; 1821 struct seq_net_private p;
1831 struct fib6_walker_t w; 1822 struct fib6_walker w;
1832 loff_t skip; 1823 loff_t skip;
1833 struct fib6_table *tbl; 1824 struct fib6_table *tbl;
1834 __u32 sernum; 1825 __u32 sernum;
@@ -1859,7 +1850,7 @@ static int ipv6_route_seq_show(struct seq_file *seq, void *v)
1859 return 0; 1850 return 0;
1860} 1851}
1861 1852
1862static int ipv6_route_yield(struct fib6_walker_t *w) 1853static int ipv6_route_yield(struct fib6_walker *w)
1863{ 1854{
1864 struct ipv6_route_iter *iter = w->args; 1855 struct ipv6_route_iter *iter = w->args;
1865 1856
@@ -1980,7 +1971,7 @@ static void *ipv6_route_seq_start(struct seq_file *seq, loff_t *pos)
1980 1971
1981static bool ipv6_route_iter_active(struct ipv6_route_iter *iter) 1972static bool ipv6_route_iter_active(struct ipv6_route_iter *iter)
1982{ 1973{
1983 struct fib6_walker_t *w = &iter->w; 1974 struct fib6_walker *w = &iter->w;
1984 return w->node && !(w->state == FWS_U && w->node == w->root); 1975 return w->node && !(w->state == FWS_U && w->node == w->root);
1985} 1976}
1986 1977