summaryrefslogtreecommitdiff
path: root/usr.sbin/ospfd
diff options
context:
space:
mode:
Diffstat (limited to 'usr.sbin/ospfd')
-rw-r--r--usr.sbin/ospfd/rde.c8
-rw-r--r--usr.sbin/ospfd/rde.h4
-rw-r--r--usr.sbin/ospfd/rde_spf.c10
3 files changed, 14 insertions, 8 deletions
diff --git a/usr.sbin/ospfd/rde.c b/usr.sbin/ospfd/rde.c
index 186b2f2f07c..9d88bd33d49 100644
--- a/usr.sbin/ospfd/rde.c
+++ b/usr.sbin/ospfd/rde.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: rde.c,v 1.37 2006/01/12 15:10:02 claudio Exp $ */
+/* $OpenBSD: rde.c,v 1.38 2006/02/10 13:00:49 claudio Exp $ */
/*
* Copyright (c) 2004, 2005 Claudio Jeker <claudio@openbsd.org>
@@ -273,8 +273,12 @@ rde_dispatch_imsg(int fd, short event, void *bula)
fatalx("rde_dispatch_imsg: "
"neighbor does not exist");
- nbr->state = state;
+ if (state != nbr->state && (nbr->state & NBR_STA_FULL ||
+ state & NBR_STA_FULL))
+ area_track(nbr->area, state);
+
+ nbr->state = state;
if (nbr->state & NBR_STA_FULL)
rde_req_list_free(nbr);
break;
diff --git a/usr.sbin/ospfd/rde.h b/usr.sbin/ospfd/rde.h
index 2f11ecafb05..65f31116a12 100644
--- a/usr.sbin/ospfd/rde.h
+++ b/usr.sbin/ospfd/rde.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: rde.h,v 1.24 2006/02/02 15:10:57 norby Exp $ */
+/* $OpenBSD: rde.h,v 1.25 2006/02/10 13:00:49 claudio Exp $ */
/*
* Copyright (c) 2004, 2005 Esben Norby <norby@openbsd.org>
@@ -119,7 +119,7 @@ void lsa_remove_invalid_sums(struct area *);
/* rde_spf.c */
void spf_calc(struct area *);
-void rt_calc(struct vertex *, struct area *);
+void rt_calc(struct vertex *, struct area *, struct ospfd_conf *);
void asext_calc(struct vertex *);
void spf_tree_clr(struct area *);
diff --git a/usr.sbin/ospfd/rde_spf.c b/usr.sbin/ospfd/rde_spf.c
index 72818bdca9a..4607e152a38 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.47 2006/02/09 20:47:20 norby Exp $ */
+/* $OpenBSD: rde_spf.c,v 1.48 2006/02/10 13:00:49 claudio Exp $ */
/*
* Copyright (c) 2005 Esben Norby <norby@openbsd.org>
@@ -202,7 +202,7 @@ spf_calc(struct area *area)
}
void
-rt_calc(struct vertex *v, struct area *area)
+rt_calc(struct vertex *v, struct area *area, struct ospfd_conf *conf)
{
struct vertex *w;
struct lsa_rtr_link *rtr_link = NULL;
@@ -256,6 +256,8 @@ rt_calc(struct vertex *v, struct area *area)
case LSA_TYPE_SUM_NETWORK:
case LSA_TYPE_SUM_ROUTER:
/* if ABR only look at area 0.0.0.0 LSA */
+ if (area_border_router(conf) && area->id.s_addr != INADDR_ANY)
+ return;
/* ignore self-originated stuff */
if (v->nbr->self)
@@ -542,7 +544,7 @@ spf_timer(int fd, short event, void *arg)
/* calculate route table */
RB_FOREACH(v, lsa_tree, &area->lsa_tree) {
- rt_calc(v, area);
+ rt_calc(v, area, conf);
}
area->dirty = 0;
@@ -550,7 +552,7 @@ spf_timer(int fd, short event, void *arg)
}
/* calculate as-external routes */
- RB_FOREACH(v, lsa_tree, &rdeconf->lsa_tree) {
+ RB_FOREACH(v, lsa_tree, &conf->lsa_tree) {
asext_calc(v);
}