RDMA/bnxt_re: Refactor doorbell management functions
Moving all the fast path doorbell functions at one place under qplib_res.h. To pass doorbell record information a new structure bnxt_qplib_db_info has been introduced. Every roce object holds an instance of this structure and doorbell information is initialized during resource creation. When DB is rung only the current queue index is read from hardware ring and rest of the data is taken from pre-initialized dbinfo structure. Link: https://lore.kernel.org/r/1581786665-23705-8-git-send-email-devesh.sharma@broadcom.com Signed-off-by: Devesh Sharma <devesh.sharma@broadcom.com> Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
This commit is contained in:
Родитель
9555352bac
Коммит
6f53196bc5
|
@ -53,9 +53,7 @@
|
||||||
#include "qplib_sp.h"
|
#include "qplib_sp.h"
|
||||||
#include "qplib_fp.h"
|
#include "qplib_fp.h"
|
||||||
|
|
||||||
static void bnxt_qplib_arm_cq_enable(struct bnxt_qplib_cq *cq);
|
|
||||||
static void __clean_cq(struct bnxt_qplib_cq *cq, u64 qp);
|
static void __clean_cq(struct bnxt_qplib_cq *cq, u64 qp);
|
||||||
static void bnxt_qplib_arm_srq(struct bnxt_qplib_srq *srq, u32 arm_type);
|
|
||||||
|
|
||||||
static void bnxt_qplib_cancel_phantom_processing(struct bnxt_qplib_qp *qp)
|
static void bnxt_qplib_cancel_phantom_processing(struct bnxt_qplib_qp *qp)
|
||||||
{
|
{
|
||||||
|
@ -236,7 +234,6 @@ fail:
|
||||||
static void bnxt_qplib_service_nq(unsigned long data)
|
static void bnxt_qplib_service_nq(unsigned long data)
|
||||||
{
|
{
|
||||||
struct bnxt_qplib_nq *nq = (struct bnxt_qplib_nq *)data;
|
struct bnxt_qplib_nq *nq = (struct bnxt_qplib_nq *)data;
|
||||||
bool gen_p5 = bnxt_qplib_is_chip_gen_p5(nq->res->cctx);
|
|
||||||
struct bnxt_qplib_hwq *hwq = &nq->hwq;
|
struct bnxt_qplib_hwq *hwq = &nq->hwq;
|
||||||
struct nq_base *nqe, **nq_ptr;
|
struct nq_base *nqe, **nq_ptr;
|
||||||
struct bnxt_qplib_cq *cq;
|
struct bnxt_qplib_cq *cq;
|
||||||
|
@ -272,7 +269,8 @@ static void bnxt_qplib_service_nq(unsigned long data)
|
||||||
q_handle |= (u64)le32_to_cpu(nqcne->cq_handle_high)
|
q_handle |= (u64)le32_to_cpu(nqcne->cq_handle_high)
|
||||||
<< 32;
|
<< 32;
|
||||||
cq = (struct bnxt_qplib_cq *)(unsigned long)q_handle;
|
cq = (struct bnxt_qplib_cq *)(unsigned long)q_handle;
|
||||||
bnxt_qplib_arm_cq_enable(cq);
|
bnxt_qplib_armen_db(&cq->dbinfo,
|
||||||
|
DBC_DBC_TYPE_CQ_ARMENA);
|
||||||
spin_lock_bh(&cq->compl_lock);
|
spin_lock_bh(&cq->compl_lock);
|
||||||
atomic_set(&cq->arm_state, 0);
|
atomic_set(&cq->arm_state, 0);
|
||||||
if (!nq->cqn_handler(nq, (cq)))
|
if (!nq->cqn_handler(nq, (cq)))
|
||||||
|
@ -285,14 +283,16 @@ static void bnxt_qplib_service_nq(unsigned long data)
|
||||||
}
|
}
|
||||||
case NQ_BASE_TYPE_SRQ_EVENT:
|
case NQ_BASE_TYPE_SRQ_EVENT:
|
||||||
{
|
{
|
||||||
|
struct bnxt_qplib_srq *srq;
|
||||||
struct nq_srq_event *nqsrqe =
|
struct nq_srq_event *nqsrqe =
|
||||||
(struct nq_srq_event *)nqe;
|
(struct nq_srq_event *)nqe;
|
||||||
|
|
||||||
q_handle = le32_to_cpu(nqsrqe->srq_handle_low);
|
q_handle = le32_to_cpu(nqsrqe->srq_handle_low);
|
||||||
q_handle |= (u64)le32_to_cpu(nqsrqe->srq_handle_high)
|
q_handle |= (u64)le32_to_cpu(nqsrqe->srq_handle_high)
|
||||||
<< 32;
|
<< 32;
|
||||||
bnxt_qplib_arm_srq((struct bnxt_qplib_srq *)q_handle,
|
srq = (struct bnxt_qplib_srq *)q_handle;
|
||||||
DBC_DBC_TYPE_SRQ_ARMENA);
|
bnxt_qplib_armen_db(&srq->dbinfo,
|
||||||
|
DBC_DBC_TYPE_SRQ_ARMENA);
|
||||||
if (!nq->srqn_handler(nq,
|
if (!nq->srqn_handler(nq,
|
||||||
(struct bnxt_qplib_srq *)q_handle,
|
(struct bnxt_qplib_srq *)q_handle,
|
||||||
nqsrqe->event))
|
nqsrqe->event))
|
||||||
|
@ -314,9 +314,7 @@ static void bnxt_qplib_service_nq(unsigned long data)
|
||||||
}
|
}
|
||||||
if (hwq->cons != raw_cons) {
|
if (hwq->cons != raw_cons) {
|
||||||
hwq->cons = raw_cons;
|
hwq->cons = raw_cons;
|
||||||
bnxt_qplib_ring_nq_db_rearm(nq->nq_db.db, hwq->cons,
|
bnxt_qplib_ring_nq_db(&nq->nq_db.dbinfo, nq->res->cctx, true);
|
||||||
hwq->max_elements, nq->ring_id,
|
|
||||||
gen_p5);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -340,11 +338,9 @@ static irqreturn_t bnxt_qplib_nq_irq(int irq, void *dev_instance)
|
||||||
|
|
||||||
void bnxt_qplib_nq_stop_irq(struct bnxt_qplib_nq *nq, bool kill)
|
void bnxt_qplib_nq_stop_irq(struct bnxt_qplib_nq *nq, bool kill)
|
||||||
{
|
{
|
||||||
bool gen_p5 = bnxt_qplib_is_chip_gen_p5(nq->res->cctx);
|
|
||||||
tasklet_disable(&nq->nq_tasklet);
|
tasklet_disable(&nq->nq_tasklet);
|
||||||
/* Mask h/w interrupt */
|
/* Mask h/w interrupt */
|
||||||
bnxt_qplib_ring_nq_db(nq->nq_db.db, nq->hwq.cons,
|
bnxt_qplib_ring_nq_db(&nq->nq_db.dbinfo, nq->res->cctx, false);
|
||||||
nq->hwq.max_elements, nq->ring_id, gen_p5);
|
|
||||||
/* Sync with last running IRQ handler */
|
/* Sync with last running IRQ handler */
|
||||||
synchronize_irq(nq->msix_vec);
|
synchronize_irq(nq->msix_vec);
|
||||||
if (kill)
|
if (kill)
|
||||||
|
@ -369,7 +365,6 @@ void bnxt_qplib_disable_nq(struct bnxt_qplib_nq *nq)
|
||||||
if (nq->nq_db.reg.bar_reg) {
|
if (nq->nq_db.reg.bar_reg) {
|
||||||
iounmap(nq->nq_db.reg.bar_reg);
|
iounmap(nq->nq_db.reg.bar_reg);
|
||||||
nq->nq_db.reg.bar_reg = NULL;
|
nq->nq_db.reg.bar_reg = NULL;
|
||||||
nq->nq_db.db = NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
nq->cqn_handler = NULL;
|
nq->cqn_handler = NULL;
|
||||||
|
@ -380,7 +375,6 @@ void bnxt_qplib_disable_nq(struct bnxt_qplib_nq *nq)
|
||||||
int bnxt_qplib_nq_start_irq(struct bnxt_qplib_nq *nq, int nq_indx,
|
int bnxt_qplib_nq_start_irq(struct bnxt_qplib_nq *nq, int nq_indx,
|
||||||
int msix_vector, bool need_init)
|
int msix_vector, bool need_init)
|
||||||
{
|
{
|
||||||
bool gen_p5 = bnxt_qplib_is_chip_gen_p5(nq->res->cctx);
|
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
if (nq->requested)
|
if (nq->requested)
|
||||||
|
@ -407,8 +401,7 @@ int bnxt_qplib_nq_start_irq(struct bnxt_qplib_nq *nq, int nq_indx,
|
||||||
nq->msix_vec, nq_indx);
|
nq->msix_vec, nq_indx);
|
||||||
}
|
}
|
||||||
nq->requested = true;
|
nq->requested = true;
|
||||||
bnxt_qplib_ring_nq_db_rearm(nq->nq_db.db, nq->hwq.cons,
|
bnxt_qplib_ring_nq_db(&nq->nq_db.dbinfo, nq->res->cctx, true);
|
||||||
nq->hwq.max_elements, nq->ring_id, gen_p5);
|
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
@ -443,7 +436,9 @@ static int bnxt_qplib_map_nq_db(struct bnxt_qplib_nq *nq, u32 reg_offt)
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
nq_db->db = nq_db->reg.bar_reg;
|
nq_db->dbinfo.db = nq_db->reg.bar_reg;
|
||||||
|
nq_db->dbinfo.hwq = &nq->hwq;
|
||||||
|
nq_db->dbinfo.xid = nq->ring_id;
|
||||||
fail:
|
fail:
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
@ -516,24 +511,6 @@ int bnxt_qplib_alloc_nq(struct bnxt_qplib_res *res, struct bnxt_qplib_nq *nq)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* SRQ */
|
/* SRQ */
|
||||||
static void bnxt_qplib_arm_srq(struct bnxt_qplib_srq *srq, u32 arm_type)
|
|
||||||
{
|
|
||||||
struct bnxt_qplib_hwq *srq_hwq = &srq->hwq;
|
|
||||||
void __iomem *db;
|
|
||||||
u32 sw_prod;
|
|
||||||
u64 val = 0;
|
|
||||||
|
|
||||||
/* Ring DB */
|
|
||||||
sw_prod = (arm_type == DBC_DBC_TYPE_SRQ_ARM) ?
|
|
||||||
srq->threshold : HWQ_CMP(srq_hwq->prod, srq_hwq);
|
|
||||||
db = (arm_type == DBC_DBC_TYPE_SRQ_ARMENA) ? srq->dbr_base :
|
|
||||||
srq->dpi->dbr;
|
|
||||||
val = ((srq->id << DBC_DBC_XID_SFT) & DBC_DBC_XID_MASK) | arm_type;
|
|
||||||
val <<= 32;
|
|
||||||
val |= (sw_prod << DBC_DBC_INDEX_SFT) & DBC_DBC_INDEX_MASK;
|
|
||||||
writeq(val, db);
|
|
||||||
}
|
|
||||||
|
|
||||||
void bnxt_qplib_destroy_srq(struct bnxt_qplib_res *res,
|
void bnxt_qplib_destroy_srq(struct bnxt_qplib_res *res,
|
||||||
struct bnxt_qplib_srq *srq)
|
struct bnxt_qplib_srq *srq)
|
||||||
{
|
{
|
||||||
|
@ -624,9 +601,12 @@ int bnxt_qplib_create_srq(struct bnxt_qplib_res *res,
|
||||||
srq->swq[srq->last_idx].next_idx = -1;
|
srq->swq[srq->last_idx].next_idx = -1;
|
||||||
|
|
||||||
srq->id = le32_to_cpu(resp.xid);
|
srq->id = le32_to_cpu(resp.xid);
|
||||||
srq->dbr_base = res->dpi_tbl.dbr_bar_reg_iomem;
|
srq->dbinfo.hwq = &srq->hwq;
|
||||||
|
srq->dbinfo.xid = srq->id;
|
||||||
|
srq->dbinfo.db = srq->dpi->dbr;
|
||||||
|
srq->dbinfo.priv_db = res->dpi_tbl.dbr_bar_reg_iomem;
|
||||||
if (srq->threshold)
|
if (srq->threshold)
|
||||||
bnxt_qplib_arm_srq(srq, DBC_DBC_TYPE_SRQ_ARMENA);
|
bnxt_qplib_armen_db(&srq->dbinfo, DBC_DBC_TYPE_SRQ_ARMENA);
|
||||||
srq->arm_req = false;
|
srq->arm_req = false;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -650,7 +630,7 @@ int bnxt_qplib_modify_srq(struct bnxt_qplib_res *res,
|
||||||
srq_hwq->max_elements - sw_cons + sw_prod;
|
srq_hwq->max_elements - sw_cons + sw_prod;
|
||||||
if (count > srq->threshold) {
|
if (count > srq->threshold) {
|
||||||
srq->arm_req = false;
|
srq->arm_req = false;
|
||||||
bnxt_qplib_arm_srq(srq, DBC_DBC_TYPE_SRQ_ARM);
|
bnxt_qplib_srq_arm_db(&srq->dbinfo, srq->threshold);
|
||||||
} else {
|
} else {
|
||||||
/* Deferred arming */
|
/* Deferred arming */
|
||||||
srq->arm_req = true;
|
srq->arm_req = true;
|
||||||
|
@ -738,10 +718,10 @@ int bnxt_qplib_post_srq_recv(struct bnxt_qplib_srq *srq,
|
||||||
srq_hwq->max_elements - sw_cons + sw_prod;
|
srq_hwq->max_elements - sw_cons + sw_prod;
|
||||||
spin_unlock(&srq_hwq->lock);
|
spin_unlock(&srq_hwq->lock);
|
||||||
/* Ring DB */
|
/* Ring DB */
|
||||||
bnxt_qplib_arm_srq(srq, DBC_DBC_TYPE_SRQ);
|
bnxt_qplib_ring_prod_db(&srq->dbinfo, DBC_DBC_TYPE_SRQ);
|
||||||
if (srq->arm_req == true && count > srq->threshold) {
|
if (srq->arm_req == true && count > srq->threshold) {
|
||||||
srq->arm_req = false;
|
srq->arm_req = false;
|
||||||
bnxt_qplib_arm_srq(srq, DBC_DBC_TYPE_SRQ_ARM);
|
bnxt_qplib_srq_arm_db(&srq->dbinfo, srq->threshold);
|
||||||
}
|
}
|
||||||
done:
|
done:
|
||||||
return rc;
|
return rc;
|
||||||
|
@ -872,6 +852,15 @@ int bnxt_qplib_create_qp1(struct bnxt_qplib_res *res, struct bnxt_qplib_qp *qp)
|
||||||
|
|
||||||
qp->id = le32_to_cpu(resp.xid);
|
qp->id = le32_to_cpu(resp.xid);
|
||||||
qp->cur_qp_state = CMDQ_MODIFY_QP_NEW_STATE_RESET;
|
qp->cur_qp_state = CMDQ_MODIFY_QP_NEW_STATE_RESET;
|
||||||
|
qp->cctx = res->cctx;
|
||||||
|
sq->dbinfo.hwq = &sq->hwq;
|
||||||
|
sq->dbinfo.xid = qp->id;
|
||||||
|
sq->dbinfo.db = qp->dpi->dbr;
|
||||||
|
if (rq->max_wqe) {
|
||||||
|
rq->dbinfo.hwq = &rq->hwq;
|
||||||
|
rq->dbinfo.xid = qp->id;
|
||||||
|
rq->dbinfo.db = qp->dpi->dbr;
|
||||||
|
}
|
||||||
rcfw->qp_tbl[qp->id].qp_id = qp->id;
|
rcfw->qp_tbl[qp->id].qp_id = qp->id;
|
||||||
rcfw->qp_tbl[qp->id].qp_handle = (void *)qp;
|
rcfw->qp_tbl[qp->id].qp_handle = (void *)qp;
|
||||||
|
|
||||||
|
@ -1109,9 +1098,17 @@ int bnxt_qplib_create_qp(struct bnxt_qplib_res *res, struct bnxt_qplib_qp *qp)
|
||||||
|
|
||||||
qp->id = le32_to_cpu(resp.xid);
|
qp->id = le32_to_cpu(resp.xid);
|
||||||
qp->cur_qp_state = CMDQ_MODIFY_QP_NEW_STATE_RESET;
|
qp->cur_qp_state = CMDQ_MODIFY_QP_NEW_STATE_RESET;
|
||||||
qp->cctx = res->cctx;
|
|
||||||
INIT_LIST_HEAD(&qp->sq_flush);
|
INIT_LIST_HEAD(&qp->sq_flush);
|
||||||
INIT_LIST_HEAD(&qp->rq_flush);
|
INIT_LIST_HEAD(&qp->rq_flush);
|
||||||
|
qp->cctx = res->cctx;
|
||||||
|
sq->dbinfo.hwq = &sq->hwq;
|
||||||
|
sq->dbinfo.xid = qp->id;
|
||||||
|
sq->dbinfo.db = qp->dpi->dbr;
|
||||||
|
if (rq->max_wqe) {
|
||||||
|
rq->dbinfo.hwq = &rq->hwq;
|
||||||
|
rq->dbinfo.xid = qp->id;
|
||||||
|
rq->dbinfo.db = qp->dpi->dbr;
|
||||||
|
}
|
||||||
rcfw->qp_tbl[qp->id].qp_id = qp->id;
|
rcfw->qp_tbl[qp->id].qp_id = qp->id;
|
||||||
rcfw->qp_tbl[qp->id].qp_handle = (void *)qp;
|
rcfw->qp_tbl[qp->id].qp_handle = (void *)qp;
|
||||||
|
|
||||||
|
@ -1551,16 +1548,8 @@ void *bnxt_qplib_get_qp1_rq_buf(struct bnxt_qplib_qp *qp,
|
||||||
void bnxt_qplib_post_send_db(struct bnxt_qplib_qp *qp)
|
void bnxt_qplib_post_send_db(struct bnxt_qplib_qp *qp)
|
||||||
{
|
{
|
||||||
struct bnxt_qplib_q *sq = &qp->sq;
|
struct bnxt_qplib_q *sq = &qp->sq;
|
||||||
u32 sw_prod;
|
|
||||||
u64 val = 0;
|
|
||||||
|
|
||||||
val = (((qp->id << DBC_DBC_XID_SFT) & DBC_DBC_XID_MASK) |
|
bnxt_qplib_ring_prod_db(&sq->dbinfo, DBC_DBC_TYPE_SQ);
|
||||||
DBC_DBC_TYPE_SQ);
|
|
||||||
val <<= 32;
|
|
||||||
sw_prod = HWQ_CMP(sq->hwq.prod, &sq->hwq);
|
|
||||||
val |= (sw_prod << DBC_DBC_INDEX_SFT) & DBC_DBC_INDEX_MASK;
|
|
||||||
/* Flush all the WQE writes to HW */
|
|
||||||
writeq(val, qp->dpi->dbr);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int bnxt_qplib_post_send(struct bnxt_qplib_qp *qp,
|
int bnxt_qplib_post_send(struct bnxt_qplib_qp *qp,
|
||||||
|
@ -1852,16 +1841,8 @@ done:
|
||||||
void bnxt_qplib_post_recv_db(struct bnxt_qplib_qp *qp)
|
void bnxt_qplib_post_recv_db(struct bnxt_qplib_qp *qp)
|
||||||
{
|
{
|
||||||
struct bnxt_qplib_q *rq = &qp->rq;
|
struct bnxt_qplib_q *rq = &qp->rq;
|
||||||
u32 sw_prod;
|
|
||||||
u64 val = 0;
|
|
||||||
|
|
||||||
val = (((qp->id << DBC_DBC_XID_SFT) & DBC_DBC_XID_MASK) |
|
bnxt_qplib_ring_prod_db(&rq->dbinfo, DBC_DBC_TYPE_RQ);
|
||||||
DBC_DBC_TYPE_RQ);
|
|
||||||
val <<= 32;
|
|
||||||
sw_prod = HWQ_CMP(rq->hwq.prod, &rq->hwq);
|
|
||||||
val |= (sw_prod << DBC_DBC_INDEX_SFT) & DBC_DBC_INDEX_MASK;
|
|
||||||
/* Flush the writes to HW Rx WQE before the ringing Rx DB */
|
|
||||||
writeq(val, qp->dpi->dbr);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int bnxt_qplib_post_recv(struct bnxt_qplib_qp *qp,
|
int bnxt_qplib_post_recv(struct bnxt_qplib_qp *qp,
|
||||||
|
@ -1941,34 +1922,6 @@ done:
|
||||||
}
|
}
|
||||||
|
|
||||||
/* CQ */
|
/* CQ */
|
||||||
|
|
||||||
/* Spinlock must be held */
|
|
||||||
static void bnxt_qplib_arm_cq_enable(struct bnxt_qplib_cq *cq)
|
|
||||||
{
|
|
||||||
u64 val = 0;
|
|
||||||
|
|
||||||
val = ((cq->id << DBC_DBC_XID_SFT) & DBC_DBC_XID_MASK) |
|
|
||||||
DBC_DBC_TYPE_CQ_ARMENA;
|
|
||||||
val <<= 32;
|
|
||||||
/* Flush memory writes before enabling the CQ */
|
|
||||||
writeq(val, cq->dbr_base);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void bnxt_qplib_arm_cq(struct bnxt_qplib_cq *cq, u32 arm_type)
|
|
||||||
{
|
|
||||||
struct bnxt_qplib_hwq *cq_hwq = &cq->hwq;
|
|
||||||
u32 sw_cons;
|
|
||||||
u64 val = 0;
|
|
||||||
|
|
||||||
/* Ring DB */
|
|
||||||
val = ((cq->id << DBC_DBC_XID_SFT) & DBC_DBC_XID_MASK) | arm_type;
|
|
||||||
val <<= 32;
|
|
||||||
sw_cons = HWQ_CMP(cq_hwq->cons, cq_hwq);
|
|
||||||
val |= (sw_cons << DBC_DBC_INDEX_SFT) & DBC_DBC_INDEX_MASK;
|
|
||||||
/* flush memory writes before arming the CQ */
|
|
||||||
writeq(val, cq->dpi->dbr);
|
|
||||||
}
|
|
||||||
|
|
||||||
int bnxt_qplib_create_cq(struct bnxt_qplib_res *res, struct bnxt_qplib_cq *cq)
|
int bnxt_qplib_create_cq(struct bnxt_qplib_res *res, struct bnxt_qplib_cq *cq)
|
||||||
{
|
{
|
||||||
struct bnxt_qplib_rcfw *rcfw = res->rcfw;
|
struct bnxt_qplib_rcfw *rcfw = res->rcfw;
|
||||||
|
@ -2023,7 +1976,6 @@ int bnxt_qplib_create_cq(struct bnxt_qplib_res *res, struct bnxt_qplib_cq *cq)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
cq->id = le32_to_cpu(resp.xid);
|
cq->id = le32_to_cpu(resp.xid);
|
||||||
cq->dbr_base = res->dpi_tbl.dbr_bar_reg_iomem;
|
|
||||||
cq->period = BNXT_QPLIB_QUEUE_START_PERIOD;
|
cq->period = BNXT_QPLIB_QUEUE_START_PERIOD;
|
||||||
init_waitqueue_head(&cq->waitq);
|
init_waitqueue_head(&cq->waitq);
|
||||||
INIT_LIST_HEAD(&cq->sqf_head);
|
INIT_LIST_HEAD(&cq->sqf_head);
|
||||||
|
@ -2031,7 +1983,13 @@ int bnxt_qplib_create_cq(struct bnxt_qplib_res *res, struct bnxt_qplib_cq *cq)
|
||||||
spin_lock_init(&cq->compl_lock);
|
spin_lock_init(&cq->compl_lock);
|
||||||
spin_lock_init(&cq->flush_lock);
|
spin_lock_init(&cq->flush_lock);
|
||||||
|
|
||||||
bnxt_qplib_arm_cq_enable(cq);
|
cq->dbinfo.hwq = &cq->hwq;
|
||||||
|
cq->dbinfo.xid = cq->id;
|
||||||
|
cq->dbinfo.db = cq->dpi->dbr;
|
||||||
|
cq->dbinfo.priv_db = res->dpi_tbl.dbr_bar_reg_iomem;
|
||||||
|
|
||||||
|
bnxt_qplib_armen_db(&cq->dbinfo, DBC_DBC_TYPE_CQ_ARMENA);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
fail:
|
fail:
|
||||||
|
@ -2188,8 +2146,7 @@ static int do_wa9060(struct bnxt_qplib_qp *qp, struct bnxt_qplib_cq *cq,
|
||||||
sq->send_phantom = true;
|
sq->send_phantom = true;
|
||||||
|
|
||||||
/* TODO: Only ARM if the previous SQE is ARMALL */
|
/* TODO: Only ARM if the previous SQE is ARMALL */
|
||||||
bnxt_qplib_arm_cq(cq, DBC_DBC_TYPE_CQ_ARMALL);
|
bnxt_qplib_ring_db(&cq->dbinfo, DBC_DBC_TYPE_CQ_ARMALL);
|
||||||
|
|
||||||
rc = -EAGAIN;
|
rc = -EAGAIN;
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
@ -2859,7 +2816,7 @@ int bnxt_qplib_poll_cq(struct bnxt_qplib_cq *cq, struct bnxt_qplib_cqe *cqe,
|
||||||
}
|
}
|
||||||
if (cq->hwq.cons != raw_cons) {
|
if (cq->hwq.cons != raw_cons) {
|
||||||
cq->hwq.cons = raw_cons;
|
cq->hwq.cons = raw_cons;
|
||||||
bnxt_qplib_arm_cq(cq, DBC_DBC_TYPE_CQ);
|
bnxt_qplib_ring_db(&cq->dbinfo, DBC_DBC_TYPE_CQ);
|
||||||
}
|
}
|
||||||
exit:
|
exit:
|
||||||
return num_cqes - budget;
|
return num_cqes - budget;
|
||||||
|
@ -2868,7 +2825,7 @@ exit:
|
||||||
void bnxt_qplib_req_notify_cq(struct bnxt_qplib_cq *cq, u32 arm_type)
|
void bnxt_qplib_req_notify_cq(struct bnxt_qplib_cq *cq, u32 arm_type)
|
||||||
{
|
{
|
||||||
if (arm_type)
|
if (arm_type)
|
||||||
bnxt_qplib_arm_cq(cq, arm_type);
|
bnxt_qplib_ring_db(&cq->dbinfo, arm_type);
|
||||||
/* Using cq->arm_state variable to track whether to issue cq handler */
|
/* Using cq->arm_state variable to track whether to issue cq handler */
|
||||||
atomic_set(&cq->arm_state, 1);
|
atomic_set(&cq->arm_state, 1);
|
||||||
}
|
}
|
||||||
|
|
|
@ -42,7 +42,7 @@
|
||||||
struct bnxt_qplib_srq {
|
struct bnxt_qplib_srq {
|
||||||
struct bnxt_qplib_pd *pd;
|
struct bnxt_qplib_pd *pd;
|
||||||
struct bnxt_qplib_dpi *dpi;
|
struct bnxt_qplib_dpi *dpi;
|
||||||
void __iomem *dbr_base;
|
struct bnxt_qplib_db_info dbinfo;
|
||||||
u64 srq_handle;
|
u64 srq_handle;
|
||||||
u32 id;
|
u32 id;
|
||||||
u32 max_wqe;
|
u32 max_wqe;
|
||||||
|
@ -236,6 +236,7 @@ struct bnxt_qplib_swqe {
|
||||||
struct bnxt_qplib_q {
|
struct bnxt_qplib_q {
|
||||||
struct bnxt_qplib_hwq hwq;
|
struct bnxt_qplib_hwq hwq;
|
||||||
struct bnxt_qplib_swq *swq;
|
struct bnxt_qplib_swq *swq;
|
||||||
|
struct bnxt_qplib_db_info dbinfo;
|
||||||
struct bnxt_qplib_sg_info sg_info;
|
struct bnxt_qplib_sg_info sg_info;
|
||||||
u32 max_wqe;
|
u32 max_wqe;
|
||||||
u16 q_full_delta;
|
u16 q_full_delta;
|
||||||
|
@ -370,7 +371,7 @@ struct bnxt_qplib_cqe {
|
||||||
#define BNXT_QPLIB_QUEUE_START_PERIOD 0x01
|
#define BNXT_QPLIB_QUEUE_START_PERIOD 0x01
|
||||||
struct bnxt_qplib_cq {
|
struct bnxt_qplib_cq {
|
||||||
struct bnxt_qplib_dpi *dpi;
|
struct bnxt_qplib_dpi *dpi;
|
||||||
void __iomem *dbr_base;
|
struct bnxt_qplib_db_info dbinfo;
|
||||||
u32 max_wqe;
|
u32 max_wqe;
|
||||||
u32 id;
|
u32 id;
|
||||||
u16 count;
|
u16 count;
|
||||||
|
@ -433,46 +434,9 @@ struct bnxt_qplib_cq {
|
||||||
NQ_DB_IDX_VALID | \
|
NQ_DB_IDX_VALID | \
|
||||||
NQ_DB_IRQ_DIS)
|
NQ_DB_IRQ_DIS)
|
||||||
|
|
||||||
static inline void bnxt_qplib_ring_nq_db64(void __iomem *db, u32 index,
|
|
||||||
u32 xid, bool arm)
|
|
||||||
{
|
|
||||||
u64 val;
|
|
||||||
|
|
||||||
val = xid & DBC_DBC_XID_MASK;
|
|
||||||
val |= DBC_DBC_PATH_ROCE;
|
|
||||||
val |= arm ? DBC_DBC_TYPE_NQ_ARM : DBC_DBC_TYPE_NQ;
|
|
||||||
val <<= 32;
|
|
||||||
val |= index & DBC_DBC_INDEX_MASK;
|
|
||||||
writeq(val, db);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void bnxt_qplib_ring_nq_db_rearm(void __iomem *db, u32 raw_cons,
|
|
||||||
u32 max_elements, u32 xid,
|
|
||||||
bool gen_p5)
|
|
||||||
{
|
|
||||||
u32 index = raw_cons & (max_elements - 1);
|
|
||||||
|
|
||||||
if (gen_p5)
|
|
||||||
bnxt_qplib_ring_nq_db64(db, index, xid, true);
|
|
||||||
else
|
|
||||||
writel(NQ_DB_CP_FLAGS_REARM | (index & DBC_DBC32_XID_MASK), db);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void bnxt_qplib_ring_nq_db(void __iomem *db, u32 raw_cons,
|
|
||||||
u32 max_elements, u32 xid,
|
|
||||||
bool gen_p5)
|
|
||||||
{
|
|
||||||
u32 index = raw_cons & (max_elements - 1);
|
|
||||||
|
|
||||||
if (gen_p5)
|
|
||||||
bnxt_qplib_ring_nq_db64(db, index, xid, false);
|
|
||||||
else
|
|
||||||
writel(NQ_DB_CP_FLAGS | (index & DBC_DBC32_XID_MASK), db);
|
|
||||||
}
|
|
||||||
|
|
||||||
struct bnxt_qplib_nq_db {
|
struct bnxt_qplib_nq_db {
|
||||||
struct bnxt_qplib_reg_desc reg;
|
struct bnxt_qplib_reg_desc reg;
|
||||||
void __iomem *db;
|
struct bnxt_qplib_db_info dbinfo;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef int (*cqn_handler_t)(struct bnxt_qplib_nq *nq,
|
typedef int (*cqn_handler_t)(struct bnxt_qplib_nq *nq,
|
||||||
|
|
|
@ -379,7 +379,6 @@ static int bnxt_qplib_process_qp_event(struct bnxt_qplib_rcfw *rcfw,
|
||||||
static void bnxt_qplib_service_creq(unsigned long data)
|
static void bnxt_qplib_service_creq(unsigned long data)
|
||||||
{
|
{
|
||||||
struct bnxt_qplib_rcfw *rcfw = (struct bnxt_qplib_rcfw *)data;
|
struct bnxt_qplib_rcfw *rcfw = (struct bnxt_qplib_rcfw *)data;
|
||||||
bool gen_p5 = bnxt_qplib_is_chip_gen_p5(rcfw->res->cctx);
|
|
||||||
struct bnxt_qplib_creq_ctx *creq = &rcfw->creq;
|
struct bnxt_qplib_creq_ctx *creq = &rcfw->creq;
|
||||||
u32 type, budget = CREQ_ENTRY_POLL_BUDGET;
|
u32 type, budget = CREQ_ENTRY_POLL_BUDGET;
|
||||||
struct bnxt_qplib_hwq *hwq = &creq->hwq;
|
struct bnxt_qplib_hwq *hwq = &creq->hwq;
|
||||||
|
@ -429,9 +428,8 @@ static void bnxt_qplib_service_creq(unsigned long data)
|
||||||
|
|
||||||
if (hwq->cons != raw_cons) {
|
if (hwq->cons != raw_cons) {
|
||||||
hwq->cons = raw_cons;
|
hwq->cons = raw_cons;
|
||||||
bnxt_qplib_ring_creq_db_rearm(creq->creq_db.db,
|
bnxt_qplib_ring_nq_db(&creq->creq_db.dbinfo,
|
||||||
raw_cons, hwq->max_elements,
|
rcfw->res->cctx, true);
|
||||||
creq->ring_id, gen_p5);
|
|
||||||
}
|
}
|
||||||
spin_unlock_irqrestore(&hwq->lock, flags);
|
spin_unlock_irqrestore(&hwq->lock, flags);
|
||||||
}
|
}
|
||||||
|
@ -660,15 +658,12 @@ fail:
|
||||||
|
|
||||||
void bnxt_qplib_rcfw_stop_irq(struct bnxt_qplib_rcfw *rcfw, bool kill)
|
void bnxt_qplib_rcfw_stop_irq(struct bnxt_qplib_rcfw *rcfw, bool kill)
|
||||||
{
|
{
|
||||||
bool gen_p5 = bnxt_qplib_is_chip_gen_p5(rcfw->res->cctx);
|
|
||||||
struct bnxt_qplib_creq_ctx *creq;
|
struct bnxt_qplib_creq_ctx *creq;
|
||||||
|
|
||||||
creq = &rcfw->creq;
|
creq = &rcfw->creq;
|
||||||
tasklet_disable(&creq->creq_tasklet);
|
tasklet_disable(&creq->creq_tasklet);
|
||||||
/* Mask h/w interrupts */
|
/* Mask h/w interrupts */
|
||||||
bnxt_qplib_ring_creq_db(creq->creq_db.db, creq->hwq.cons,
|
bnxt_qplib_ring_nq_db(&creq->creq_db.dbinfo, rcfw->res->cctx, false);
|
||||||
creq->hwq.max_elements, creq->ring_id,
|
|
||||||
gen_p5);
|
|
||||||
/* Sync with last running IRQ-handler */
|
/* Sync with last running IRQ-handler */
|
||||||
synchronize_irq(creq->msix_vec);
|
synchronize_irq(creq->msix_vec);
|
||||||
if (kill)
|
if (kill)
|
||||||
|
@ -708,7 +703,6 @@ void bnxt_qplib_disable_rcfw_channel(struct bnxt_qplib_rcfw *rcfw)
|
||||||
int bnxt_qplib_rcfw_start_irq(struct bnxt_qplib_rcfw *rcfw, int msix_vector,
|
int bnxt_qplib_rcfw_start_irq(struct bnxt_qplib_rcfw *rcfw, int msix_vector,
|
||||||
bool need_init)
|
bool need_init)
|
||||||
{
|
{
|
||||||
bool gen_p5 = bnxt_qplib_is_chip_gen_p5(rcfw->res->cctx);
|
|
||||||
struct bnxt_qplib_creq_ctx *creq;
|
struct bnxt_qplib_creq_ctx *creq;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
|
@ -728,9 +722,8 @@ int bnxt_qplib_rcfw_start_irq(struct bnxt_qplib_rcfw *rcfw, int msix_vector,
|
||||||
if (rc)
|
if (rc)
|
||||||
return rc;
|
return rc;
|
||||||
creq->requested = true;
|
creq->requested = true;
|
||||||
bnxt_qplib_ring_creq_db_rearm(creq->creq_db.db,
|
|
||||||
creq->hwq.cons, creq->hwq.max_elements,
|
bnxt_qplib_ring_nq_db(&creq->creq_db.dbinfo, rcfw->res->cctx, true);
|
||||||
creq->ring_id, gen_p5);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -799,7 +792,9 @@ static int bnxt_qplib_map_creq_db(struct bnxt_qplib_rcfw *rcfw, u32 reg_offt)
|
||||||
creq_db->reg.bar_id);
|
creq_db->reg.bar_id);
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
creq_db->db = creq_db->reg.bar_reg;
|
creq_db->dbinfo.db = creq_db->reg.bar_reg;
|
||||||
|
creq_db->dbinfo.hwq = &rcfw->creq.hwq;
|
||||||
|
creq_db->dbinfo.xid = rcfw->creq.ring_id;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -247,7 +247,7 @@ struct bnxt_qplib_cmdq_ctx {
|
||||||
|
|
||||||
struct bnxt_qplib_creq_db {
|
struct bnxt_qplib_creq_db {
|
||||||
struct bnxt_qplib_reg_desc reg;
|
struct bnxt_qplib_reg_desc reg;
|
||||||
void __iomem *db;
|
struct bnxt_qplib_db_info dbinfo;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct bnxt_qplib_creq_stat {
|
struct bnxt_qplib_creq_stat {
|
||||||
|
|
|
@ -133,6 +133,13 @@ struct bnxt_qplib_hwq {
|
||||||
u8 is_user;
|
u8 is_user;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct bnxt_qplib_db_info {
|
||||||
|
void __iomem *db;
|
||||||
|
void __iomem *priv_db;
|
||||||
|
struct bnxt_qplib_hwq *hwq;
|
||||||
|
u32 xid;
|
||||||
|
};
|
||||||
|
|
||||||
/* Tables */
|
/* Tables */
|
||||||
struct bnxt_qplib_pd_tbl {
|
struct bnxt_qplib_pd_tbl {
|
||||||
unsigned long *tbl;
|
unsigned long *tbl;
|
||||||
|
@ -290,4 +297,75 @@ void bnxt_qplib_free_ctx(struct bnxt_qplib_res *res,
|
||||||
int bnxt_qplib_alloc_ctx(struct bnxt_qplib_res *res,
|
int bnxt_qplib_alloc_ctx(struct bnxt_qplib_res *res,
|
||||||
struct bnxt_qplib_ctx *ctx,
|
struct bnxt_qplib_ctx *ctx,
|
||||||
bool virt_fn, bool is_p5);
|
bool virt_fn, bool is_p5);
|
||||||
|
|
||||||
|
static inline void bnxt_qplib_ring_db32(struct bnxt_qplib_db_info *info,
|
||||||
|
bool arm)
|
||||||
|
{
|
||||||
|
u32 key;
|
||||||
|
|
||||||
|
key = info->hwq->cons & (info->hwq->max_elements - 1);
|
||||||
|
key |= (CMPL_DOORBELL_IDX_VALID |
|
||||||
|
(CMPL_DOORBELL_KEY_CMPL & CMPL_DOORBELL_KEY_MASK));
|
||||||
|
if (!arm)
|
||||||
|
key |= CMPL_DOORBELL_MASK;
|
||||||
|
writel(key, info->db);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void bnxt_qplib_ring_db(struct bnxt_qplib_db_info *info,
|
||||||
|
u32 type)
|
||||||
|
{
|
||||||
|
u64 key = 0;
|
||||||
|
|
||||||
|
key = (info->xid & DBC_DBC_XID_MASK) | DBC_DBC_PATH_ROCE | type;
|
||||||
|
key <<= 32;
|
||||||
|
key |= (info->hwq->cons & (info->hwq->max_elements - 1)) &
|
||||||
|
DBC_DBC_INDEX_MASK;
|
||||||
|
writeq(key, info->db);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void bnxt_qplib_ring_prod_db(struct bnxt_qplib_db_info *info,
|
||||||
|
u32 type)
|
||||||
|
{
|
||||||
|
u64 key = 0;
|
||||||
|
|
||||||
|
key = (info->xid & DBC_DBC_XID_MASK) | DBC_DBC_PATH_ROCE | type;
|
||||||
|
key <<= 32;
|
||||||
|
key |= (info->hwq->prod & (info->hwq->max_elements - 1)) &
|
||||||
|
DBC_DBC_INDEX_MASK;
|
||||||
|
writeq(key, info->db);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void bnxt_qplib_armen_db(struct bnxt_qplib_db_info *info,
|
||||||
|
u32 type)
|
||||||
|
{
|
||||||
|
u64 key = 0;
|
||||||
|
|
||||||
|
key = (info->xid & DBC_DBC_XID_MASK) | DBC_DBC_PATH_ROCE | type;
|
||||||
|
key <<= 32;
|
||||||
|
writeq(key, info->priv_db);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void bnxt_qplib_srq_arm_db(struct bnxt_qplib_db_info *info,
|
||||||
|
u32 th)
|
||||||
|
{
|
||||||
|
u64 key = 0;
|
||||||
|
|
||||||
|
key = (info->xid & DBC_DBC_XID_MASK) | DBC_DBC_PATH_ROCE | th;
|
||||||
|
key <<= 32;
|
||||||
|
key |= th & DBC_DBC_INDEX_MASK;
|
||||||
|
writeq(key, info->priv_db);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void bnxt_qplib_ring_nq_db(struct bnxt_qplib_db_info *info,
|
||||||
|
struct bnxt_qplib_chip_ctx *cctx,
|
||||||
|
bool arm)
|
||||||
|
{
|
||||||
|
u32 type;
|
||||||
|
|
||||||
|
type = arm ? DBC_DBC_TYPE_NQ_ARM : DBC_DBC_TYPE_NQ;
|
||||||
|
if (bnxt_qplib_is_chip_gen_p5(cctx))
|
||||||
|
bnxt_qplib_ring_db(info, type);
|
||||||
|
else
|
||||||
|
bnxt_qplib_ring_db32(info, arm);
|
||||||
|
}
|
||||||
#endif /* __BNXT_QPLIB_RES_H__ */
|
#endif /* __BNXT_QPLIB_RES_H__ */
|
||||||
|
|
Загрузка…
Ссылка в новой задаче