Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/netbsd-7]: src/sys/netinet6 Pull up following revision(s) (requested by ...



details:   https://anonhg.NetBSD.org/src/rev/22fc07016858
branches:  netbsd-7
changeset: 799715:22fc07016858
user:      msaitoh <msaitoh%NetBSD.org@localhost>
date:      Wed Nov 18 08:33:08 2015 +0000

description:
Pull up following revision(s) (requested by joerg in ticket #1035):
        sys/netinet6/mld6.c: revision 1.64
Ensure that the callout of the multicast address is valid before
hooking it up.

diffstat:

 sys/netinet6/mld6.c |  11 +++++++----
 1 files changed, 7 insertions(+), 4 deletions(-)

diffs (48 lines):

diff -r 093df8ba101f -r 22fc07016858 sys/netinet6/mld6.c
--- a/sys/netinet6/mld6.c       Wed Nov 18 08:29:21 2015 +0000
+++ b/sys/netinet6/mld6.c       Wed Nov 18 08:33:08 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: mld6.c,v 1.59.2.2 2015/01/23 09:27:15 martin Exp $     */
+/*     $NetBSD: mld6.c,v 1.59.2.3 2015/11/18 08:33:08 msaitoh Exp $    */
 /*     $KAME: mld6.c,v 1.25 2001/01/16 14:14:18 itojun Exp $   */
 
 /*
@@ -102,7 +102,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: mld6.c,v 1.59.2.2 2015/01/23 09:27:15 martin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: mld6.c,v 1.59.2.3 2015/11/18 08:33:08 msaitoh Exp $");
 
 #include "opt_inet.h"
 
@@ -656,8 +656,12 @@
                in6m->in6m_ifp = ifp;
                in6m->in6m_refcount = 1;
                in6m->in6m_timer = IN6M_TIMER_UNDEF;
+               callout_init(&in6m->in6m_timer_ch, CALLOUT_MPSAFE);
+               callout_setfunc(&in6m->in6m_timer_ch, mld_timeo, in6m);
+
                IFP_TO_IA6(ifp, ia);
                if (ia == NULL) {
+                       callout_destroy(&in6m->in6m_timer_ch);
                        free(in6m, M_IPMADDR);
                        splx(s);
                        *errorp = EADDRNOTAVAIL; /* appropriate? */
@@ -674,6 +678,7 @@
                sockaddr_in6_init(&sin6, maddr6, 0, 0, 0);
                *errorp = if_mcast_op(ifp, SIOCADDMULTI, sin6tosa(&sin6));
                if (*errorp) {
+                       callout_destroy(&in6m->in6m_timer_ch);
                        LIST_REMOVE(in6m, in6m_entry);
                        free(in6m, M_IPMADDR);
                        IFAFREE(&ia->ia_ifa);
@@ -681,8 +686,6 @@
                        return (NULL);
                }
 
-               callout_init(&in6m->in6m_timer_ch, CALLOUT_MPSAFE);
-               callout_setfunc(&in6m->in6m_timer_ch, mld_timeo, in6m);
                in6m->in6m_timer = timer;
                if (in6m->in6m_timer > 0) {
                        in6m->in6m_state = MLD_REPORTPENDING;



Home | Main Index | Thread Index | Old Index