icmp: Fix a data-race around sysctl_icmp_errors_use_inbound_ifaddr.
While reading sysctl_icmp_errors_use_inbound_ifaddr, it can be changed
concurrently. Thus, we need to add READ_ONCE() to its reader.
Fixes: 1c2fb7f93c ("[IPV4]: Sysctl configurable icmp error source address.")
Signed-off-by: Kuniyuki Iwashima <kuniyu@amazon.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
b04f9b7e85
commit
d2efabce81
@@ -693,7 +693,7 @@ void __icmp_send(struct sk_buff *skb_in, int type, int code, __be32 info,
|
|||||||
|
|
||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
if (rt_is_input_route(rt) &&
|
if (rt_is_input_route(rt) &&
|
||||||
net->ipv4.sysctl_icmp_errors_use_inbound_ifaddr)
|
READ_ONCE(net->ipv4.sysctl_icmp_errors_use_inbound_ifaddr))
|
||||||
dev = dev_get_by_index_rcu(net, inet_iif(skb_in));
|
dev = dev_get_by_index_rcu(net, inet_iif(skb_in));
|
||||||
|
|
||||||
if (dev)
|
if (dev)
|
||||||
|
|||||||
@@ -635,6 +635,8 @@ static struct ctl_table ipv4_net_table[] = {
|
|||||||
.maxlen = sizeof(u8),
|
.maxlen = sizeof(u8),
|
||||||
.mode = 0644,
|
.mode = 0644,
|
||||||
.proc_handler = proc_dou8vec_minmax,
|
.proc_handler = proc_dou8vec_minmax,
|
||||||
|
.extra1 = SYSCTL_ZERO,
|
||||||
|
.extra2 = SYSCTL_ONE
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
.procname = "icmp_ratelimit",
|
.procname = "icmp_ratelimit",
|
||||||
|
|||||||
Reference in New Issue
Block a user