summaryrefslogtreecommitdiffstats
path: root/fs/cifs/connect.c
diff options
context:
space:
mode:
authorLong Li2017-11-23 01:38:36 +0100
committerSteve French2018-01-25 02:49:06 +0100
commit781a8050f2a8e1474a75122b7d940959cc579e14 (patch)
treeb21892740250aeaf62bc436662da4b39db93d25f /fs/cifs/connect.c
parentCIFS: SMBD: Implement function to reconnect to a SMB Direct transport (diff)
downloadkernel-qcow2-linux-781a8050f2a8e1474a75122b7d940959cc579e14.tar.gz
kernel-qcow2-linux-781a8050f2a8e1474a75122b7d940959cc579e14.tar.xz
kernel-qcow2-linux-781a8050f2a8e1474a75122b7d940959cc579e14.zip
CIFS: SMBD: Upper layer reconnects to SMB Direct session
Do a reconnect on SMB Direct when it is used as the connection. Reconnect can happen for many reasons and it's mostly the decision of SMB2 upper layer. Signed-off-by: Long Li <longli@microsoft.com> Signed-off-by: Steve French <smfrench@gmail.com> Reviewed-by: Ronnie Sahlberg <lsahlber@redhat.com> Reviewed-by: Pavel Shilovsky <pshilov@microsoft.com>
Diffstat (limited to 'fs/cifs/connect.c')
-rw-r--r--fs/cifs/connect.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/fs/cifs/connect.c b/fs/cifs/connect.c
index fafaecb5fb18..fc460663b308 100644
--- a/fs/cifs/connect.c
+++ b/fs/cifs/connect.c
@@ -406,7 +406,10 @@ cifs_reconnect(struct TCP_Server_Info *server)
/* we should try only the port we connected to before */
mutex_lock(&server->srv_mutex);
- rc = generic_ip_connect(server);
+ if (cifs_rdma_enabled(server))
+ rc = smbd_reconnect(server);
+ else
+ rc = generic_ip_connect(server);
if (rc) {
cifs_dbg(FYI, "reconnect error %d\n", rc);
mutex_unlock(&server->srv_mutex);