提交 8a70f812 编写于 作者: H Hariprasad S 提交者: Doug Ledford

RDMA/iw_cxgb4: in process_timeout() don't move ep state to ABORTING

Moving the state to ABORTING causes the ep to get stuck because
c4iw_ep_timeout() thinks the ABORT has already been done. So leave the
state alone and let c4iw_ep_disconnect() do the right thing given the
ep state.
Signed-off-by: NSteve Wise <swise@opengridcomputing.com>
Signed-off-by: NHariprasad Shenai <hariprasad@chelsio.com>
Signed-off-by: NDoug Ledford <dledford@redhat.com>
上级 caa6c9f2
...@@ -3971,12 +3971,10 @@ static void process_timeout(struct c4iw_ep *ep) ...@@ -3971,12 +3971,10 @@ static void process_timeout(struct c4iw_ep *ep)
set_bit(TIMEDOUT, &ep->com.history); set_bit(TIMEDOUT, &ep->com.history);
switch (ep->com.state) { switch (ep->com.state) {
case MPA_REQ_SENT: case MPA_REQ_SENT:
__state_set(&ep->com, ABORTING);
connect_reply_upcall(ep, -ETIMEDOUT); connect_reply_upcall(ep, -ETIMEDOUT);
break; break;
case MPA_REQ_WAIT: case MPA_REQ_WAIT:
case MPA_REP_SENT: case MPA_REP_SENT:
__state_set(&ep->com, ABORTING);
break; break;
case CLOSING: case CLOSING:
case MORIBUND: case MORIBUND:
...@@ -3986,7 +3984,6 @@ static void process_timeout(struct c4iw_ep *ep) ...@@ -3986,7 +3984,6 @@ static void process_timeout(struct c4iw_ep *ep)
ep->com.qp, C4IW_QP_ATTR_NEXT_STATE, ep->com.qp, C4IW_QP_ATTR_NEXT_STATE,
&attrs, 1); &attrs, 1);
} }
__state_set(&ep->com, ABORTING);
close_complete_upcall(ep, -ETIMEDOUT); close_complete_upcall(ep, -ETIMEDOUT);
break; break;
case ABORTING: case ABORTING:
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册