mirror of
https://github.com/torvalds/linux.git
synced 2024-11-23 20:51:44 +00:00
Adjust cifssb maximum read size
When session gets reconnected during mount then read size in super block fs context gets set to zero and after negotiate, rsize is not modified which results in incorrect read with requested bytes as zero. Fixes intermittent failure of xfstest generic/240 Note that stable requires a different version of this patch which will be sent to the stable mailing list. Signed-off-by: Rohith Surabattula <rohiths@microsoft.com> Acked-by: Paulo Alcantara (SUSE) <pc@cjr.nz> Signed-off-by: Steve French <stfrench@microsoft.com>
This commit is contained in:
parent
84330d41ef
commit
06a466565d
@ -210,6 +210,9 @@ cifs_read_super(struct super_block *sb)
|
||||
if (rc)
|
||||
goto out_no_root;
|
||||
/* tune readahead according to rsize if readahead size not set on mount */
|
||||
if (cifs_sb->ctx->rsize == 0)
|
||||
cifs_sb->ctx->rsize =
|
||||
tcon->ses->server->ops->negotiate_rsize(tcon, cifs_sb->ctx);
|
||||
if (cifs_sb->ctx->rasize)
|
||||
sb->s_bdi->ra_pages = cifs_sb->ctx->rasize / PAGE_SIZE;
|
||||
else
|
||||
|
@ -3740,6 +3740,11 @@ cifs_send_async_read(loff_t offset, size_t len, struct cifsFileInfo *open_file,
|
||||
break;
|
||||
}
|
||||
|
||||
if (cifs_sb->ctx->rsize == 0)
|
||||
cifs_sb->ctx->rsize =
|
||||
server->ops->negotiate_rsize(tlink_tcon(open_file->tlink),
|
||||
cifs_sb->ctx);
|
||||
|
||||
rc = server->ops->wait_mtu_credits(server, cifs_sb->ctx->rsize,
|
||||
&rsize, credits);
|
||||
if (rc)
|
||||
@ -4474,6 +4479,11 @@ static void cifs_readahead(struct readahead_control *ractl)
|
||||
}
|
||||
}
|
||||
|
||||
if (cifs_sb->ctx->rsize == 0)
|
||||
cifs_sb->ctx->rsize =
|
||||
server->ops->negotiate_rsize(tlink_tcon(open_file->tlink),
|
||||
cifs_sb->ctx);
|
||||
|
||||
rc = server->ops->wait_mtu_credits(server, cifs_sb->ctx->rsize,
|
||||
&rsize, credits);
|
||||
if (rc)
|
||||
|
Loading…
Reference in New Issue
Block a user