Fix a possible refcount leak in regen_tmpaddr().

public_ifa6 may be set to NULL after taking a reference to a previous
address list element. Instead, only take the reference after leaving the
loop but before releasing the address list lock.

Differential Revision:	https://reviews.freebsd.org/D2253
Reviewed by:		ae
MFC after:		2 weeks
This commit is contained in:
markj 2015-04-13 01:55:42 +00:00
parent e3b60002c6
commit 47f557e75d

View File

@ -765,11 +765,10 @@ regen_tmpaddr(struct in6_ifaddr *ia6)
* address with the prefix. * address with the prefix.
*/ */
if (!IFA6_IS_DEPRECATED(it6)) if (!IFA6_IS_DEPRECATED(it6))
public_ifa6 = it6; public_ifa6 = it6;
if (public_ifa6 != NULL)
ifa_ref(&public_ifa6->ia_ifa);
} }
if (public_ifa6 != NULL)
ifa_ref(&public_ifa6->ia_ifa);
IF_ADDR_RUNLOCK(ifp); IF_ADDR_RUNLOCK(ifp);
if (public_ifa6 != NULL) { if (public_ifa6 != NULL) {