metag: define __smp_xxx
[cascardo/linux.git] / arch / metag / include / asm / barrier.h
index b5b778b..5418517 100644 (file)
@@ -44,13 +44,6 @@ static inline void wr_fence(void)
 #define rmb()          barrier()
 #define wmb()          mb()
 
-#ifndef CONFIG_SMP
-#define fence()                do { } while (0)
-#define smp_mb()        barrier()
-#define smp_rmb()       barrier()
-#define smp_wmb()       barrier()
-#else
-
 #ifdef CONFIG_METAG_SMP_WRITE_REORDERING
 /*
  * Write to the atomic memory unlock system event register (command 0). This is
@@ -60,26 +53,31 @@ static inline void wr_fence(void)
  * incoherence). It is therefore ineffective if used after and on the same
  * thread as a write.
  */
-static inline void fence(void)
+static inline void metag_fence(void)
 {
        volatile int *flushptr = (volatile int *) LINSYSEVENT_WR_ATOMIC_UNLOCK;
        barrier();
        *flushptr = 0;
        barrier();
 }
-#define smp_mb()        fence()
-#define smp_rmb()       fence()
-#define smp_wmb()       barrier()
+#define __smp_mb()     metag_fence()
+#define __smp_rmb()    metag_fence()
+#define __smp_wmb()    barrier()
 #else
-#define fence()                do { } while (0)
-#define smp_mb()        barrier()
-#define smp_rmb()       barrier()
-#define smp_wmb()       barrier()
+#define metag_fence()  do { } while (0)
+#define __smp_mb()     barrier()
+#define __smp_rmb()    barrier()
+#define __smp_wmb()    barrier()
 #endif
+
+#ifdef CONFIG_SMP
+#define fence()                metag_fence()
+#else
+#define fence()                do { } while (0)
 #endif
 
-#define smp_mb__before_atomic()        barrier()
-#define smp_mb__after_atomic() barrier()
+#define __smp_mb__before_atomic()      barrier()
+#define __smp_mb__after_atomic()       barrier()
 
 #include <asm-generic/barrier.h>