smb: client: don't wait for info->send_pending == 0 on error
authorStefan Metzmacher <metze@samba.org>
Tue, 12 Aug 2025 16:45:06 +0000 (18:45 +0200)
committerSteve French <stfrench@microsoft.com>
Wed, 13 Aug 2025 16:36:12 +0000 (11:36 -0500)
commit8c48e1c7520321cc87ff651e96093e2f412785fb
tree9a910677d33b3aed272202e77d359c900eeb3cce
parente3835731e169a48a2c73018d135b5c08c39ea61d
smb: client: don't wait for info->send_pending == 0 on error

We already called ib_drain_qp() before and that makes sure
send_done() was called with IB_WC_WR_FLUSH_ERR, but
didn't called atomic_dec_and_test(&sc->send_io.pending.count)

So we may never reach the info->send_pending == 0 condition.

Cc: Steve French <smfrench@gmail.com>
Cc: Tom Talpey <tom@talpey.com>
Cc: Long Li <longli@microsoft.com>
Cc: linux-cifs@vger.kernel.org
Cc: samba-technical@lists.samba.org
Fixes: 5349ae5e05fa ("smb: client: let send_done() cleanup before calling smbd_disconnect_rdma_connection()")
Signed-off-by: Stefan Metzmacher <metze@samba.org>
Signed-off-by: Steve French <stfrench@microsoft.com>
fs/smb/client/smbdirect.c