diff options
author | Ursula Braun <ubraun@linux.ibm.com> | 2020-09-10 18:48:20 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2020-09-11 00:24:26 +0200 |
commit | a60a2b1e0af1a7517ba41689b39e9df90ef09041 (patch) | |
tree | 821da1d90afd0ce0aada4bc2df6a774162d42463 /net/smc/smc.h | |
parent | Merge branch 'nfc-s3fwrn5-Few-cleanups' (diff) | |
download | linux-a60a2b1e0af1a7517ba41689b39e9df90ef09041.tar.xz linux-a60a2b1e0af1a7517ba41689b39e9df90ef09041.zip |
net/smc: reduce active tcp_listen workers
SMC starts a separate tcp_listen worker for every SMC socket in
state SMC_LISTEN, and can accept an incoming connection request only,
if this worker is really running and waiting in kernel_accept(). But
the number of running workers is limited.
This patch reworks the listening SMC code and starts a tcp_listen worker
after the SYN-ACK handshake on the internal clc-socket only.
Suggested-by: Karsten Graul <kgraul@linux.ibm.com>
Signed-off-by: Ursula Braun <ubraun@linux.ibm.com>
Reviewed-by: Guvenc Gulce <guvenc@linux.ibm.com>
Signed-off-by: Karsten Graul <kgraul@linux.ibm.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/smc/smc.h')
-rw-r--r-- | net/smc/smc.h | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/net/smc/smc.h b/net/smc/smc.h index 6f1c42da7a4c..f38144f83f54 100644 --- a/net/smc/smc.h +++ b/net/smc/smc.h @@ -201,6 +201,8 @@ struct smc_connection { struct smc_sock { /* smc sock container */ struct sock sk; struct socket *clcsock; /* internal tcp socket */ + void (*clcsk_data_ready)(struct sock *sk); + /* original data_ready fct. **/ struct smc_connection conn; /* smc connection */ struct smc_sock *listen_smc; /* listen parent */ struct work_struct connect_work; /* handle non-blocking connect*/ |