RDMA/hns: Add TPQ link table support
In hip08, the TPQ(Timer Poll Queue) should be extended to host memory. This patch adds the support of TPQ. Signed-off-by: Yixian Liu <liuyixian@huawei.com> Signed-off-by: Lijun Ou <oulijun@huawei.com> Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
This commit is contained in:
parent
6b63597d35
commit
ded58ff987
|
@ -722,6 +722,7 @@ struct hns_roce_caps {
|
||||||
u32 eqe_hop_num;
|
u32 eqe_hop_num;
|
||||||
u32 sl_num;
|
u32 sl_num;
|
||||||
u32 tsq_buf_pg_sz;
|
u32 tsq_buf_pg_sz;
|
||||||
|
u32 tpq_buf_pg_sz;
|
||||||
u32 chunk_sz; /* chunk size in non multihop mode*/
|
u32 chunk_sz; /* chunk size in non multihop mode*/
|
||||||
u64 flags;
|
u64 flags;
|
||||||
};
|
};
|
||||||
|
|
|
@ -1251,6 +1251,10 @@ static int hns_roce_config_link_table(struct hns_roce_dev *hr_dev,
|
||||||
link_tbl = &priv->tsq;
|
link_tbl = &priv->tsq;
|
||||||
opcode = HNS_ROCE_OPC_CFG_EXT_LLM;
|
opcode = HNS_ROCE_OPC_CFG_EXT_LLM;
|
||||||
break;
|
break;
|
||||||
|
case TPQ_LINK_TABLE:
|
||||||
|
link_tbl = &priv->tpq;
|
||||||
|
opcode = HNS_ROCE_OPC_CFG_TMOUT_LLM;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
@ -1315,6 +1319,7 @@ static int hns_roce_init_link_table(struct hns_roce_dev *hr_dev,
|
||||||
struct device *dev = hr_dev->dev;
|
struct device *dev = hr_dev->dev;
|
||||||
u32 buf_chk_sz;
|
u32 buf_chk_sz;
|
||||||
dma_addr_t t;
|
dma_addr_t t;
|
||||||
|
int func_num = 1;
|
||||||
int pg_num_a;
|
int pg_num_a;
|
||||||
int pg_num_b;
|
int pg_num_b;
|
||||||
int pg_num;
|
int pg_num;
|
||||||
|
@ -1328,6 +1333,12 @@ static int hns_roce_init_link_table(struct hns_roce_dev *hr_dev,
|
||||||
pg_num_a = hr_dev->caps.num_qps * 8 / buf_chk_sz;
|
pg_num_a = hr_dev->caps.num_qps * 8 / buf_chk_sz;
|
||||||
pg_num_b = hr_dev->caps.sl_num * 4 + 2;
|
pg_num_b = hr_dev->caps.sl_num * 4 + 2;
|
||||||
break;
|
break;
|
||||||
|
case TPQ_LINK_TABLE:
|
||||||
|
link_tbl = &priv->tpq;
|
||||||
|
buf_chk_sz = 1 << (hr_dev->caps.tpq_buf_pg_sz + PAGE_SHIFT);
|
||||||
|
pg_num_a = hr_dev->caps.num_cqs * 4 / buf_chk_sz;
|
||||||
|
pg_num_b = 2 * 4 * func_num + 2;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
@ -1410,12 +1421,26 @@ static void hns_roce_free_link_table(struct hns_roce_dev *hr_dev,
|
||||||
|
|
||||||
static int hns_roce_v2_init(struct hns_roce_dev *hr_dev)
|
static int hns_roce_v2_init(struct hns_roce_dev *hr_dev)
|
||||||
{
|
{
|
||||||
|
struct hns_roce_v2_priv *priv = hr_dev->priv;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
/* TSQ includes SQ doorbell and ack doorbell */
|
/* TSQ includes SQ doorbell and ack doorbell */
|
||||||
ret = hns_roce_init_link_table(hr_dev, TSQ_LINK_TABLE);
|
ret = hns_roce_init_link_table(hr_dev, TSQ_LINK_TABLE);
|
||||||
if (ret)
|
if (ret) {
|
||||||
dev_err(hr_dev->dev, "TSQ init failed, ret = %d.\n", ret);
|
dev_err(hr_dev->dev, "TSQ init failed, ret = %d.\n", ret);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = hns_roce_init_link_table(hr_dev, TPQ_LINK_TABLE);
|
||||||
|
if (ret) {
|
||||||
|
dev_err(hr_dev->dev, "TPQ init failed, ret = %d.\n", ret);
|
||||||
|
goto err_tpq_init_failed;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
err_tpq_init_failed:
|
||||||
|
hns_roce_free_link_table(hr_dev, &priv->tsq);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -1424,6 +1449,7 @@ static void hns_roce_v2_exit(struct hns_roce_dev *hr_dev)
|
||||||
{
|
{
|
||||||
struct hns_roce_v2_priv *priv = hr_dev->priv;
|
struct hns_roce_v2_priv *priv = hr_dev->priv;
|
||||||
|
|
||||||
|
hns_roce_free_link_table(hr_dev, &priv->tpq);
|
||||||
hns_roce_free_link_table(hr_dev, &priv->tsq);
|
hns_roce_free_link_table(hr_dev, &priv->tsq);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -204,6 +204,7 @@ enum hns_roce_opcode_type {
|
||||||
HNS_ROCE_OPC_QUERY_PF_RES = 0x8400,
|
HNS_ROCE_OPC_QUERY_PF_RES = 0x8400,
|
||||||
HNS_ROCE_OPC_ALLOC_VF_RES = 0x8401,
|
HNS_ROCE_OPC_ALLOC_VF_RES = 0x8401,
|
||||||
HNS_ROCE_OPC_CFG_EXT_LLM = 0x8403,
|
HNS_ROCE_OPC_CFG_EXT_LLM = 0x8403,
|
||||||
|
HNS_ROCE_OPC_CFG_TMOUT_LLM = 0x8404,
|
||||||
HNS_ROCE_OPC_CFG_BT_ATTR = 0x8506,
|
HNS_ROCE_OPC_CFG_BT_ATTR = 0x8506,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1339,6 +1340,7 @@ struct hns_roce_v2_cmq {
|
||||||
|
|
||||||
enum hns_roce_link_table_type {
|
enum hns_roce_link_table_type {
|
||||||
TSQ_LINK_TABLE,
|
TSQ_LINK_TABLE,
|
||||||
|
TPQ_LINK_TABLE,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct hns_roce_link_table {
|
struct hns_roce_link_table {
|
||||||
|
@ -1361,6 +1363,7 @@ struct hns_roce_link_table_entry {
|
||||||
struct hns_roce_v2_priv {
|
struct hns_roce_v2_priv {
|
||||||
struct hns_roce_v2_cmq cmq;
|
struct hns_roce_v2_cmq cmq;
|
||||||
struct hns_roce_link_table tsq;
|
struct hns_roce_link_table tsq;
|
||||||
|
struct hns_roce_link_table tpq;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct hns_roce_eq_context {
|
struct hns_roce_eq_context {
|
||||||
|
|
Loading…
Reference in New Issue