diff options
Diffstat (limited to 'drivers/infiniband/hw/irdma/puda.c')
| -rw-r--r-- | drivers/infiniband/hw/irdma/puda.c | 6 | 
1 files changed, 6 insertions, 0 deletions
diff --git a/drivers/infiniband/hw/irdma/puda.c b/drivers/infiniband/hw/irdma/puda.c index 4ec9639f1bdb..562531712ea4 100644 --- a/drivers/infiniband/hw/irdma/puda.c +++ b/drivers/infiniband/hw/irdma/puda.c @@ -230,6 +230,9 @@ static int irdma_puda_poll_info(struct irdma_sc_cq *cq,  	if (valid_bit != cq_uk->polarity)  		return -ENOENT; +	/* Ensure CQE contents are read after valid bit is checked */ +	dma_rmb(); +  	if (cq->dev->hw_attrs.uk_attrs.hw_rev >= IRDMA_GEN_2)  		ext_valid = (bool)FIELD_GET(IRDMA_CQ_EXTCQE, qword3); @@ -243,6 +246,9 @@ static int irdma_puda_poll_info(struct irdma_sc_cq *cq,  		if (polarity != cq_uk->polarity)  			return -ENOENT; +		/* Ensure ext CQE contents are read after ext valid bit is checked */ +		dma_rmb(); +  		IRDMA_RING_MOVE_HEAD_NOCHECK(cq_uk->cq_ring);  		if (!IRDMA_RING_CURRENT_HEAD(cq_uk->cq_ring))  			cq_uk->polarity = !cq_uk->polarity;  |