OSDN Git Service

smb3: request more credits on tree connect
authorSteve French <stfrench@microsoft.com>
Thu, 14 Feb 2019 07:19:02 +0000 (01:19 -0600)
committerSteve French <stfrench@microsoft.com>
Tue, 5 Mar 2019 02:05:35 +0000 (20:05 -0600)
If we try large I/O (read or write) immediately after mount
we won't typically have enough credits because we only request
large amounts of credits on the first session setup.  So if
large I/O is attempted soon after mount we will typically only
have about 43 credits rather than 105 credits (with this patch)
available for the large i/o (which needs 64 credits minimum).

This patch requests more credits during tree connect, which
helps ensure that we have enough credits when mount completes
(between these requests and the first session setup) in order
 to start large I/O immediately after mount if needed.

Signed-off-by: Steve French <stfrench@microsoft.com>
Reviewed-by: Pavel Shilovsky <pshilov@microsoft.com>
fs/cifs/smb2pdu.c

index 7d9a1cb..3e9bee3 100644 (file)
@@ -1614,6 +1614,9 @@ SMB2_tcon(const unsigned int xid, struct cifs_ses *ses, const char *tree,
        rqst.rq_iov = iov;
        rqst.rq_nvec = 2;
 
+       /* Need 64 for max size write so ask for more in case not there yet */
+       req->sync_hdr.CreditRequest = cpu_to_le16(64);
+
        rc = cifs_send_recv(xid, ses, &rqst, &resp_buftype, flags, &rsp_iov);
        cifs_small_buf_release(req);
        rsp = (struct smb2_tree_connect_rsp *)rsp_iov.iov_base;