mirror of
https://github.com/torvalds/linux.git
synced 2026-05-25 07:33:19 +02:00
ipv6: annotate data-races over sysctl.flowlabel_reflect
Add missing READ_ONCE() when reading ipv6.sysctl.flowlabel_reflect, as its value can be changed under us. Signed-off-by: Eric Dumazet <edumazet@google.com> Reviewed-by: Simon Horman <horms@kernel.org> Link: https://patch.msgid.link/20260115094141.3124990-6-edumazet@google.com Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
parent
03e9d91dd6
commit
5ade47c974
|
|
@ -224,8 +224,8 @@ static int inet6_create(struct net *net, struct socket *sock, int protocol,
|
|||
inet6_set_bit(MC6_LOOP, sk);
|
||||
inet6_set_bit(MC6_ALL, sk);
|
||||
np->pmtudisc = IPV6_PMTUDISC_WANT;
|
||||
inet6_assign_bit(REPFLOW, sk, net->ipv6.sysctl.flowlabel_reflect &
|
||||
FLOWLABEL_REFLECT_ESTABLISHED);
|
||||
inet6_assign_bit(REPFLOW, sk, READ_ONCE(net->ipv6.sysctl.flowlabel_reflect) &
|
||||
FLOWLABEL_REFLECT_ESTABLISHED);
|
||||
sk->sk_ipv6only = net->ipv6.sysctl.bindv6only;
|
||||
sk->sk_txrehash = READ_ONCE(net->core.sysctl_txrehash);
|
||||
|
||||
|
|
|
|||
|
|
@ -958,7 +958,8 @@ static enum skb_drop_reason icmpv6_echo_reply(struct sk_buff *skb)
|
|||
tmp_hdr.icmp6_type = type;
|
||||
|
||||
memset(&fl6, 0, sizeof(fl6));
|
||||
if (net->ipv6.sysctl.flowlabel_reflect & FLOWLABEL_REFLECT_ICMPV6_ECHO_REPLIES)
|
||||
if (READ_ONCE(net->ipv6.sysctl.flowlabel_reflect) &
|
||||
FLOWLABEL_REFLECT_ICMPV6_ECHO_REPLIES)
|
||||
fl6.flowlabel = ip6_flowlabel(ipv6_hdr(skb));
|
||||
|
||||
fl6.flowi6_proto = IPPROTO_ICMPV6;
|
||||
|
|
|
|||
|
|
@ -1085,7 +1085,8 @@ static void tcp_v6_send_reset(const struct sock *sk, struct sk_buff *skb,
|
|||
txhash = inet_twsk(sk)->tw_txhash;
|
||||
}
|
||||
} else {
|
||||
if (net->ipv6.sysctl.flowlabel_reflect & FLOWLABEL_REFLECT_TCP_RESET)
|
||||
if (READ_ONCE(net->ipv6.sysctl.flowlabel_reflect) &
|
||||
FLOWLABEL_REFLECT_TCP_RESET)
|
||||
label = ip6_flowlabel(ipv6h);
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user