mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-14 06:26:43 +07:00
net: SOCKWQ_ASYNC_NOSPACE optimizations
SOCKWQ_ASYNC_NOSPACE is tested in sock_wake_async() so that a SIGIO signal is sent when needed. tcp_sendmsg() clears the bit. tcp_poll() sets the bit when stream is not writeable. We can avoid two atomic operations by first checking if socket is actually interested in the FASYNC business (most sockets in real applications do not use AIO, but select()/poll()/epoll()) This also removes one cache line miss to access sk->sk_wq->flags in tcp_sendmsg() Signed-off-by: Eric Dumazet <edumazet@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
210732d16d
commit
9317bb6982
@ -1940,11 +1940,17 @@ static inline unsigned long sock_wspace(struct sock *sk)
|
||||
*/
|
||||
static inline void sk_set_bit(int nr, struct sock *sk)
|
||||
{
|
||||
if (nr == SOCKWQ_ASYNC_NOSPACE && !sock_flag(sk, SOCK_FASYNC))
|
||||
return;
|
||||
|
||||
set_bit(nr, &sk->sk_wq_raw->flags);
|
||||
}
|
||||
|
||||
static inline void sk_clear_bit(int nr, struct sock *sk)
|
||||
{
|
||||
if (nr == SOCKWQ_ASYNC_NOSPACE && !sock_flag(sk, SOCK_FASYNC))
|
||||
return;
|
||||
|
||||
clear_bit(nr, &sk->sk_wq_raw->flags);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user