Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 795b609c authored by Bodong Wang's avatar Bodong Wang Committed by Doug Ledford
Browse files

IB/mlx5: Allow posting multi packet send WQEs if hardware supports



Set the field to allow posting multi packet send WQEs if hardware
supports this feature. This doesn't mean the send WQEs will be for
multi packet unless the send WQE was prepared according to multi
packet send WQE format.

User space shall use flag MLX5_IB_ALLOW_MPW to check if hardware
supports MPW and allows MPW in SQ context.

Signed-off-by: default avatarBodong Wang <bodong@mellanox.com>
Reviewed-by: default avatarDaniel Jurgens <danielj@mellanox.com>
Signed-off-by: default avatarLeon Romanovsky <leon@kernel.org>
Signed-off-by: default avatarDoug Ledford <dledford@redhat.com>
parent a550ddfc
Loading
Loading
Loading
Loading
+3 −2
Original line number Original line Diff line number Diff line
@@ -802,8 +802,9 @@ static int mlx5_ib_query_device(struct ib_device *ibdev,


	if (field_avail(typeof(resp), mlx5_ib_support_multi_pkt_send_wqes,
	if (field_avail(typeof(resp), mlx5_ib_support_multi_pkt_send_wqes,
			uhw->outlen)) {
			uhw->outlen)) {
		if (MLX5_CAP_ETH(mdev, multi_pkt_send_wqe))
			resp.mlx5_ib_support_multi_pkt_send_wqes =
			resp.mlx5_ib_support_multi_pkt_send_wqes =
			MLX5_CAP_ETH(mdev, multi_pkt_send_wqe);
				MLX5_IB_ALLOW_MPW;
		resp.response_length +=
		resp.response_length +=
			sizeof(resp.mlx5_ib_support_multi_pkt_send_wqes);
			sizeof(resp.mlx5_ib_support_multi_pkt_send_wqes);
	}
	}
+2 −0
Original line number Original line Diff line number Diff line
@@ -1083,6 +1083,8 @@ static int create_raw_packet_qp_sq(struct mlx5_ib_dev *dev,


	sqc = MLX5_ADDR_OF(create_sq_in, in, ctx);
	sqc = MLX5_ADDR_OF(create_sq_in, in, ctx);
	MLX5_SET(sqc, sqc, flush_in_error_en, 1);
	MLX5_SET(sqc, sqc, flush_in_error_en, 1);
	if (MLX5_CAP_ETH(dev->mdev, multi_pkt_send_wqe))
		MLX5_SET(sqc, sqc, allow_multi_pkt_send_wqe, 1);
	MLX5_SET(sqc, sqc, state, MLX5_SQC_STATE_RST);
	MLX5_SET(sqc, sqc, state, MLX5_SQC_STATE_RST);
	MLX5_SET(sqc, sqc, user_index, MLX5_GET(qpc, qpc, user_index));
	MLX5_SET(sqc, sqc, user_index, MLX5_GET(qpc, qpc, user_index));
	MLX5_SET(sqc, sqc, cqn, MLX5_GET(qpc, qpc, cqn_snd));
	MLX5_SET(sqc, sqc, cqn, MLX5_GET(qpc, qpc, cqn_snd));
+1 −1
Original line number Original line Diff line number Diff line
@@ -2445,7 +2445,7 @@ struct mlx5_ifc_sqc_bits {
	u8         cd_master[0x1];
	u8         cd_master[0x1];
	u8         fre[0x1];
	u8         fre[0x1];
	u8         flush_in_error_en[0x1];
	u8         flush_in_error_en[0x1];
	u8         reserved_at_4[0x1];
	u8         allow_multi_pkt_send_wqe[0x1];
	u8	   min_wqe_inline_mode[0x3];
	u8	   min_wqe_inline_mode[0x3];
	u8         state[0x4];
	u8         state[0x4];
	u8         reg_umr[0x1];
	u8         reg_umr[0x1];
+5 −0
Original line number Original line Diff line number Diff line
@@ -168,6 +168,11 @@ struct mlx5_packet_pacing_caps {
	__u32 reserved;
	__u32 reserved;
};
};


enum mlx5_ib_mpw_caps {
	MPW_RESERVED		= 1 << 0,
	MLX5_IB_ALLOW_MPW	= 1 << 1,
};

enum mlx5_ib_sw_parsing_offloads {
enum mlx5_ib_sw_parsing_offloads {
	MLX5_IB_SW_PARSING = 1 << 0,
	MLX5_IB_SW_PARSING = 1 << 0,
	MLX5_IB_SW_PARSING_CSUM = 1 << 1,
	MLX5_IB_SW_PARSING_CSUM = 1 << 1,