diff options
Diffstat (limited to 'fs/smb/client/smbdirect.c')
| -rw-r--r-- | fs/smb/client/smbdirect.c | 36 | 
1 files changed, 23 insertions, 13 deletions
| diff --git a/fs/smb/client/smbdirect.c b/fs/smb/client/smbdirect.c index f2da694336ee..85a4c55b61b8 100644 --- a/fs/smb/client/smbdirect.c +++ b/fs/smb/client/smbdirect.c @@ -1784,6 +1784,7 @@ static struct smbd_connection *_smbd_get_connection(  	struct smbdirect_socket *sc;  	struct smbdirect_socket_parameters *sp;  	struct rdma_conn_param conn_param; +	struct ib_qp_cap qp_cap;  	struct ib_qp_init_attr qp_attr;  	struct sockaddr_in *addr_in = (struct sockaddr_in *) dstaddr;  	struct ib_port_immutable port_immutable; @@ -1855,6 +1856,25 @@ static struct smbd_connection *_smbd_get_connection(  		goto config_failed;  	} +	sp->responder_resources = +		min_t(u8, sp->responder_resources, +		      sc->ib.dev->attrs.max_qp_rd_atom); +	log_rdma_mr(INFO, "responder_resources=%d\n", +		sp->responder_resources); + +	/* +	 * We use allocate sp->responder_resources * 2 MRs +	 * and each MR needs WRs for REG and INV, so +	 * we use '* 4'. +	 * +	 * +1 for ib_drain_qp() +	 */ +	memset(&qp_cap, 0, sizeof(qp_cap)); +	qp_cap.max_send_wr = sp->send_credit_target + sp->responder_resources * 4 + 1; +	qp_cap.max_recv_wr = sp->recv_credit_max + 1; +	qp_cap.max_send_sge = SMBDIRECT_SEND_IO_MAX_SGE; +	qp_cap.max_recv_sge = SMBDIRECT_RECV_IO_MAX_SGE; +  	sc->ib.pd = ib_alloc_pd(sc->ib.dev, 0);  	if (IS_ERR(sc->ib.pd)) {  		rc = PTR_ERR(sc->ib.pd); @@ -1865,7 +1885,7 @@ static struct smbd_connection *_smbd_get_connection(  	sc->ib.send_cq =  		ib_alloc_cq_any(sc->ib.dev, sc, -				sp->send_credit_target, IB_POLL_SOFTIRQ); +				qp_cap.max_send_wr, IB_POLL_SOFTIRQ);  	if (IS_ERR(sc->ib.send_cq)) {  		sc->ib.send_cq = NULL;  		goto alloc_cq_failed; @@ -1873,7 +1893,7 @@ static struct smbd_connection *_smbd_get_connection(  	sc->ib.recv_cq =  		ib_alloc_cq_any(sc->ib.dev, sc, -				sp->recv_credit_max, IB_POLL_SOFTIRQ); +				qp_cap.max_recv_wr, IB_POLL_SOFTIRQ);  	if (IS_ERR(sc->ib.recv_cq)) {  		sc->ib.recv_cq = NULL;  		goto alloc_cq_failed; @@ -1882,11 +1902,7 @@ static struct smbd_connection *_smbd_get_connection(  	memset(&qp_attr, 0, sizeof(qp_attr));  	qp_attr.event_handler = smbd_qp_async_error_upcall;  	qp_attr.qp_context = sc; -	qp_attr.cap.max_send_wr = sp->send_credit_target; -	qp_attr.cap.max_recv_wr = sp->recv_credit_max; -	qp_attr.cap.max_send_sge = SMBDIRECT_SEND_IO_MAX_SGE; -	qp_attr.cap.max_recv_sge = SMBDIRECT_RECV_IO_MAX_SGE; -	qp_attr.cap.max_inline_data = 0; +	qp_attr.cap = qp_cap;  	qp_attr.sq_sig_type = IB_SIGNAL_REQ_WR;  	qp_attr.qp_type = IB_QPT_RC;  	qp_attr.send_cq = sc->ib.send_cq; @@ -1900,12 +1916,6 @@ static struct smbd_connection *_smbd_get_connection(  	}  	sc->ib.qp = sc->rdma.cm_id->qp; -	sp->responder_resources = -		min_t(u8, sp->responder_resources, -		      sc->ib.dev->attrs.max_qp_rd_atom); -	log_rdma_mr(INFO, "responder_resources=%d\n", -		sp->responder_resources); -  	memset(&conn_param, 0, sizeof(conn_param));  	conn_param.initiator_depth = sp->initiator_depth;  	conn_param.responder_resources = sp->responder_resources; | 
