Commit 4cdad802 authored by Shyam Prasad N's avatar Shyam Prasad N Committed by Steve French
Browse files

cifs: set replay flag for retries of write command



Similar to the rest of the commands, this is a change
to add replay flags on retry. This one does not add a
back-off, considering that we may want to flush a write
ASAP to the server. Considering that this will be a
flush of cached pages, the retrans value is also not
honoured.

Signed-off-by: default avatarShyam Prasad N <sprasad@microsoft.com>
Signed-off-by: default avatarSteve French <stfrench@microsoft.com>
parent 4f1fffa2
Loading
Loading
Loading
Loading
+1 −0
Original line number Diff line number Diff line
@@ -1506,6 +1506,7 @@ struct cifs_writedata {
	struct smbd_mr			*mr;
#endif
	struct cifs_credits		credits;
	bool				replay;
};

/*
+1 −0
Original line number Diff line number Diff line
@@ -3300,6 +3300,7 @@ cifs_resend_wdata(struct cifs_writedata *wdata, struct list_head *wdata_list,
			if (wdata->cfile->invalidHandle)
				rc = -EAGAIN;
			else {
				wdata->replay = true;
#ifdef CONFIG_CIFS_SMB_DIRECT
				if (wdata->mr) {
					wdata->mr->need_invalidate = true;
+3 −1
Original line number Diff line number Diff line
@@ -4771,7 +4771,7 @@ smb2_async_writev(struct cifs_writedata *wdata,
	struct cifs_io_parms *io_parms = NULL;
	int credit_request;

	if (!wdata->server)
	if (!wdata->server || wdata->replay)
		server = wdata->server = cifs_pick_channel(tcon->ses);

	/*
@@ -4856,6 +4856,8 @@ smb2_async_writev(struct cifs_writedata *wdata,
	rqst.rq_nvec = 1;
	rqst.rq_iter = wdata->iter;
	rqst.rq_iter_size = iov_iter_count(&rqst.rq_iter);
	if (wdata->replay)
		smb2_set_replay(server, &rqst);
#ifdef CONFIG_CIFS_SMB_DIRECT
	if (wdata->mr)
		iov[0].iov_len += sizeof(struct smbd_buffer_descriptor_v1);