mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	RDMA/hns: Fix wrong assignment of lp_pktn_ini in QPC
The RoCE Engine will schedule to another QP after one has sent
(2 ^ lp_pktn_ini) packets. lp_pktn_ini is set in QPC and should be
calculated from 2 factors:
1. current MTU as a integer
2. the RoCE Engine's maximum slice length 64KB
But the driver use MTU as a enum ib_mtu and the max inline capability, the
lp_pktn_ini will be much bigger than expected which may cause traffic of
some QPs to never get scheduled.
Fixes: b713128de7 ("RDMA/hns: Adjust lp_pktn_ini dynamically")
Link: https://lore.kernel.org/r/1594726138-49294-1-git-send-email-liweihang@huawei.com
Signed-off-by: Weihang Li <liweihang@huawei.com>
Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
			
			
This commit is contained in:
		
							parent
							
								
									c3d6057e07
								
							
						
					
					
						commit
						7b9bd73ed1
					
				| @ -3954,6 +3954,15 @@ static int config_qp_sq_buf(struct hns_roce_dev *hr_dev, | |||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | static inline enum ib_mtu get_mtu(struct ib_qp *ibqp, | ||||||
|  | 				  const struct ib_qp_attr *attr) | ||||||
|  | { | ||||||
|  | 	if (ibqp->qp_type == IB_QPT_GSI || ibqp->qp_type == IB_QPT_UD) | ||||||
|  | 		return IB_MTU_4096; | ||||||
|  | 
 | ||||||
|  | 	return attr->path_mtu; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| static int modify_qp_init_to_rtr(struct ib_qp *ibqp, | static int modify_qp_init_to_rtr(struct ib_qp *ibqp, | ||||||
| 				 const struct ib_qp_attr *attr, int attr_mask, | 				 const struct ib_qp_attr *attr, int attr_mask, | ||||||
| 				 struct hns_roce_v2_qp_context *context, | 				 struct hns_roce_v2_qp_context *context, | ||||||
| @ -3965,6 +3974,7 @@ static int modify_qp_init_to_rtr(struct ib_qp *ibqp, | |||||||
| 	struct ib_device *ibdev = &hr_dev->ib_dev; | 	struct ib_device *ibdev = &hr_dev->ib_dev; | ||||||
| 	dma_addr_t trrl_ba; | 	dma_addr_t trrl_ba; | ||||||
| 	dma_addr_t irrl_ba; | 	dma_addr_t irrl_ba; | ||||||
|  | 	enum ib_mtu mtu; | ||||||
| 	u8 port_num; | 	u8 port_num; | ||||||
| 	u64 *mtts; | 	u64 *mtts; | ||||||
| 	u8 *dmac; | 	u8 *dmac; | ||||||
| @ -4062,22 +4072,22 @@ static int modify_qp_init_to_rtr(struct ib_qp *ibqp, | |||||||
| 	roce_set_field(qpc_mask->byte_52_udpspn_dmac, V2_QPC_BYTE_52_DMAC_M, | 	roce_set_field(qpc_mask->byte_52_udpspn_dmac, V2_QPC_BYTE_52_DMAC_M, | ||||||
| 		       V2_QPC_BYTE_52_DMAC_S, 0); | 		       V2_QPC_BYTE_52_DMAC_S, 0); | ||||||
| 
 | 
 | ||||||
| 	/* mtu*(2^LP_PKTN_INI) should not bigger than 1 message length 64kb */ | 	mtu = get_mtu(ibqp, attr); | ||||||
| 	roce_set_field(context->byte_56_dqpn_err, V2_QPC_BYTE_56_LP_PKTN_INI_M, |  | ||||||
| 		       V2_QPC_BYTE_56_LP_PKTN_INI_S, |  | ||||||
| 		       ilog2(hr_dev->caps.max_sq_inline / IB_MTU_4096)); |  | ||||||
| 	roce_set_field(qpc_mask->byte_56_dqpn_err, V2_QPC_BYTE_56_LP_PKTN_INI_M, |  | ||||||
| 		       V2_QPC_BYTE_56_LP_PKTN_INI_S, 0); |  | ||||||
| 
 | 
 | ||||||
| 	if (ibqp->qp_type == IB_QPT_GSI || ibqp->qp_type == IB_QPT_UD) | 	if (attr_mask & IB_QP_PATH_MTU) { | ||||||
| 		roce_set_field(context->byte_24_mtu_tc, V2_QPC_BYTE_24_MTU_M, | 		roce_set_field(context->byte_24_mtu_tc, V2_QPC_BYTE_24_MTU_M, | ||||||
| 			       V2_QPC_BYTE_24_MTU_S, IB_MTU_4096); | 			       V2_QPC_BYTE_24_MTU_S, mtu); | ||||||
| 	else if (attr_mask & IB_QP_PATH_MTU) |  | ||||||
| 		roce_set_field(context->byte_24_mtu_tc, V2_QPC_BYTE_24_MTU_M, |  | ||||||
| 			       V2_QPC_BYTE_24_MTU_S, attr->path_mtu); |  | ||||||
| 
 |  | ||||||
| 		roce_set_field(qpc_mask->byte_24_mtu_tc, V2_QPC_BYTE_24_MTU_M, | 		roce_set_field(qpc_mask->byte_24_mtu_tc, V2_QPC_BYTE_24_MTU_M, | ||||||
| 			       V2_QPC_BYTE_24_MTU_S, 0); | 			       V2_QPC_BYTE_24_MTU_S, 0); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | #define MAX_LP_MSG_LEN 65536 | ||||||
|  | 	/* MTU*(2^LP_PKTN_INI) shouldn't be bigger than 64kb */ | ||||||
|  | 	roce_set_field(context->byte_56_dqpn_err, V2_QPC_BYTE_56_LP_PKTN_INI_M, | ||||||
|  | 		       V2_QPC_BYTE_56_LP_PKTN_INI_S, | ||||||
|  | 		       ilog2(MAX_LP_MSG_LEN / ib_mtu_enum_to_int(mtu))); | ||||||
|  | 	roce_set_field(qpc_mask->byte_56_dqpn_err, V2_QPC_BYTE_56_LP_PKTN_INI_M, | ||||||
|  | 		       V2_QPC_BYTE_56_LP_PKTN_INI_S, 0); | ||||||
| 
 | 
 | ||||||
| 	roce_set_bit(qpc_mask->byte_108_rx_reqepsn, | 	roce_set_bit(qpc_mask->byte_108_rx_reqepsn, | ||||||
| 		     V2_QPC_BYTE_108_RX_REQ_PSN_ERR_S, 0); | 		     V2_QPC_BYTE_108_RX_REQ_PSN_ERR_S, 0); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Weihang Li
						Weihang Li