Make the sysctl routines take out softnet_lock before dealing with

any data structures.

Change inet6ctlerrmap and zeroin6_addr to const.
This commit is contained in:
matt 2008-08-20 18:35:20 +00:00
parent 3e7c7228f4
commit 34cedfb2bf
5 changed files with 76 additions and 44 deletions

View File

@ -1,4 +1,4 @@
/* $NetBSD: ip_input.c,v 1.272 2008/05/05 17:11:17 ad Exp $ */
/* $NetBSD: ip_input.c,v 1.273 2008/08/20 18:35:20 matt 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.272 2008/05/05 17:11:17 ad Exp $");
__KERNEL_RCSID(0, "$NetBSD: ip_input.c,v 1.273 2008/08/20 18:35:20 matt Exp $");
#include "opt_inet.h"
#include "opt_gateway.h"
@ -2143,9 +2143,13 @@ sysctl_net_inet_ip_pmtudto(SYSCTLFN_ARGS)
if (tmp < 0)
return (EINVAL);
mutex_enter(softnet_lock);
ip_mtudisc_timeout = tmp;
rt_timer_queue_change(ip_mtudisc_timeout_q, ip_mtudisc_timeout);
mutex_exit(softnet_lock);
return (0);
}
@ -2156,15 +2160,19 @@ sysctl_net_inet_ip_pmtudto(SYSCTLFN_ARGS)
static int
sysctl_net_inet_ip_maxflows(SYSCTLFN_ARGS)
{
int s;
int error;
s = sysctl_lookup(SYSCTLFN_CALL(rnode));
if (s || newp == NULL)
return (s);
error = sysctl_lookup(SYSCTLFN_CALL(rnode));
if (error || newp == NULL)
return (error);
mutex_enter(softnet_lock);
KERNEL_LOCK(1, NULL);
s = splsoftnet();
ipflow_prune();
splx(s);
KERNEL_UNLOCK_ONE(NULL);
mutex_exit(softnet_lock);
return (0);
}
@ -2186,16 +2194,22 @@ sysctl_net_inet_ip_hashsize(SYSCTLFN_ARGS)
/*
* Can only fail due to malloc()
*/
if (ipflow_invalidate_all(tmp))
return ENOMEM;
mutex_enter(softnet_lock);
KERNEL_LOCK(1, NULL);
error = ipflow_invalidate_all(tmp);
KERNEL_UNLOCK_ONE(NULL);
mutex_exit(softnet_lock);
} else {
/*
* EINVAL if not a power of 2
*/
return EINVAL;
error = EINVAL;
}
return (0);
return error;
}
#endif /* GATEWAY */

View File

@ -1,4 +1,4 @@
/* $NetBSD: tcp_usrreq.c,v 1.147 2008/08/06 15:01:23 plunky Exp $ */
/* $NetBSD: tcp_usrreq.c,v 1.148 2008/08/20 18:35:20 matt Exp $ */
/*
* Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
@ -95,7 +95,7 @@
*/
#include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: tcp_usrreq.c,v 1.147 2008/08/06 15:01:23 plunky Exp $");
__KERNEL_RCSID(0, "$NetBSD: tcp_usrreq.c,v 1.148 2008/08/20 18:35:20 matt Exp $");
#include "opt_inet.h"
#include "opt_ipsec.h"
@ -1272,7 +1272,7 @@ sysctl_net_inet_tcp_ident(SYSCTLFN_ARGS)
struct sockaddr_in6 *si6[2];
#endif /* INET6 */
struct sockaddr_storage sa[2];
int error, pf, dodrop, s;
int error, pf, dodrop;
dodrop = name[-1] == TCPCTL_DROP;
if (dodrop) {
@ -1302,10 +1302,10 @@ sysctl_net_inet_tcp_ident(SYSCTLFN_ARGS)
laddr.s_addr = (uint32_t)name[2];
lport = (u_int)name[3];
s = splsoftnet();
mutex_enter(softnet_lock);
error = inet4_ident_core(raddr, rport, laddr, lport,
oldp, oldlenp, l, dodrop);
splx(s);
mutex_exit(softnet_lock);
return error;
#else /* INET */
return EINVAL;
@ -1342,11 +1342,11 @@ sysctl_net_inet_tcp_ident(SYSCTLFN_ARGS)
if (error)
return error;
s = splsoftnet();
mutex_enter(softnet_lock);
error = inet6_ident_core(&si6[0]->sin6_addr,
si6[0]->sin6_port, &si6[1]->sin6_addr,
si6[1]->sin6_port, oldp, oldlenp, l, dodrop);
splx(s);
mutex_exit(softnet_lock);
return error;
}
@ -1366,11 +1366,11 @@ sysctl_net_inet_tcp_ident(SYSCTLFN_ARGS)
si4[0]->sin_len != sizeof(*si4[1]))
return EINVAL;
s = splsoftnet();
mutex_enter(softnet_lock);
error = inet4_ident_core(si4[0]->sin_addr, si4[0]->sin_port,
si4[1]->sin_addr, si4[1]->sin_port,
oldp, oldlenp, l, dodrop);
splx(s);
mutex_exit(softnet_lock);
return error;
#endif /* INET */
default:
@ -1439,6 +1439,8 @@ sysctl_inpcblist(SYSCTLFN_ARGS)
proto = oname[2];
pf2 = (oldp != NULL) ? pf : 0;
mutex_enter(softnet_lock);
CIRCLEQ_FOREACH(inph, &pcbtbl->inpt_queue, inph_queue) {
#ifdef INET
inp = (const struct inpcb *)inph;
@ -1566,6 +1568,8 @@ sysctl_inpcblist(SYSCTLFN_ARGS)
if (oldp == NULL)
*oldlenp += PCB_SLOP * sizeof(struct kinfo_pcb);
mutex_exit(softnet_lock);
return (error);
}
@ -1573,7 +1577,7 @@ static int
sysctl_tcp_congctl(SYSCTLFN_ARGS)
{
struct sysctlnode node;
int error, r;
int error;
char newname[TCPCC_MAXLEN];
strlcpy(newname, tcp_congctl_global_name, sizeof(newname) - 1);
@ -1589,8 +1593,9 @@ sysctl_tcp_congctl(SYSCTLFN_ARGS)
strncmp(newname, tcp_congctl_global_name, sizeof(newname)) == 0)
return error;
if ((r = tcp_congctl_select(NULL, newname)))
return r;
mutex_enter(softnet_lock);
error = tcp_congctl_select(NULL, newname);
mutex_exit(softnet_lock);
return error;
}
@ -1610,8 +1615,12 @@ sysctl_tcp_keep(SYSCTLFN_ARGS)
if (error || newp == NULL)
return error;
mutex_enter(softnet_lock);
*(u_int *)rnode->sysctl_data = tmp;
tcp_tcpcb_template(); /* update the template */
mutex_exit(softnet_lock);
return 0;
}

View File

@ -1,4 +1,4 @@
/* $NetBSD: in6_pcb.c,v 1.98 2008/08/04 06:47:52 matt Exp $ */
/* $NetBSD: in6_pcb.c,v 1.99 2008/08/20 18:35:20 matt Exp $ */
/* $KAME: in6_pcb.c,v 1.84 2001/02/08 18:02:08 itojun Exp $ */
/*
@ -62,7 +62,7 @@
*/
#include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: in6_pcb.c,v 1.98 2008/08/04 06:47:52 matt Exp $");
__KERNEL_RCSID(0, "$NetBSD: in6_pcb.c,v 1.99 2008/08/20 18:35:20 matt Exp $");
#include "opt_inet.h"
#include "opt_ipsec.h"
@ -107,7 +107,7 @@ __KERNEL_RCSID(0, "$NetBSD: in6_pcb.c,v 1.98 2008/08/04 06:47:52 matt Exp $");
#include <netipsec/key.h>
#endif /* FAST_IPSEC */
struct in6_addr zeroin6_addr;
const struct in6_addr zeroin6_addr;
#define IN6PCBHASH_PORT(table, lport) \
&(table)->inpt_porthashtbl[ntohs(lport) & (table)->inpt_porthash]

