nvmf/vfio-user: add memory barrier after posting a completion
We met an issue that client got a NVMe completion with old SC bit, so we add a memory barrier here to ensure the NVMe completion is fully populated. Fix issue #2323. Change-Id: I7887d789a0acd3634a10aa7dc8de81a153137ae7 Signed-off-by: Changpeng Liu <changpeng.liu@intel.com> Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/11076 Community-CI: Broadcom CI <spdk-ci.pdl@broadcom.com> Community-CI: Mellanox Build Bot Tested-by: SPDK CI Jenkins <sys_sgci@intel.com> Reviewed-by: John Levon <levon@movementarian.org> Reviewed-by: Jim Harris <james.r.harris@intel.com> Reviewed-by: Ben Walker <benjamin.walker@intel.com>
This commit is contained in:
parent
d87afb4cbd
commit
b7775dae8e
@ -939,9 +939,11 @@ post_completion(struct nvmf_vfio_user_ctrlr *ctrlr, struct nvme_q *cq,
|
||||
cpl->status.dnr = 0x0;
|
||||
cpl->status.m = 0x0;
|
||||
cpl->status.sct = sct;
|
||||
cpl->status.p = cq->phase;
|
||||
cpl->status.sc = sc;
|
||||
cpl->status.p = cq->phase;
|
||||
|
||||
/* Ensure the Completion Queue Entry is visible. */
|
||||
spdk_wmb();
|
||||
cq_tail_advance(cq);
|
||||
|
||||
/*
|
||||
|
Loading…
Reference in New Issue
Block a user