summaryrefslogtreecommitdiff
path: root/sys/net/if.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/net/if.c')
-rw-r--r--sys/net/if.c56
1 files changed, 32 insertions, 24 deletions
diff --git a/sys/net/if.c b/sys/net/if.c
index 9278b1bba7c..97bf45555fa 100644
--- a/sys/net/if.c
+++ b/sys/net/if.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if.c,v 1.49 2001/06/29 22:46:05 fgsch Exp $ */
+/* $OpenBSD: if.c,v 1.50 2001/12/09 12:57:26 jason Exp $ */
/* $NetBSD: if.c,v 1.35 1996/05/07 05:26:04 thorpej Exp $ */
/*
@@ -409,8 +409,8 @@ ifa_ifwithaddr(addr)
#define equal(a1, a2) \
(bcmp((caddr_t)(a1), (caddr_t)(a2), ((struct sockaddr *)(a1))->sa_len) == 0)
- for (ifp = ifnet.tqh_first; ifp != 0; ifp = ifp->if_list.tqe_next)
- for (ifa = ifp->if_addrlist.tqh_first; ifa != 0; ifa = ifa->ifa_list.tqe_next) {
+ TAILQ_FOREACH(ifp, &ifnet, if_list) {
+ TAILQ_FOREACH(ifa, &ifp->if_addrlist, ifa_list) {
if (ifa->ifa_addr->sa_family != addr->sa_family)
continue;
if (equal(addr, ifa->ifa_addr))
@@ -420,6 +420,7 @@ ifa_ifwithaddr(addr)
ifa->ifa_broadaddr->sa_len != 0 &&
equal(ifa->ifa_broadaddr, addr))
return (ifa);
+ }
}
return (NULL);
}
@@ -434,14 +435,15 @@ ifa_ifwithdstaddr(addr)
register struct ifnet *ifp;
register struct ifaddr *ifa;
- for (ifp = ifnet.tqh_first; ifp != 0; ifp = ifp->if_list.tqe_next)
+ TAILQ_FOREACH(ifp, &ifnet, if_list) {
if (ifp->if_flags & IFF_POINTOPOINT)
- for (ifa = ifp->if_addrlist.tqh_first; ifa != 0; ifa = ifa->ifa_list.tqe_next) {
+ TAILQ_FOREACH(ifa, &ifp->if_addrlist, ifa_list) {
if (ifa->ifa_addr->sa_family != addr->sa_family ||
ifa->ifa_dstaddr == NULL)
continue;
if (equal(addr, ifa->ifa_dstaddr))
return (ifa);
+ }
}
return (NULL);
}
@@ -465,8 +467,8 @@ ifa_ifwithnet(addr)
if (sdl->sdl_index && sdl->sdl_index <= if_index)
return (ifnet_addrs[sdl->sdl_index]);
}
- for (ifp = ifnet.tqh_first; ifp != 0; ifp = ifp->if_list.tqe_next)
- for (ifa = ifp->if_addrlist.tqh_first; ifa != 0; ifa = ifa->ifa_list.tqe_next) {
+ TAILQ_FOREACH(ifp, &ifnet, if_list) {
+ TAILQ_FOREACH(ifa, &ifp->if_addrlist, ifa_list) {
register char *cp, *cp2, *cp3;
if (ifa->ifa_addr->sa_family != af ||
@@ -486,6 +488,7 @@ ifa_ifwithnet(addr)
(caddr_t)ifa_maybe->ifa_netmask))
ifa_maybe = ifa;
}
+ }
return (ifa_maybe);
}
@@ -499,10 +502,12 @@ ifa_ifwithaf(af)
register struct ifnet *ifp;
register struct ifaddr *ifa;
- for (ifp = ifnet.tqh_first; ifp != 0; ifp = ifp->if_list.tqe_next)
- for (ifa = ifp->if_addrlist.tqh_first; ifa != 0; ifa = ifa->ifa_list.tqe_next)
+ TAILQ_FOREACH(ifp, &ifnet, if_list) {
+ TAILQ_FOREACH(ifa, &ifp->if_addrlist, ifa_list) {
if (ifa->ifa_addr->sa_family == af)
return (ifa);
+ }
+ }
return (NULL);
}
@@ -523,7 +528,7 @@ ifaof_ifpforaddr(addr, ifp)
if (af >= AF_MAX)
return (NULL);
- for (ifa = ifp->if_addrlist.tqh_first; ifa != 0; ifa = ifa->ifa_list.tqe_next) {
+ TAILQ_FOREACH(ifa, &ifp->if_addrlist, ifa_list) {
if (ifa->ifa_addr->sa_family != af)
continue;
ifa_maybe = ifa;
@@ -588,8 +593,9 @@ if_down(ifp)
ifp->if_flags &= ~IFF_UP;
microtime(&ifp->if_lastchange);
- for (ifa = ifp->if_addrlist.tqh_first; ifa != 0; ifa = ifa->ifa_list.tqe_next)
+ TAILQ_FOREACH(ifa, &ifp->if_addrlist, ifa_list) {
pfctlinput(PRC_IFDOWN, ifa->ifa_addr);
+ }
IFQ_PURGE(&ifp->if_snd);
rt_ifmsg(ifp);
@@ -623,9 +629,9 @@ if_up(ifp)
microtime(&ifp->if_lastchange);
#ifdef notyet
/* this has no effect on IP, and will kill all ISO connections XXX */
- for (ifa = ifp->if_addrlist.tqh_first; ifa != 0;
- ifa = ifa->ifa_list.tqe_next)
+ TAILQ_FOREACH(ifa, &ifp->if_addrlist, ifa_list) {
pfctlinput(PRC_IFUP, ifa->ifa_addr);
+ }
#endif
rt_ifmsg(ifp);
#ifdef INET6
@@ -675,7 +681,7 @@ if_slowtimo(arg)
struct ifnet *ifp;
int s = splimp();
- for (ifp = ifnet.tqh_first; ifp != 0; ifp = ifp->if_list.tqe_next) {
+ TAILQ_FOREACH(ifp, &ifnet, if_list) {
if (ifp->if_timer == 0 || --ifp->if_timer)
continue;
if (ifp->if_watchdog)
@@ -695,10 +701,10 @@ ifunit(name)
{
register struct ifnet *ifp;
- for (ifp = ifnet.tqh_first; ifp != 0; ifp = ifp->if_list.tqe_next)
+ TAILQ_FOREACH(ifp, &ifnet, if_list) {
if (strcmp(ifp->if_xname, name) == 0)
return (ifp);
-
+ }
return (NULL);
}
@@ -908,13 +914,13 @@ ifconf(cmd, data)
/* If ifc->ifc_len is 0, fill it in with the needed size and return. */
if (space == 0) {
- for (ifp = ifnet.tqh_first; ifp; ifp = ifp->if_list.tqe_next) {
+ TAILQ_FOREACH(ifp, &ifnet, if_list) {
register struct sockaddr *sa;
- if ((ifa = ifp->if_addrlist.tqh_first) == 0)
+ if (TAILQ_EMPTY(&ifp->if_addrlist))
space += sizeof (ifr);
else
- for (; ifa != 0; ifa = ifa->ifa_list.tqe_next) {
+ TAILQ_FOREACH(ifa, &ifp->if_addrlist, ifa_list) {
sa = ifa->ifa_addr;
#if defined(COMPAT_43) || defined(COMPAT_LINUX) || defined(COMPAT_SVR4)
if (cmd != OSIOCGIFCONF)
@@ -930,10 +936,10 @@ ifconf(cmd, data)
}
ifrp = ifc->ifc_req;
- for (ifp = ifnet.tqh_first; space >= sizeof (ifr) && ifp != 0;
- ifp = ifp->if_list.tqe_next) {
+ for (ifp = TAILQ_FIRST(&ifnet); space >= sizeof(ifr) &&
+ ifp != TAILQ_END(&ifnet); ifp = TAILQ_NEXT(ifp, if_list)) {
bcopy(ifp->if_xname, ifr.ifr_name, IFNAMSIZ);
- if ((ifa = ifp->if_addrlist.tqh_first) == 0) {
+ if (TAILQ_EMPTY(&ifp->if_addrlist)) {
bzero((caddr_t)&ifr.ifr_addr, sizeof(ifr.ifr_addr));
error = copyout((caddr_t)&ifr, (caddr_t)ifrp,
sizeof(ifr));
@@ -941,8 +947,10 @@ ifconf(cmd, data)
break;
space -= sizeof (ifr), ifrp++;
} else
- for (; space >= sizeof (ifr) && ifa != 0;
- ifa = ifa->ifa_list.tqe_next) {
+ for (ifa = TAILQ_FIRST(&ifp->if_addrlist);
+ space >= sizeof (ifr) &&
+ ifa != TAILQ_END(&ifp->if_addrlist);
+ ifa = TAILQ_NEXT(ifa, ifa_list)) {
register struct sockaddr *sa = ifa->ifa_addr;
#if defined(COMPAT_43) || defined(COMPAT_LINUX) || defined(COMPAT_SVR4)
if (cmd == OSIOCGIFCONF) {