Commit afc09540 authored by Mark Rutland's avatar Mark Rutland Committed by Greg Kroah-Hartman

arm64: barrier: Add CSDB macros to control data-value prediction


From: Will Deacon <will.deacon@arm.com>

commit 669474e7 upstream.

For CPUs capable of data value prediction, CSDB waits for any outstanding
predictions to architecturally resolve before allowing speculative execution
to continue. Provide macros to expose it to the arch code.
Reviewed-by: default avatarMark Rutland <mark.rutland@arm.com>
Signed-off-by: default avatarWill Deacon <will.deacon@arm.com>
Signed-off-by: default avatarCatalin Marinas <catalin.marinas@arm.com>
Signed-off-by: Mark Rutland <mark.rutland@arm.com [v4.9 backport]
Tested-by: default avatarGreg Hackmann <ghackmann@google.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent cacf0217
...@@ -86,6 +86,13 @@ ...@@ -86,6 +86,13 @@
dmb \opt dmb \opt
.endm .endm
/*
* Value prediction barrier
*/
.macro csdb
hint #20
.endm
/* /*
* NOP sequence * NOP sequence
*/ */
......
...@@ -31,6 +31,8 @@ ...@@ -31,6 +31,8 @@
#define dmb(opt) asm volatile("dmb " #opt : : : "memory") #define dmb(opt) asm volatile("dmb " #opt : : : "memory")
#define dsb(opt) asm volatile("dsb " #opt : : : "memory") #define dsb(opt) asm volatile("dsb " #opt : : : "memory")
#define csdb() asm volatile("hint #20" : : : "memory")
#define mb() dsb(sy) #define mb() dsb(sy)
#define rmb() dsb(ld) #define rmb() dsb(ld)
#define wmb() dsb(st) #define wmb() dsb(st)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment