root/arch/arm64/include/asm/vdso/compat_barrier.h

/* [<][>][^][v][top][bottom][index][help] */

INCLUDED FROM


   1 /* SPDX-License-Identifier: GPL-2.0 */
   2 /*
   3  * Copyright (C) 2018 ARM Limited
   4  */
   5 #ifndef __COMPAT_BARRIER_H
   6 #define __COMPAT_BARRIER_H
   7 
   8 #ifndef __ASSEMBLY__
   9 /*
  10  * Warning: This code is meant to be used with
  11  * ENABLE_COMPAT_VDSO only.
  12  */
  13 #ifndef ENABLE_COMPAT_VDSO
  14 #error This header is meant to be used with ENABLE_COMPAT_VDSO only
  15 #endif
  16 
  17 #ifdef dmb
  18 #undef dmb
  19 #endif
  20 
  21 #define dmb(option) __asm__ __volatile__ ("dmb " #option : : : "memory")
  22 
  23 #if __LINUX_ARM_ARCH__ >= 8 && defined(CONFIG_AS_DMB_ISHLD)
  24 #define aarch32_smp_mb()        dmb(ish)
  25 #define aarch32_smp_rmb()       dmb(ishld)
  26 #define aarch32_smp_wmb()       dmb(ishst)
  27 #else
  28 #define aarch32_smp_mb()        dmb(ish)
  29 #define aarch32_smp_rmb()       aarch32_smp_mb()
  30 #define aarch32_smp_wmb()       dmb(ishst)
  31 #endif
  32 
  33 
  34 #undef smp_mb
  35 #undef smp_rmb
  36 #undef smp_wmb
  37 
  38 #define smp_mb()        aarch32_smp_mb()
  39 #define smp_rmb()       aarch32_smp_rmb()
  40 #define smp_wmb()       aarch32_smp_wmb()
  41 
  42 #endif /* !__ASSEMBLY__ */
  43 
  44 #endif /* __COMPAT_BARRIER_H */

/* [<][>][^][v][top][bottom][index][help] */