svn commit: r191341 - head/sys/netinet6
Robert Watson
rwatson at FreeBSD.org
Mon Apr 20 22:56:35 UTC 2009
Author: rwatson
Date: Mon Apr 20 22:56:34 2009
New Revision: 191341
URL: http://svn.freebsd.org/changeset/base/191341
Log:
Assert the interface address list lock in IFP_TO_IA6(), as it will
iterate the interface address list. Marginally expand IF_ADDR_LOCK()
coverage in mld6.c to make sure it's held when IFP_TO_IA6() is called.
MFC after: 2 weeks
Modified:
head/sys/netinet6/in6_var.h
head/sys/netinet6/mld6.c
Modified: head/sys/netinet6/in6_var.h
==============================================================================
--- head/sys/netinet6/in6_var.h Mon Apr 20 22:45:21 2009 (r191340)
+++ head/sys/netinet6/in6_var.h Mon Apr 20 22:56:34 2009 (r191341)
@@ -503,6 +503,7 @@ MALLOC_DECLARE(M_IP6MADDR);
/* struct in6_ifaddr *ia; */ \
do { \
struct ifaddr *ifa; \
+ IF_ADDR_LOCK_ASSERT(ifp); \
TAILQ_FOREACH(ifa, &(ifp)->if_addrhead, ifa_link) { \
if (ifa->ifa_addr->sa_family == AF_INET6) \
break; \
Modified: head/sys/netinet6/mld6.c
==============================================================================
--- head/sys/netinet6/mld6.c Mon Apr 20 22:45:21 2009 (r191340)
+++ head/sys/netinet6/mld6.c Mon Apr 20 22:56:34 2009 (r191341)
@@ -360,9 +360,12 @@ mld6_input(struct mbuf *m, int off)
*/
timer = ntohs(mldh->mld_maxdelay);
+ IF_ADDR_LOCK(ifp);
IFP_TO_IA6(ifp, ia);
- if (ia == NULL)
+ if (ia == NULL) {
+ IF_ADDR_UNLOCK(ifp);
break;
+ }
/*
* XXX: System timer resolution is too low to handle Max
@@ -374,7 +377,6 @@ mld6_input(struct mbuf *m, int off)
if (timer == 0 && mldh->mld_maxdelay)
timer = 1;
- IF_ADDR_LOCK(ifp);
TAILQ_FOREACH(ifma, &ifp->if_multiaddrs, ifma_link) {
if (ifma->ifma_addr->sa_family != AF_INET6)
continue;
More information about the svn-src-head
mailing list