summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorClaudio Jeker <claudio@cvs.openbsd.org>2007-10-11 08:21:30 +0000
committerClaudio Jeker <claudio@cvs.openbsd.org>2007-10-11 08:21:30 +0000
commit9c0d95cb3e60aa6706fc0795e4e00c0dbc5510c7 (patch)
tree5a44945e256b5063598a03ea55e662566f234b0a
parent0985786502a8aaaaa406b75817b113c4d080ed3a (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.c61
-rw-r--r--usr.sbin/ospfd/neighbor.c10
-rw-r--r--usr.sbin/ospfd/ospfe.h5
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 */