]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
smb: client: let smbd_disconnect_rdma_connection() turn CREATED into DISCONNECTED
authorStefan Metzmacher <metze@samba.org>
Mon, 10 Nov 2025 15:23:52 +0000 (16:23 +0100)
committerSteve French <stfrench@microsoft.com>
Tue, 11 Nov 2025 17:05:35 +0000 (11:05 -0600)
When smbd_disconnect_rdma_connection() turns SMBDIRECT_SOCKET_CREATED
into SMBDIRECT_SOCKET_ERROR, we'll have the situation that
smbd_disconnect_rdma_work() will set SMBDIRECT_SOCKET_DISCONNECTING
and call rdma_disconnect(), which likely fails as we never reached
the RDMA_CM_EVENT_ESTABLISHED. it means that
wait_event(sc->status_wait, sc->status == SMBDIRECT_SOCKET_DISCONNECTED)
in smbd_destroy() will hang forever in SMBDIRECT_SOCKET_DISCONNECTING
never reaching SMBDIRECT_SOCKET_DISCONNECTED.

So we directly go from SMBDIRECT_SOCKET_CREATED to
SMBDIRECT_SOCKET_DISCONNECTED.

Fixes: ffbfc73e84eb ("smb: client: let smbd_disconnect_rdma_connection() set SMBDIRECT_SOCKET_ERROR...")
Cc: Steve French <smfrench@gmail.com>
Cc: Tom Talpey <tom@talpey.com>
Cc: Long Li <longli@microsoft.com>
Cc: Namjae Jeon <linkinjeon@kernel.org>
Cc: linux-cifs@vger.kernel.org
Cc: samba-technical@lists.samba.org
Signed-off-by: Stefan Metzmacher <metze@samba.org>
Signed-off-by: Steve French <stfrench@microsoft.com>
fs/smb/client/smbdirect.c

index 85a4c55b61b851657232175b7926591cf2daa2ca..c6c428c2e08ddb0ee43580327234c0b48218af08 100644 (file)
@@ -290,6 +290,9 @@ static void smbd_disconnect_rdma_connection(struct smbdirect_socket *sc)
                break;
 
        case SMBDIRECT_SOCKET_CREATED:
+               sc->status = SMBDIRECT_SOCKET_DISCONNECTED;
+               break;
+
        case SMBDIRECT_SOCKET_CONNECTED:
                sc->status = SMBDIRECT_SOCKET_ERROR;
                break;