Commit 783f8b68 authored by Martin Mareš's avatar Martin Mareš

When protocols go down, prune the neighbor list.

parent 013a9b91
......@@ -23,7 +23,6 @@ static void auto_router_id(void);
* Neighbor Cache
*
* FIXME: Use hashing to get some real speed.
* FIXME: Cleanup when a protocol goes down.
*/
static slab *neigh_slab;
......@@ -160,6 +159,30 @@ neigh_if_down(struct iface *i)
}
}
void
neigh_prune(void)
{
neighbor *n, *m, **N;
struct iface *i;
DBG("Pruning neighbors\n");
WALK_LIST(i, iface_list)
{
N = &i->neigh;
while (n = *N)
{
if (n->proto->core_state == FS_HUNGRY || n->proto->core_state == FS_FLUSHING)
{
*N = n->sibling;
rem_node(&n->n);
sl_free(neigh_slab, n);
continue;
}
N = &n->sibling;
}
}
}
/*
* The Interface List
*/
......
......@@ -89,6 +89,7 @@ neighbor *neigh_find(struct proto *, ip_addr *, unsigned flags);
void neigh_dump(neighbor *);
void neigh_dump_all(void);
void neigh_prune(void);
/*
* Interface Pattern Lists
......
......@@ -330,6 +330,7 @@ proto_flush_all(void *unused)
struct proto *p;
rt_prune(&master_table);
neigh_prune();
while ((p = HEAD(flush_proto_list))->n.next)
{
DBG("Flushing protocol %s\n", p->name);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment