forked from Minki/linux
i40iw: Add missing memory barriers
Remove duplicate set_64bit_val call to offset 24.
Replace some instances of set_64bit_val with
i40iw_insert_wqe_hdr as valid bit needs a write
barrier and should be the last write operation for the WQE.
Fixes: 786c6adb3a
("i40iw: add puda code")
Signed-off-by: Mustafa Ismail <mustafa.ismail@intel.com>
Signed-off-by: Shiraz Saleem <shiraz.saleem@intel.com>
Signed-off-by: Doug Ledford <dledford@redhat.com>
This commit is contained in:
parent
1736b4c99d
commit
43bfc24ec1
@ -48,7 +48,7 @@
|
||||
* @wqe: cqp wqe for header
|
||||
* @header: header for the cqp wqe
|
||||
*/
|
||||
static inline void i40iw_insert_wqe_hdr(u64 *wqe, u64 header)
|
||||
void i40iw_insert_wqe_hdr(u64 *wqe, u64 header)
|
||||
{
|
||||
wmb(); /* make sure WQE is populated before polarity is set */
|
||||
set_64bit_val(wqe, 24, header);
|
||||
|
@ -59,6 +59,8 @@ enum i40iw_status_code i40iw_sc_mr_fast_register(struct i40iw_sc_qp *qp,
|
||||
struct i40iw_fast_reg_stag_info *info,
|
||||
bool post_sq);
|
||||
|
||||
void i40iw_insert_wqe_hdr(u64 *wqe, u64 header);
|
||||
|
||||
/* HMC/FPM functions */
|
||||
enum i40iw_status_code i40iw_sc_init_iw_hmc(struct i40iw_sc_dev *dev,
|
||||
u8 hmc_fn_id);
|
||||
|
@ -123,12 +123,11 @@ static void i40iw_puda_post_recvbuf(struct i40iw_puda_rsrc *rsrc, u32 wqe_idx,
|
||||
get_64bit_val(wqe, 24, &offset24);
|
||||
|
||||
offset24 = (offset24) ? 0 : LS_64(1, I40IWQPSQ_VALID);
|
||||
set_64bit_val(wqe, 24, offset24);
|
||||
|
||||
set_64bit_val(wqe, 0, buf->mem.pa);
|
||||
set_64bit_val(wqe, 8,
|
||||
LS_64(buf->mem.size, I40IWQPSQ_FRAG_LEN));
|
||||
set_64bit_val(wqe, 24, offset24);
|
||||
i40iw_insert_wqe_hdr(wqe, offset24);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -409,9 +408,7 @@ enum i40iw_status_code i40iw_puda_send(struct i40iw_sc_qp *qp,
|
||||
set_64bit_val(wqe, 8, LS_64(info->len, I40IWQPSQ_FRAG_LEN));
|
||||
set_64bit_val(wqe, 16, header[0]);
|
||||
|
||||
/* Ensure all data is written before writing valid bit */
|
||||
wmb();
|
||||
set_64bit_val(wqe, 24, header[1]);
|
||||
i40iw_insert_wqe_hdr(wqe, header[1]);
|
||||
|
||||
i40iw_debug_buf(qp->dev, I40IW_DEBUG_PUDA, "PUDA SEND WQE", wqe, 32);
|
||||
i40iw_qp_post_wr(&qp->qp_uk);
|
||||
@ -539,7 +536,7 @@ static enum i40iw_status_code i40iw_puda_qp_wqe(struct i40iw_sc_dev *dev, struct
|
||||
LS_64(2, I40IW_CQPSQ_QP_NEXTIWSTATE) |
|
||||
LS_64(cqp->polarity, I40IW_CQPSQ_WQEVALID);
|
||||
|
||||
set_64bit_val(wqe, 24, header);
|
||||
i40iw_insert_wqe_hdr(wqe, header);
|
||||
|
||||
i40iw_debug_buf(cqp->dev, I40IW_DEBUG_PUDA, "PUDA CQE", wqe, 32);
|
||||
i40iw_sc_cqp_post_sq(cqp);
|
||||
@ -655,7 +652,7 @@ static enum i40iw_status_code i40iw_puda_cq_wqe(struct i40iw_sc_dev *dev, struct
|
||||
LS_64(1, I40IW_CQPSQ_CQ_ENCEQEMASK) |
|
||||
LS_64(1, I40IW_CQPSQ_CQ_CEQIDVALID) |
|
||||
LS_64(cqp->polarity, I40IW_CQPSQ_WQEVALID);
|
||||
set_64bit_val(wqe, 24, header);
|
||||
i40iw_insert_wqe_hdr(wqe, header);
|
||||
|
||||
i40iw_debug_buf(dev, I40IW_DEBUG_PUDA, "PUDA CQE",
|
||||
wqe, I40IW_CQP_WQE_SIZE * 8);
|
||||
|
Loading…
Reference in New Issue
Block a user