aboutsummaryrefslogtreecommitdiffstats
path: root/net/ipv6/ip6_fib.c
diff options
context:
space:
mode:
Diffstat (limited to 'net/ipv6/ip6_fib.c')
-rw-r--r--net/ipv6/ip6_fib.c46
1 files changed, 23 insertions, 23 deletions
diff --git a/net/ipv6/ip6_fib.c b/net/ipv6/ip6_fib.c
index 96d8310ae9c8..f90ab5233326 100644
--- a/net/ipv6/ip6_fib.c
+++ b/net/ipv6/ip6_fib.c
@@ -1,9 +1,9 @@
1/* 1/*
2 * Linux INET6 implementation 2 * Linux INET6 implementation
3 * Forwarding Information Database 3 * Forwarding Information Database
4 * 4 *
5 * Authors: 5 * Authors:
6 * Pedro Roque <roque@di.fc.ul.pt> 6 * Pedro Roque <roque@di.fc.ul.pt>
7 * 7 *
8 * $Id: ip6_fib.c,v 1.25 2001/10/31 21:55:55 davem Exp $ 8 * $Id: ip6_fib.c,v 1.25 2001/10/31 21:55:55 davem Exp $
9 * 9 *
@@ -97,7 +97,7 @@ static DEFINE_TIMER(ip6_fib_timer, fib6_run_gc, 0, 0);
97 97
98static struct fib6_walker_t fib6_walker_list = { 98static struct fib6_walker_t fib6_walker_list = {
99 .prev = &fib6_walker_list, 99 .prev = &fib6_walker_list,
100 .next = &fib6_walker_list, 100 .next = &fib6_walker_list,
101}; 101};
102 102
103#define FOR_WALKERS(w) for ((w)=fib6_walker_list.next; (w) != &fib6_walker_list; (w)=(w)->next) 103#define FOR_WALKERS(w) for ((w)=fib6_walker_list.next; (w) != &fib6_walker_list; (w)=(w)->next)
@@ -131,7 +131,7 @@ static __inline__ u32 fib6_new_sernum(void)
131/* 131/*
132 * Auxiliary address test functions for the radix tree. 132 * Auxiliary address test functions for the radix tree.
133 * 133 *
134 * These assume a 32bit processor (although it will work on 134 * These assume a 32bit processor (although it will work on
135 * 64bit processors) 135 * 64bit processors)
136 */ 136 */
137 137
@@ -434,7 +434,7 @@ static struct fib6_node * fib6_add_1(struct fib6_node *root, void *addr,
434 struct fib6_node *pn = NULL; 434 struct fib6_node *pn = NULL;
435 struct rt6key *key; 435 struct rt6key *key;
436 int bit; 436 int bit;
437 __be32 dir = 0; 437 __be32 dir = 0;
438 __u32 sernum = fib6_new_sernum(); 438 __u32 sernum = fib6_new_sernum();
439 439
440 RT6_TRACE("fib6_add_1\n"); 440 RT6_TRACE("fib6_add_1\n");
@@ -452,27 +452,27 @@ static struct fib6_node * fib6_add_1(struct fib6_node *root, void *addr,
452 if (plen < fn->fn_bit || 452 if (plen < fn->fn_bit ||
453 !ipv6_prefix_equal(&key->addr, addr, fn->fn_bit)) 453 !ipv6_prefix_equal(&key->addr, addr, fn->fn_bit))
454 goto insert_above; 454 goto insert_above;
455 455
456 /* 456 /*
457 * Exact match ? 457 * Exact match ?
458 */ 458 */
459 459
460 if (plen == fn->fn_bit) { 460 if (plen == fn->fn_bit) {
461 /* clean up an intermediate node */ 461 /* clean up an intermediate node */
462 if ((fn->fn_flags & RTN_RTINFO) == 0) { 462 if ((fn->fn_flags & RTN_RTINFO) == 0) {
463 rt6_release(fn->leaf); 463 rt6_release(fn->leaf);
464 fn->leaf = NULL; 464 fn->leaf = NULL;
465 } 465 }
466 466
467 fn->fn_sernum = sernum; 467 fn->fn_sernum = sernum;
468 468
469 return fn; 469 return fn;
470 } 470 }
471 471
472 /* 472 /*
473 * We have more bits to go 473 * We have more bits to go
474 */ 474 */
475 475
476 /* Try to walk down on tree. */ 476 /* Try to walk down on tree. */
477 fn->fn_sernum = sernum; 477 fn->fn_sernum = sernum;
478 dir = addr_bit_set(addr, fn->fn_bit); 478 dir = addr_bit_set(addr, fn->fn_bit);
@@ -490,7 +490,7 @@ static struct fib6_node * fib6_add_1(struct fib6_node *root, void *addr,
490 if (ln == NULL) 490 if (ln == NULL)
491 return NULL; 491 return NULL;
492 ln->fn_bit = plen; 492 ln->fn_bit = plen;
493 493
494 ln->parent = pn; 494 ln->parent = pn;
495 ln->fn_sernum = sernum; 495 ln->fn_sernum = sernum;
496 496
@@ -504,7 +504,7 @@ static struct fib6_node * fib6_add_1(struct fib6_node *root, void *addr,
504 504
505insert_above: 505insert_above:
506 /* 506 /*
507 * split since we don't have a common prefix anymore or 507 * split since we don't have a common prefix anymore or
508 * we have a less significant route. 508 * we have a less significant route.
509 * we've to insert an intermediate node on the list 509 * we've to insert an intermediate node on the list
510 * this new node will point to the one we need to create 510 * this new node will point to the one we need to create
@@ -518,18 +518,18 @@ insert_above:
518 See comment in __ipv6_addr_diff: bit may be an invalid value, 518 See comment in __ipv6_addr_diff: bit may be an invalid value,
519 but if it is >= plen, the value is ignored in any case. 519 but if it is >= plen, the value is ignored in any case.
520 */ 520 */
521 521
522 bit = __ipv6_addr_diff(addr, &key->addr, addrlen); 522 bit = __ipv6_addr_diff(addr, &key->addr, addrlen);
523 523
524 /* 524 /*
525 * (intermediate)[in] 525 * (intermediate)[in]
526 * / \ 526 * / \
527 * (new leaf node)[ln] (old node)[fn] 527 * (new leaf node)[ln] (old node)[fn]
528 */ 528 */
529 if (plen > bit) { 529 if (plen > bit) {
530 in = node_alloc(); 530 in = node_alloc();
531 ln = node_alloc(); 531 ln = node_alloc();
532 532
533 if (in == NULL || ln == NULL) { 533 if (in == NULL || ln == NULL) {
534 if (in) 534 if (in)
535 node_free(in); 535 node_free(in);
@@ -538,8 +538,8 @@ insert_above:
538 return NULL; 538 return NULL;
539 } 539 }
540 540
541 /* 541 /*
542 * new intermediate node. 542 * new intermediate node.
543 * RTN_RTINFO will 543 * RTN_RTINFO will
544 * be off since that an address that chooses one of 544 * be off since that an address that chooses one of
545 * the branches would not match less specific routes 545 * the branches would not match less specific routes
@@ -576,7 +576,7 @@ insert_above:
576 } 576 }
577 } else { /* plen <= bit */ 577 } else { /* plen <= bit */
578 578
579 /* 579 /*
580 * (new leaf node)[ln] 580 * (new leaf node)[ln]
581 * / \ 581 * / \
582 * (old node)[fn] NULL 582 * (old node)[fn] NULL
@@ -592,7 +592,7 @@ insert_above:
592 ln->parent = pn; 592 ln->parent = pn;
593 593
594 ln->fn_sernum = sernum; 594 ln->fn_sernum = sernum;
595 595
596 if (dir) 596 if (dir)
597 pn->right = ln; 597 pn->right = ln;
598 else 598 else
@@ -1206,7 +1206,7 @@ int fib6_del(struct rt6_info *rt, struct nl_info *info)
1206 * However, it is internally reenterable wrt itself and fib6_add/fib6_del. 1206 * However, it is internally reenterable wrt itself and fib6_add/fib6_del.
1207 * It means, that we can modify tree during walking 1207 * It means, that we can modify tree during walking
1208 * and use this function for garbage collection, clone pruning, 1208 * and use this function for garbage collection, clone pruning,
1209 * cleaning tree when a device goes down etc. etc. 1209 * cleaning tree when a device goes down etc. etc.
1210 * 1210 *
1211 * It guarantees that every node will be traversed, 1211 * It guarantees that every node will be traversed,
1212 * and that it will be traversed only once. 1212 * and that it will be traversed only once.
@@ -1245,7 +1245,7 @@ static int fib6_walk_continue(struct fib6_walker_t *w)
1245 continue; 1245 continue;
1246 } 1246 }
1247 w->state = FWS_L; 1247 w->state = FWS_L;
1248#endif 1248#endif
1249 case FWS_L: 1249 case FWS_L:
1250 if (fn->left) { 1250 if (fn->left) {
1251 w->node = fn->left; 1251 w->node = fn->left;
@@ -1338,7 +1338,7 @@ static int fib6_clean_node(struct fib6_walker_t *w)
1338 1338
1339/* 1339/*
1340 * Convenient frontend to tree walker. 1340 * Convenient frontend to tree walker.
1341 * 1341 *
1342 * func is called on each route. 1342 * func is called on each route.
1343 * It may return -1 -> delete this route. 1343 * It may return -1 -> delete this route.
1344 * 0 -> continue walking 1344 * 0 -> continue walking