tcp: annotate sk->sk_rcvbuf lockless reads
For the sake of tcp_poll(), there are few places where we fetch sk->sk_rcvbuf while this field can change from IRQ or other cpu. We need to add READ_ONCE() annotations, and also make sure write sides use corresponding WRITE_ONCE() to avoid store-tearing. Note that other transports probably need similar fixes. Signed-off-by: Eric Dumazet <edumazet@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
d9b55bf7b6
commit
ebb3b78db7
@@ -82,7 +82,7 @@ TRACE_EVENT(sock_rcvqueue_full,
|
||||
TP_fast_assign(
|
||||
__entry->rmem_alloc = atomic_read(&sk->sk_rmem_alloc);
|
||||
__entry->truesize = skb->truesize;
|
||||
__entry->sk_rcvbuf = sk->sk_rcvbuf;
|
||||
__entry->sk_rcvbuf = READ_ONCE(sk->sk_rcvbuf);
|
||||
),
|
||||
|
||||
TP_printk("rmem_alloc=%d truesize=%u sk_rcvbuf=%d",
|
||||
|
||||
Reference in New Issue
Block a user