mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-10 15:10:38 +00:00
[TIPC]: Optimize wakeup logic when socket has no waiting processes
This patch adds a simple test so TIPC doesn't try waking up processes waiting on a socket if there are none waiting. Signed-off-by: Allan Stephens <allan.stephens@windriver.com> Signed-off-by: Per Liden <per.liden@ericsson.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
e91ed0bcdf
commit
cfb0c0890b
@ -1208,7 +1208,8 @@ static u32 dispatch(struct tipc_port *tport, struct sk_buff *buf)
|
||||
atomic_inc(&tipc_queue_size);
|
||||
skb_queue_tail(&sock->sk->sk_receive_queue, buf);
|
||||
|
||||
wake_up_interruptible(sock->sk->sk_sleep);
|
||||
if (waitqueue_active(sock->sk->sk_sleep))
|
||||
wake_up_interruptible(sock->sk->sk_sleep);
|
||||
return TIPC_OK;
|
||||
}
|
||||
|
||||
@ -1223,7 +1224,8 @@ static void wakeupdispatch(struct tipc_port *tport)
|
||||
{
|
||||
struct tipc_sock *tsock = (struct tipc_sock *)tport->usr_handle;
|
||||
|
||||
wake_up_interruptible(tsock->sk.sk_sleep);
|
||||
if (waitqueue_active(tsock->sk.sk_sleep))
|
||||
wake_up_interruptible(tsock->sk.sk_sleep);
|
||||
}
|
||||
|
||||
/**
|
||||
|
Loading…
x
Reference in New Issue
Block a user