Commit b1f2f6f3 authored by Noam Camus's avatar Noam Camus Committed by Vineet Gupta

ARC: [plat-eznps] Use dedicated SMP barriers

NPS device got 256 cores and each got 16 HW threads (SMT).
We use EZchip dedicated ISA to trigger HW scheduler of the
core that current HW thread belongs to.
This scheduling makes sure that data beyond barrier is available
to all HW threads in core and by that to all in device (4K).
Signed-off-by: default avatarNoam Camus <noamc@ezchip.com>
Cc: Peter Zijlstra <peterz@infradead.org>
parent a5a10d99
...@@ -30,9 +30,7 @@ ...@@ -30,9 +30,7 @@
#define rmb() asm volatile("dmb 1\n" : : : "memory") #define rmb() asm volatile("dmb 1\n" : : : "memory")
#define wmb() asm volatile("dmb 2\n" : : : "memory") #define wmb() asm volatile("dmb 2\n" : : : "memory")
#endif #elif !defined(CONFIG_ARC_PLAT_EZNPS) /* CONFIG_ISA_ARCOMPACT */
#ifdef CONFIG_ISA_ARCOMPACT
/* /*
* ARCompact based cores (ARC700) only have SYNC instruction which is super * ARCompact based cores (ARC700) only have SYNC instruction which is super
...@@ -41,6 +39,14 @@ ...@@ -41,6 +39,14 @@
*/ */
#define mb() asm volatile("sync\n" : : : "memory") #define mb() asm volatile("sync\n" : : : "memory")
#else /* CONFIG_ARC_PLAT_EZNPS */
#include <plat/ctop.h>
#define mb() asm volatile (".word %0" : : "i"(CTOP_INST_SCHD_RW) : "memory")
#define rmb() asm volatile (".word %0" : : "i"(CTOP_INST_SCHD_RD) : "memory")
#endif #endif
#include <asm-generic/barrier.h> #include <asm-generic/barrier.h>
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment