On 23. Dec 2011, at 19:46 , John Baldwin wrote: > 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.
I think they should be good; may I ask you to fix the locking in one commit and the "style" foreach one in another? /bz > 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 -- Bjoern A. Zeeb You have to have visions! Stop bit received. Insert coin for new address family. _______________________________________________ freebsd-net@freebsd.org mailing list http://lists.freebsd.org/mailman/listinfo/freebsd-net To unsubscribe, send any mail to "freebsd-net-unsubscr...@freebsd.org"