diff options
author | Claudio Jeker <claudio@cvs.openbsd.org> | 2005-02-09 16:37:30 +0000 |
---|---|---|
committer | Claudio Jeker <claudio@cvs.openbsd.org> | 2005-02-09 16:37:30 +0000 |
commit | 2a9d3c8040bea60f113b573b91ac44a9c794dfac (patch) | |
tree | 3b2a3e981ecbe0bb9286c3ef33df50a5577a1184 /usr.sbin | |
parent | 3a13655888ba9cd57a68f525c822fc5cd659a769 (diff) |
Don't elect neighbors that are down and fix a stupid copy-pasto.
Diffstat (limited to 'usr.sbin')
-rw-r--r-- | usr.sbin/ospfd/interface.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/usr.sbin/ospfd/interface.c b/usr.sbin/ospfd/interface.c index 46277eb4f7f..a6eb36781cc 100644 --- a/usr.sbin/ospfd/interface.c +++ b/usr.sbin/ospfd/interface.c @@ -1,4 +1,4 @@ -/* $OpenBSD: interface.c,v 1.5 2005/02/09 16:32:32 claudio Exp $ */ +/* $OpenBSD: interface.c,v 1.6 2005/02/09 16:37:29 claudio Exp $ */ /* * Copyright (c) 2005 Claudio Jeker <claudio@openbsd.org> @@ -429,6 +429,7 @@ start: /* elect backup designated router */ LIST_FOREACH(nbr, &iface->nbr_list, entry) { if (nbr->priority == 0 || nbr == dr || /* not electable */ + nbr->state & NBR_STA_DOWN || /* not available */ nbr->dr.s_addr == nbr->addr.s_addr) /* don't elect DR */ continue; if (bdr != NULL) { @@ -446,14 +447,14 @@ start: inet_ntop(AF_INET, &bdr->addr, b4, sizeof(b4)) : "none"); /* elect designated router */ LIST_FOREACH(nbr, &iface->nbr_list, entry) { - if (nbr->priority == 0 || (nbr != dr && - nbr->dr.s_addr != nbr->addr.s_addr)) + if (nbr->priority == 0 || nbr->state & NBR_STA_DOWN || + (nbr != dr && nbr->dr.s_addr != nbr->addr.s_addr)) /* only DR may be elected check priority too */ continue; if (dr == NULL || bdr == NULL) dr = nbr; else - dr = if_elect(bdr, nbr); + dr = if_elect(dr, nbr); } log_debug("if_act_elect: dr %s", dr ? inet_ntop(AF_INET, &dr->addr, b4, sizeof(b4)) : "none"); |