[IB] mthca: report asynchronous CQ events
Implement reporting asynchronous CQ events in Mellanox HCA driver. Signed-off-by: Michael S. Tsirkin <mst@mellanox.co.il> Signed-off-by: Roland Dreier <rolandd@cisco.com>
This commit is contained in:
parent
89fbb69c4f
commit
affcd50546
@ -208,7 +208,7 @@ static inline void update_cons_index(struct mthca_dev *dev, struct mthca_cq *cq,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void mthca_cq_event(struct mthca_dev *dev, u32 cqn)
|
void mthca_cq_completion(struct mthca_dev *dev, u32 cqn)
|
||||||
{
|
{
|
||||||
struct mthca_cq *cq;
|
struct mthca_cq *cq;
|
||||||
|
|
||||||
@ -224,6 +224,35 @@ void mthca_cq_event(struct mthca_dev *dev, u32 cqn)
|
|||||||
cq->ibcq.comp_handler(&cq->ibcq, cq->ibcq.cq_context);
|
cq->ibcq.comp_handler(&cq->ibcq, cq->ibcq.cq_context);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void mthca_cq_event(struct mthca_dev *dev, u32 cqn,
|
||||||
|
enum ib_event_type event_type)
|
||||||
|
{
|
||||||
|
struct mthca_cq *cq;
|
||||||
|
struct ib_event event;
|
||||||
|
|
||||||
|
spin_lock(&dev->cq_table.lock);
|
||||||
|
|
||||||
|
cq = mthca_array_get(&dev->cq_table.cq, cqn & (dev->limits.num_cqs - 1));
|
||||||
|
|
||||||
|
if (cq)
|
||||||
|
atomic_inc(&cq->refcount);
|
||||||
|
spin_unlock(&dev->cq_table.lock);
|
||||||
|
|
||||||
|
if (!cq) {
|
||||||
|
mthca_warn(dev, "Async event for bogus CQ %08x\n", cqn);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
event.device = &dev->ib_dev;
|
||||||
|
event.event = event_type;
|
||||||
|
event.element.cq = &cq->ibcq;
|
||||||
|
if (cq->ibcq.event_handler)
|
||||||
|
cq->ibcq.event_handler(&event, cq->ibcq.cq_context);
|
||||||
|
|
||||||
|
if (atomic_dec_and_test(&cq->refcount))
|
||||||
|
wake_up(&cq->wait);
|
||||||
|
}
|
||||||
|
|
||||||
void mthca_cq_clean(struct mthca_dev *dev, u32 cqn, u32 qpn,
|
void mthca_cq_clean(struct mthca_dev *dev, u32 cqn, u32 qpn,
|
||||||
struct mthca_srq *srq)
|
struct mthca_srq *srq)
|
||||||
{
|
{
|
||||||
|
@ -460,7 +460,9 @@ int mthca_init_cq(struct mthca_dev *dev, int nent,
|
|||||||
struct mthca_cq *cq);
|
struct mthca_cq *cq);
|
||||||
void mthca_free_cq(struct mthca_dev *dev,
|
void mthca_free_cq(struct mthca_dev *dev,
|
||||||
struct mthca_cq *cq);
|
struct mthca_cq *cq);
|
||||||
void mthca_cq_event(struct mthca_dev *dev, u32 cqn);
|
void mthca_cq_completion(struct mthca_dev *dev, u32 cqn);
|
||||||
|
void mthca_cq_event(struct mthca_dev *dev, u32 cqn,
|
||||||
|
enum ib_event_type event_type);
|
||||||
void mthca_cq_clean(struct mthca_dev *dev, u32 cqn, u32 qpn,
|
void mthca_cq_clean(struct mthca_dev *dev, u32 cqn, u32 qpn,
|
||||||
struct mthca_srq *srq);
|
struct mthca_srq *srq);
|
||||||
|
|
||||||
|
@ -292,7 +292,7 @@ static int mthca_eq_int(struct mthca_dev *dev, struct mthca_eq *eq)
|
|||||||
case MTHCA_EVENT_TYPE_COMP:
|
case MTHCA_EVENT_TYPE_COMP:
|
||||||
disarm_cqn = be32_to_cpu(eqe->event.comp.cqn) & 0xffffff;
|
disarm_cqn = be32_to_cpu(eqe->event.comp.cqn) & 0xffffff;
|
||||||
disarm_cq(dev, eq->eqn, disarm_cqn);
|
disarm_cq(dev, eq->eqn, disarm_cqn);
|
||||||
mthca_cq_event(dev, disarm_cqn);
|
mthca_cq_completion(dev, disarm_cqn);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MTHCA_EVENT_TYPE_PATH_MIG:
|
case MTHCA_EVENT_TYPE_PATH_MIG:
|
||||||
@ -364,6 +364,8 @@ static int mthca_eq_int(struct mthca_dev *dev, struct mthca_eq *eq)
|
|||||||
eqe->event.cq_err.syndrome == 1 ?
|
eqe->event.cq_err.syndrome == 1 ?
|
||||||
"overrun" : "access violation",
|
"overrun" : "access violation",
|
||||||
be32_to_cpu(eqe->event.cq_err.cqn) & 0xffffff);
|
be32_to_cpu(eqe->event.cq_err.cqn) & 0xffffff);
|
||||||
|
mthca_cq_event(dev, be32_to_cpu(eqe->event.cq_err.cqn),
|
||||||
|
IB_EVENT_CQ_ERR);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MTHCA_EVENT_TYPE_EQ_OVERFLOW:
|
case MTHCA_EVENT_TYPE_EQ_OVERFLOW:
|
||||||
|
Loading…
Reference in New Issue
Block a user