|
@@ -14,27 +14,27 @@
|
|
|
#endif
|
|
|
|
|
|
#if __LINUX_ARM_ARCH__ >= 7
|
|
|
-#define isb() __asm__ __volatile__ ("isb" : : : "memory")
|
|
|
-#define dsb() __asm__ __volatile__ ("dsb" : : : "memory")
|
|
|
-#define dmb() __asm__ __volatile__ ("dmb" : : : "memory")
|
|
|
+#define isb(option) __asm__ __volatile__ ("isb " #option : : : "memory")
|
|
|
+#define dsb(option) __asm__ __volatile__ ("dsb " #option : : : "memory")
|
|
|
+#define dmb(option) __asm__ __volatile__ ("dmb " #option : : : "memory")
|
|
|
#elif defined(CONFIG_CPU_XSC3) || __LINUX_ARM_ARCH__ == 6
|
|
|
-#define isb() __asm__ __volatile__ ("mcr p15, 0, %0, c7, c5, 4" \
|
|
|
+#define isb(x) __asm__ __volatile__ ("mcr p15, 0, %0, c7, c5, 4" \
|
|
|
: : "r" (0) : "memory")
|
|
|
-#define dsb() __asm__ __volatile__ ("mcr p15, 0, %0, c7, c10, 4" \
|
|
|
+#define dsb(x) __asm__ __volatile__ ("mcr p15, 0, %0, c7, c10, 4" \
|
|
|
: : "r" (0) : "memory")
|
|
|
-#define dmb() __asm__ __volatile__ ("mcr p15, 0, %0, c7, c10, 5" \
|
|
|
+#define dmb(x) __asm__ __volatile__ ("mcr p15, 0, %0, c7, c10, 5" \
|
|
|
: : "r" (0) : "memory")
|
|
|
#elif defined(CONFIG_CPU_FA526)
|
|
|
-#define isb() __asm__ __volatile__ ("mcr p15, 0, %0, c7, c5, 4" \
|
|
|
+#define isb(x) __asm__ __volatile__ ("mcr p15, 0, %0, c7, c5, 4" \
|
|
|
: : "r" (0) : "memory")
|
|
|
-#define dsb() __asm__ __volatile__ ("mcr p15, 0, %0, c7, c10, 4" \
|
|
|
+#define dsb(x) __asm__ __volatile__ ("mcr p15, 0, %0, c7, c10, 4" \
|
|
|
: : "r" (0) : "memory")
|
|
|
-#define dmb() __asm__ __volatile__ ("" : : : "memory")
|
|
|
+#define dmb(x) __asm__ __volatile__ ("" : : : "memory")
|
|
|
#else
|
|
|
-#define isb() __asm__ __volatile__ ("" : : : "memory")
|
|
|
-#define dsb() __asm__ __volatile__ ("mcr p15, 0, %0, c7, c10, 4" \
|
|
|
+#define isb(x) __asm__ __volatile__ ("" : : : "memory")
|
|
|
+#define dsb(x) __asm__ __volatile__ ("mcr p15, 0, %0, c7, c10, 4" \
|
|
|
: : "r" (0) : "memory")
|
|
|
-#define dmb() __asm__ __volatile__ ("" : : : "memory")
|
|
|
+#define dmb(x) __asm__ __volatile__ ("" : : : "memory")
|
|
|
#endif
|
|
|
|
|
|
#ifdef CONFIG_ARCH_HAS_BARRIERS
|
|
@@ -42,7 +42,7 @@
|
|
|
#elif defined(CONFIG_ARM_DMA_MEM_BUFFERABLE) || defined(CONFIG_SMP)
|
|
|
#define mb() do { dsb(); outer_sync(); } while (0)
|
|
|
#define rmb() dsb()
|
|
|
-#define wmb() mb()
|
|
|
+#define wmb() do { dsb(st); outer_sync(); } while (0)
|
|
|
#else
|
|
|
#define mb() barrier()
|
|
|
#define rmb() barrier()
|
|
@@ -54,9 +54,9 @@
|
|
|
#define smp_rmb() barrier()
|
|
|
#define smp_wmb() barrier()
|
|
|
#else
|
|
|
-#define smp_mb() dmb()
|
|
|
-#define smp_rmb() dmb()
|
|
|
-#define smp_wmb() dmb()
|
|
|
+#define smp_mb() dmb(ish)
|
|
|
+#define smp_rmb() smp_mb()
|
|
|
+#define smp_wmb() dmb(ishst)
|
|
|
#endif
|
|
|
|
|
|
#define read_barrier_depends() do { } while(0)
|