nvme/pcie: add memory barrier process completions
Because ppc64 has less strict memory ordering behaviour than x86 we need to introduce a memory barrier when polling for completions due to possible reordering of tracker and cpl access. Change-Id: Id17116c38b2ba69154c175c539fc97c60897deb0 Signed-off-by: Jonas Pfefferle <jpf@zurich.ibm.com> Reviewed-on: https://review.gerrithub.io/383728 Tested-by: SPDK Automated Test System <sys_sgsw@intel.com> Reviewed-by: Jim Harris <james.r.harris@intel.com> Reviewed-by: Daniel Verkamp <daniel.verkamp@intel.com>
This commit is contained in:
parent
7bcb08c02b
commit
4382434855
@ -1907,6 +1907,14 @@ nvme_pcie_qpair_process_completions(struct spdk_nvme_qpair *qpair, uint32_t max_
|
|||||||
|
|
||||||
if (cpl->status.p != pqpair->phase)
|
if (cpl->status.p != pqpair->phase)
|
||||||
break;
|
break;
|
||||||
|
#ifdef __PPC64__
|
||||||
|
/*
|
||||||
|
* This memory barrier prevents reordering of:
|
||||||
|
* - load after store from/to tr
|
||||||
|
* - load after load cpl phase and cpl cid
|
||||||
|
*/
|
||||||
|
spdk_mb();
|
||||||
|
#endif
|
||||||
|
|
||||||
tr = &pqpair->tr[cpl->cid];
|
tr = &pqpair->tr[cpl->cid];
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user