diff options
Diffstat (limited to 'drivers/infiniband/hw/qib/qib_uc.c')
| -rw-r--r-- | drivers/infiniband/hw/qib/qib_uc.c | 6 |
1 files changed, 0 insertions, 6 deletions
diff --git a/drivers/infiniband/hw/qib/qib_uc.c b/drivers/infiniband/hw/qib/qib_uc.c index 6c7fe78cca64..b9c8b6346c1b 100644 --- a/drivers/infiniband/hw/qib/qib_uc.c +++ b/drivers/infiniband/hw/qib/qib_uc.c | |||
| @@ -272,9 +272,6 @@ void qib_uc_rcv(struct qib_ibport *ibp, struct qib_ib_header *hdr, | |||
| 272 | opcode >>= 24; | 272 | opcode >>= 24; |
| 273 | memset(&wc, 0, sizeof wc); | 273 | memset(&wc, 0, sizeof wc); |
| 274 | 274 | ||
| 275 | /* Prevent simultaneous processing after APM on different CPUs */ | ||
| 276 | spin_lock(&qp->r_lock); | ||
| 277 | |||
| 278 | /* Compare the PSN verses the expected PSN. */ | 275 | /* Compare the PSN verses the expected PSN. */ |
| 279 | if (unlikely(qib_cmp24(psn, qp->r_psn) != 0)) { | 276 | if (unlikely(qib_cmp24(psn, qp->r_psn) != 0)) { |
| 280 | /* | 277 | /* |
| @@ -534,7 +531,6 @@ rdma_last: | |||
| 534 | } | 531 | } |
| 535 | qp->r_psn++; | 532 | qp->r_psn++; |
| 536 | qp->r_state = opcode; | 533 | qp->r_state = opcode; |
| 537 | spin_unlock(&qp->r_lock); | ||
| 538 | return; | 534 | return; |
| 539 | 535 | ||
| 540 | rewind: | 536 | rewind: |
| @@ -542,12 +538,10 @@ rewind: | |||
| 542 | qp->r_sge.num_sge = 0; | 538 | qp->r_sge.num_sge = 0; |
| 543 | drop: | 539 | drop: |
| 544 | ibp->n_pkt_drops++; | 540 | ibp->n_pkt_drops++; |
| 545 | spin_unlock(&qp->r_lock); | ||
| 546 | return; | 541 | return; |
| 547 | 542 | ||
| 548 | op_err: | 543 | op_err: |
| 549 | qib_rc_error(qp, IB_WC_LOC_QP_OP_ERR); | 544 | qib_rc_error(qp, IB_WC_LOC_QP_OP_ERR); |
| 550 | spin_unlock(&qp->r_lock); | ||
| 551 | return; | 545 | return; |
| 552 | 546 | ||
| 553 | sunlock: | 547 | sunlock: |