View File

@ -1,4 +1,4 @@
/* $NetBSD: in6_var.h,v 1.59 2008/07/31 18:24:07 matt Exp $ */
/* $NetBSD: in6_var.h,v 1.60 2008/08/20 18:35:20 matt Exp $ */
/* $KAME: in6_var.h,v 1.81 2002/06/08 11:16:51 itojun Exp $ */
/*
@ -480,8 +480,8 @@ do { \
} while (/*CONSTCOND*/ 0)
extern struct ifqueue ip6intrq; /* IP6 packet input queue */
extern struct in6_addr zeroin6_addr;
extern u_char inet6ctlerrmap[];
extern const struct in6_addr zeroin6_addr;
extern const u_char inet6ctlerrmap[];
extern unsigned long in6_maxmtu;
/*

View File

@ -1,4 +1,4 @@
/* $NetBSD: ip6_input.c,v 1.119 2008/05/04 07:22:15 thorpej Exp $ */
/* $NetBSD: ip6_input.c,v 1.120 2008/08/20 18:35:20 matt Exp $ */
/* $KAME: ip6_input.c,v 1.188 2001/03/29 05:34:31 itojun Exp $ */
/*
@ -62,7 +62,7 @@
*/
#include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: ip6_input.c,v 1.119 2008/05/04 07:22:15 thorpej Exp $");
__KERNEL_RCSID(0, "$NetBSD: ip6_input.c,v 1.120 2008/08/20 18:35:20 matt Exp $");
#include "opt_inet.h"
#include "opt_inet6.h"
@ -1595,15 +1595,19 @@ ip6_delaux(struct mbuf *m)
static int
sysctl_net_inet6_ip6_maxflows(SYSCTLFN_ARGS)
{
int s;
int error;
s = sysctl_lookup(SYSCTLFN_CALL(rnode));
if (s || newp == NULL)
return (s);
error = sysctl_lookup(SYSCTLFN_CALL(rnode));
if (error || newp == NULL)
return (error);
mutex_enter(softnet_lock);
KERNEL_LOCK_ONE(1, NULL);
s = splsoftnet();
ip6flow_reap(0);
splx(s);
KERNEL_UNLOCK_ONE(NULL);
mutex_exit(softnet_lock);
return (0);
}
@ -1625,16 +1629,21 @@ sysctl_net_inet6_ip6_hashsize(SYSCTLFN_ARGS)
/*
* Can only fail due to malloc()
*/
if (ip6flow_invalidate_all(tmp))
return ENOMEM;
mutex_enter(softnet_lock);
KERNEL_LOCK_ONE(1, NULL);
error = ip6flow_invalidate_all(tmp);
KERNEL_UNLOCK_ONE(NULL);
mutex_exit(softnet_lock);
} else {
/*
* EINVAL if not a power of 2
*/
return EINVAL;
error = EINVAL;
}
return (0);
return error;
}
#endif /* GATEWAY */
@ -1642,7 +1651,7 @@ sysctl_net_inet6_ip6_hashsize(SYSCTLFN_ARGS)
* System control for IP6
*/
u_char inet6ctlerrmap[PRC_NCMDS] = {
const u_char inet6ctlerrmap[PRC_NCMDS] = {
0, 0, 0, 0,
0, EMSGSIZE, EHOSTDOWN, EHOSTUNREACH,
EHOSTUNREACH, EHOSTUNREACH, ECONNREFUSED, ECONNREFUSED,