OSPF: Fixes some issues with link detection
Thanks to Bernardo Figueiredo and Israel G. Lugo for the bugreport.
This commit is contained in:
parent
c7b99a932c
commit
b5e76398de
2 changed files with 9 additions and 2 deletions
|
@ -493,8 +493,11 @@ ospf_iface_add(struct object_lock *lock)
|
||||||
ifa->flood_queue = mb_allocz(ifa->pool, ifa->flood_queue_size * sizeof(void *));
|
ifa->flood_queue = mb_allocz(ifa->pool, ifa->flood_queue_size * sizeof(void *));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Do iface UP, unless there is no link and we use link detection */
|
/* Do iface UP, unless there is no link (then wait in LOOP state) */
|
||||||
ospf_iface_sm(ifa, (ifa->check_link && !(ifa->iface->flags & IF_LINK_UP)) ? ISM_LOOP : ISM_UP);
|
if (!ifa->check_link || (ifa->iface->flags & IF_LINK_UP))
|
||||||
|
ospf_iface_sm(ifa, ISM_UP);
|
||||||
|
else
|
||||||
|
ospf_iface_chstate(ifa, OSPF_IS_LOOP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void
|
static inline void
|
||||||
|
|
|
@ -231,6 +231,10 @@ ospf_rx_hook(sock *sk, int len)
|
||||||
const char *err_dsc = NULL;
|
const char *err_dsc = NULL;
|
||||||
uint err_val = 0;
|
uint err_val = 0;
|
||||||
|
|
||||||
|
/* Should not happen */
|
||||||
|
if (ifa->state <= OSPF_IS_LOOP)
|
||||||
|
return 1;
|
||||||
|
|
||||||
int src_local, dst_local, dst_mcast;
|
int src_local, dst_local, dst_mcast;
|
||||||
src_local = ipa_in_net(sk->faddr, ifa->addr->prefix, ifa->addr->pxlen);
|
src_local = ipa_in_net(sk->faddr, ifa->addr->prefix, ifa->addr->pxlen);
|
||||||
dst_local = ipa_equal(sk->laddr, ifa->addr->ip);
|
dst_local = ipa_equal(sk->laddr, ifa->addr->ip);
|
||||||
|
|
Loading…
Reference in a new issue