diff options
| author | David S. Miller <davem@davemloft.net> | 2022-07-13 12:56:50 +0100 | 
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2022-07-13 12:56:50 +0100 | 
| commit | 7d5424b26f17b74d94e73815718b424ad207a3e7 (patch) | |
| tree | a571db15de0e5ac08997aab9705356eff39685b6 /kernel/sysctl.c | |
| parent | 22b9c41a3fb8ef4624bcda312665937d2ba98aa7 (diff) | |
| parent | bdf00bf24bef9be1ca641a6390fd5487873e0d2e (diff) | |
Merge branch 'net-sysctl-races'
Kuniyuki Iwashima says:
====================
sysctl: Fix data-races around ipv4_net_table (Roun).
This series fixes data-races around the first 13 knobs and
nexthop_compat_mode in ipv4_net_table.
I will post another patch for three early_demux knobs later,
so the next round will start from ip_default_ttl.
====================
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'kernel/sysctl.c')
| -rw-r--r-- | kernel/sysctl.c | 12 | 
1 files changed, 6 insertions, 6 deletions
| diff --git a/kernel/sysctl.c b/kernel/sysctl.c index bf9383d17e1b..d99bc3945445 100644 --- a/kernel/sysctl.c +++ b/kernel/sysctl.c @@ -1007,13 +1007,13 @@ int proc_dou8vec_minmax(struct ctl_table *table, int write,  	tmp.maxlen = sizeof(val);  	tmp.data = &val; -	val = *data; +	val = READ_ONCE(*data);  	res = do_proc_douintvec(&tmp, write, buffer, lenp, ppos,  				do_proc_douintvec_minmax_conv, ¶m);  	if (res)  		return res;  	if (write) -		*data = val; +		WRITE_ONCE(*data, val);  	return 0;  }  EXPORT_SYMBOL_GPL(proc_dou8vec_minmax); @@ -1224,9 +1224,9 @@ static int do_proc_dointvec_ms_jiffies_conv(bool *negp, unsigned long *lvalp,  		if (jif > INT_MAX)  			return 1; -		*valp = (int)jif; +		WRITE_ONCE(*valp, (int)jif);  	} else { -		int val = *valp; +		int val = READ_ONCE(*valp);  		unsigned long lval;  		if (val < 0) {  			*negp = true; @@ -1294,8 +1294,8 @@ int proc_dointvec_userhz_jiffies(struct ctl_table *table, int write,   * @ppos: the current position in the file   *   * Reads/writes up to table->maxlen/sizeof(unsigned int) integer - * values from/to the user buffer, treated as an ASCII string.  - * The values read are assumed to be in 1/1000 seconds, and  + * values from/to the user buffer, treated as an ASCII string. + * The values read are assumed to be in 1/1000 seconds, and   * are converted into jiffies.   *   * Returns 0 on success. | 
