IB/mlx4: Fix possible missed completion event
authorEli Cohen <eli@mellanox.com>
Tue, 6 Mar 2012 13:50:51 +0000 (15:50 +0200)
committerRoland Dreier <roland@purestorage.com>
Mon, 12 Mar 2012 23:24:59 +0000 (16:24 -0700)
If an erroneous CQE is polled in the first iteration (i.e. npolled ==
0), we don't update the consumer index and hence the hardware could
get a wrong notion of how many CQEs software polled.  Fix this by
unconditionally updating the doorbell record.  We could change the
check to be something like

if (npolled || err != -EAGAIN)
...

but it does not seem worth the effort since a posted write to memory
should not cost too much.

Signed-off-by: Eli Cohen <eli@mellanox.com>
Signed-off-by: Roland Dreier <roland@purestorage.com>
drivers/infiniband/hw/mlx4/cq.c

index 5ecf38d97269f1d98189c5e8543198fcab26ecbc..275861bddf1c9eb6392fc880a4d7e4984202b449 100644 (file)
@@ -747,8 +747,7 @@ int mlx4_ib_poll_cq(struct ib_cq *ibcq, int num_entries, struct ib_wc *wc)
                        break;
        }
 
-       if (npolled)
-               mlx4_cq_set_ci(&cq->mcq);
+       mlx4_cq_set_ci(&cq->mcq);
 
        spin_unlock_irqrestore(&cq->lock, flags);