diff options
author | Parthasarathy Bhuvaragan | 2019-05-09 07:13:42 +0200 |
---|---|---|
committer | David S. Miller | 2019-05-09 18:26:09 +0200 |
commit | ff946833b70e0c7f93de9a3f5b329b5ae2287b38 (patch) | |
tree | 3e765dd8dbd1455ace9773bf0a561b466fd413e8 /net/tipc/bcast.c | |
parent | tuntap: synchronize through tfiles array instead of tun->numqueues (diff) | |
download | kernel-qcow2-linux-ff946833b70e0c7f93de9a3f5b329b5ae2287b38.tar.gz kernel-qcow2-linux-ff946833b70e0c7f93de9a3f5b329b5ae2287b38.tar.xz kernel-qcow2-linux-ff946833b70e0c7f93de9a3f5b329b5ae2287b38.zip |
tipc: fix hanging clients using poll with EPOLLOUT flag
commit 517d7c79bdb398 ("tipc: fix hanging poll() for stream sockets")
introduced a regression for clients using non-blocking sockets.
After the commit, we send EPOLLOUT event to the client even in
TIPC_CONNECTING state. This causes the subsequent send() to fail
with ENOTCONN, as the socket is still not in TIPC_ESTABLISHED state.
In this commit, we:
- improve the fix for hanging poll() by replacing sk_data_ready()
with sk_state_change() to wake up all clients.
- revert the faulty updates introduced by commit 517d7c79bdb398
("tipc: fix hanging poll() for stream sockets").
Fixes: 517d7c79bdb398 ("tipc: fix hanging poll() for stream sockets")
Signed-off-by: Parthasarathy Bhuvaragan <parthasarathy.bhuvaragan@gmail.com>
Acked-by: Jon Maloy <jon.maloy@ericsson.se>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/tipc/bcast.c')
0 files changed, 0 insertions, 0 deletions