Skip to content

Commit b1383aa

Browse files
noaosdledford
authored andcommitted
IB/mlx5: Add PCI write end padding support
Add the PCI write end padding flag to device_cap_flags enum and set it during mlx5_ib_query_device so it will be reported to user-space. During WQ/QP creation, set that capability for WQ/QP if user requested it and HW supports it. PCI write end padding modification is not supported for now. There's no such flag for a QP but for a WQ, create and modify use the same flag. Return an error if PCI write end padding flag is set during modify_wq. Signed-off-by: Noa Osherovich <[email protected]> Reviewed-by: Majd Dibbiny <[email protected]> Signed-off-by: Leon Romanovsky <[email protected]> Signed-off-by: Doug Ledford <[email protected]>
1 parent e1d2e88 commit b1383aa

File tree

3 files changed

+38
-4
lines changed

3 files changed

+38
-4
lines changed

drivers/infiniband/hw/mlx5/main.c

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -715,6 +715,9 @@ static int mlx5_ib_query_device(struct ib_device *ibdev,
715715
if (mlx5_get_flow_namespace(dev->mdev, MLX5_FLOW_NAMESPACE_BYPASS))
716716
props->device_cap_flags |= IB_DEVICE_MANAGED_FLOW_STEERING;
717717

718+
if (MLX5_CAP_GEN(mdev, end_pad))
719+
props->device_cap_flags |= IB_DEVICE_PCI_WRITE_END_PADDING;
720+
718721
props->vendor_part_id = mdev->pdev->device;
719722
props->hw_ver = mdev->pdev->revision;
720723

drivers/infiniband/hw/mlx5/mlx5_ib.h

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -228,6 +228,7 @@ struct wr_list {
228228

229229
enum mlx5_ib_rq_flags {
230230
MLX5_IB_RQ_CVLAN_STRIPPING = 1 << 0,
231+
MLX5_IB_RQ_PCI_WRITE_END_PADDING = 1 << 1,
231232
};
232233

233234
struct mlx5_ib_wq {
@@ -421,7 +422,7 @@ enum mlx5_ib_qp_flags {
421422
MLX5_IB_QP_RSS = 1 << 8,
422423
MLX5_IB_QP_CVLAN_STRIPPING = 1 << 9,
423424
MLX5_IB_QP_UNDERLAY = 1 << 10,
424-
/* Reserved for PCI_WRITE_PAD = 1 << 11, */
425+
MLX5_IB_QP_PCI_WRITE_END_PADDING = 1 << 11,
425426
MLX5_IB_QP_TUNNEL_OFFLOAD = 1 << 12,
426427
};
427428

drivers/infiniband/hw/mlx5/qp.c

Lines changed: 33 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1178,8 +1178,8 @@ static int create_raw_packet_qp_rq(struct mlx5_ib_dev *dev,
11781178

11791179
wq = MLX5_ADDR_OF(rqc, rqc, wq);
11801180
MLX5_SET(wq, wq, wq_type, MLX5_WQ_TYPE_CYCLIC);
1181-
MLX5_SET(wq, wq, end_padding_mode,
1182-
MLX5_GET(qpc, qpc, end_padding_mode));
1181+
if (rq->flags & MLX5_IB_RQ_PCI_WRITE_END_PADDING)
1182+
MLX5_SET(wq, wq, end_padding_mode, MLX5_WQ_END_PAD_MODE_ALIGN);
11831183
MLX5_SET(wq, wq, page_offset, MLX5_GET(qpc, qpc, page_offset));
11841184
MLX5_SET(wq, wq, pd, MLX5_GET(qpc, qpc, pd));
11851185
MLX5_SET64(wq, wq, dbr_addr, MLX5_GET64(qpc, qpc, dbr_addr));
@@ -1276,6 +1276,8 @@ static int create_raw_packet_qp(struct mlx5_ib_dev *dev, struct mlx5_ib_qp *qp,
12761276

12771277
if (qp->flags & MLX5_IB_QP_CVLAN_STRIPPING)
12781278
rq->flags |= MLX5_IB_RQ_CVLAN_STRIPPING;
1279+
if (qp->flags & MLX5_IB_QP_PCI_WRITE_END_PADDING)
1280+
rq->flags |= MLX5_IB_RQ_PCI_WRITE_END_PADDING;
12791281
err = create_raw_packet_qp_rq(dev, rq, in);
12801282
if (err)
12811283
goto err_destroy_sq;
@@ -1821,6 +1823,19 @@ static int create_qp_common(struct mlx5_ib_dev *dev, struct ib_pd *pd,
18211823
qp->flags |= MLX5_IB_QP_LSO;
18221824
}
18231825

1826+
if (init_attr->create_flags & IB_QP_CREATE_PCI_WRITE_END_PADDING) {
1827+
if (!MLX5_CAP_GEN(dev->mdev, end_pad)) {
1828+
mlx5_ib_dbg(dev, "scatter end padding is not supported\n");
1829+
err = -EOPNOTSUPP;
1830+
goto err;
1831+
} else if (init_attr->qp_type != IB_QPT_RAW_PACKET) {
1832+
MLX5_SET(qpc, qpc, end_padding_mode,
1833+
MLX5_WQ_END_PAD_MODE_ALIGN);
1834+
} else {
1835+
qp->flags |= MLX5_IB_QP_PCI_WRITE_END_PADDING;
1836+
}
1837+
}
1838+
18241839
if (init_attr->qp_type == IB_QPT_RAW_PACKET ||
18251840
qp->flags & MLX5_IB_QP_UNDERLAY) {
18261841
qp->raw_packet_qp.sq.ubuffer.buf_addr = ucmd.sq_buf_addr;
@@ -1865,6 +1880,7 @@ static int create_qp_common(struct mlx5_ib_dev *dev, struct ib_pd *pd,
18651880
else if (qp->create_type == MLX5_QP_KERNEL)
18661881
destroy_qp_kernel(dev, qp);
18671882

1883+
err:
18681884
kvfree(in);
18691885
return err;
18701886
}
@@ -4749,7 +4765,15 @@ static int create_rq(struct mlx5_ib_rwq *rwq, struct ib_pd *pd,
47494765
MLX5_SET(wq, wq, wq_type,
47504766
rwq->create_flags & MLX5_IB_WQ_FLAGS_STRIDING_RQ ?
47514767
MLX5_WQ_TYPE_CYCLIC_STRIDING_RQ : MLX5_WQ_TYPE_CYCLIC);
4752-
MLX5_SET(wq, wq, end_padding_mode, MLX5_WQ_END_PAD_MODE_ALIGN);
4768+
if (init_attr->create_flags & IB_WQ_FLAGS_PCI_WRITE_END_PADDING) {
4769+
if (!MLX5_CAP_GEN(dev->mdev, end_pad)) {
4770+
mlx5_ib_dbg(dev, "Scatter end padding is not supported\n");
4771+
err = -EOPNOTSUPP;
4772+
goto out;
4773+
} else {
4774+
MLX5_SET(wq, wq, end_padding_mode, MLX5_WQ_END_PAD_MODE_ALIGN);
4775+
}
4776+
}
47534777
MLX5_SET(wq, wq, log_wq_stride, rwq->log_rq_stride);
47544778
if (rwq->create_flags & MLX5_IB_WQ_FLAGS_STRIDING_RQ) {
47554779
MLX5_SET(wq, wq, two_byte_shift_en, rwq->two_byte_shift_en);
@@ -5129,6 +5153,12 @@ int mlx5_ib_modify_wq(struct ib_wq *wq, struct ib_wq_attr *wq_attr,
51295153
MLX5_SET(rqc, rqc, vsd,
51305154
(wq_attr->flags & IB_WQ_FLAGS_CVLAN_STRIPPING) ? 0 : 1);
51315155
}
5156+
5157+
if (wq_attr->flags_mask & IB_WQ_FLAGS_PCI_WRITE_END_PADDING) {
5158+
mlx5_ib_dbg(dev, "Modifying scatter end padding is not supported\n");
5159+
err = -EOPNOTSUPP;
5160+
goto out;
5161+
}
51325162
}
51335163

51345164
if (curr_wq_state == IB_WQS_RESET && wq_state == IB_WQS_RDY) {

0 commit comments

Comments
 (0)