Add a test for the dmb instruction on ARM
authorJason Wessel <jason.wessel@windriver.com>
Mon, 28 Feb 2011 16:34:10 +0000 (11:34 -0500)
committerMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Mon, 28 Feb 2011 16:34:10 +0000 (11:34 -0500)
The dmb instruction is used to implement a memory barrier on modern
ARM hardware.  The older generations of processors which are included
in single processor systems can get by on the generic implementation
of the cmm_mb().  This will allow the user space rcu to work on many
other ARM systems.

Signed-off-by: Jason Wessel <jason.wessel@windriver.com>
Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
configure.ac
urcu/arch_arm.h

index 69ce396ef07956e98d0480103a879fc8ed382305..3e1b50141efc49fc5ba6d316b16c7453ba207db3 100644 (file)
@@ -20,6 +20,7 @@ AH_TEMPLATE([CONFIG_RCU_HAVE_FENCE], [Defined when on a system that has memory f
 AH_TEMPLATE([CONFIG_RCU_HAVE_FUTEX], [Defined when on a system with futex support.])
 AH_TEMPLATE([CONFIG_RCU_COMPAT_ARCH], [Compatibility mode for i386 which lacks
 cmpxchg instruction.])
+AH_TEMPLATE([CONFIG_ARM_HAVE_DMB], [Use the dmb instruction is available for use on ARM.])
 
 # Checks for programs.
 AC_PROG_CC
@@ -56,6 +57,25 @@ case $host_cpu in
        *) ARCHTYPE="unknown";;
 esac
 
+if test "x$ARCHTYPE" = "xarm" ; then
+AC_MSG_CHECKING([checking for dmb instruction])
+AC_TRY_COMPILE(
+[
+],
+[
+asm volatile("dmb":::"memory");
+],
+[
+       AC_MSG_RESULT([yes])
+       AC_DEFINE([CONFIG_ARM_HAVE_DMB], [1])
+]
+,
+[
+       AC_MSG_RESULT([no])
+]
+)
+fi
+
 UATOMICSRC=urcu/uatomic_arch_$ARCHTYPE.h
 ARCHSRC=urcu/arch_$ARCHTYPE.h
 if test "x$ARCHTYPE" != xx86 -a "x$ARCHTYPE" != xppc; then
index e25457d707427b5cd70a2141089da9909f1c4bc5..83cbb60a209f286093e9abb10ce238329b385243 100644 (file)
@@ -29,7 +29,9 @@
 extern "C" {
 #endif 
 
+#ifdef CONFIG_ARM_HAVE_DMB
 #define cmm_mb()    asm volatile("dmb":::"memory")
+#endif /* CONFIG_ARM_HAVE_DMB */
 
 #include <stdlib.h>
 #include <sys/time.h>
This page took 0.025886 seconds and 4 git commands to generate.