Module Name:    src
Committed By:   ozaki-r
Date:           Fri Feb 17 04:32:10 UTC 2017

Modified Files:
        src/sys/netinet: ip_icmp.c ip_icmp.h ip_input.c

Log Message:
Protect sysctl_net_inet_ip_pmtudto with icmp_mtx instead of softnet_lock


To generate a diff of this commit:
cvs rdiff -u -r1.158 -r1.159 src/sys/netinet/ip_icmp.c
cvs rdiff -u -r1.34 -r1.35 src/sys/netinet/ip_icmp.h
cvs rdiff -u -r1.349 -r1.350 src/sys/netinet/ip_input.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/netinet/ip_icmp.c
diff -u src/sys/netinet/ip_icmp.c:1.158 src/sys/netinet/ip_icmp.c:1.159
--- src/sys/netinet/ip_icmp.c:1.158	Mon Feb 13 07:18:20 2017
+++ src/sys/netinet/ip_icmp.c	Fri Feb 17 04:32:10 2017
@@ -1,4 +1,4 @@
-/*	$NetBSD: ip_icmp.c,v 1.158 2017/02/13 07:18:20 ozaki-r Exp $	*/
+/*	$NetBSD: ip_icmp.c,v 1.159 2017/02/17 04:32:10 ozaki-r Exp $	*/
 
 /*
  * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
@@ -94,7 +94,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ip_icmp.c,v 1.158 2017/02/13 07:18:20 ozaki-r Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ip_icmp.c,v 1.159 2017/02/17 04:32:10 ozaki-r Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_ipsec.h"
@@ -205,6 +205,20 @@ icmp_init(void)
 	icmp_wqinput = wqinput_create("icmp", _icmp_input);
 }
 
+void
+icmp_mtudisc_lock(void)
+{
+
+	mutex_enter(&icmp_mtx);
+}
+
+void
+icmp_mtudisc_unlock(void)
+{
+
+	mutex_exit(&icmp_mtx);
+}
+
 /*
  * Register a Path MTU Discovery callback.
  */

Index: src/sys/netinet/ip_icmp.h
diff -u src/sys/netinet/ip_icmp.h:1.34 src/sys/netinet/ip_icmp.h:1.35
--- src/sys/netinet/ip_icmp.h:1.34	Wed Feb 18 17:00:15 2015
+++ src/sys/netinet/ip_icmp.h	Fri Feb 17 04:32:10 2017
@@ -1,4 +1,4 @@
-/*	$NetBSD: ip_icmp.h,v 1.34 2015/02/18 17:00:15 christos Exp $	*/
+/*	$NetBSD: ip_icmp.h,v 1.35 2017/02/17 04:32:10 ozaki-r Exp $	*/
 
 /*
  * Copyright (c) 1982, 1986, 1993
@@ -248,6 +248,8 @@ int	icmp_sysctl(int *, u_int, void *, si
 
 void	icmp_mtudisc_callback_register(void (*)(struct in_addr));
 int	icmp_ratelimit(const struct in_addr *, const int, const int);
+void	icmp_mtudisc_lock(void);
+void	icmp_mtudisc_unlock(void);
 #endif
 
 

Index: src/sys/netinet/ip_input.c
diff -u src/sys/netinet/ip_input.c:1.349 src/sys/netinet/ip_input.c:1.350
--- src/sys/netinet/ip_input.c:1.349	Tue Feb  7 02:38:08 2017
+++ src/sys/netinet/ip_input.c	Fri Feb 17 04:32:10 2017
@@ -1,4 +1,4 @@
-/*	$NetBSD: ip_input.c,v 1.349 2017/02/07 02:38:08 ozaki-r Exp $	*/
+/*	$NetBSD: ip_input.c,v 1.350 2017/02/17 04:32:10 ozaki-r Exp $	*/
 
 /*
  * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
@@ -91,7 +91,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ip_input.c,v 1.349 2017/02/07 02:38:08 ozaki-r Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ip_input.c,v 1.350 2017/02/17 04:32:10 ozaki-r Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -1601,24 +1601,25 @@ sysctl_net_inet_ip_pmtudto(SYSCTLFN_ARGS
 	int error, tmp;
 	struct sysctlnode node;
 
+	icmp_mtudisc_lock();
+
 	node = *rnode;
 	tmp = ip_mtudisc_timeout;
 	node.sysctl_data = &tmp;
 	error = sysctl_lookup(SYSCTLFN_CALL(&node));
 	if (error || newp == NULL)
-		return (error);
-	if (tmp < 0)
-		return (EINVAL);
-
-	/* XXX NOMPSAFE still need softnet_lock */
-	mutex_enter(softnet_lock);
+		goto out;
+	if (tmp < 0) {
+		error = EINVAL;
+		goto out;
+	}
 
 	ip_mtudisc_timeout = tmp;
 	rt_timer_queue_change(ip_mtudisc_timeout_q, ip_mtudisc_timeout);
-
-	mutex_exit(softnet_lock);
-
-	return (0);
+	error = 0;
+out:
+	icmp_mtudisc_unlock();
+	return 0;
 }
 
 static int

Reply via email to