diff options
| -rw-r--r-- | drivers/infiniband/sw/rxe/rxe_resp.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/infiniband/sw/rxe/rxe_resp.c b/drivers/infiniband/sw/rxe/rxe_resp.c index 7a36ec9dbc0c..3435efff8799 100644 --- a/drivers/infiniband/sw/rxe/rxe_resp.c +++ b/drivers/infiniband/sw/rxe/rxe_resp.c | |||
| @@ -1070,12 +1070,13 @@ static enum resp_states duplicate_request(struct rxe_qp *qp, | |||
| 1070 | struct rxe_pkt_info *pkt) | 1070 | struct rxe_pkt_info *pkt) |
| 1071 | { | 1071 | { |
| 1072 | enum resp_states rc; | 1072 | enum resp_states rc; |
| 1073 | u32 prev_psn = (qp->resp.psn - 1) & BTH_PSN_MASK; | ||
| 1073 | 1074 | ||
| 1074 | if (pkt->mask & RXE_SEND_MASK || | 1075 | if (pkt->mask & RXE_SEND_MASK || |
| 1075 | pkt->mask & RXE_WRITE_MASK) { | 1076 | pkt->mask & RXE_WRITE_MASK) { |
| 1076 | /* SEND. Ack again and cleanup. C9-105. */ | 1077 | /* SEND. Ack again and cleanup. C9-105. */ |
| 1077 | if (bth_ack(pkt)) | 1078 | if (bth_ack(pkt)) |
| 1078 | send_ack(qp, pkt, AETH_ACK_UNLIMITED, qp->resp.psn - 1); | 1079 | send_ack(qp, pkt, AETH_ACK_UNLIMITED, prev_psn); |
| 1079 | rc = RESPST_CLEANUP; | 1080 | rc = RESPST_CLEANUP; |
| 1080 | goto out; | 1081 | goto out; |
| 1081 | } else if (pkt->mask & RXE_READ_MASK) { | 1082 | } else if (pkt->mask & RXE_READ_MASK) { |
