Commit 704d68f5 authored by Yixian Liu's avatar Yixian Liu Committed by Jason Gunthorpe

RDMA/hns: Reorganize doorbell update interfaces for all queues

The doorbell update interfaces are very similar for different queues, such
as SQ, RQ, SRQ, CQ and EQ. So reorganize these code and also fix some
inappropriate naming.

Link: https://lore.kernel.org/r/1616840738-7866-3-git-send-email-liweihang@huawei.comSigned-off-by: default avatarYixian Liu <liuyixian@huawei.com>
Signed-off-by: default avatarWeihang Li <liweihang@huawei.com>
Signed-off-by: default avatarJason Gunthorpe <jgg@nvidia.com>
parent cf8cd4cc
...@@ -250,7 +250,7 @@ static int alloc_cq_db(struct hns_roce_dev *hr_dev, struct hns_roce_cq *hr_cq, ...@@ -250,7 +250,7 @@ static int alloc_cq_db(struct hns_roce_dev *hr_dev, struct hns_roce_cq *hr_cq,
*hr_cq->set_ci_db = 0; *hr_cq->set_ci_db = 0;
hr_cq->flags |= HNS_ROCE_CQ_FLAG_RECORD_DB; hr_cq->flags |= HNS_ROCE_CQ_FLAG_RECORD_DB;
} }
hr_cq->cq_db_l = hr_dev->reg_base + hr_dev->odb_offset + hr_cq->db_reg = hr_dev->reg_base + hr_dev->odb_offset +
DB_REG_OFFSET * hr_dev->priv_uar.index; DB_REG_OFFSET * hr_dev->priv_uar.index;
} }
......
...@@ -366,7 +366,7 @@ struct hns_roce_wq { ...@@ -366,7 +366,7 @@ struct hns_roce_wq {
int wqe_shift; /* WQE size */ int wqe_shift; /* WQE size */
u32 head; u32 head;
u32 tail; u32 tail;
void __iomem *db_reg_l; void __iomem *db_reg;
}; };
struct hns_roce_sge { struct hns_roce_sge {
...@@ -440,7 +440,7 @@ struct hns_roce_cq { ...@@ -440,7 +440,7 @@ struct hns_roce_cq {
u32 cq_depth; u32 cq_depth;
u32 cons_index; u32 cons_index;
u32 *set_ci_db; u32 *set_ci_db;
void __iomem *cq_db_l; void __iomem *db_reg;
u16 *tptr_addr; u16 *tptr_addr;
int arm_sn; int arm_sn;
int cqe_size; int cqe_size;
...@@ -471,7 +471,7 @@ struct hns_roce_srq { ...@@ -471,7 +471,7 @@ struct hns_roce_srq {
int wqe_shift; int wqe_shift;
u32 cqn; u32 cqn;
u32 xrcdn; u32 xrcdn;
void __iomem *db_reg_l; void __iomem *db_reg;
atomic_t refcount; atomic_t refcount;
struct completion free; struct completion free;
...@@ -701,7 +701,7 @@ struct hns_roce_aeqe { ...@@ -701,7 +701,7 @@ struct hns_roce_aeqe {
struct hns_roce_eq { struct hns_roce_eq {
struct hns_roce_dev *hr_dev; struct hns_roce_dev *hr_dev;
void __iomem *doorbell; void __iomem *db_reg;
int type_flag; /* Aeq:1 ceq:0 */ int type_flag; /* Aeq:1 ceq:0 */
int eqn; int eqn;
......
...@@ -345,7 +345,7 @@ static int hns_roce_v1_post_send(struct ib_qp *ibqp, ...@@ -345,7 +345,7 @@ static int hns_roce_v1_post_send(struct ib_qp *ibqp,
doorbell[0] = sq_db.u32_4; doorbell[0] = sq_db.u32_4;
doorbell[1] = sq_db.u32_8; doorbell[1] = sq_db.u32_8;
hns_roce_write64_k(doorbell, qp->sq.db_reg_l); hns_roce_write64_k(doorbell, qp->sq.db_reg);
} }
spin_unlock_irqrestore(&qp->sq.lock, flags); spin_unlock_irqrestore(&qp->sq.lock, flags);
...@@ -440,7 +440,7 @@ static int hns_roce_v1_post_recv(struct ib_qp *ibqp, ...@@ -440,7 +440,7 @@ static int hns_roce_v1_post_recv(struct ib_qp *ibqp,
doorbell[0] = rq_db.u32_4; doorbell[0] = rq_db.u32_4;
doorbell[1] = rq_db.u32_8; doorbell[1] = rq_db.u32_8;
hns_roce_write64_k(doorbell, hr_qp->rq.db_reg_l); hns_roce_write64_k(doorbell, hr_qp->rq.db_reg);
} }
} }
spin_unlock_irqrestore(&hr_qp->rq.lock, flags); spin_unlock_irqrestore(&hr_qp->rq.lock, flags);
...@@ -1939,7 +1939,7 @@ static void hns_roce_v1_cq_set_ci(struct hns_roce_cq *hr_cq, u32 cons_index) ...@@ -1939,7 +1939,7 @@ static void hns_roce_v1_cq_set_ci(struct hns_roce_cq *hr_cq, u32 cons_index)
roce_set_field(doorbell[1], ROCEE_DB_OTHERS_H_ROCEE_DB_OTH_INP_H_M, roce_set_field(doorbell[1], ROCEE_DB_OTHERS_H_ROCEE_DB_OTH_INP_H_M,
ROCEE_DB_OTHERS_H_ROCEE_DB_OTH_INP_H_S, hr_cq->cqn); ROCEE_DB_OTHERS_H_ROCEE_DB_OTH_INP_H_S, hr_cq->cqn);
hns_roce_write64_k(doorbell, hr_cq->cq_db_l); hns_roce_write64_k(doorbell, hr_cq->db_reg);
} }
static void __hns_roce_v1_cq_clean(struct hns_roce_cq *hr_cq, u32 qpn, static void __hns_roce_v1_cq_clean(struct hns_roce_cq *hr_cq, u32 qpn,
...@@ -2092,7 +2092,7 @@ static int hns_roce_v1_req_notify_cq(struct ib_cq *ibcq, ...@@ -2092,7 +2092,7 @@ static int hns_roce_v1_req_notify_cq(struct ib_cq *ibcq,
ROCEE_DB_OTHERS_H_ROCEE_DB_OTH_INP_H_S, ROCEE_DB_OTHERS_H_ROCEE_DB_OTH_INP_H_S,
hr_cq->cqn | notification_flag); hr_cq->cqn | notification_flag);
hns_roce_write64_k(doorbell, hr_cq->cq_db_l); hns_roce_write64_k(doorbell, hr_cq->db_reg);
return 0; return 0;
} }
...@@ -3217,12 +3217,12 @@ static int hns_roce_v1_m_qp(struct ib_qp *ibqp, const struct ib_qp_attr *attr, ...@@ -3217,12 +3217,12 @@ static int hns_roce_v1_m_qp(struct ib_qp *ibqp, const struct ib_qp_attr *attr,
roce_set_bit(doorbell[1], RQ_DOORBELL_U32_8_HW_SYNC_S, 1); roce_set_bit(doorbell[1], RQ_DOORBELL_U32_8_HW_SYNC_S, 1);
if (ibqp->uobject) { if (ibqp->uobject) {
hr_qp->rq.db_reg_l = hr_dev->reg_base + hr_qp->rq.db_reg = hr_dev->reg_base +
hr_dev->odb_offset + hr_dev->odb_offset +
DB_REG_OFFSET * hr_dev->priv_uar.index; DB_REG_OFFSET * hr_dev->priv_uar.index;
} }
hns_roce_write64_k(doorbell, hr_qp->rq.db_reg_l); hns_roce_write64_k(doorbell, hr_qp->rq.db_reg);
} }
hr_qp->state = new_state; hr_qp->state = new_state;
...@@ -3604,7 +3604,7 @@ static int hns_roce_v1_destroy_cq(struct ib_cq *ibcq, struct ib_udata *udata) ...@@ -3604,7 +3604,7 @@ static int hns_roce_v1_destroy_cq(struct ib_cq *ibcq, struct ib_udata *udata)
static void set_eq_cons_index_v1(struct hns_roce_eq *eq, u32 req_not) static void set_eq_cons_index_v1(struct hns_roce_eq *eq, u32 req_not)
{ {
roce_raw_write((eq->cons_index & HNS_ROCE_V1_CONS_IDX_M) | roce_raw_write((eq->cons_index & HNS_ROCE_V1_CONS_IDX_M) |
(req_not << eq->log_entries), eq->doorbell); (req_not << eq->log_entries), eq->db_reg);
} }
static void hns_roce_v1_wq_catas_err_handle(struct hns_roce_dev *hr_dev, static void hns_roce_v1_wq_catas_err_handle(struct hns_roce_dev *hr_dev,
...@@ -4234,7 +4234,7 @@ static int hns_roce_v1_init_eq_table(struct hns_roce_dev *hr_dev) ...@@ -4234,7 +4234,7 @@ static int hns_roce_v1_init_eq_table(struct hns_roce_dev *hr_dev)
ROCEE_CAEP_CEQC_SHIFT_0_REG + ROCEE_CAEP_CEQC_SHIFT_0_REG +
CEQ_REG_OFFSET * i; CEQ_REG_OFFSET * i;
eq->type_flag = HNS_ROCE_CEQ; eq->type_flag = HNS_ROCE_CEQ;
eq->doorbell = hr_dev->reg_base + eq->db_reg = hr_dev->reg_base +
ROCEE_CAEP_CEQC_CONS_IDX_0_REG + ROCEE_CAEP_CEQC_CONS_IDX_0_REG +
CEQ_REG_OFFSET * i; CEQ_REG_OFFSET * i;
eq->entries = hr_dev->caps.ceqe_depth; eq->entries = hr_dev->caps.ceqe_depth;
...@@ -4245,7 +4245,7 @@ static int hns_roce_v1_init_eq_table(struct hns_roce_dev *hr_dev) ...@@ -4245,7 +4245,7 @@ static int hns_roce_v1_init_eq_table(struct hns_roce_dev *hr_dev)
eq_table->eqc_base[i] = hr_dev->reg_base + eq_table->eqc_base[i] = hr_dev->reg_base +
ROCEE_CAEP_AEQC_AEQE_SHIFT_REG; ROCEE_CAEP_AEQC_AEQE_SHIFT_REG;
eq->type_flag = HNS_ROCE_AEQ; eq->type_flag = HNS_ROCE_AEQ;
eq->doorbell = hr_dev->reg_base + eq->db_reg = hr_dev->reg_base +
ROCEE_CAEP_AEQE_CONS_IDX_REG; ROCEE_CAEP_AEQE_CONS_IDX_REG;
eq->entries = hr_dev->caps.aeqe_depth; eq->entries = hr_dev->caps.aeqe_depth;
eq->log_entries = ilog2(eq->entries); eq->log_entries = ilog2(eq->entries);
......
...@@ -644,18 +644,19 @@ static inline void update_sq_db(struct hns_roce_dev *hr_dev, ...@@ -644,18 +644,19 @@ static inline void update_sq_db(struct hns_roce_dev *hr_dev,
} else { } else {
struct hns_roce_v2_db sq_db = {}; struct hns_roce_v2_db sq_db = {};
roce_set_field(sq_db.byte_4, V2_DB_BYTE_4_TAG_M, roce_set_field(sq_db.byte_4, V2_DB_TAG_M, V2_DB_TAG_S,
V2_DB_BYTE_4_TAG_S, qp->doorbell_qpn); qp->doorbell_qpn);
roce_set_field(sq_db.byte_4, V2_DB_BYTE_4_CMD_M, roce_set_field(sq_db.byte_4, V2_DB_CMD_M, V2_DB_CMD_S,
V2_DB_BYTE_4_CMD_S, HNS_ROCE_V2_SQ_DB); HNS_ROCE_V2_SQ_DB);
/* indicates data on new BAR, 0 : SQ doorbell, 1 : DWQE */ /* indicates data on new BAR, 0 : SQ doorbell, 1 : DWQE */
roce_set_bit(sq_db.byte_4, V2_DB_FLAG_S, 0); roce_set_bit(sq_db.byte_4, V2_DB_FLAG_S, 0);
roce_set_field(sq_db.parameter, V2_DB_PARAMETER_IDX_M, roce_set_field(sq_db.parameter, V2_DB_PRODUCER_IDX_M,
V2_DB_PARAMETER_IDX_S, qp->sq.head); V2_DB_PRODUCER_IDX_S, qp->sq.head);
roce_set_field(sq_db.parameter, V2_DB_PARAMETER_SL_M, roce_set_field(sq_db.parameter, V2_DB_SL_M, V2_DB_SL_S,
V2_DB_PARAMETER_SL_S, qp->sl); qp->sl);
hns_roce_write64(hr_dev, (__le32 *)&sq_db, qp->sq.db_reg_l); hns_roce_write64(hr_dev, (__le32 *)&sq_db, qp->sq.db_reg);
} }
} }
...@@ -677,18 +678,19 @@ static inline void update_rq_db(struct hns_roce_dev *hr_dev, ...@@ -677,18 +678,19 @@ static inline void update_rq_db(struct hns_roce_dev *hr_dev,
} else { } else {
if (likely(qp->en_flags & HNS_ROCE_QP_CAP_RQ_RECORD_DB)) { if (likely(qp->en_flags & HNS_ROCE_QP_CAP_RQ_RECORD_DB)) {
*qp->rdb.db_record = *qp->rdb.db_record =
qp->rq.head & V2_DB_PARAMETER_IDX_M; qp->rq.head & V2_DB_PRODUCER_IDX_M;
} else { } else {
struct hns_roce_v2_db rq_db = {}; struct hns_roce_v2_db rq_db = {};
roce_set_field(rq_db.byte_4, V2_DB_BYTE_4_TAG_M, roce_set_field(rq_db.byte_4, V2_DB_TAG_M, V2_DB_TAG_S,
V2_DB_BYTE_4_TAG_S, qp->qpn); qp->qpn);
roce_set_field(rq_db.byte_4, V2_DB_BYTE_4_CMD_M, roce_set_field(rq_db.byte_4, V2_DB_CMD_M, V2_DB_CMD_S,
V2_DB_BYTE_4_CMD_S, HNS_ROCE_V2_RQ_DB); HNS_ROCE_V2_RQ_DB);
roce_set_field(rq_db.parameter, V2_DB_PARAMETER_IDX_M, roce_set_field(rq_db.parameter, V2_DB_PRODUCER_IDX_M,
V2_DB_PARAMETER_IDX_S, qp->rq.head); V2_DB_PRODUCER_IDX_S, qp->rq.head);
hns_roce_write64_k((__le32 *)&rq_db, qp->rq.db_reg_l); hns_roce_write64(hr_dev, (__le32 *)&rq_db,
qp->rq.db_reg);
} }
} }
} }
...@@ -721,7 +723,7 @@ static void write_dwqe(struct hns_roce_dev *hr_dev, struct hns_roce_qp *qp, ...@@ -721,7 +723,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, qp->sq.db_reg_l); hns_roce_write512(hr_dev, wqe, qp->sq.db_reg);
} }
static int hns_roce_v2_post_send(struct ib_qp *ibqp, static int hns_roce_v2_post_send(struct ib_qp *ibqp,
...@@ -1040,13 +1042,14 @@ static int hns_roce_v2_post_srq_recv(struct ib_srq *ibsrq, ...@@ -1040,13 +1042,14 @@ static int hns_roce_v2_post_srq_recv(struct ib_srq *ibsrq,
} }
if (likely(nreq)) { if (likely(nreq)) {
srq_db.byte_4 = roce_set_field(srq_db.byte_4, V2_DB_TAG_M, V2_DB_TAG_S,
cpu_to_le32(HNS_ROCE_V2_SRQ_DB << V2_DB_BYTE_4_CMD_S | srq->srqn);
(srq->srqn & V2_DB_BYTE_4_TAG_M)); roce_set_field(srq_db.byte_4, V2_DB_CMD_M, V2_DB_CMD_S,
srq_db.parameter = HNS_ROCE_V2_SRQ_DB);
cpu_to_le32(srq->idx_que.head & V2_DB_PARAMETER_IDX_M); roce_set_field(srq_db.parameter, V2_DB_PRODUCER_IDX_M,
V2_DB_PRODUCER_IDX_S, srq->idx_que.head);
hns_roce_write64(hr_dev, (__le32 *)&srq_db, srq->db_reg_l); hns_roce_write64(hr_dev, (__le32 *)&srq_db, srq->db_reg);
} }
spin_unlock_irqrestore(&srq->lock, flags); spin_unlock_irqrestore(&srq->lock, flags);
...@@ -3162,30 +3165,31 @@ static void *get_sw_cqe_v2(struct hns_roce_cq *hr_cq, unsigned int n) ...@@ -3162,30 +3165,31 @@ static void *get_sw_cqe_v2(struct hns_roce_cq *hr_cq, unsigned int n)
!!(n & hr_cq->cq_depth)) ? cqe : NULL; !!(n & hr_cq->cq_depth)) ? cqe : NULL;
} }
static inline void hns_roce_v2_cq_set_ci(struct hns_roce_cq *hr_cq, u32 ci) static inline void update_cq_db(struct hns_roce_dev *hr_dev,
struct hns_roce_cq *hr_cq)
{ {
if (likely(hr_cq->flags & HNS_ROCE_CQ_FLAG_RECORD_DB)) { if (likely(hr_cq->flags & HNS_ROCE_CQ_FLAG_RECORD_DB)) {
*hr_cq->set_ci_db = ci & V2_CQ_DB_PARAMETER_CONS_IDX_M; *hr_cq->set_ci_db = hr_cq->cons_index & V2_CQ_DB_CONS_IDX_M;
} else { } else {
struct hns_roce_v2_db cq_db = {}; struct hns_roce_v2_db cq_db = {};
roce_set_field(cq_db.byte_4, V2_CQ_DB_BYTE_4_TAG_M, roce_set_field(cq_db.byte_4, V2_DB_TAG_M, V2_DB_TAG_S,
V2_CQ_DB_BYTE_4_TAG_S, hr_cq->cqn); hr_cq->cqn);
roce_set_field(cq_db.byte_4, V2_CQ_DB_BYTE_4_CMD_M, roce_set_field(cq_db.byte_4, V2_DB_CMD_M, V2_DB_CMD_S,
V2_CQ_DB_BYTE_4_CMD_S, HNS_ROCE_V2_CQ_DB_PTR); HNS_ROCE_V2_CQ_DB);
roce_set_field(cq_db.parameter, V2_CQ_DB_PARAMETER_CONS_IDX_M, roce_set_field(cq_db.parameter, V2_CQ_DB_CONS_IDX_M,
V2_CQ_DB_PARAMETER_CONS_IDX_S, V2_CQ_DB_CONS_IDX_S, hr_cq->cons_index);
ci & ((hr_cq->cq_depth << 1) - 1)); roce_set_field(cq_db.parameter, V2_CQ_DB_CMD_SN_M,
roce_set_field(cq_db.parameter, V2_CQ_DB_PARAMETER_CMD_SN_M, V2_CQ_DB_CMD_SN_S, 1);
V2_CQ_DB_PARAMETER_CMD_SN_S, 1);
hns_roce_write64_k((__le32 *)&cq_db, hr_cq->cq_db_l); hns_roce_write64(hr_dev, (__le32 *)&cq_db, hr_cq->db_reg);
} }
} }
static void __hns_roce_v2_cq_clean(struct hns_roce_cq *hr_cq, u32 qpn, static void __hns_roce_v2_cq_clean(struct hns_roce_cq *hr_cq, u32 qpn,
struct hns_roce_srq *srq) struct hns_roce_srq *srq)
{ {
struct hns_roce_dev *hr_dev = to_hr_dev(hr_cq->ib_cq.device);
struct hns_roce_v2_cqe *cqe, *dest; struct hns_roce_v2_cqe *cqe, *dest;
u32 prod_index; u32 prod_index;
int nfreed = 0; int nfreed = 0;
...@@ -3228,7 +3232,7 @@ static void __hns_roce_v2_cq_clean(struct hns_roce_cq *hr_cq, u32 qpn, ...@@ -3228,7 +3232,7 @@ static void __hns_roce_v2_cq_clean(struct hns_roce_cq *hr_cq, u32 qpn,
if (nfreed) { if (nfreed) {
hr_cq->cons_index += nfreed; hr_cq->cons_index += nfreed;
hns_roce_v2_cq_set_ci(hr_cq, hr_cq->cons_index); update_cq_db(hr_dev, hr_cq);
} }
} }
...@@ -3323,30 +3327,26 @@ static int hns_roce_v2_req_notify_cq(struct ib_cq *ibcq, ...@@ -3323,30 +3327,26 @@ static int hns_roce_v2_req_notify_cq(struct ib_cq *ibcq,
{ {
struct hns_roce_dev *hr_dev = to_hr_dev(ibcq->device); struct hns_roce_dev *hr_dev = to_hr_dev(ibcq->device);
struct hns_roce_cq *hr_cq = to_hr_cq(ibcq); struct hns_roce_cq *hr_cq = to_hr_cq(ibcq);
u32 notification_flag; struct hns_roce_v2_db cq_db = {};
__le32 doorbell[2]; u32 notify_flag;
doorbell[0] = 0;
doorbell[1] = 0;
notification_flag = (flags & IB_CQ_SOLICITED_MASK) == IB_CQ_SOLICITED ?
V2_CQ_DB_REQ_NOT : V2_CQ_DB_REQ_NOT_SOL;
/* /*
* flags = 0; Notification Flag = 1, next * flags = 0, then notify_flag : next
* flags = 1; Notification Flag = 0, solocited * flags = 1, then notify flag : solocited
*/ */
roce_set_field(doorbell[0], V2_CQ_DB_BYTE_4_TAG_M, V2_DB_BYTE_4_TAG_S, notify_flag = (flags & IB_CQ_SOLICITED_MASK) == IB_CQ_SOLICITED ?
hr_cq->cqn); V2_CQ_DB_REQ_NOT : V2_CQ_DB_REQ_NOT_SOL;
roce_set_field(doorbell[0], V2_CQ_DB_BYTE_4_CMD_M, V2_DB_BYTE_4_CMD_S,
HNS_ROCE_V2_CQ_DB_NTR);
roce_set_field(doorbell[1], V2_CQ_DB_PARAMETER_CONS_IDX_M,
V2_CQ_DB_PARAMETER_CONS_IDX_S, hr_cq->cons_index);
roce_set_field(doorbell[1], V2_CQ_DB_PARAMETER_CMD_SN_M,
V2_CQ_DB_PARAMETER_CMD_SN_S, hr_cq->arm_sn & 0x3);
roce_set_bit(doorbell[1], V2_CQ_DB_PARAMETER_NOTIFY_S,
notification_flag);
hns_roce_write64(hr_dev, doorbell, hr_cq->cq_db_l); roce_set_field(cq_db.byte_4, V2_DB_TAG_M, V2_DB_TAG_S, hr_cq->cqn);
roce_set_field(cq_db.byte_4, V2_DB_CMD_M, V2_DB_CMD_S,
HNS_ROCE_V2_CQ_DB_NOTIFY);
roce_set_field(cq_db.parameter, V2_CQ_DB_CONS_IDX_M,
V2_CQ_DB_CONS_IDX_S, hr_cq->cons_index);
roce_set_field(cq_db.parameter, V2_CQ_DB_CMD_SN_M,
V2_CQ_DB_CMD_SN_S, hr_cq->arm_sn);
roce_set_bit(cq_db.parameter, V2_CQ_DB_NOTIFY_TYPE_S, notify_flag);
hns_roce_write64(hr_dev, (__le32 *)&cq_db, hr_cq->db_reg);
return 0; return 0;
} }
...@@ -3782,7 +3782,7 @@ static int hns_roce_v2_poll_cq(struct ib_cq *ibcq, int num_entries, ...@@ -3782,7 +3782,7 @@ static int hns_roce_v2_poll_cq(struct ib_cq *ibcq, int num_entries,
} }
if (npolled) if (npolled)
hns_roce_v2_cq_set_ci(hr_cq, hr_cq->cons_index); update_cq_db(hr_dev, hr_cq);
out: out:
spin_unlock_irqrestore(&hr_cq->lock, flags); spin_unlock_irqrestore(&hr_cq->lock, flags);
...@@ -5823,33 +5823,30 @@ static void hns_roce_v2_init_irq_work(struct hns_roce_dev *hr_dev, ...@@ -5823,33 +5823,30 @@ static void hns_roce_v2_init_irq_work(struct hns_roce_dev *hr_dev,
queue_work(hr_dev->irq_workq, &(irq_work->work)); queue_work(hr_dev->irq_workq, &(irq_work->work));
} }
static void set_eq_cons_index_v2(struct hns_roce_eq *eq) static void update_eq_db(struct hns_roce_eq *eq)
{ {
struct hns_roce_dev *hr_dev = eq->hr_dev; struct hns_roce_dev *hr_dev = eq->hr_dev;
__le32 doorbell[2] = {}; struct hns_roce_v2_db eq_db = {};
if (eq->type_flag == HNS_ROCE_AEQ) { if (eq->type_flag == HNS_ROCE_AEQ) {
roce_set_field(doorbell[0], HNS_ROCE_V2_EQ_DB_CMD_M, roce_set_field(eq_db.byte_4, V2_EQ_DB_CMD_M, V2_EQ_DB_CMD_S,
HNS_ROCE_V2_EQ_DB_CMD_S,
eq->arm_st == HNS_ROCE_V2_EQ_ALWAYS_ARMED ? eq->arm_st == HNS_ROCE_V2_EQ_ALWAYS_ARMED ?
HNS_ROCE_EQ_DB_CMD_AEQ : HNS_ROCE_EQ_DB_CMD_AEQ :
HNS_ROCE_EQ_DB_CMD_AEQ_ARMED); HNS_ROCE_EQ_DB_CMD_AEQ_ARMED);
} else { } else {
roce_set_field(doorbell[0], HNS_ROCE_V2_EQ_DB_TAG_M, roce_set_field(eq_db.byte_4, V2_EQ_DB_TAG_M, V2_EQ_DB_TAG_S,
HNS_ROCE_V2_EQ_DB_TAG_S, eq->eqn); eq->eqn);
roce_set_field(doorbell[0], HNS_ROCE_V2_EQ_DB_CMD_M, roce_set_field(eq_db.byte_4, V2_EQ_DB_CMD_M, V2_EQ_DB_CMD_S,
HNS_ROCE_V2_EQ_DB_CMD_S,
eq->arm_st == HNS_ROCE_V2_EQ_ALWAYS_ARMED ? eq->arm_st == HNS_ROCE_V2_EQ_ALWAYS_ARMED ?
HNS_ROCE_EQ_DB_CMD_CEQ : HNS_ROCE_EQ_DB_CMD_CEQ :
HNS_ROCE_EQ_DB_CMD_CEQ_ARMED); HNS_ROCE_EQ_DB_CMD_CEQ_ARMED);
} }
roce_set_field(doorbell[1], HNS_ROCE_V2_EQ_DB_PARA_M, roce_set_field(eq_db.parameter, V2_EQ_DB_CONS_IDX_M,
HNS_ROCE_V2_EQ_DB_PARA_S, V2_EQ_DB_CONS_IDX_S, eq->cons_index);
(eq->cons_index & HNS_ROCE_V2_CONS_IDX_M));
hns_roce_write64(hr_dev, doorbell, eq->doorbell); hns_roce_write64(hr_dev, (__le32 *)&eq_db, eq->db_reg);
} }
static struct hns_roce_aeqe *next_aeqe_sw_v2(struct hns_roce_eq *eq) static struct hns_roce_aeqe *next_aeqe_sw_v2(struct hns_roce_eq *eq)
...@@ -5936,7 +5933,7 @@ static int hns_roce_v2_aeq_int(struct hns_roce_dev *hr_dev, ...@@ -5936,7 +5933,7 @@ static int hns_roce_v2_aeq_int(struct hns_roce_dev *hr_dev,
aeqe = next_aeqe_sw_v2(eq); aeqe = next_aeqe_sw_v2(eq);
} }
set_eq_cons_index_v2(eq); update_eq_db(eq);
return aeqe_found; return aeqe_found;
} }
...@@ -5976,7 +5973,7 @@ static int hns_roce_v2_ceq_int(struct hns_roce_dev *hr_dev, ...@@ -5976,7 +5973,7 @@ static int hns_roce_v2_ceq_int(struct hns_roce_dev *hr_dev,
ceqe = next_ceqe_sw_v2(eq); ceqe = next_ceqe_sw_v2(eq);
} }
set_eq_cons_index_v2(eq); update_eq_db(eq);
return ceqe_found; return ceqe_found;
} }
...@@ -6118,7 +6115,7 @@ static int config_eqc(struct hns_roce_dev *hr_dev, struct hns_roce_eq *eq, ...@@ -6118,7 +6115,7 @@ static int config_eqc(struct hns_roce_dev *hr_dev, struct hns_roce_eq *eq,
memset(eqc, 0, sizeof(struct hns_roce_eq_context)); memset(eqc, 0, sizeof(struct hns_roce_eq_context));
/* init eqc */ /* init eqc */
eq->doorbell = hr_dev->reg_base + ROCEE_VF_EQ_DB_CFG0_REG; eq->db_reg = hr_dev->reg_base + ROCEE_VF_EQ_DB_CFG0_REG;
eq->cons_index = 0; eq->cons_index = 0;
eq->over_ignore = HNS_ROCE_V2_EQ_OVER_IGNORE_0; eq->over_ignore = HNS_ROCE_V2_EQ_OVER_IGNORE_0;
eq->coalesce = HNS_ROCE_V2_EQ_COALESCE_0; eq->coalesce = HNS_ROCE_V2_EQ_COALESCE_0;
......
...@@ -199,11 +199,11 @@ enum { ...@@ -199,11 +199,11 @@ enum {
}; };
enum { enum {
HNS_ROCE_V2_SQ_DB = 0x0, HNS_ROCE_V2_SQ_DB,
HNS_ROCE_V2_RQ_DB = 0x1, HNS_ROCE_V2_RQ_DB,
HNS_ROCE_V2_SRQ_DB = 0x2, HNS_ROCE_V2_SRQ_DB,
HNS_ROCE_V2_CQ_DB_PTR = 0x3, HNS_ROCE_V2_CQ_DB,
HNS_ROCE_V2_CQ_DB_NTR = 0x4, HNS_ROCE_V2_CQ_DB_NOTIFY
}; };
enum { enum {
...@@ -1140,33 +1140,27 @@ struct hns_roce_v2_mpt_entry { ...@@ -1140,33 +1140,27 @@ struct hns_roce_v2_mpt_entry {
#define V2_MPT_BYTE_64_PBL_BUF_PG_SZ_S 28 #define V2_MPT_BYTE_64_PBL_BUF_PG_SZ_S 28
#define V2_MPT_BYTE_64_PBL_BUF_PG_SZ_M GENMASK(31, 28) #define V2_MPT_BYTE_64_PBL_BUF_PG_SZ_M GENMASK(31, 28)
#define V2_DB_BYTE_4_TAG_S 0 #define V2_DB_TAG_S 0
#define V2_DB_BYTE_4_TAG_M GENMASK(23, 0) #define V2_DB_TAG_M GENMASK(23, 0)
#define V2_DB_BYTE_4_CMD_S 24 #define V2_DB_CMD_S 24
#define V2_DB_BYTE_4_CMD_M GENMASK(27, 24) #define V2_DB_CMD_M GENMASK(27, 24)
#define V2_DB_FLAG_S 31 #define V2_DB_FLAG_S 31
#define V2_DB_PARAMETER_IDX_S 0 #define V2_DB_PRODUCER_IDX_S 0
#define V2_DB_PARAMETER_IDX_M GENMASK(15, 0) #define V2_DB_PRODUCER_IDX_M GENMASK(15, 0)
#define V2_DB_PARAMETER_SL_S 16 #define V2_DB_SL_S 16
#define V2_DB_PARAMETER_SL_M GENMASK(18, 16) #define V2_DB_SL_M GENMASK(18, 16)
#define V2_CQ_DB_BYTE_4_TAG_S 0 #define V2_CQ_DB_CONS_IDX_S 0
#define V2_CQ_DB_BYTE_4_TAG_M GENMASK(23, 0) #define V2_CQ_DB_CONS_IDX_M GENMASK(23, 0)
#define V2_CQ_DB_BYTE_4_CMD_S 24 #define V2_CQ_DB_NOTIFY_TYPE_S 24
#define V2_CQ_DB_BYTE_4_CMD_M GENMASK(27, 24)
#define V2_CQ_DB_PARAMETER_CONS_IDX_S 0 #define V2_CQ_DB_CMD_SN_S 25
#define V2_CQ_DB_PARAMETER_CONS_IDX_M GENMASK(23, 0) #define V2_CQ_DB_CMD_SN_M GENMASK(26, 25)
#define V2_CQ_DB_PARAMETER_CMD_SN_S 25
#define V2_CQ_DB_PARAMETER_CMD_SN_M GENMASK(26, 25)
#define V2_CQ_DB_PARAMETER_NOTIFY_S 24
struct hns_roce_v2_ud_send_wqe { struct hns_roce_v2_ud_send_wqe {
__le32 byte_4; __le32 byte_4;
...@@ -1978,8 +1972,6 @@ struct hns_roce_dip { ...@@ -1978,8 +1972,6 @@ struct hns_roce_dip {
#define HNS_ROCE_INT_NAME_LEN 32 #define HNS_ROCE_INT_NAME_LEN 32
#define HNS_ROCE_V2_EQN_M GENMASK(23, 0) #define HNS_ROCE_V2_EQN_M GENMASK(23, 0)
#define HNS_ROCE_V2_CONS_IDX_M GENMASK(23, 0)
#define HNS_ROCE_V2_VF_ABN_INT_EN_S 0 #define HNS_ROCE_V2_VF_ABN_INT_EN_S 0
#define HNS_ROCE_V2_VF_ABN_INT_EN_M GENMASK(0, 0) #define HNS_ROCE_V2_VF_ABN_INT_EN_M GENMASK(0, 0)
#define HNS_ROCE_V2_VF_ABN_INT_ST_M GENMASK(2, 0) #define HNS_ROCE_V2_VF_ABN_INT_ST_M GENMASK(2, 0)
...@@ -2078,14 +2070,14 @@ struct hns_roce_dip { ...@@ -2078,14 +2070,14 @@ struct hns_roce_dip {
#define HNS_ROCE_V2_AEQE_SUB_TYPE_S 8 #define HNS_ROCE_V2_AEQE_SUB_TYPE_S 8
#define HNS_ROCE_V2_AEQE_SUB_TYPE_M GENMASK(15, 8) #define HNS_ROCE_V2_AEQE_SUB_TYPE_M GENMASK(15, 8)
#define HNS_ROCE_V2_EQ_DB_CMD_S 16 #define V2_EQ_DB_TAG_S 0
#define HNS_ROCE_V2_EQ_DB_CMD_M GENMASK(17, 16) #define V2_EQ_DB_TAG_M GENMASK(7, 0)
#define HNS_ROCE_V2_EQ_DB_TAG_S 0 #define V2_EQ_DB_CMD_S 16
#define HNS_ROCE_V2_EQ_DB_TAG_M GENMASK(7, 0) #define V2_EQ_DB_CMD_M GENMASK(17, 16)
#define HNS_ROCE_V2_EQ_DB_PARA_S 0 #define V2_EQ_DB_CONS_IDX_S 0
#define HNS_ROCE_V2_EQ_DB_PARA_M GENMASK(23, 0) #define V2_EQ_DB_CONS_IDX_M GENMASK(23, 0)
#define HNS_ROCE_V2_AEQE_EVENT_QUEUE_NUM_S 0 #define HNS_ROCE_V2_AEQE_EVENT_QUEUE_NUM_S 0
#define HNS_ROCE_V2_AEQE_EVENT_QUEUE_NUM_M GENMASK(23, 0) #define HNS_ROCE_V2_AEQE_EVENT_QUEUE_NUM_M GENMASK(23, 0)
......
...@@ -850,14 +850,14 @@ static int alloc_qp_db(struct hns_roce_dev *hr_dev, struct hns_roce_qp *hr_qp, ...@@ -850,14 +850,14 @@ static int alloc_qp_db(struct hns_roce_dev *hr_dev, struct hns_roce_qp *hr_qp,
} }
} else { } else {
if (hr_dev->pci_dev->revision >= PCI_REVISION_ID_HIP09) if (hr_dev->pci_dev->revision >= PCI_REVISION_ID_HIP09)
hr_qp->sq.db_reg_l = hr_dev->mem_base + hr_qp->sq.db_reg = hr_dev->mem_base +
HNS_ROCE_DWQE_SIZE * hr_qp->qpn; HNS_ROCE_DWQE_SIZE * hr_qp->qpn;
else else
hr_qp->sq.db_reg_l = hr_qp->sq.db_reg =
hr_dev->reg_base + hr_dev->sdb_offset + hr_dev->reg_base + hr_dev->sdb_offset +
DB_REG_OFFSET * hr_dev->priv_uar.index; 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 = hr_dev->reg_base + hr_dev->odb_offset +
DB_REG_OFFSET * hr_dev->priv_uar.index; DB_REG_OFFSET * hr_dev->priv_uar.index;
if (kernel_qp_has_rdb(hr_dev, init_attr)) { if (kernel_qp_has_rdb(hr_dev, init_attr)) {
......
...@@ -415,7 +415,7 @@ int hns_roce_create_srq(struct ib_srq *ib_srq, ...@@ -415,7 +415,7 @@ int hns_roce_create_srq(struct ib_srq *ib_srq,
} }
} }
srq->db_reg_l = hr_dev->reg_base + SRQ_DB_REG; srq->db_reg = hr_dev->reg_base + SRQ_DB_REG;
srq->event = hns_roce_ib_srq_event; srq->event = hns_roce_ib_srq_event;
atomic_set(&srq->refcount, 1); atomic_set(&srq->refcount, 1);
init_completion(&srq->free); init_completion(&srq->free);
......
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