Commit d2e81f92 authored by Tom Talpey's avatar Tom Talpey Committed by Steve French

Decrease the number of SMB3 smbdirect client SGEs

The client-side SMBDirect layer requires no more than 6 send SGEs
and 1 receive SGE. The previous default of 8 send and 8 receive
causes smbdirect to fail on the SoftiWARP (siw) provider, and
possibly others. Additionally, large numbers of SGEs reduces
performance significantly on adapter implementations.

Also correct the frmr page count comment (not an SGE count).
Acked-by: default avatarPaulo Alcantara (SUSE) <pc@cjr.nz>
Signed-off-by: default avatarTom Talpey <tom@talpey.com>
Signed-off-by: default avatarSteve French <stfrench@microsoft.com>
parent e98ecc6e
...@@ -99,7 +99,7 @@ int smbd_keep_alive_interval = 120; ...@@ -99,7 +99,7 @@ int smbd_keep_alive_interval = 120;
* User configurable initial values for RDMA transport * User configurable initial values for RDMA transport
* The actual values used may be lower and are limited to hardware capabilities * The actual values used may be lower and are limited to hardware capabilities
*/ */
/* Default maximum number of SGEs in a RDMA write/read */ /* Default maximum number of pages in a single RDMA write/read */
int smbd_max_frmr_depth = 2048; int smbd_max_frmr_depth = 2048;
/* If payload is less than this byte, use RDMA send/recv not read/write */ /* If payload is less than this byte, use RDMA send/recv not read/write */
...@@ -1017,9 +1017,9 @@ static int smbd_post_send_data( ...@@ -1017,9 +1017,9 @@ static int smbd_post_send_data(
{ {
int i; int i;
u32 data_length = 0; u32 data_length = 0;
struct scatterlist sgl[SMBDIRECT_MAX_SGE]; struct scatterlist sgl[SMBDIRECT_MAX_SEND_SGE - 1];
if (n_vec > SMBDIRECT_MAX_SGE) { if (n_vec > SMBDIRECT_MAX_SEND_SGE - 1) {
cifs_dbg(VFS, "Can't fit data to SGL, n_vec=%d\n", n_vec); cifs_dbg(VFS, "Can't fit data to SGL, n_vec=%d\n", n_vec);
return -EINVAL; return -EINVAL;
} }
...@@ -1562,17 +1562,15 @@ static struct smbd_connection *_smbd_get_connection( ...@@ -1562,17 +1562,15 @@ static struct smbd_connection *_smbd_get_connection(
info->max_receive_size = smbd_max_receive_size; info->max_receive_size = smbd_max_receive_size;
info->keep_alive_interval = smbd_keep_alive_interval; info->keep_alive_interval = smbd_keep_alive_interval;
if (info->id->device->attrs.max_send_sge < SMBDIRECT_MAX_SGE) { if (info->id->device->attrs.max_send_sge < SMBDIRECT_MAX_SEND_SGE ||
info->id->device->attrs.max_recv_sge < SMBDIRECT_MAX_RECV_SGE) {
log_rdma_event(ERR, log_rdma_event(ERR,
"warning: device max_send_sge = %d too small\n", "device %.*s max_send_sge/max_recv_sge = %d/%d too small\n",
info->id->device->attrs.max_send_sge); IB_DEVICE_NAME_MAX,
log_rdma_event(ERR, "Queue Pair creation may fail\n"); info->id->device->name,
} info->id->device->attrs.max_send_sge,
if (info->id->device->attrs.max_recv_sge < SMBDIRECT_MAX_SGE) {
log_rdma_event(ERR,
"warning: device max_recv_sge = %d too small\n",
info->id->device->attrs.max_recv_sge); info->id->device->attrs.max_recv_sge);
log_rdma_event(ERR, "Queue Pair creation may fail\n"); goto config_failed;
} }
info->send_cq = NULL; info->send_cq = NULL;
...@@ -1598,8 +1596,8 @@ static struct smbd_connection *_smbd_get_connection( ...@@ -1598,8 +1596,8 @@ static struct smbd_connection *_smbd_get_connection(
qp_attr.qp_context = info; qp_attr.qp_context = info;
qp_attr.cap.max_send_wr = info->send_credit_target; qp_attr.cap.max_send_wr = info->send_credit_target;
qp_attr.cap.max_recv_wr = info->receive_credit_max; qp_attr.cap.max_recv_wr = info->receive_credit_max;
qp_attr.cap.max_send_sge = SMBDIRECT_MAX_SGE; qp_attr.cap.max_send_sge = SMBDIRECT_MAX_SEND_SGE;
qp_attr.cap.max_recv_sge = SMBDIRECT_MAX_SGE; qp_attr.cap.max_recv_sge = SMBDIRECT_MAX_RECV_SGE;
qp_attr.cap.max_inline_data = 0; qp_attr.cap.max_inline_data = 0;
qp_attr.sq_sig_type = IB_SIGNAL_REQ_WR; qp_attr.sq_sig_type = IB_SIGNAL_REQ_WR;
qp_attr.qp_type = IB_QPT_RC; qp_attr.qp_type = IB_QPT_RC;
......
...@@ -91,7 +91,7 @@ struct smbd_connection { ...@@ -91,7 +91,7 @@ struct smbd_connection {
/* Memory registrations */ /* Memory registrations */
/* Maximum number of RDMA read/write outstanding on this connection */ /* Maximum number of RDMA read/write outstanding on this connection */
int responder_resources; int responder_resources;
/* Maximum number of SGEs in a RDMA write/read */ /* Maximum number of pages in a single RDMA write/read on this connection */
int max_frmr_depth; int max_frmr_depth;
/* /*
* If payload is less than or equal to the threshold, * If payload is less than or equal to the threshold,
...@@ -225,21 +225,25 @@ struct smbd_buffer_descriptor_v1 { ...@@ -225,21 +225,25 @@ struct smbd_buffer_descriptor_v1 {
__le32 length; __le32 length;
} __packed; } __packed;
/* Default maximum number of SGEs in a RDMA send/recv */ /* Maximum number of SGEs used by smbdirect.c in any send work request */
#define SMBDIRECT_MAX_SGE 16 #define SMBDIRECT_MAX_SEND_SGE 6
/* The context for a SMBD request */ /* The context for a SMBD request */
struct smbd_request { struct smbd_request {
struct smbd_connection *info; struct smbd_connection *info;
struct ib_cqe cqe; struct ib_cqe cqe;
/* the SGE entries for this packet */ /* the SGE entries for this work request */
struct ib_sge sge[SMBDIRECT_MAX_SGE]; struct ib_sge sge[SMBDIRECT_MAX_SEND_SGE];
int num_sge; int num_sge;
/* SMBD packet header follows this structure */ /* SMBD packet header follows this structure */
u8 packet[]; u8 packet[];
}; };
/* Maximum number of SGEs used by smbdirect.c in any receive work request */
#define SMBDIRECT_MAX_RECV_SGE 1
/* The context for a SMBD response */ /* The context for a SMBD response */
struct smbd_response { struct smbd_response {
struct smbd_connection *info; struct smbd_connection *info;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment