diff options
author | Ondrej Filip <feela@network.cz> | 1999-05-14 08:46:06 +0000 |
---|---|---|
committer | Ondrej Filip <feela@network.cz> | 1999-05-14 08:46:06 +0000 |
commit | 67ff91302f21f6a40201bcc8a01c9c76eaaf1ed1 (patch) | |
tree | 1b8bcef47c9caa316f0e9034fa02696d31d5affc /proto/ospf/ospf.c | |
parent | 7426ee3d49fab13428f198c78c8b7f3da131382e (diff) |
Netmask checking for hello packets added.
Diffstat (limited to 'proto/ospf/ospf.c')
-rw-r--r-- | proto/ospf/ospf.c | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/proto/ospf/ospf.c b/proto/ospf/ospf.c index 6996540f..5c303d4f 100644 --- a/proto/ospf/ospf.c +++ b/proto/ospf/ospf.c @@ -27,10 +27,22 @@ void ospf_hello_rx(struct ospf_hello_packet *ps, struct proto *p, struct ospf_iface *ifa) { + char sip[100]; /* FIXME: Should be smaller */ + + if(ipa_mklen(ipa_ntoh(ps->netmask))!=ifa->iface->addr->pxlen) + { + ip_ntop(ps->netmask,sip); + log("%s: Bad OSPF packet from %d received: bad netmask %s.", + p->name, ntohl(((struct ospf_packet *)ps)->routerid), sip); + /*ip_ntop(ps->netmask, sip));*/ + log("%s: Discarding",p->name); + return; + } + switch(ifa->state) { case OSPF_IS_DOWN: - die("%s: Iface %s in down state?",p->name, ifa->iface->name); + die("%s: Iface %s in down state?", p->name, ifa->iface->name); break; case OSPF_IS_WAITING: DBG(p->name); |