diff --git a/proto/ospf/packet.c b/proto/ospf/packet.c index d156474..8479c30 100644 --- a/proto/ospf/packet.c +++ b/proto/ospf/packet.c @@ -60,12 +60,13 @@ ospf_pkt_finalize(struct ospf_iface *ifa, struct ospf_packet *pkt) struct MD5Context ctxt; char password[OSPF_AUTH_CRYPT_SIZE]; + pkt->checksum = 0; pkt->autype = htons(ifa->autype); + bzero(&pkt->u, sizeof(union ospf_auth)); switch(ifa->autype) { case OSPF_AUTH_SIMPLE: - bzero(&pkt->u, sizeof(union ospf_auth)); passwd = password_find(ifa->passwords, 1); if (!passwd) { @@ -74,7 +75,6 @@ ospf_pkt_finalize(struct ospf_iface *ifa, struct ospf_packet *pkt) } password_cpy(pkt->u.password, passwd->password, sizeof(union ospf_auth)); case OSPF_AUTH_NONE: - pkt->checksum = 0; pkt->checksum = ipsum_calculate(pkt, sizeof(struct ospf_packet) - sizeof(union ospf_auth), (pkt + 1), ntohs(pkt->length) - @@ -88,8 +88,6 @@ ospf_pkt_finalize(struct ospf_iface *ifa, struct ospf_packet *pkt) return; } - pkt->checksum = 0; - /* Perhaps use random value to prevent replay attacks after reboot when system does not have independent RTC? */ if (!ifa->csn)