| /linux-4.4.14/drivers/infiniband/hw/cxgb3/ |
| D | iwch_qp.c | 248 static int build_rdma_recv(struct iwch_qp *qhp, union t3_wr *wqe, in build_rdma_recv() argument 255 err = iwch_sgl2pbl_map(qhp->rhp, wr->sg_list, wr->num_sge, pbl_addr, in build_rdma_recv() 281 qhp->wq.rq[Q_PTR2IDX(qhp->wq.rq_wptr, in build_rdma_recv() 282 qhp->wq.rq_size_log2)].wr_id = wr->wr_id; in build_rdma_recv() 283 qhp->wq.rq[Q_PTR2IDX(qhp->wq.rq_wptr, in build_rdma_recv() 284 qhp->wq.rq_size_log2)].pbl_addr = 0; in build_rdma_recv() 288 static int build_zero_stag_recv(struct iwch_qp *qhp, union t3_wr *wqe, in build_zero_stag_recv() argument 302 pbl_addr = cxio_hal_pblpool_alloc(&qhp->rhp->rdev, T3_STAG0_PBL_SIZE); in build_zero_stag_recv() 309 pbl_offset = (pbl_addr - qhp->rhp->rdev.rnic_info.pbl_base) >> 3; in build_zero_stag_recv() 344 qhp->wq.rq[Q_PTR2IDX(qhp->wq.rq_wptr, in build_zero_stag_recv() [all …]
|
| D | iwch_ev.c | 48 struct iwch_qp *qhp; in post_qp_event() local 52 qhp = get_qhp(rnicp, CQE_QPID(rsp_msg->cqe)); in post_qp_event() 54 if (!qhp) { in post_qp_event() 62 if ((qhp->attr.state == IWCH_QP_STATE_ERROR) || in post_qp_event() 63 (qhp->attr.state == IWCH_QP_STATE_TERMINATE)) { in post_qp_event() 66 qhp->attr.state, qhp->wq.qpid, CQE_STATUS(rsp_msg->cqe)); in post_qp_event() 77 atomic_inc(&qhp->refcnt); in post_qp_event() 80 if (qhp->attr.state == IWCH_QP_STATE_RTS) { in post_qp_event() 82 iwch_modify_qp(qhp->rhp, qhp, IWCH_QP_ATTR_NEXT_STATE, in post_qp_event() 85 iwch_post_terminate(qhp, rsp_msg); in post_qp_event() [all …]
|
| D | iwch_provider.c | 890 struct iwch_qp *qhp; in iwch_destroy_qp() local 894 qhp = to_iwch_qp(ib_qp); in iwch_destroy_qp() 895 rhp = qhp->rhp; in iwch_destroy_qp() 898 iwch_modify_qp(rhp, qhp, IWCH_QP_ATTR_NEXT_STATE, &attrs, 0); in iwch_destroy_qp() 899 wait_event(qhp->wait, !qhp->ep); in iwch_destroy_qp() 901 remove_handle(rhp, &rhp->qpidr, qhp->wq.qpid); in iwch_destroy_qp() 903 atomic_dec(&qhp->refcnt); in iwch_destroy_qp() 904 wait_event(qhp->wait, !atomic_read(&qhp->refcnt)); in iwch_destroy_qp() 908 cxio_destroy_qp(&rhp->rdev, &qhp->wq, in iwch_destroy_qp() 912 ib_qp, qhp->wq.qpid, qhp); in iwch_destroy_qp() [all …]
|
| D | iwch_cq.c | 47 struct iwch_qp *qhp = NULL; in iwch_poll_cq_one() local 60 qhp = get_qhp(rhp, CQE_QPID(*rd_cqe)); in iwch_poll_cq_one() 61 if (!qhp) in iwch_poll_cq_one() 64 spin_lock(&qhp->lock); in iwch_poll_cq_one() 65 wq = &(qhp->wq); in iwch_poll_cq_one() 82 wc->qp = &qhp->ibqp; in iwch_poll_cq_one() 191 spin_unlock(&qhp->lock); in iwch_poll_cq_one()
|
| D | iwch.c | 68 struct iwch_qp *qhp = p; in disable_qp_db() local 70 cxio_disable_wq_db(&qhp->wq); in disable_qp_db() 76 struct iwch_qp *qhp = p; in enable_qp_db() local 79 ring_doorbell(qhp->rhp->rdev.ctrl_qp.doorbell, qhp->wq.qpid); in enable_qp_db() 80 cxio_enable_wq_db(&qhp->wq); in enable_qp_db()
|
| D | iwch_provider.h | 174 static inline int qp_quiesced(struct iwch_qp *qhp) in qp_quiesced() argument 176 return qhp->flags & QP_QUIESCED; in qp_quiesced() 261 struct iwch_qp *qhp, 328 u16 iwch_rqes_posted(struct iwch_qp *qhp); 337 int iwch_post_terminate(struct iwch_qp *qhp, struct respQ_msg_t *rsp_msg); 341 void stop_read_rep_timer(struct iwch_qp *qhp);
|
| /linux-4.4.14/drivers/infiniband/hw/cxgb4/ |
| D | qp.c | 86 static void set_state(struct c4iw_qp *qhp, enum c4iw_qp_state state) in set_state() argument 89 spin_lock_irqsave(&qhp->lock, flag); in set_state() 90 qhp->attr.state = state; in set_state() 91 spin_unlock_irqrestore(&qhp->lock, flag); in set_state() 597 static int build_rdma_recv(struct c4iw_qp *qhp, union t4_recv_wr *wqe, in build_rdma_recv() argument 602 ret = build_isgl((__be64 *)qhp->wq.rq.queue, in build_rdma_recv() 603 (__be64 *)&qhp->wq.rq.queue[qhp->wq.rq.size], in build_rdma_recv() 705 static int ring_kernel_sq_db(struct c4iw_qp *qhp, u16 inc) in ring_kernel_sq_db() argument 709 spin_lock_irqsave(&qhp->rhp->lock, flags); in ring_kernel_sq_db() 710 spin_lock(&qhp->lock); in ring_kernel_sq_db() [all …]
|
| D | ev.c | 88 struct c4iw_qp *qhp, in post_qp_event() argument 98 if (qhp->attr.state == C4IW_QP_STATE_RTS) { in post_qp_event() 100 c4iw_modify_qp(qhp->rhp, qhp, C4IW_QP_ATTR_NEXT_STATE, in post_qp_event() 109 event.element.qp = &qhp->ibqp; in post_qp_event() 110 if (qhp->ibqp.event_handler) in post_qp_event() 111 (*qhp->ibqp.event_handler)(&event, qhp->ibqp.qp_context); in post_qp_event() 121 struct c4iw_qp *qhp; in c4iw_ev_dispatch() local 125 qhp = get_qhp(dev, CQE_QPID(err_cqe)); in c4iw_ev_dispatch() 126 if (!qhp) { in c4iw_ev_dispatch() 138 cqid = qhp->attr.scq; in c4iw_ev_dispatch() [all …]
|
| D | cq.c | 236 int c4iw_flush_sq(struct c4iw_qp *qhp) in c4iw_flush_sq() argument 239 struct t4_wq *wq = &qhp->wq; in c4iw_flush_sq() 240 struct c4iw_cq *chp = to_c4iw_cq(qhp->ibqp.send_cq); in c4iw_flush_sq() 342 struct c4iw_qp *qhp; in c4iw_flush_hw_cq() local 355 qhp = get_qhp(chp->rhp, CQE_QPID(hw_cqe)); in c4iw_flush_hw_cq() 360 if (qhp == NULL) in c4iw_flush_hw_cq() 383 if (!qhp->wq.sq.oldest_read->signaled) { in c4iw_flush_hw_cq() 384 advance_oldest_read(&qhp->wq); in c4iw_flush_hw_cq() 392 create_read_req_cqe(&qhp->wq, hw_cqe, &read_cqe); in c4iw_flush_hw_cq() 394 advance_oldest_read(&qhp->wq); in c4iw_flush_hw_cq() [all …]
|
| D | iw_cxgb4.h | 562 struct c4iw_qp *qhp, 1010 int c4iw_flush_sq(struct c4iw_qp *qhp); 1012 u16 c4iw_rqes_posted(struct c4iw_qp *qhp); 1013 int c4iw_post_terminate(struct c4iw_qp *qhp, struct t4_cqe *err_cqe);
|