X-Git-Url: http://git.liburcu.org/?a=blobdiff_plain;f=include%2Furcu%2Farch%2Farm.h;h=54ca4fabc79de65bad94009c177e73a88b37b481;hb=ddec79fd4f75b5ae0c49ee25c843220cf060cb96;hp=5d1c60836da9a34fb1f2f71783255f5532d546b3;hpb=3f0dd283a89ab114ffbf5c3dd46463217c6bb2ff;p=urcu.git diff --git a/include/urcu/arch/arm.h b/include/urcu/arch/arm.h index 5d1c608..54ca4fa 100644 --- a/include/urcu/arch/arm.h +++ b/include/urcu/arch/arm.h @@ -30,7 +30,15 @@ extern "C" { #endif -#ifdef CONFIG_RCU_ARM_HAVE_DMB +/* + * Using DMB is faster than the builtin __sync_synchronize and this instruction is + * part of the baseline ARMv7 ISA. + */ +#ifdef URCU_ARCH_ARMV7 + +/* For backwards compat. */ +#define CONFIG_RCU_ARM_HAVE_DMB 1 + /* * Issues full system DMB operation. */ @@ -44,7 +52,8 @@ extern "C" { #define cmm_smp_mb() __asm__ __volatile__ ("dmb ish":::"memory") #define cmm_smp_rmb() __asm__ __volatile__ ("dmb ish":::"memory") #define cmm_smp_wmb() __asm__ __volatile__ ("dmb ish":::"memory") -#endif /* CONFIG_RCU_ARM_HAVE_DMB */ + +#endif /* URCU_ARCH_ARMV7 */ #include #include @@ -70,6 +79,15 @@ extern "C" { # endif #endif +/* + * https://gcc.gnu.org/bugzilla/show_bug.cgi?id=42263 + */ +#ifdef URCU_GCC_VERSION +# if URCU_GCC_VERSION >= 40400 && URCU_GCC_VERSION <= 40402 +# error Your gcc version has a non-functional __sync_synchronize() +# endif +#endif + #ifdef __cplusplus } #endif