Commit 915ec7ed authored by Leon Romanovsky's avatar Leon Romanovsky Committed by Jason Gunthorpe

RDMA/mlx4: Embed GSI QP into general mlx4_ib QP

Refactor the storage struct of mlx4 GSI QP to be embedded in mlx4_ib
QP. This allows to remove internal memory allocation of QP struct which is
hidden inside the mlx4_ib_create_qp() flow.

Link: https://lore.kernel.org/r/20200926102450.2966017-6-leon@kernel.orgReviewed-by: default avatarMaor Gottlieb <maorg@mellanox.com>
Signed-off-by: default avatarLeon Romanovsky <leonro@nvidia.com>
Signed-off-by: default avatarJason Gunthorpe <jgg@nvidia.com>
parent eebe580f
...@@ -299,6 +299,26 @@ struct mlx4_ib_rss { ...@@ -299,6 +299,26 @@ struct mlx4_ib_rss {
u8 rss_key[MLX4_EN_RSS_KEY_SIZE]; u8 rss_key[MLX4_EN_RSS_KEY_SIZE];
}; };
enum {
/*
* Largest possible UD header: send with GRH and immediate
* data plus 18 bytes for an Ethernet header with VLAN/802.1Q
* tag. (LRH would only use 8 bytes, so Ethernet is the
* biggest case)
*/
MLX4_IB_UD_HEADER_SIZE = 82,
MLX4_IB_LSO_HEADER_SPARE = 128,
};
struct mlx4_ib_sqp {
int pkey_index;
u32 qkey;
u32 send_psn;
struct ib_ud_header ud_header;
u8 header_buf[MLX4_IB_UD_HEADER_SIZE];
struct ib_qp *roce_v2_gsi;
};
struct mlx4_ib_qp { struct mlx4_ib_qp {
union { union {
struct ib_qp ibqp; struct ib_qp ibqp;
...@@ -344,7 +364,10 @@ struct mlx4_ib_qp { ...@@ -344,7 +364,10 @@ struct mlx4_ib_qp {
struct mlx4_wqn_range *wqn_range; struct mlx4_wqn_range *wqn_range;
/* Number of RSS QP parents that uses this WQ */ /* Number of RSS QP parents that uses this WQ */
u32 rss_usecnt; u32 rss_usecnt;
union {
struct mlx4_ib_rss *rss_ctx; struct mlx4_ib_rss *rss_ctx;
struct mlx4_ib_sqp *sqp;
};
}; };
struct mlx4_ib_srq { struct mlx4_ib_srq {
......
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment