As Arnd points out: gcc-4.8 already supported -march=armv8, and we require gcc-5.1 now, so both this #if/#else construct and the corresponding "cc32-option,-march=armv8-a" check should be obsolete now. Link: https://lore.kernel.org/lkml/CAK8P3a3UBEJ0Py2ycz=rHfgog8g3mCOeQOwO0Gmp-iz6Uxkapg@mail.gmail.com/ Suggested-by: Arnd Bergmann <arnd@arndb.de> Signed-off-by: Nick Desaulniers <ndesaulniers@google.com> Reviewed-by: Vincenzo Frascino <vincenzo.frascino@arm.com> Reviewed-by: Nathan Chancellor <nathan@kernel.org> Link: https://lore.kernel.org/r/20211019223646.1146945-3-ndesaulniers@google.com Signed-off-by: Will Deacon <will@kernel.org>
37 lines
766 B
C
37 lines
766 B
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright (C) 2018 ARM Limited
|
|
*/
|
|
#ifndef __COMPAT_BARRIER_H
|
|
#define __COMPAT_BARRIER_H
|
|
|
|
#ifndef __ASSEMBLY__
|
|
/*
|
|
* Warning: This code is meant to be used with
|
|
* ENABLE_COMPAT_VDSO only.
|
|
*/
|
|
#ifndef ENABLE_COMPAT_VDSO
|
|
#error This header is meant to be used with ENABLE_COMPAT_VDSO only
|
|
#endif
|
|
|
|
#ifdef dmb
|
|
#undef dmb
|
|
#endif
|
|
|
|
#define dmb(option) __asm__ __volatile__ ("dmb " #option : : : "memory")
|
|
|
|
#define aarch32_smp_mb() dmb(ish)
|
|
#define aarch32_smp_rmb() dmb(ishld)
|
|
#define aarch32_smp_wmb() dmb(ishst)
|
|
|
|
#undef smp_mb
|
|
#undef smp_rmb
|
|
#undef smp_wmb
|
|
|
|
#define smp_mb() aarch32_smp_mb()
|
|
#define smp_rmb() aarch32_smp_rmb()
|
|
#define smp_wmb() aarch32_smp_wmb()
|
|
|
|
#endif /* !__ASSEMBLY__ */
|
|
|
|
#endif /* __COMPAT_BARRIER_H */
|