RDMA/mlx5: Allow creating RAW ethernet QP with loopback support
Expose two new flags: MLX5_QP_FLAG_TIR_ALLOW_SELF_LB_UC MLX5_QP_FLAG_TIR_ALLOW_SELF_LB_MC Those flags can be used at creation time in order to allow a QP to be able to receive loopback traffic (unicast and multicast). We store the state in the QP to be used on the destroy path to indicate with which flags the QP was created with. Signed-off-by: Mark Bloch <markb@mellanox.com> Reviewed-by: Yishai Hadas <yishaih@mellanox.com> Signed-off-by: Leon Romanovsky <leonro@mellanox.com> Signed-off-by: Doug Ledford <dledford@redhat.com>
This commit is contained in:
parent
a560f1d9af
commit
175edba856
|
@ -428,7 +428,7 @@ struct mlx5_ib_qp {
|
||||||
struct list_head cq_send_list;
|
struct list_head cq_send_list;
|
||||||
struct mlx5_rate_limit rl;
|
struct mlx5_rate_limit rl;
|
||||||
u32 underlay_qpn;
|
u32 underlay_qpn;
|
||||||
bool tunnel_offload_en;
|
u32 flags_en;
|
||||||
/* storage for qp sub type when core qp type is IB_QPT_DRIVER */
|
/* storage for qp sub type when core qp type is IB_QPT_DRIVER */
|
||||||
enum ib_qp_type qp_sub_type;
|
enum ib_qp_type qp_sub_type;
|
||||||
};
|
};
|
||||||
|
|
|
@ -1258,8 +1258,9 @@ static bool tunnel_offload_supported(struct mlx5_core_dev *dev)
|
||||||
|
|
||||||
static int create_raw_packet_qp_tir(struct mlx5_ib_dev *dev,
|
static int create_raw_packet_qp_tir(struct mlx5_ib_dev *dev,
|
||||||
struct mlx5_ib_rq *rq, u32 tdn,
|
struct mlx5_ib_rq *rq, u32 tdn,
|
||||||
bool tunnel_offload_en)
|
u32 *qp_flags_en)
|
||||||
{
|
{
|
||||||
|
u8 lb_flag = 0;
|
||||||
u32 *in;
|
u32 *in;
|
||||||
void *tirc;
|
void *tirc;
|
||||||
int inlen;
|
int inlen;
|
||||||
|
@ -1274,12 +1275,21 @@ static int create_raw_packet_qp_tir(struct mlx5_ib_dev *dev,
|
||||||
MLX5_SET(tirc, tirc, disp_type, MLX5_TIRC_DISP_TYPE_DIRECT);
|
MLX5_SET(tirc, tirc, disp_type, MLX5_TIRC_DISP_TYPE_DIRECT);
|
||||||
MLX5_SET(tirc, tirc, inline_rqn, rq->base.mqp.qpn);
|
MLX5_SET(tirc, tirc, inline_rqn, rq->base.mqp.qpn);
|
||||||
MLX5_SET(tirc, tirc, transport_domain, tdn);
|
MLX5_SET(tirc, tirc, transport_domain, tdn);
|
||||||
if (tunnel_offload_en)
|
if (*qp_flags_en & MLX5_QP_FLAG_TUNNEL_OFFLOADS)
|
||||||
MLX5_SET(tirc, tirc, tunneled_offload_en, 1);
|
MLX5_SET(tirc, tirc, tunneled_offload_en, 1);
|
||||||
|
|
||||||
if (dev->rep)
|
if (*qp_flags_en & MLX5_QP_FLAG_TIR_ALLOW_SELF_LB_UC)
|
||||||
MLX5_SET(tirc, tirc, self_lb_block,
|
lb_flag |= MLX5_TIRC_SELF_LB_BLOCK_BLOCK_UNICAST;
|
||||||
MLX5_TIRC_SELF_LB_BLOCK_BLOCK_UNICAST);
|
|
||||||
|
if (*qp_flags_en & MLX5_QP_FLAG_TIR_ALLOW_SELF_LB_MC)
|
||||||
|
lb_flag |= MLX5_TIRC_SELF_LB_BLOCK_BLOCK_MULTICAST;
|
||||||
|
|
||||||
|
if (dev->rep) {
|
||||||
|
lb_flag |= MLX5_TIRC_SELF_LB_BLOCK_BLOCK_UNICAST;
|
||||||
|
*qp_flags_en |= MLX5_QP_FLAG_TIR_ALLOW_SELF_LB_UC;
|
||||||
|
}
|
||||||
|
|
||||||
|
MLX5_SET(tirc, tirc, self_lb_block, lb_flag);
|
||||||
|
|
||||||
err = mlx5_core_create_tir(dev->mdev, in, inlen, &rq->tirn);
|
err = mlx5_core_create_tir(dev->mdev, in, inlen, &rq->tirn);
|
||||||
|
|
||||||
|
@ -1332,8 +1342,7 @@ static int create_raw_packet_qp(struct mlx5_ib_dev *dev, struct mlx5_ib_qp *qp,
|
||||||
goto err_destroy_sq;
|
goto err_destroy_sq;
|
||||||
|
|
||||||
|
|
||||||
err = create_raw_packet_qp_tir(dev, rq, tdn,
|
err = create_raw_packet_qp_tir(dev, rq, tdn, &qp->flags_en);
|
||||||
qp->tunnel_offload_en);
|
|
||||||
if (err)
|
if (err)
|
||||||
goto err_destroy_rq;
|
goto err_destroy_rq;
|
||||||
}
|
}
|
||||||
|
@ -1410,6 +1419,7 @@ static int create_rss_raw_qp_tir(struct mlx5_ib_dev *dev, struct mlx5_ib_qp *qp,
|
||||||
u32 tdn = mucontext->tdn;
|
u32 tdn = mucontext->tdn;
|
||||||
struct mlx5_ib_create_qp_rss ucmd = {};
|
struct mlx5_ib_create_qp_rss ucmd = {};
|
||||||
size_t required_cmd_sz;
|
size_t required_cmd_sz;
|
||||||
|
u8 lb_flag = 0;
|
||||||
|
|
||||||
if (init_attr->qp_type != IB_QPT_RAW_PACKET)
|
if (init_attr->qp_type != IB_QPT_RAW_PACKET)
|
||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
@ -1444,7 +1454,9 @@ static int create_rss_raw_qp_tir(struct mlx5_ib_dev *dev, struct mlx5_ib_qp *qp,
|
||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ucmd.flags & ~MLX5_QP_FLAG_TUNNEL_OFFLOADS) {
|
if (ucmd.flags & ~(MLX5_QP_FLAG_TUNNEL_OFFLOADS |
|
||||||
|
MLX5_QP_FLAG_TIR_ALLOW_SELF_LB_UC |
|
||||||
|
MLX5_QP_FLAG_TIR_ALLOW_SELF_LB_MC)) {
|
||||||
mlx5_ib_dbg(dev, "invalid flags\n");
|
mlx5_ib_dbg(dev, "invalid flags\n");
|
||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
}
|
}
|
||||||
|
@ -1461,6 +1473,16 @@ static int create_rss_raw_qp_tir(struct mlx5_ib_dev *dev, struct mlx5_ib_qp *qp,
|
||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (ucmd.flags & MLX5_QP_FLAG_TIR_ALLOW_SELF_LB_UC || dev->rep) {
|
||||||
|
lb_flag |= MLX5_TIRC_SELF_LB_BLOCK_BLOCK_UNICAST;
|
||||||
|
qp->flags_en |= MLX5_QP_FLAG_TIR_ALLOW_SELF_LB_UC;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ucmd.flags & MLX5_QP_FLAG_TIR_ALLOW_SELF_LB_MC) {
|
||||||
|
lb_flag |= MLX5_TIRC_SELF_LB_BLOCK_BLOCK_MULTICAST;
|
||||||
|
qp->flags_en |= MLX5_QP_FLAG_TIR_ALLOW_SELF_LB_MC;
|
||||||
|
}
|
||||||
|
|
||||||
err = ib_copy_to_udata(udata, &resp, min(udata->outlen, sizeof(resp)));
|
err = ib_copy_to_udata(udata, &resp, min(udata->outlen, sizeof(resp)));
|
||||||
if (err) {
|
if (err) {
|
||||||
mlx5_ib_dbg(dev, "copy failed\n");
|
mlx5_ib_dbg(dev, "copy failed\n");
|
||||||
|
@ -1484,6 +1506,8 @@ static int create_rss_raw_qp_tir(struct mlx5_ib_dev *dev, struct mlx5_ib_qp *qp,
|
||||||
if (ucmd.flags & MLX5_QP_FLAG_TUNNEL_OFFLOADS)
|
if (ucmd.flags & MLX5_QP_FLAG_TUNNEL_OFFLOADS)
|
||||||
MLX5_SET(tirc, tirc, tunneled_offload_en, 1);
|
MLX5_SET(tirc, tirc, tunneled_offload_en, 1);
|
||||||
|
|
||||||
|
MLX5_SET(tirc, tirc, self_lb_block, lb_flag);
|
||||||
|
|
||||||
if (ucmd.rx_hash_fields_mask & MLX5_RX_HASH_INNER)
|
if (ucmd.rx_hash_fields_mask & MLX5_RX_HASH_INNER)
|
||||||
hfso = MLX5_ADDR_OF(tirc, tirc, rx_hash_field_selector_inner);
|
hfso = MLX5_ADDR_OF(tirc, tirc, rx_hash_field_selector_inner);
|
||||||
else
|
else
|
||||||
|
@ -1580,10 +1604,6 @@ static int create_rss_raw_qp_tir(struct mlx5_ib_dev *dev, struct mlx5_ib_qp *qp,
|
||||||
MLX5_SET(rx_hash_field_select, hfso, selected_fields, selected_fields);
|
MLX5_SET(rx_hash_field_select, hfso, selected_fields, selected_fields);
|
||||||
|
|
||||||
create_tir:
|
create_tir:
|
||||||
if (dev->rep)
|
|
||||||
MLX5_SET(tirc, tirc, self_lb_block,
|
|
||||||
MLX5_TIRC_SELF_LB_BLOCK_BLOCK_UNICAST);
|
|
||||||
|
|
||||||
err = mlx5_core_create_tir(dev->mdev, in, inlen, &qp->rss_qp.tirn);
|
err = mlx5_core_create_tir(dev->mdev, in, inlen, &qp->rss_qp.tirn);
|
||||||
|
|
||||||
if (err)
|
if (err)
|
||||||
|
@ -1710,7 +1730,23 @@ static int create_qp_common(struct mlx5_ib_dev *dev, struct ib_pd *pd,
|
||||||
mlx5_ib_dbg(dev, "Tunnel offload isn't supported\n");
|
mlx5_ib_dbg(dev, "Tunnel offload isn't supported\n");
|
||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
}
|
}
|
||||||
qp->tunnel_offload_en = true;
|
qp->flags_en |= MLX5_QP_FLAG_TUNNEL_OFFLOADS;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ucmd.flags & MLX5_QP_FLAG_TIR_ALLOW_SELF_LB_UC) {
|
||||||
|
if (init_attr->qp_type != IB_QPT_RAW_PACKET) {
|
||||||
|
mlx5_ib_dbg(dev, "Self-LB UC isn't supported\n");
|
||||||
|
return -EOPNOTSUPP;
|
||||||
|
}
|
||||||
|
qp->flags_en |= MLX5_QP_FLAG_TIR_ALLOW_SELF_LB_UC;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ucmd.flags & MLX5_QP_FLAG_TIR_ALLOW_SELF_LB_MC) {
|
||||||
|
if (init_attr->qp_type != IB_QPT_RAW_PACKET) {
|
||||||
|
mlx5_ib_dbg(dev, "Self-LB UM isn't supported\n");
|
||||||
|
return -EOPNOTSUPP;
|
||||||
|
}
|
||||||
|
qp->flags_en |= MLX5_QP_FLAG_TIR_ALLOW_SELF_LB_MC;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (init_attr->create_flags & IB_QP_CREATE_SOURCE_QPN) {
|
if (init_attr->create_flags & IB_QP_CREATE_SOURCE_QPN) {
|
||||||
|
|
|
@ -45,6 +45,8 @@ enum {
|
||||||
MLX5_QP_FLAG_BFREG_INDEX = 1 << 3,
|
MLX5_QP_FLAG_BFREG_INDEX = 1 << 3,
|
||||||
MLX5_QP_FLAG_TYPE_DCT = 1 << 4,
|
MLX5_QP_FLAG_TYPE_DCT = 1 << 4,
|
||||||
MLX5_QP_FLAG_TYPE_DCI = 1 << 5,
|
MLX5_QP_FLAG_TYPE_DCI = 1 << 5,
|
||||||
|
MLX5_QP_FLAG_TIR_ALLOW_SELF_LB_UC = 1 << 6,
|
||||||
|
MLX5_QP_FLAG_TIR_ALLOW_SELF_LB_MC = 1 << 7,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
|
|
Loading…
Reference in New Issue