Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/netinet6 Take softnet_lock and kernel lock in frag6_slow...
details:   https://anonhg.NetBSD.org/src/rev/94514531da89
branches:  trunk
changeset: 772056:94514531da89
user:      jakllsch <jakllsch%NetBSD.org@localhost>
date:      Fri Dec 16 00:57:59 2011 +0000
description:
Take softnet_lock and kernel lock in frag6_slowtimo and frag6_fasttimo,
similar to how it's done with other protocols.
If we don't do this sending ICMPv6 messages in this path can cause races
in network interface drivers.
diffstat:
 sys/netinet6/frag6.c |  16 ++++++++++++++--
 1 files changed, 14 insertions(+), 2 deletions(-)
diffs (55 lines):
diff -r 5399e13856df -r 94514531da89 sys/netinet6/frag6.c
--- a/sys/netinet6/frag6.c      Thu Dec 15 22:20:26 2011 +0000
+++ b/sys/netinet6/frag6.c      Fri Dec 16 00:57:59 2011 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: frag6.c,v 1.50 2011/11/04 00:22:33 zoltan Exp $        */
+/*     $NetBSD: frag6.c,v 1.51 2011/12/16 00:57:59 jakllsch Exp $      */
 /*     $KAME: frag6.c,v 1.40 2002/05/27 21:40:31 itojun Exp $  */
 
 /*
@@ -31,7 +31,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: frag6.c,v 1.50 2011/11/04 00:22:33 zoltan Exp $");
+__KERNEL_RCSID(0, "$NetBSD: frag6.c,v 1.51 2011/12/16 00:57:59 jakllsch Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -644,10 +644,16 @@
 void
 frag6_fasttimo(void)
 {
+       mutex_enter(softnet_lock);
+       KERNEL_LOCK(1, NULL);
+
        if (frag6_drainwanted) {
                frag6_drain();
                frag6_drainwanted = 0;
        }
+
+       KERNEL_UNLOCK_ONE(NULL);
+       mutex_exit(softnet_lock);
 }
 
 /*
@@ -660,6 +666,9 @@
 {
        struct ip6q *q6;
 
+       mutex_enter(softnet_lock);
+       KERNEL_LOCK(1, NULL);
+
        mutex_enter(&frag6_lock);
        q6 = ip6q.ip6q_next;
        if (q6)
@@ -685,6 +694,9 @@
        }
        mutex_exit(&frag6_lock);
 
+       KERNEL_UNLOCK_ONE(NULL);
+       mutex_exit(softnet_lock);
+
 #if 0
        /*
         * Routing changes might produce a better route than we last used;
Home |
Main Index |
Thread Index |
Old Index