diff options
author | Claudio Jeker <claudio@cvs.openbsd.org> | 2005-08-30 21:02:36 +0000 |
---|---|---|
committer | Claudio Jeker <claudio@cvs.openbsd.org> | 2005-08-30 21:02:36 +0000 |
commit | d17583154f2601b95afe247324cb69da1d7a4a8f (patch) | |
tree | 2450384ad58e3540cb56c7806d0a9d711632e163 /usr.sbin | |
parent | b8159f25a64f3163d5b2f544bf87027977935076 (diff) |
Fix a bug in the nexthop calculation for complex networks. The result was a
routing table where most entries used the local interface IP as nexthop. This
bug was found by jakob@ and he verified that it fixes his problems. Additional
tests by me and norby@.
OK norby@ deraadt@
Diffstat (limited to 'usr.sbin')
-rw-r--r-- | usr.sbin/ospfd/rde_spf.c | 27 |
1 files changed, 14 insertions, 13 deletions
diff --git a/usr.sbin/ospfd/rde_spf.c b/usr.sbin/ospfd/rde_spf.c index 745350caaa2..1cc372ae21a 100644 --- a/usr.sbin/ospfd/rde_spf.c +++ b/usr.sbin/ospfd/rde_spf.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rde_spf.c,v 1.31 2005/08/08 12:22:48 claudio Exp $ */ +/* $OpenBSD: rde_spf.c,v 1.32 2005/08/30 21:02:35 claudio Exp $ */ /* * Copyright (c) 2005 Esben Norby <norby@openbsd.org> @@ -152,7 +152,12 @@ spf_calc(struct area *area) } if (!linked(w, v)) { - log_debug("spf_calc: w has no link to v"); + a.s_addr = htonl(w->ls_id); + log_debug("spf_calc: w id %s type %d has ", + inet_ntoa(a), w->type); + a.s_addr = htonl(v->ls_id); + log_debug(" no link to v id %s type %d", + inet_ntoa(a), v->type); continue; } @@ -168,19 +173,15 @@ spf_calc(struct area *area) if (d < w->cost) { w->cost = d; w->prev = v; + calc_next_hop(w, v); } + } else if (w->cost == LS_INFINITY && d < LS_INFINITY) { + w->cost = d; - calc_next_hop(w, v); - } else { - if (w->cost == LS_INFINITY || - w->prev == NULL) { - w->cost = d; - - cand_list_add(w); - w->prev = v; + cand_list_add(w); + w->prev = v; - calc_next_hop(w, v); - } + calc_next_hop(w, v); } } @@ -201,7 +202,7 @@ spf_calc(struct area *area) switch (v->type) { case LSA_TYPE_ROUTER: /* stub networks */ - if (v->cost == LS_INFINITY || v->nexthop.s_addr == 0) + if (v->cost >= LS_INFINITY || v->nexthop.s_addr == 0) continue; for (i = 0; i < lsa_num_links(v); i++) { |