IB/rxe: Advance the consumer pointer before posting the CQE
authorAndrew Boyer <andrew.boyer@dell.com>
Wed, 23 Nov 2016 17:39:18 +0000 (12:39 -0500)
committerDoug Ledford <dledford@redhat.com>
Mon, 12 Dec 2016 21:31:45 +0000 (16:31 -0500)
A simple userspace application might poll the CQ, find a completion,
and then attempt to post a new WQE to the SQ. A spurious error can
occur if the userspace application detects a full SQ in the instant
before the kernel is able to advance the SQ consumer pointer.

This is noticeable when using single-entry SQs with ibv_rc_pingpong
if lots of kernel and userspace library debugging is enabled.

Signed-off-by: Andrew Boyer <andrew.boyer@dell.com>
Reviewed-by: Yonatan Cohen <yonatanc@mellanox.com>
Signed-off-by: Doug Ledford <dledford@redhat.com>
drivers/infiniband/sw/rxe/rxe_comp.c

index 6c5e29db88e360b0188d4c3bf3ee74214afc3c79..d46c49b33b13d123f6c24e39410fd7ffbe2d6429 100644 (file)
@@ -420,11 +420,12 @@ static void do_complete(struct rxe_qp *qp, struct rxe_send_wqe *wqe)
            (wqe->wr.send_flags & IB_SEND_SIGNALED) ||
            (qp->req.state == QP_STATE_ERROR)) {
                make_send_cqe(qp, wqe, &cqe);
+               advance_consumer(qp->sq.queue);
                rxe_cq_post(qp->scq, &cqe, 0);
+       } else {
+               advance_consumer(qp->sq.queue);
        }
 
-       advance_consumer(qp->sq.queue);
-
        /*
         * we completed something so let req run again
         * if it is trying to fence