mirror of
https://github.com/torvalds/linux.git
synced 2024-11-26 22:21:42 +00:00
icmp: Fix a data-race around sysctl_icmp_echo_ignore_all.
While reading sysctl_icmp_echo_ignore_all, it can be changed concurrently.
Thus, we need to add READ_ONCE() to its reader.
Fixes: 1da177e4c3
("Linux-2.6.12-rc2")
Signed-off-by: Kuniyuki Iwashima <kuniyu@amazon.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
6f605b57f3
commit
bb7bb35a63
@ -993,7 +993,7 @@ static enum skb_drop_reason icmp_echo(struct sk_buff *skb)
|
|||||||
|
|
||||||
net = dev_net(skb_dst(skb)->dev);
|
net = dev_net(skb_dst(skb)->dev);
|
||||||
/* should there be an ICMP stat for ignored echos? */
|
/* should there be an ICMP stat for ignored echos? */
|
||||||
if (net->ipv4.sysctl_icmp_echo_ignore_all)
|
if (READ_ONCE(net->ipv4.sysctl_icmp_echo_ignore_all))
|
||||||
return SKB_NOT_DROPPED_YET;
|
return SKB_NOT_DROPPED_YET;
|
||||||
|
|
||||||
icmp_param.data.icmph = *icmp_hdr(skb);
|
icmp_param.data.icmph = *icmp_hdr(skb);
|
||||||
|
@ -599,6 +599,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_echo_enable_probe",
|
.procname = "icmp_echo_enable_probe",
|
||||||
|
Loading…
Reference in New Issue
Block a user