Fixes a bug with neighbor cache and overlapping IP prefixes.
When there are overlapping IP prefixes and one disappears, neighbors associated with it was removed even if there is another covering IP prefix.
This commit is contained in:
parent
d760229ab8
commit
8ecbaf9c70
1 changed files with 16 additions and 2 deletions
|
@ -114,7 +114,7 @@ neighbor *
|
||||||
neigh_find2(struct proto *p, ip_addr *a, struct iface *ifa, unsigned flags)
|
neigh_find2(struct proto *p, ip_addr *a, struct iface *ifa, unsigned flags)
|
||||||
{
|
{
|
||||||
neighbor *n;
|
neighbor *n;
|
||||||
int class, scope = -1; ;
|
int class, scope = -1;
|
||||||
unsigned int h = neigh_hash(p, a);
|
unsigned int h = neigh_hash(p, a);
|
||||||
struct iface *i;
|
struct iface *i;
|
||||||
|
|
||||||
|
@ -240,7 +240,21 @@ neigh_down(neighbor *n)
|
||||||
n->proto->neigh_notify(n);
|
n->proto->neigh_notify(n);
|
||||||
rem_node(&n->n);
|
rem_node(&n->n);
|
||||||
if (n->flags & NEF_STICKY)
|
if (n->flags & NEF_STICKY)
|
||||||
|
{
|
||||||
add_tail(&sticky_neigh_list, &n->n);
|
add_tail(&sticky_neigh_list, &n->n);
|
||||||
|
|
||||||
|
/* Respawn neighbor if there is another matching prefix */
|
||||||
|
struct iface *i;
|
||||||
|
int scope;
|
||||||
|
|
||||||
|
if (!n->iface)
|
||||||
|
WALK_LIST(i, iface_list)
|
||||||
|
if ((scope = if_connected(&n->addr, i)) >= 0)
|
||||||
|
{
|
||||||
|
neigh_up(n, i, scope);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
else
|
else
|
||||||
sl_free(neigh_slab, n);
|
sl_free(neigh_slab, n);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue