aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/infiniband
diff options
context:
space:
mode:
authorSteve Wise <swise@opengridcomputing.com>2013-08-06 11:34:34 -0400
committerRoland Dreier <roland@purestorage.com>2013-08-13 14:55:44 -0400
commit97d7ec0c410e89ece852e768b8bfd42d4d5822fd (patch)
treeb52aa6e67492bd54415563787c71c06ce7bf6981 /drivers/infiniband
parent68074bb1abf6fd30cec3e29fd3ff974bdebdc4ef (diff)
RDMA/cxgb4: Handle newer firmware changes
Move QP to TERMINATE instead to allow the peer to get the TERM message. This bug wasn't detectable until newer FW that moves connections out of RDMA mode as soon as an error is detected. QP can exit RTS before the last AE arrives. This was introduced by changes in the FW to kick connections out of RDMA mode as soon as an error is detected. A side effect of this is that the driver can move the QP out of RTS before the AE causing the connection to get kicked out of RDMA mode is processed. Fix for this is to always post async errors even if the QP is out of RTS. Signed-off-by: Steve Wise <swise@opengridcomputing.com> Signed-off-by: Vipul Pandya <vipul@chelsio.com> Signed-off-by: Roland Dreier <roland@purestorage.com>
Diffstat (limited to 'drivers/infiniband')
-rw-r--r--drivers/infiniband/hw/cxgb4/cm.c5
-rw-r--r--drivers/infiniband/hw/cxgb4/ev.c10
2 files changed, 2 insertions, 13 deletions
diff --git a/drivers/infiniband/hw/cxgb4/cm.c b/drivers/infiniband/hw/cxgb4/cm.c
index 6ee5d8415f58..8865a3332a62 100644
--- a/drivers/infiniband/hw/cxgb4/cm.c
+++ b/drivers/infiniband/hw/cxgb4/cm.c
@@ -1572,10 +1572,9 @@ static int rx_data(struct c4iw_dev *dev, struct sk_buff *skb)
1572 " qpid %u ep %p state %d tid %u status %d\n", 1572 " qpid %u ep %p state %d tid %u status %d\n",
1573 __func__, ep->com.qp->wq.sq.qid, ep, 1573 __func__, ep->com.qp->wq.sq.qid, ep,
1574 state_read(&ep->com), ep->hwtid, status); 1574 state_read(&ep->com), ep->hwtid, status);
1575 attrs.next_state = C4IW_QP_STATE_ERROR; 1575 attrs.next_state = C4IW_QP_STATE_TERMINATE;
1576 c4iw_modify_qp(ep->com.qp->rhp, ep->com.qp, 1576 c4iw_modify_qp(ep->com.qp->rhp, ep->com.qp,
1577 C4IW_QP_ATTR_NEXT_STATE, &attrs, 1); 1577 C4IW_QP_ATTR_NEXT_STATE, &attrs, 0);
1578 c4iw_ep_disconnect(ep, 1, GFP_KERNEL);
1579 break; 1578 break;
1580 } 1579 }
1581 default: 1580 default:
diff --git a/drivers/infiniband/hw/cxgb4/ev.c b/drivers/infiniband/hw/cxgb4/ev.c
index 1a840b2211dd..d61d0a18f784 100644
--- a/drivers/infiniband/hw/cxgb4/ev.c
+++ b/drivers/infiniband/hw/cxgb4/ev.c
@@ -44,16 +44,6 @@ static void post_qp_event(struct c4iw_dev *dev, struct c4iw_cq *chp,
44 struct c4iw_qp_attributes attrs; 44 struct c4iw_qp_attributes attrs;
45 unsigned long flag; 45 unsigned long flag;
46 46
47 if ((qhp->attr.state == C4IW_QP_STATE_ERROR) ||
48 (qhp->attr.state == C4IW_QP_STATE_TERMINATE)) {
49 pr_err("%s AE after RTS - qpid 0x%x opcode %d status 0x%x "\
50 "type %d wrid.hi 0x%x wrid.lo 0x%x\n",
51 __func__, CQE_QPID(err_cqe), CQE_OPCODE(err_cqe),
52 CQE_STATUS(err_cqe), CQE_TYPE(err_cqe),
53 CQE_WRID_HI(err_cqe), CQE_WRID_LOW(err_cqe));
54 return;
55 }
56
57 printk(KERN_ERR MOD "AE qpid 0x%x opcode %d status 0x%x " 47 printk(KERN_ERR MOD "AE qpid 0x%x opcode %d status 0x%x "
58 "type %d wrid.hi 0x%x wrid.lo 0x%x\n", 48 "type %d wrid.hi 0x%x wrid.lo 0x%x\n",
59 CQE_QPID(err_cqe), CQE_OPCODE(err_cqe), 49 CQE_QPID(err_cqe), CQE_OPCODE(err_cqe),