mirror of
https://github.com/torvalds/linux.git
synced 2024-11-27 14:41:39 +00:00
smb3: update default requested iosize to 4MB from 1MB for recent dialects
Modern servers often support 8MB as maximum i/o size, and we see some performance benefits (my testing showed 1 to 13% on write paths, and 1 to 3% on read paths for increasing the default to 4MB). If server doesn't support larger i/o size, during negotiate protocol it is already set correctly to the server's maximum if lower than 4MB. Signed-off-by: Steve French <stfrench@microsoft.com> Reviewed-by: Ronnie Sahlberg <lsahlber@redhat.com>
This commit is contained in:
parent
6e4d3bbe92
commit
3d621230b8
@ -799,6 +799,7 @@ compare_mid(__u16 mid, const struct smb_hdr *smb)
|
|||||||
* a single wsize request with a single call.
|
* a single wsize request with a single call.
|
||||||
*/
|
*/
|
||||||
#define CIFS_DEFAULT_IOSIZE (1024 * 1024)
|
#define CIFS_DEFAULT_IOSIZE (1024 * 1024)
|
||||||
|
#define SMB3_DEFAULT_IOSIZE (4 * 1024 * 1024)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Windows only supports a max of 60kb reads and 65535 byte writes. Default to
|
* Windows only supports a max of 60kb reads and 65535 byte writes. Default to
|
||||||
|
@ -280,6 +280,31 @@ smb2_negotiate_wsize(struct cifs_tcon *tcon, struct smb_vol *volume_info)
|
|||||||
return wsize;
|
return wsize;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static unsigned int
|
||||||
|
smb3_negotiate_wsize(struct cifs_tcon *tcon, struct smb_vol *volume_info)
|
||||||
|
{
|
||||||
|
struct TCP_Server_Info *server = tcon->ses->server;
|
||||||
|
unsigned int wsize;
|
||||||
|
|
||||||
|
/* start with specified wsize, or default */
|
||||||
|
wsize = volume_info->wsize ? volume_info->wsize : SMB3_DEFAULT_IOSIZE;
|
||||||
|
wsize = min_t(unsigned int, wsize, server->max_write);
|
||||||
|
#ifdef CONFIG_CIFS_SMB_DIRECT
|
||||||
|
if (server->rdma) {
|
||||||
|
if (server->sign)
|
||||||
|
wsize = min_t(unsigned int,
|
||||||
|
wsize, server->smbd_conn->max_fragmented_send_size);
|
||||||
|
else
|
||||||
|
wsize = min_t(unsigned int,
|
||||||
|
wsize, server->smbd_conn->max_readwrite_size);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
if (!(server->capabilities & SMB2_GLOBAL_CAP_LARGE_MTU))
|
||||||
|
wsize = min_t(unsigned int, wsize, SMB2_MAX_BUFFER_SIZE);
|
||||||
|
|
||||||
|
return wsize;
|
||||||
|
}
|
||||||
|
|
||||||
static unsigned int
|
static unsigned int
|
||||||
smb2_negotiate_rsize(struct cifs_tcon *tcon, struct smb_vol *volume_info)
|
smb2_negotiate_rsize(struct cifs_tcon *tcon, struct smb_vol *volume_info)
|
||||||
{
|
{
|
||||||
@ -306,6 +331,31 @@ smb2_negotiate_rsize(struct cifs_tcon *tcon, struct smb_vol *volume_info)
|
|||||||
return rsize;
|
return rsize;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static unsigned int
|
||||||
|
smb3_negotiate_rsize(struct cifs_tcon *tcon, struct smb_vol *volume_info)
|
||||||
|
{
|
||||||
|
struct TCP_Server_Info *server = tcon->ses->server;
|
||||||
|
unsigned int rsize;
|
||||||
|
|
||||||
|
/* start with specified rsize, or default */
|
||||||
|
rsize = volume_info->rsize ? volume_info->rsize : SMB3_DEFAULT_IOSIZE;
|
||||||
|
rsize = min_t(unsigned int, rsize, server->max_read);
|
||||||
|
#ifdef CONFIG_CIFS_SMB_DIRECT
|
||||||
|
if (server->rdma) {
|
||||||
|
if (server->sign)
|
||||||
|
rsize = min_t(unsigned int,
|
||||||
|
rsize, server->smbd_conn->max_fragmented_recv_size);
|
||||||
|
else
|
||||||
|
rsize = min_t(unsigned int,
|
||||||
|
rsize, server->smbd_conn->max_readwrite_size);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (!(server->capabilities & SMB2_GLOBAL_CAP_LARGE_MTU))
|
||||||
|
rsize = min_t(unsigned int, rsize, SMB2_MAX_BUFFER_SIZE);
|
||||||
|
|
||||||
|
return rsize;
|
||||||
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
parse_server_interfaces(struct network_interface_info_ioctl_rsp *buf,
|
parse_server_interfaces(struct network_interface_info_ioctl_rsp *buf,
|
||||||
@ -3436,8 +3486,8 @@ struct smb_version_operations smb30_operations = {
|
|||||||
.downgrade_oplock = smb2_downgrade_oplock,
|
.downgrade_oplock = smb2_downgrade_oplock,
|
||||||
.need_neg = smb2_need_neg,
|
.need_neg = smb2_need_neg,
|
||||||
.negotiate = smb2_negotiate,
|
.negotiate = smb2_negotiate,
|
||||||
.negotiate_wsize = smb2_negotiate_wsize,
|
.negotiate_wsize = smb3_negotiate_wsize,
|
||||||
.negotiate_rsize = smb2_negotiate_rsize,
|
.negotiate_rsize = smb3_negotiate_rsize,
|
||||||
.sess_setup = SMB2_sess_setup,
|
.sess_setup = SMB2_sess_setup,
|
||||||
.logoff = SMB2_logoff,
|
.logoff = SMB2_logoff,
|
||||||
.tree_connect = SMB2_tcon,
|
.tree_connect = SMB2_tcon,
|
||||||
@ -3540,8 +3590,8 @@ struct smb_version_operations smb311_operations = {
|
|||||||
.downgrade_oplock = smb2_downgrade_oplock,
|
.downgrade_oplock = smb2_downgrade_oplock,
|
||||||
.need_neg = smb2_need_neg,
|
.need_neg = smb2_need_neg,
|
||||||
.negotiate = smb2_negotiate,
|
.negotiate = smb2_negotiate,
|
||||||
.negotiate_wsize = smb2_negotiate_wsize,
|
.negotiate_wsize = smb3_negotiate_wsize,
|
||||||
.negotiate_rsize = smb2_negotiate_rsize,
|
.negotiate_rsize = smb3_negotiate_rsize,
|
||||||
.sess_setup = SMB2_sess_setup,
|
.sess_setup = SMB2_sess_setup,
|
||||||
.logoff = SMB2_logoff,
|
.logoff = SMB2_logoff,
|
||||||
.tree_connect = SMB2_tcon,
|
.tree_connect = SMB2_tcon,
|
||||||
|
Loading…
Reference in New Issue
Block a user