From: Parthasarathy Bhuvaragan Date: Tue, 1 Nov 2016 13:02:35 +0000 (+0100) Subject: tipc: wakeup sleeping users at disconnect X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=4891d8fe16343660b4c1ddbcca4792300b5fd4f4;p=GitHub%2Fmoto-9609%2Fandroid_kernel_motorola_exynos9610.git tipc: wakeup sleeping users at disconnect Until now, in filter_connect() when we terminate a connection due to an error message from peer, we set the socket state to DISCONNECTING. The socket is notified about this broken connection using EPIPE when a user tries to send a message. However if a socket was waiting on a poll() while the connection is being terminated, we fail to wakeup that socket. In this commit, we wakeup sleeping sockets at connection termination. Acked-by: Jon Maloy Signed-off-by: Parthasarathy Bhuvaragan Signed-off-by: David S. Miller --- diff --git a/net/tipc/socket.c b/net/tipc/socket.c index adf3e6ecf61e..cd01deb1da9c 100644 --- a/net/tipc/socket.c +++ b/net/tipc/socket.c @@ -1599,6 +1599,7 @@ static bool filter_connect(struct tipc_sock *tsk, struct sk_buff *skb) /* Let timer expire on it's own */ tipc_node_remove_conn(net, tsk_peer_node(tsk), tsk->portid); + sk->sk_state_change(sk); } return true;