[PATCH net-next 1/3] arm64: barrier: add DGH macros to control memory accesses merging
Guangbin Huang
huangguangbin2 at huawei.com
Tue Jun 22 04:11:09 PDT 2021
From: Xiongfeng Wang <wangxiongfeng2 at huawei.com>
DGH prohibits merging memory accesses with Normal-NC or Device-GRE
attributes before the hint instruction with any memory accesses
appearing after the hint instruction. Provide macros to expose it to the
arch code.
Signed-off-by: Xiongfeng Wang <wangxiongfeng2 at huawei.com>
Signed-off-by: Cheng Jian <cj.chengjian at huawei.com>
Signed-off-by: Yufeng Mo <moyufeng at huawei.com>
---
arch/arm64/include/asm/assembler.h | 7 +++++++
arch/arm64/include/asm/barrier.h | 1 +
2 files changed, 8 insertions(+)
diff --git a/arch/arm64/include/asm/assembler.h b/arch/arm64/include/asm/assembler.h
index 8418c1bd8f04..d723899328bd 100644
--- a/arch/arm64/include/asm/assembler.h
+++ b/arch/arm64/include/asm/assembler.h
@@ -90,6 +90,13 @@
.endm
/*
+ * Data gathering hint
+ */
+ .macro dgh
+ hint #6
+ .endm
+
+/*
* RAS Error Synchronization barrier
*/
.macro esb
diff --git a/arch/arm64/include/asm/barrier.h b/arch/arm64/include/asm/barrier.h
index 451e11e5fd23..02e1735706d2 100644
--- a/arch/arm64/include/asm/barrier.h
+++ b/arch/arm64/include/asm/barrier.h
@@ -22,6 +22,7 @@
#define dmb(opt) asm volatile("dmb " #opt : : : "memory")
#define dsb(opt) asm volatile("dsb " #opt : : : "memory")
+#define dgh() asm volatile("hint #6" : : : "memory")
#define psb_csync() asm volatile("hint #17" : : : "memory")
#define tsb_csync() asm volatile("hint #18" : : : "memory")
#define csdb() asm volatile("hint #20" : : : "memory")
--
2.8.1
More information about the linux-arm-kernel
mailing list