Commit 139653bc authored by Tony Lu's avatar Tony Lu Committed by David S. Miller

net/smc: Remove corked dealyed work

Based on the manual of TCP_CORK [1] and MSG_MORE [2], these two options
have the same effect. Applications can set these options and informs the
kernel to pend the data, and send them out only when the socket or
syscall does not specify this flag. In other words, there's no need to
send data out by a delayed work, which will queue a lot of work.

This removes corked delayed work with SMC_TX_CORK_DELAY (250ms), and the
applications control how/when to send them out. It improves the
performance for sendfile and throughput, and remove unnecessary race of
lock_sock(). This also unlocks the limitation of sndbuf, and try to fill
it up before sending.

[1] https://linux.die.net/man/7/tcp
[2] https://man7.org/linux/man-pages/man2/send.2.htmlSigned-off-by: default avatarTony Lu <tonylu@linux.alibaba.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent ea785a1a
...@@ -31,7 +31,6 @@ ...@@ -31,7 +31,6 @@
#include "smc_tracepoint.h" #include "smc_tracepoint.h"
#define SMC_TX_WORK_DELAY 0 #define SMC_TX_WORK_DELAY 0
#define SMC_TX_CORK_DELAY (HZ >> 2) /* 250 ms */
/***************************** sndbuf producer *******************************/ /***************************** sndbuf producer *******************************/
...@@ -237,14 +236,12 @@ int smc_tx_sendmsg(struct smc_sock *smc, struct msghdr *msg, size_t len) ...@@ -237,14 +236,12 @@ int smc_tx_sendmsg(struct smc_sock *smc, struct msghdr *msg, size_t len)
if ((msg->msg_flags & MSG_OOB) && !send_remaining) if ((msg->msg_flags & MSG_OOB) && !send_remaining)
conn->urg_tx_pend = true; conn->urg_tx_pend = true;
if ((msg->msg_flags & MSG_MORE || smc_tx_is_corked(smc)) && if ((msg->msg_flags & MSG_MORE || smc_tx_is_corked(smc)) &&
(atomic_read(&conn->sndbuf_space) > (atomic_read(&conn->sndbuf_space)))
(conn->sndbuf_desc->len >> 1))) /* for a corked socket defer the RDMA writes if
/* for a corked socket defer the RDMA writes if there * sndbuf_space is still available. The applications
* is still sufficient sndbuf_space available * should known how/when to uncork it.
*/ */
queue_delayed_work(conn->lgr->tx_wq, &conn->tx_work, continue;
SMC_TX_CORK_DELAY);
else
smc_tx_sndbuf_nonempty(conn); smc_tx_sndbuf_nonempty(conn);
trace_smc_tx_sendmsg(smc, copylen); trace_smc_tx_sendmsg(smc, copylen);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment