net/smc: rebuild nonblocking connect
authorUrsula Braun <ubraun@linux.ibm.com>
Wed, 27 Jun 2018 15:59:50 +0000 (17:59 +0200)
committerDavid S. Miller <davem@davemloft.net>
Thu, 28 Jun 2018 13:03:55 +0000 (22:03 +0900)
commit24ac3a08e65845a098140ff270229dec4a897404
tree81c017a18cbff69130be4d721c517d60e7d0b3ab
parent15ecbe94a45ef88491ca459b26efdd02f91edb6d
net/smc: rebuild nonblocking connect

The recent poll change may lead to stalls for non-blocking connecting
SMC sockets, since sock_poll_wait is no longer performed on the
internal CLC socket, but on the outer SMC socket.  kernel_connect() on
the internal CLC socket returns with -EINPROGRESS, but the wake up
logic does not work in all cases. If the internal CLC socket is still
in state TCP_SYN_SENT when polled, sock_poll_wait() from sock_poll()
does not sleep. It is supposed to sleep till the state of the internal
CLC socket switches to TCP_ESTABLISHED.

This problem triggered a redesign of the SMC nonblocking connect logic.
This patch introduces a connect worker covering all connect steps
followed by a wake up of socket waiters. It allows to get rid of all
delays and locks in smc_poll().

Fixes: c0129a061442 ("smc: convert to ->poll_mask")
Signed-off-by: Ursula Braun <ubraun@linux.ibm.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/smc/af_smc.c
net/smc/smc.h