Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 23 Dec 2011 14:46:37 -0500
From:      John Baldwin <jhb@freebsd.org>
To:        net@freebsd.org
Cc:        Bjoern Zeeb <bz@freebsd.org>
Subject:   [PATCH] Minor fixes to netinet6/icmp6.c
Message-ID:  <201112231446.38057.jhb@freebsd.org>

next in thread | raw e-mail | index | archive | help
I found these nits while working on the patches to convert if_addr_mtx to an 
rwlock.  The first change is cosmetic, it just un-inlines a TAILQ_FOREACH().  
The second change is an actual bug.  The code is currently reading 
TAILQ_FIRST(&V_ifnet) without holding the appropriate lock.

Index: icmp6.c
===================================================================
--- icmp6.c	(revision 228777)
+++ icmp6.c	(working copy)
@@ -1780,7 +1780,7 @@ ni6_addrs(struct icmp6_nodeinfo *ni6, struct mbuf
 	}
 
 	IFNET_RLOCK_NOSLEEP();
-	for (ifp = TAILQ_FIRST(&V_ifnet); ifp; ifp = TAILQ_NEXT(ifp, if_list)) {
+	TAILQ_FOREACH(ifp, &V_ifnet, if_list) {
 		addrsofif = 0;
 		IF_ADDR_LOCK(ifp);
 		TAILQ_FOREACH(ifa, &ifp->if_addrhead, ifa_link) {
@@ -1851,7 +1851,7 @@ static int
 ni6_store_addrs(struct icmp6_nodeinfo *ni6, struct icmp6_nodeinfo *nni6,
     struct ifnet *ifp0, int resid)
 {
-	struct ifnet *ifp = ifp0 ? ifp0 : TAILQ_FIRST(&V_ifnet);
+	struct ifnet *ifp;
 	struct in6_ifaddr *ifa6;
 	struct ifaddr *ifa;
 	struct ifnet *ifp_dep = NULL;
@@ -1864,6 +1864,7 @@ ni6_store_addrs(struct icmp6_nodeinfo *ni6, struct
 		return (0);	/* needless to copy */
 
 	IFNET_RLOCK_NOSLEEP();
+	ifp = ifp0 ? ifp0 : TAILQ_FIRST(&V_ifnet);
   again:
 
 	for (; ifp; ifp = TAILQ_NEXT(ifp, if_list)) {

-- 
John Baldwin



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201112231446.38057.jhb>