|
Michal Suchanek |
02451c |
From 1a42156f52bd4de0e2442671bc24b7ffc7b01c52 Mon Sep 17 00:00:00 2001
|
|
Michal Suchanek |
02451c |
From: Lijun Pan <ljp@linux.ibm.com>
|
|
Michal Suchanek |
02451c |
Date: Fri, 12 Feb 2021 20:36:46 -0600
|
|
Michal Suchanek |
02451c |
Subject: [PATCH] ibmvnic: substitute mb() with dma_wmb() for send_*crq*
|
|
Michal Suchanek |
02451c |
functions
|
|
Michal Suchanek |
02451c |
|
|
Michal Suchanek |
02451c |
References: bsc#1184114 ltc#192237 bsc#1183023 ltc#191791
|
|
Michal Suchanek |
02451c |
Patch-mainline: v5.12-rc1
|
|
Michal Suchanek |
02451c |
Git-commit: 1a42156f52bd4de0e2442671bc24b7ffc7b01c52
|
|
Michal Suchanek |
02451c |
|
|
Michal Suchanek |
02451c |
The CRQ and subCRQ descriptors are DMA mapped, so dma_wmb(),
|
|
Michal Suchanek |
02451c |
though weaker, is good enough to protect the data structures.
|
|
Michal Suchanek |
02451c |
|
|
Michal Suchanek |
02451c |
Signed-off-by: Lijun Pan <ljp@linux.ibm.com>
|
|
Michal Suchanek |
02451c |
Acked-by: Thomas Falcon <tlfalcon@linux.ibm.com>
|
|
Michal Suchanek |
02451c |
Signed-off-by: David S. Miller <davem@davemloft.net>
|
|
Michal Suchanek |
02451c |
Acked-by: Michal Suchanek <msuchanek@suse.de>
|
|
Michal Suchanek |
02451c |
---
|
|
Michal Suchanek |
02451c |
drivers/net/ethernet/ibm/ibmvnic.c | 4 ++--
|
|
Michal Suchanek |
02451c |
1 file changed, 2 insertions(+), 2 deletions(-)
|
|
Michal Suchanek |
02451c |
|
|
Michal Suchanek |
02451c |
diff --git a/drivers/net/ethernet/ibm/ibmvnic.c b/drivers/net/ethernet/ibm/ibmvnic.c
|
|
Michal Suchanek |
02451c |
index 7a5e589e7223..927d5f36d308 100644
|
|
Michal Suchanek |
02451c |
--- a/drivers/net/ethernet/ibm/ibmvnic.c
|
|
Michal Suchanek |
02451c |
+++ b/drivers/net/ethernet/ibm/ibmvnic.c
|
|
Michal Suchanek |
02451c |
@@ -3599,7 +3599,7 @@ static int send_subcrq_indirect(struct ibmvnic_adapter *adapter,
|
|
Michal Suchanek |
02451c |
int rc;
|
|
Michal Suchanek |
02451c |
|
|
Michal Suchanek |
02451c |
/* Make sure the hypervisor sees the complete request */
|
|
Michal Suchanek |
02451c |
- mb();
|
|
Michal Suchanek |
02451c |
+ dma_wmb();
|
|
Michal Suchanek |
02451c |
rc = plpar_hcall_norets(H_SEND_SUB_CRQ_INDIRECT, ua,
|
|
Michal Suchanek |
02451c |
cpu_to_be64(remote_handle),
|
|
Michal Suchanek |
02451c |
ioba, num_entries);
|
|
Michal Suchanek |
02451c |
@@ -3629,7 +3629,7 @@ static int ibmvnic_send_crq(struct ibmvnic_adapter *adapter,
|
|
Michal Suchanek |
02451c |
}
|
|
Michal Suchanek |
02451c |
|
|
Michal Suchanek |
02451c |
/* Make sure the hypervisor sees the complete request */
|
|
Michal Suchanek |
02451c |
- mb();
|
|
Michal Suchanek |
02451c |
+ dma_wmb();
|
|
Michal Suchanek |
02451c |
|
|
Michal Suchanek |
02451c |
rc = plpar_hcall_norets(H_SEND_CRQ, ua,
|
|
Michal Suchanek |
02451c |
cpu_to_be64(u64_crq[0]),
|
|
Michal Suchanek |
02451c |
--
|
|
Michal Suchanek |
02451c |
2.26.2
|
|
Michal Suchanek |
02451c |
|