summaryrefslogtreecommitdiff
path: root/usr.sbin
diff options
context:
space:
mode:
Diffstat (limited to 'usr.sbin')
-rw-r--r--usr.sbin/ospf6d/interface.c10
-rw-r--r--usr.sbin/ospf6d/neighbor.c6
-rw-r--r--usr.sbin/ospf6d/ospf6d.c4
-rw-r--r--usr.sbin/ospf6d/ospfe.c19
-rw-r--r--usr.sbin/ospf6d/ospfe.h4
-rw-r--r--usr.sbin/ospf6d/rde.c4
-rw-r--r--usr.sbin/ospf6d/rde_lsdb.c8
7 files changed, 20 insertions, 35 deletions
diff --git a/usr.sbin/ospf6d/interface.c b/usr.sbin/ospf6d/interface.c
index ad0fb9f1df5..d91eb3bd882 100644
--- a/usr.sbin/ospf6d/interface.c
+++ b/usr.sbin/ospf6d/interface.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: interface.c,v 1.27 2019/12/23 07:33:49 denis Exp $ */
+/* $OpenBSD: interface.c,v 1.28 2020/01/02 10:16:46 denis Exp $ */
/*
* Copyright (c) 2005 Claudio Jeker <claudio@openbsd.org>
@@ -144,7 +144,7 @@ if_fsm(struct iface *iface, enum iface_event event)
if (iface->state != old_state) {
area_track(iface->area);
- orig_rtr_lsa(iface);
+ orig_rtr_lsa(iface->area);
orig_link_lsa(iface);
/* state change inform RDE */
@@ -395,7 +395,7 @@ if_act_start(struct iface *iface)
if (iface->cflags & F_IFACE_PASSIVE) {
/* for an update of stub network entries */
- orig_rtr_lsa(iface);
+ orig_rtr_lsa(iface->area);
return (0);
}
@@ -569,7 +569,7 @@ start:
nbr_fsm(nbr, NBR_EVT_ADJ_OK);
}
- orig_rtr_lsa(iface);
+ orig_rtr_lsa(iface->area);
if (iface->state & IF_STA_DR || old_state & IF_STA_DR)
orig_net_lsa(iface);
}
@@ -586,7 +586,7 @@ if_act_reset(struct iface *iface)
if (iface->cflags & F_IFACE_PASSIVE) {
/* for an update of stub network entries */
- orig_rtr_lsa(iface);
+ orig_rtr_lsa(iface->area);
return (0);
}
diff --git a/usr.sbin/ospf6d/neighbor.c b/usr.sbin/ospf6d/neighbor.c
index df8564f4b1f..8e13b7644e7 100644
--- a/usr.sbin/ospf6d/neighbor.c
+++ b/usr.sbin/ospf6d/neighbor.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: neighbor.c,v 1.15 2019/12/23 07:33:49 denis Exp $ */
+/* $OpenBSD: neighbor.c,v 1.16 2020/01/02 10:16:46 denis Exp $ */
/*
* Copyright (c) 2005 Claudio Jeker <claudio@openbsd.org>
@@ -202,7 +202,7 @@ nbr_fsm(struct nbr *nbr, enum nbr_event event)
* neighbor changed from/to FULL
* originate new rtr and net LSA
*/
- orig_rtr_lsa(nbr->iface);
+ orig_rtr_lsa(nbr->iface->area);
if (nbr->iface->state & IF_STA_DR)
orig_net_lsa(nbr->iface);
@@ -226,7 +226,7 @@ nbr_fsm(struct nbr *nbr, enum nbr_event event)
nbr_state_name(nbr->state));
if (nbr->iface->type == IF_TYPE_VIRTUALLINK) {
- orig_rtr_lsa(nbr->iface);
+ orig_rtr_lsa(nbr->iface->area);
}
}
diff --git a/usr.sbin/ospf6d/ospf6d.c b/usr.sbin/ospf6d/ospf6d.c
index 703992230ad..26e15b09782 100644
--- a/usr.sbin/ospf6d/ospf6d.c
+++ b/usr.sbin/ospf6d/ospf6d.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ospf6d.c,v 1.45 2019/12/16 08:28:33 denis Exp $ */
+/* $OpenBSD: ospf6d.c,v 1.46 2020/01/02 10:16:46 denis Exp $ */
/*
* Copyright (c) 2005 Claudio Jeker <claudio@openbsd.org>
@@ -741,7 +741,7 @@ merge_config(struct ospfd_conf *conf, struct ospfd_conf *xconf)
}
if (a->dirty) {
a->dirty = 0;
- orig_rtr_lsa(LIST_FIRST(&a->iface_list));
+ orig_rtr_lsa(LIST_FIRST(&a->iface_list)->area);
}
}
}
diff --git a/usr.sbin/ospf6d/ospfe.c b/usr.sbin/ospf6d/ospfe.c
index 5d0744681f7..07413f2807e 100644
--- a/usr.sbin/ospf6d/ospfe.c
+++ b/usr.sbin/ospf6d/ospfe.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ospfe.c,v 1.60 2020/01/01 10:09:34 denis Exp $ */
+/* $OpenBSD: ospfe.c,v 1.61 2020/01/02 10:16:46 denis Exp $ */
/*
* Copyright (c) 2005 Claudio Jeker <claudio@openbsd.org>
@@ -45,7 +45,6 @@
void ospfe_sig_handler(int, short, void *);
__dead void ospfe_shutdown(void);
void orig_rtr_lsa_all(struct area *);
-void orig_rtr_lsa_area(struct area *);
struct iface *find_vlink(struct abr_rtr *);
struct ospfd_conf *oeconf = NULL, *nconf;
@@ -297,7 +296,7 @@ ospfe_dispatch_main(int fd, short event, void *bula)
i->depend_ok =
ifstate_is_up(ifp);
if (ifstate_is_up(i))
- orig_rtr_lsa(i);
+ orig_rtr_lsa(i->area);
}
}
}
@@ -596,8 +595,6 @@ ospfe_dispatch_rde(int fd, short event, void *bula)
* flood on all area interfaces on
* area 0.0.0.0 include also virtual links.
*/
- if (nbr->iface->area == NULL)
- fatalx("interface lost area");
LIST_FOREACH(iface,
&nbr->iface->area->iface_list, entry) {
noack += lsa_flood(iface, nbr,
@@ -795,19 +792,11 @@ orig_rtr_lsa_all(struct area *area)
*/
LIST_FOREACH(a, &oeconf->area_list, entry)
if (a != area)
- orig_rtr_lsa_area(a);
+ orig_rtr_lsa(a);
}
void
-orig_rtr_lsa(struct iface *iface)
-{
- if (iface->area == NULL)
- fatalx("interface lost area");
- orig_rtr_lsa_area(iface->area);
-}
-
-void
-orig_rtr_lsa_area(struct area *area)
+orig_rtr_lsa(struct area *area)
{
struct lsa_hdr lsa_hdr;
struct lsa_rtr lsa_rtr;
diff --git a/usr.sbin/ospf6d/ospfe.h b/usr.sbin/ospf6d/ospfe.h
index dcdde44bdcd..e8c4f9b2985 100644
--- a/usr.sbin/ospf6d/ospfe.h
+++ b/usr.sbin/ospf6d/ospfe.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: ospfe.h,v 1.22 2019/12/28 09:25:24 denis Exp $ */
+/* $OpenBSD: ospfe.h,v 1.23 2020/01/02 10:16:46 denis Exp $ */
/*
* Copyright (c) 2004, 2005 Esben Norby <norby@openbsd.org>
@@ -121,7 +121,7 @@ u_int32_t ospfe_router_id(void);
void ospfe_fib_update(int);
void ospfe_iface_ctl(struct ctl_conn *, unsigned int);
void ospfe_nbr_ctl(struct ctl_conn *);
-void orig_rtr_lsa(struct iface *);
+void orig_rtr_lsa(struct area *);
void orig_net_lsa(struct iface *);
void orig_link_lsa(struct iface *);
void ospfe_demote_area(struct area *, int);
diff --git a/usr.sbin/ospf6d/rde.c b/usr.sbin/ospf6d/rde.c
index b2d58eb2cc9..50acfa416f7 100644
--- a/usr.sbin/ospf6d/rde.c
+++ b/usr.sbin/ospf6d/rde.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: rde.c,v 1.81 2019/12/23 07:33:49 denis Exp $ */
+/* $OpenBSD: rde.c,v 1.82 2020/01/02 10:16:46 denis Exp $ */
/*
* Copyright (c) 2004, 2005 Claudio Jeker <claudio@openbsd.org>
@@ -753,8 +753,6 @@ rde_dispatch_parent(int fd, short event, void *bula)
if (prev_link_ok == link_ok)
break;
- if (iface->area == NULL)
- fatalx("interface lost area");
orig_intra_area_prefix_lsas(iface->area);
break;
diff --git a/usr.sbin/ospf6d/rde_lsdb.c b/usr.sbin/ospf6d/rde_lsdb.c
index 1a53efff680..3326c1e90cf 100644
--- a/usr.sbin/ospf6d/rde_lsdb.c
+++ b/usr.sbin/ospf6d/rde_lsdb.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: rde_lsdb.c,v 1.40 2019/12/23 07:33:49 denis Exp $ */
+/* $OpenBSD: rde_lsdb.c,v 1.41 2020/01/02 10:16:46 denis Exp $ */
/*
* Copyright (c) 2004, 2005 Claudio Jeker <claudio@openbsd.org>
@@ -573,11 +573,9 @@ lsa_find(struct iface *iface, u_int16_t type, u_int32_t ls_id,
if (LSA_IS_SCOPE_AS(ntohs(type)))
tree = &asext_tree;
- else if (LSA_IS_SCOPE_AREA(ntohs(type))) {
- if (iface->area == NULL)
- fatalx("interface lost area");
+ else if (LSA_IS_SCOPE_AREA(ntohs(type)))
tree = &iface->area->lsa_tree;
- } else if (LSA_IS_SCOPE_LLOCAL(ntohs(type)))
+ else if (LSA_IS_SCOPE_LLOCAL(ntohs(type)))
tree = &iface->lsa_tree;
else
fatalx("unknown scope type");