summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--usr.sbin/ospf6d/rde.h4
-rw-r--r--usr.sbin/ospf6d/rde_spf.c19
2 files changed, 10 insertions, 13 deletions
diff --git a/usr.sbin/ospf6d/rde.h b/usr.sbin/ospf6d/rde.h
index fa26b649198..d3ef2ef43ff 100644
--- a/usr.sbin/ospf6d/rde.h
+++ b/usr.sbin/ospf6d/rde.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: rde.h,v 1.15 2009/03/29 19:25:49 stsp Exp $ */
+/* $OpenBSD: rde.h,v 1.16 2009/03/29 19:28:10 stsp Exp $ */
/*
* Copyright (c) 2004, 2005 Esben Norby <norby@openbsd.org>
@@ -179,7 +179,7 @@ void rt_clear(void);
void rt_dump(struct in_addr, pid_t, u_int8_t);
struct lsa_rtr_link *get_rtr_link(struct vertex *, unsigned int);
-struct lsa_net_link *get_net_link(struct vertex *, int);
+struct lsa_net_link *get_net_link(struct vertex *, unsigned int);
RB_PROTOTYPE(lsa_tree, vertex, entry, lsa_compare)
diff --git a/usr.sbin/ospf6d/rde_spf.c b/usr.sbin/ospf6d/rde_spf.c
index 0d46ab4751d..755adb77c14 100644
--- a/usr.sbin/ospf6d/rde_spf.c
+++ b/usr.sbin/ospf6d/rde_spf.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: rde_spf.c,v 1.8 2009/03/29 19:25:49 stsp Exp $ */
+/* $OpenBSD: rde_spf.c,v 1.9 2009/03/29 19:28:10 stsp Exp $ */
/*
* Copyright (c) 2005 Esben Norby <norby@openbsd.org>
@@ -1011,25 +1011,22 @@ get_rtr_link(struct vertex *v, unsigned int idx)
/* network LSA links */
struct lsa_net_link *
-get_net_link(struct vertex *v, int idx)
+get_net_link(struct vertex *v, unsigned int idx)
{
struct lsa_net_link *net_link = NULL;
char *buf = (char *)v->lsa;
- u_int16_t i, off, nlinks;
+ unsigned int i;
if (v->type != LSA_TYPE_NETWORK)
fatalx("get_net_link: invalid LSA type");
- off = sizeof(v->lsa->hdr) + sizeof(u_int32_t);
-
- /* nlinks validated earlier by lsa_check() */
- nlinks = lsa_num_links(v);
- for (i = 0; i < nlinks; i++) {
- net_link = (struct lsa_net_link *)(buf + off);
+ /* number of links validated earlier by lsa_check() */
+ net_link = (struct lsa_net_link *)(buf + sizeof(v->lsa->hdr) +
+ sizeof(struct lsa_net));
+ for (i = 0; i < lsa_num_links(v); i++) {
if (i == idx)
return (net_link);
-
- off += sizeof(struct lsa_net_link);
+ net_link++;
}
return (NULL);