diff options
author | Will Deacon <will@kernel.org> | 2019-10-16 02:30:47 +0200 |
---|---|---|
committer | Will Deacon <will@kernel.org> | 2020-07-21 11:50:35 +0200 |
commit | b78b331a3f5c0773171dadd6bbfa2a2242b45604 (patch) | |
tree | 6e9a048a1026a379b549760c863e636539e10863 /include/asm-generic | |
parent | compiler.h: Split {READ,WRITE}_ONCE definitions out into rwonce.h (diff) | |
download | linux-b78b331a3f5c0773171dadd6bbfa2a2242b45604.tar.xz linux-b78b331a3f5c0773171dadd6bbfa2a2242b45604.zip |
asm/rwonce: Allow __READ_ONCE to be overridden by the architecture
The meat and potatoes of READ_ONCE() is defined by the __READ_ONCE()
macro, which uses a volatile casts in an attempt to avoid tearing of
byte, halfword, word and double-word accesses. Allow this to be
overridden by the architecture code in the case that things like memory
barriers are also required.
Acked-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Acked-by: Paul E. McKenney <paulmck@kernel.org>
Signed-off-by: Will Deacon <will@kernel.org>
Diffstat (limited to 'include/asm-generic')
-rw-r--r-- | include/asm-generic/rwonce.h | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/include/asm-generic/rwonce.h b/include/asm-generic/rwonce.h index 87584379da43..04586b55a7c2 100644 --- a/include/asm-generic/rwonce.h +++ b/include/asm-generic/rwonce.h @@ -43,7 +43,9 @@ * atomicity or dependency ordering guarantees. Note that this may result * in tears! */ +#ifndef __READ_ONCE #define __READ_ONCE(x) (*(const volatile __unqual_scalar_typeof(x) *)&(x)) +#endif #define __READ_ONCE_SCALAR(x) \ ({ \ |