]> git.baikalelectronics.ru Git - kernel.git/commitdiff
net/smc: Send out the remaining data in sndbuf before close
authorWen Gu <guwen@linux.alibaba.com>
Mon, 28 Mar 2022 06:10:36 +0000 (14:10 +0800)
committerJakub Kicinski <kuba@kernel.org>
Mon, 28 Mar 2022 23:06:27 +0000 (16:06 -0700)
The current autocork algorithms will delay the data transmission
in BH context to smc_release_cb() when sock_lock is hold by user.

So there is a possibility that when connection is being actively
closed (sock_lock is hold by user now), some corked data still
remains in sndbuf, waiting to be sent by smc_release_cb(). This
will cause:

- smc_close_stream_wait(), which is called under the sock_lock,
  has a high probability of timeout because data transmission is
  delayed until sock_lock is released.

- Unexpected data sends may happen after connction closed and use
  the rtoken which has been deleted by remote peer through
  LLC_DELETE_RKEY messages.

So this patch will try to send out the remaining corked data in
sndbuf before active close process, to ensure data integrity and
avoid unexpected data transmission after close.

Reported-by: Guangguan Wang <guangguan.wang@linux.alibaba.com>
Fixes: 8e394b00c869 ("net/smc: don't send in the BH context if sock_owned_by_user")
Signed-off-by: Wen Gu <guwen@linux.alibaba.com>
Acked-by: Karsten Graul <kgraul@linux.ibm.com>
Link: https://lore.kernel.org/r/1648447836-111521-1-git-send-email-guwen@linux.alibaba.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
net/smc/smc_close.c

index 292e4d904ab6e4afbba2cef421bce27cae5af364..676cb2333d3c4b98f539eac4e4d69d71b4faf773 100644 (file)
@@ -57,6 +57,9 @@ static void smc_close_stream_wait(struct smc_sock *smc, long timeout)
        if (!smc_tx_prepared_sends(&smc->conn))
                return;
 
+       /* Send out corked data remaining in sndbuf */
+       smc_tx_pending(&smc->conn);
+
        smc->wait_close_tx_prepared = 1;
        add_wait_queue(sk_sleep(sk), &wait);
        while (!signal_pending(current) && timeout) {