FIB_WALK and friends are now slightly more friendly.
This commit is contained in:
parent
66e53309ac
commit
236d4eb8ce
1 changed files with 8 additions and 10 deletions
18
nest/route.h
18
nest/route.h
|
@ -51,15 +51,13 @@ void *fib_get(struct fib *, ip_addr *, int); /* Find or create new if nonexiste
|
|||
void fib_delete(struct fib *, void *); /* Remove fib entry */
|
||||
void fib_free(struct fib *); /* Destroy the fib */
|
||||
|
||||
#define FIB_WALK(fib, z, op) do { \
|
||||
#define FIB_WALK(fib, z) do { \
|
||||
struct fib_node *z, **ff = (fib)->hash_table; \
|
||||
unsigned int count = (fib)->hash_size; \
|
||||
while (count--) \
|
||||
for(z = *ff++; z; z=z->next) \
|
||||
{ \
|
||||
op; \
|
||||
} \
|
||||
} while (0)
|
||||
for(z = *ff++; z; z=z->next)
|
||||
|
||||
#define FIB_WALK_END } while (0)
|
||||
|
||||
/*
|
||||
* Master Routing Tables. Generally speaking, each of them is a list
|
||||
|
@ -120,12 +118,12 @@ extern rtable master_table;
|
|||
|
||||
void rt_init(void);
|
||||
void rt_setup(rtable *, char *);
|
||||
net *net_find(rtable *tab, unsigned tos, ip_addr mask, unsigned len);
|
||||
net *net_get(rtable *tab, unsigned tos, ip_addr mask, unsigned len);
|
||||
net *net_find(rtable *tab, unsigned tos, ip_addr addr, unsigned len);
|
||||
net *net_get(rtable *tab, unsigned tos, ip_addr addr, unsigned len);
|
||||
rte *rte_find(net *net, struct proto *p);
|
||||
rte *rte_get_temp(struct rtattr *);
|
||||
void rte_update(net *net, rte *new);
|
||||
void rte_dump(rte *);
|
||||
void rte_update(net *net, struct proto *p, rte *new);
|
||||
void rte_dump(net *, rte *);
|
||||
void rt_dump(rtable *);
|
||||
void rt_dump_all(void);
|
||||
|
||||
|
|
Loading…
Reference in a new issue