RDMA/cxgb4: Display streaming mode error only if detected in RTS
authorVipul Pandya <vipul@chelsio.com>
Mon, 7 Jan 2013 13:11:52 +0000 (13:11 +0000)
committerRoland Dreier <roland@purestorage.com>
Thu, 14 Feb 2013 23:51:55 +0000 (15:51 -0800)
With later firmware, the chances of getting streaming mode data after
we exit RTS is likely, so we don't need to warn for it.  The only real
case where we don't expect it is when the QP is in RTS.

Move QP to ERROR when streaming mode data received.

Signed-off-by: Vipul Pandya <vipul@chelsio.com>
Signed-off-by: Roland Dreier <roland@purestorage.com>
drivers/infiniband/hw/cxgb4/cm.c

index 3dce47a637094270bf025f0bff5e3cf6b2a4ac70..31d1fac605d3047942e29d4d0fe23ff18dd9dd0c 100644 (file)
@@ -1403,21 +1403,23 @@ static int rx_data(struct c4iw_dev *dev, struct sk_buff *skb)
                ep->rcv_seq += dlen;
                process_mpa_request(ep, skb);
                break;
-       default:
-               pr_err("%s Unexpected streaming data." \
-                      " ep %p state %d tid %u status %d\n",
-                      __func__, ep, state_read(&ep->com), ep->hwtid, status);
-
-               if (ep->com.qp) {
-                       struct c4iw_qp_attributes attrs;
-
-                       attrs.next_state = C4IW_QP_STATE_ERROR;
-                       c4iw_modify_qp(ep->com.qp->rhp, ep->com.qp,
-                                      C4IW_QP_ATTR_NEXT_STATE, &attrs, 1);
-               }
+       case FPDU_MODE: {
+               struct c4iw_qp_attributes attrs;
+               BUG_ON(!ep->com.qp);
+               if (ep->com.qp->attr.state == C4IW_QP_STATE_RTS)
+                       pr_err("%s Unexpected streaming data." \
+                              " ep %p state %d tid %u status %d\n",
+                              __func__, ep, state_read(&ep->com),
+                              ep->hwtid, status);
+               attrs.next_state = C4IW_QP_STATE_ERROR;
+               c4iw_modify_qp(ep->com.qp->rhp, ep->com.qp,
+                              C4IW_QP_ATTR_NEXT_STATE, &attrs, 1);
                c4iw_ep_disconnect(ep, 1, GFP_KERNEL);
                break;
        }
+       default:
+               break;
+       }
        return 0;
 }