summaryrefslogtreecommitdiff
path: root/proto/ospf
diff options
context:
space:
mode:
authorOndrej Zajicek (work) <santiago@crfreenet.org>2015-10-17 14:44:34 +0200
committerOndrej Zajicek (work) <santiago@crfreenet.org>2015-10-17 14:44:34 +0200
commit8eb8e546dc8cc647fcfa4a3a17dfa8ab36b00958 (patch)
tree837c79b9e4adbe8d9d5fb2ffaa56f89b5e491db2 /proto/ospf
parent8465dccb06afffed171dc1e224e4eb5f67cc3326 (diff)
parentacb04cfdc550697a7171a86ca559fd8c52841acb (diff)
Merge branch 'master' into rip-new
Diffstat (limited to 'proto/ospf')
-rw-r--r--proto/ospf/iface.c7
-rw-r--r--proto/ospf/packet.c4
2 files changed, 9 insertions, 2 deletions
diff --git a/proto/ospf/iface.c b/proto/ospf/iface.c
index 9b0f7797..77ce839a 100644
--- a/proto/ospf/iface.c
+++ b/proto/ospf/iface.c
@@ -493,8 +493,11 @@ ospf_iface_add(struct object_lock *lock)
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 */
- ospf_iface_sm(ifa, (ifa->check_link && !(ifa->iface->flags & IF_LINK_UP)) ? ISM_LOOP : ISM_UP);
+ /* Do iface UP, unless there is no link (then wait in LOOP state) */
+ 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
diff --git a/proto/ospf/packet.c b/proto/ospf/packet.c
index 65842037..5af9e875 100644
--- a/proto/ospf/packet.c
+++ b/proto/ospf/packet.c
@@ -231,6 +231,10 @@ ospf_rx_hook(sock *sk, int len)
const char *err_dsc = NULL;
uint err_val = 0;
+ /* Should not happen */
+ if (ifa->state <= OSPF_IS_LOOP)
+ return 1;
+
int src_local, dst_local, dst_mcast;
src_local = ipa_in_net(sk->faddr, ifa->addr->prefix, ifa->addr->pxlen);
dst_local = ipa_equal(sk->laddr, ifa->addr->ip);