diff options
author | Claudio Jeker <claudio@cvs.openbsd.org> | 2007-10-11 08:21:30 +0000 |
---|---|---|
committer | Claudio Jeker <claudio@cvs.openbsd.org> | 2007-10-11 08:21:30 +0000 |
commit | 9c0d95cb3e60aa6706fc0795e4e00c0dbc5510c7 (patch) | |
tree | 5a44945e256b5063598a03ea55e662566f234b0a | |
parent | 0985786502a8aaaaa406b75817b113c4d080ed3a (diff) |
Do not overload nbr->options with the dd exchange bits. nbr->options is used
by the hello protocol. Instead add a dd_more flag that is used together with
(the renamed) dd_master flag.
Tested and OK norby@
-rw-r--r-- | usr.sbin/ospfd/database.c | 61 | ||||
-rw-r--r-- | usr.sbin/ospfd/neighbor.c | 10 | ||||
-rw-r--r-- | usr.sbin/ospfd/ospfe.h | 5 |
3 files changed, 39 insertions, 37 deletions
diff --git a/usr.sbin/ospfd/database.c b/usr.sbin/ospfd/database.c index 0610c84da58..b222d82a4b4 100644 --- a/usr.sbin/ospfd/database.c +++ b/usr.sbin/ospfd/database.c @@ -1,4 +1,4 @@ -/* $OpenBSD: database.c,v 1.19 2006/03/13 09:36:06 claudio Exp $ */ +/* $OpenBSD: database.c,v 1.20 2007/10/11 08:21:29 claudio Exp $ */ /* * Copyright (c) 2005 Claudio Jeker <claudio@openbsd.org> @@ -45,6 +45,7 @@ send_db_description(struct nbr *nbr) struct lsa_entry *le, *nle; struct buf *buf; int ret = 0; + u_int8_t bits = 0; if ((buf = buf_open(nbr->iface->mtu - sizeof(struct ip))) == NULL) fatal("send_db_description"); @@ -69,23 +70,24 @@ send_db_description(struct nbr *nbr) ret = -1; goto done; case NBR_STA_XSTRT: - nbr->options |= OSPF_DBD_MS | OSPF_DBD_M | OSPF_DBD_I; + bits |= OSPF_DBD_MS | OSPF_DBD_M | OSPF_DBD_I; + nbr->dd_more = 1; break; case NBR_STA_XCHNG: - if (nbr->master) { - /* master */ - nbr->options |= OSPF_DBD_MS; + if (nbr->dd_master) + bits |= OSPF_DBD_MS; + else + bits &= ~OSPF_DBD_MS; + + if (TAILQ_EMPTY(&nbr->db_sum_list)) { + bits &= ~OSPF_DBD_M; + nbr->dd_more = 0; } else { - /* slave */ - nbr->options &= ~OSPF_DBD_MS; + bits |= OSPF_DBD_M; + nbr->dd_more = 1; } - if (TAILQ_EMPTY(&nbr->db_sum_list)) - nbr->options &= ~OSPF_DBD_M; - else - nbr->options |= OSPF_DBD_M; - - nbr->options &= ~OSPF_DBD_I; + bits &= ~OSPF_DBD_I; /* build LSA list, keep space for a possible md5 sum */ for (le = TAILQ_FIRST(&nbr->db_sum_list); le != NULL && @@ -98,16 +100,14 @@ send_db_description(struct nbr *nbr) break; case NBR_STA_LOAD: case NBR_STA_FULL: - if (nbr->master) { - /* master */ - nbr->options |= OSPF_DBD_MS; - } else { - /* slave */ - nbr->options &= ~OSPF_DBD_MS; - } - nbr->options &= ~OSPF_DBD_M; - nbr->options &= ~OSPF_DBD_I; + if (nbr->dd_master) + bits |= OSPF_DBD_MS; + else + bits &= ~OSPF_DBD_MS; + bits &= ~OSPF_DBD_M; + bits &= ~OSPF_DBD_I; + nbr->dd_more = 0; break; default: fatalx("send_db_description: unknown neighbor state"); @@ -139,7 +139,7 @@ send_db_description(struct nbr *nbr) } dd_hdr.opts = oeconf->options; - dd_hdr.bits = nbr->options; + dd_hdr.bits = bits; dd_hdr.dd_seq_num = htonl(nbr->dd_seq_num); memcpy(buf_seek(buf, sizeof(struct ospf_hdr), sizeof(dd_hdr)), @@ -185,7 +185,8 @@ recv_db_description(struct nbr *nbr, char *buf, u_int16_t len) if (nbr->last_rx_options == dd_hdr.opts && nbr->last_rx_bits == dd_hdr.bits && - ntohl(dd_hdr.dd_seq_num) == nbr->dd_seq_num - nbr->master ? 1 : 0) { + ntohl(dd_hdr.dd_seq_num) == nbr->dd_seq_num - nbr->dd_master ? + 1 : 0) { log_debug("recv_db_description: dupe"); dupe = 1; } @@ -217,7 +218,7 @@ recv_db_description(struct nbr *nbr, char *buf, u_int16_t len) if ((ntohl(nbr->id.s_addr)) > ntohl(ospfe_router_id())) { /* slave */ - nbr->master = 0; + nbr->dd_master = 0; nbr->dd_seq_num = ntohl(dd_hdr.dd_seq_num); /* event negotiation done */ @@ -255,7 +256,7 @@ recv_db_description(struct nbr *nbr, char *buf, u_int16_t len) case NBR_STA_LOAD: case NBR_STA_FULL: if (dd_hdr.bits & OSPF_DBD_I || - !(dd_hdr.bits & OSPF_DBD_MS) == !nbr->master) { + !(dd_hdr.bits & OSPF_DBD_MS) == !nbr->dd_master) { log_warnx("recv_db_description: seq num mismatch, " "bad flags"); nbr_fsm(nbr, NBR_EVT_SEQ_NUM_MIS); @@ -270,7 +271,7 @@ recv_db_description(struct nbr *nbr, char *buf, u_int16_t len) } if (dupe) { - if (!nbr->master) + if (!nbr->dd_master) /* retransmit */ start_db_tx_timer(nbr); return; @@ -285,7 +286,7 @@ recv_db_description(struct nbr *nbr, char *buf, u_int16_t len) } /* sanity check dd seq number */ - if (nbr->master) { + if (nbr->dd_master) { /* master */ if (ntohl(dd_hdr.dd_seq_num) != nbr->dd_seq_num) { log_warnx("recv_db_description: invalid " @@ -320,7 +321,7 @@ recv_db_description(struct nbr *nbr, char *buf, u_int16_t len) if (!(dd_hdr.bits & OSPF_DBD_M) && TAILQ_EMPTY(&nbr->db_sum_list)) - if (!nbr->master || !(nbr->options & OSPF_DBD_M)) + if (!nbr->dd_master || !nbr->dd_more) nbr_fsm(nbr, NBR_EVT_XCHNG_DONE); break; default: @@ -390,7 +391,7 @@ db_tx_timer(int fd, short event, void *arg) } /* reschedule db_tx_timer but only in master mode */ - if (nbr->master) { + if (nbr->dd_master) { timerclear(&tv); tv.tv_sec = nbr->iface->rxmt_interval; if (evtimer_add(&nbr->db_tx_timer, &tv) == -1) diff --git a/usr.sbin/ospfd/neighbor.c b/usr.sbin/ospfd/neighbor.c index a89441ab14b..ce68f96e22a 100644 --- a/usr.sbin/ospfd/neighbor.c +++ b/usr.sbin/ospfd/neighbor.c @@ -1,4 +1,4 @@ -/* $OpenBSD: neighbor.c,v 1.35 2007/06/13 17:47:52 claudio Exp $ */ +/* $OpenBSD: neighbor.c,v 1.36 2007/10/11 08:21:29 claudio Exp $ */ /* * Copyright (c) 2005 Claudio Jeker <claudio@openbsd.org> @@ -276,7 +276,7 @@ nbr_new(u_int32_t nbr_id, struct iface *iface, int self) fatal("nbr_new"); nbr->state = NBR_STA_DOWN; - nbr->master = 1; + nbr->dd_master = 1; nbr->dd_seq_num = arc4random(); /* RFC: some unique value */ nbr->id.s_addr = nbr_id; @@ -502,7 +502,7 @@ nbr_act_eval(struct nbr *nbr) } nbr->state = NBR_STA_XSTRT; - nbr->master = 1; + nbr->dd_master = 1; nbr->dd_seq_num++; /* as per RFC */ nbr->dd_pending = 0; /* initial db negotiation */ @@ -526,7 +526,7 @@ nbr_act_snapshot(struct nbr *nbr) int nbr_act_exchange_done(struct nbr *nbr) { - if (nbr->master) + if (nbr->dd_master) stop_db_tx_timer(nbr); if (ls_req_list_empty(nbr) && nbr->state == NBR_STA_XCHNG && @@ -568,7 +568,7 @@ nbr_act_restart_dd(struct nbr *nbr) } nbr->state = NBR_STA_XSTRT; - nbr->master = 1; + nbr->dd_master = 1; nbr->dd_seq_num += arc4random() & 0xffff; nbr->dd_pending = 0; diff --git a/usr.sbin/ospfd/ospfe.h b/usr.sbin/ospfd/ospfe.h index e828fe6465d..54ec653da8e 100644 --- a/usr.sbin/ospfd/ospfe.h +++ b/usr.sbin/ospfd/ospfe.h @@ -1,4 +1,4 @@ -/* $OpenBSD: ospfe.h,v 1.36 2007/05/29 22:08:25 claudio Exp $ */ +/* $OpenBSD: ospfe.h,v 1.37 2007/10/11 08:21:29 claudio Exp $ */ /* * Copyright (c) 2004, 2005 Esben Norby <norby@openbsd.org> @@ -90,7 +90,8 @@ struct nbr { u_int8_t options; u_int8_t last_rx_options; u_int8_t last_rx_bits; - u_int8_t master; + u_int8_t dd_master; + u_int8_t dd_more; }; /* auth.c */ |