Commit 0f00571f authored by Lang Cheng's avatar Lang Cheng Committed by Jason Gunthorpe

RDMA/hns: Use new SQ doorbell register for HIP09

HIP09 uses new address space to map SQ doorbell registers, the doorbell of
each QP is isolated based on the size of 64KB, which can improve the
performance in concurrency scenarios.

Link: https://lore.kernel.org/r/1614082833-23130-1-git-send-email-liweihang@huawei.comSigned-off-by: default avatarLang Cheng <chenglang@huawei.com>
Signed-off-by: default avatarWeihang Li <liweihang@huawei.com>
Signed-off-by: default avatarJason Gunthorpe <jgg@nvidia.com>
parent a38fd874
...@@ -681,8 +681,7 @@ static void write_dwqe(struct hns_roce_dev *hr_dev, struct hns_roce_qp *qp, ...@@ -681,8 +681,7 @@ static void write_dwqe(struct hns_roce_dev *hr_dev, struct hns_roce_qp *qp,
roce_set_field(rc_sq_wqe->byte_4, V2_RC_SEND_WQE_BYTE_4_WQE_INDEX_M, roce_set_field(rc_sq_wqe->byte_4, V2_RC_SEND_WQE_BYTE_4_WQE_INDEX_M,
V2_RC_SEND_WQE_BYTE_4_WQE_INDEX_S, qp->sq.head); V2_RC_SEND_WQE_BYTE_4_WQE_INDEX_S, qp->sq.head);
hns_roce_write512(hr_dev, wqe, hr_dev->mem_base + hns_roce_write512(hr_dev, wqe, qp->sq.db_reg_l);
HNS_ROCE_DWQE_SIZE * qp->ibqp.qp_num);
} }
static int hns_roce_v2_post_send(struct ib_qp *ibqp, static int hns_roce_v2_post_send(struct ib_qp *ibqp,
......
...@@ -840,9 +840,14 @@ static int alloc_qp_db(struct hns_roce_dev *hr_dev, struct hns_roce_qp *hr_qp, ...@@ -840,9 +840,14 @@ static int alloc_qp_db(struct hns_roce_dev *hr_dev, struct hns_roce_qp *hr_qp,
resp->cap_flags |= HNS_ROCE_QP_CAP_RQ_RECORD_DB; resp->cap_flags |= HNS_ROCE_QP_CAP_RQ_RECORD_DB;
} }
} else { } else {
/* QP doorbell register address */ if (hr_dev->pci_dev->revision >= PCI_REVISION_ID_HIP09)
hr_qp->sq.db_reg_l = hr_dev->reg_base + hr_dev->sdb_offset + hr_qp->sq.db_reg_l = hr_dev->mem_base +
DB_REG_OFFSET * hr_dev->priv_uar.index; HNS_ROCE_DWQE_SIZE * hr_qp->qpn;
else
hr_qp->sq.db_reg_l =
hr_dev->reg_base + hr_dev->sdb_offset +
DB_REG_OFFSET * hr_dev->priv_uar.index;
hr_qp->rq.db_reg_l = hr_dev->reg_base + hr_dev->odb_offset + hr_qp->rq.db_reg_l = hr_dev->reg_base + hr_dev->odb_offset +
DB_REG_OFFSET * hr_dev->priv_uar.index; DB_REG_OFFSET * hr_dev->priv_uar.index;
...@@ -1011,36 +1016,36 @@ static int hns_roce_create_qp_common(struct hns_roce_dev *hr_dev, ...@@ -1011,36 +1016,36 @@ static int hns_roce_create_qp_common(struct hns_roce_dev *hr_dev,
} }
} }
ret = alloc_qp_db(hr_dev, hr_qp, init_attr, udata, &ucmd, &resp);
if (ret) {
ibdev_err(ibdev, "failed to alloc QP doorbell, ret = %d.\n",
ret);
goto err_wrid;
}
ret = alloc_qp_buf(hr_dev, hr_qp, init_attr, udata, ucmd.buf_addr); ret = alloc_qp_buf(hr_dev, hr_qp, init_attr, udata, ucmd.buf_addr);
if (ret) { if (ret) {
ibdev_err(ibdev, "failed to alloc QP buffer, ret = %d.\n", ret); ibdev_err(ibdev, "failed to alloc QP buffer, ret = %d.\n", ret);
goto err_db; goto err_buf;
} }
ret = alloc_qpn(hr_dev, hr_qp); ret = alloc_qpn(hr_dev, hr_qp);
if (ret) { if (ret) {
ibdev_err(ibdev, "failed to alloc QPN, ret = %d.\n", ret); ibdev_err(ibdev, "failed to alloc QPN, ret = %d.\n", ret);
goto err_buf; goto err_qpn;
}
ret = alloc_qp_db(hr_dev, hr_qp, init_attr, udata, &ucmd, &resp);
if (ret) {
ibdev_err(ibdev, "failed to alloc QP doorbell, ret = %d.\n",
ret);
goto err_db;
} }
ret = alloc_qpc(hr_dev, hr_qp); ret = alloc_qpc(hr_dev, hr_qp);
if (ret) { if (ret) {
ibdev_err(ibdev, "failed to alloc QP context, ret = %d.\n", ibdev_err(ibdev, "failed to alloc QP context, ret = %d.\n",
ret); ret);
goto err_qpn; goto err_qpc;
} }
ret = hns_roce_qp_store(hr_dev, hr_qp, init_attr); ret = hns_roce_qp_store(hr_dev, hr_qp, init_attr);
if (ret) { if (ret) {
ibdev_err(ibdev, "failed to store QP, ret = %d.\n", ret); ibdev_err(ibdev, "failed to store QP, ret = %d.\n", ret);
goto err_qpc; goto err_store;
} }
if (udata) { if (udata) {
...@@ -1055,7 +1060,7 @@ static int hns_roce_create_qp_common(struct hns_roce_dev *hr_dev, ...@@ -1055,7 +1060,7 @@ static int hns_roce_create_qp_common(struct hns_roce_dev *hr_dev,
if (hr_dev->caps.flags & HNS_ROCE_CAP_FLAG_QP_FLOW_CTRL) { if (hr_dev->caps.flags & HNS_ROCE_CAP_FLAG_QP_FLOW_CTRL) {
ret = hr_dev->hw->qp_flow_control_init(hr_dev, hr_qp); ret = hr_dev->hw->qp_flow_control_init(hr_dev, hr_qp);
if (ret) if (ret)
goto err_store; goto err_flow_ctrl;
} }
hr_qp->ibqp.qp_num = hr_qp->qpn; hr_qp->ibqp.qp_num = hr_qp->qpn;
...@@ -1065,17 +1070,17 @@ static int hns_roce_create_qp_common(struct hns_roce_dev *hr_dev, ...@@ -1065,17 +1070,17 @@ static int hns_roce_create_qp_common(struct hns_roce_dev *hr_dev,
return 0; return 0;
err_store: err_flow_ctrl:
hns_roce_qp_remove(hr_dev, hr_qp); hns_roce_qp_remove(hr_dev, hr_qp);
err_qpc: err_store:
free_qpc(hr_dev, hr_qp); free_qpc(hr_dev, hr_qp);
err_qpn: err_qpc:
free_qp_db(hr_dev, hr_qp, udata);
err_db:
free_qpn(hr_dev, hr_qp); free_qpn(hr_dev, hr_qp);
err_buf: err_qpn:
free_qp_buf(hr_dev, hr_qp); free_qp_buf(hr_dev, hr_qp);
err_db: err_buf:
free_qp_db(hr_dev, hr_qp, udata);
err_wrid:
free_kernel_wrid(hr_qp); free_kernel_wrid(hr_qp);
return ret; return ret;
} }
......
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