forked from pool/mvapich2
b95e475e85
- Reenable arm compilation - Rename and cleanup mvapich-s390_get_cycles.patch to mvapich2-s390_get_cycles.patch for coherency - Cleanup mvapich2-pthread_yield.patch - Add mvapich2-arm-support.patch to provide missing functions for armv7hl and aarch64 OBS-URL: https://build.opensuse.org/request/show/502493 OBS-URL: https://build.opensuse.org/package/show/science:HPC/mvapich2?expand=0&rev=6
30 lines
928 B
Diff
30 lines
928 B
Diff
diff --git src/mpid/ch3/channels/common/include/mv2_clock.h src/mpid/ch3/channels/common/include/mv2_clock.h
|
|
index ac117c2..335d07f 100644
|
|
--- src/mpid/ch3/channels/common/include/mv2_clock.h
|
|
+++ src/mpid/ch3/channels/common/include/mv2_clock.h
|
|
@@ -81,7 +81,24 @@ static inline cycles_t get_cycles()
|
|
asm volatile ("mov %0=ar.itc" : "=r" (ret));
|
|
return ret;
|
|
}
|
|
+#elif defined(__ARM_ARCH_7A__)
|
|
+typedef unsigned long long cycles_t;
|
|
+static inline cycles_t get_cycles(void)
|
|
+{
|
|
+ cycles_t clk;
|
|
+ asm volatile("mrrc p15, 0, %Q0, %R0, c14" : "=r" (clk));
|
|
+ return clk;
|
|
+}
|
|
+#elif defined(__aarch64__)
|
|
|
|
+typedef unsigned long cycles_t;
|
|
+static inline cycles_t get_cycles()
|
|
+{
|
|
+ cycles_t cval;
|
|
+ asm volatile("isb" : : : "memory");
|
|
+ asm volatile("mrs %0, cntvct_el0" : "=r" (cval));
|
|
+ return cval;
|
|
+}
|
|
#elif defined(__s390__) || defined(__s390x__)
|
|
typedef unsigned long cycles_t;
|
|
static inline cycles_t get_cycles()
|