vascom / rpms / ceph

Forked from rpms/ceph 5 years ago
Clone
bedf031
From b2781fb5638afae7438b983a912ede126a8c5b85 Mon Sep 17 00:00:00 2001
bedf031
From: James Page <james.page@ubuntu.com>
bedf031
Date: Fri, 13 Mar 2015 19:46:04 +0000
bedf031
Subject: [PATCH] Add support for PPC architecture, provide fallback
bedf031
bedf031
Add high precision cpu cycles support for powerpc and powerpc64.
bedf031
bedf031
Provide a fallback for other architectures and warn during
bedf031
compilation.
bedf031
bedf031
Signed-off-by: James Page <james.page@ubuntu.com>
bedf031
bedf031
diff --git a/src/common/Cycles.h b/src/common/Cycles.h
bedf031
index 6e47cde..bb47d5c 100644
bedf031
--- a/src/common/Cycles.h
bedf031
+++ b/src/common/Cycles.h
bedf031
@@ -72,8 +72,15 @@ class Cycles {
bedf031
     uint64_t cntvct;
bedf031
     asm volatile ("isb; mrs %0, cntvct_el0; isb; " : "=r" (cntvct) :: "memory");
bedf031
     return cntvct;
bedf031
+#elif defined(__powerpc__) || defined (__powerpc64__)
bedf031
+    // Based on:
bedf031
+    // https://github.com/randombit/botan/blob/net.randombit.botan/src/lib/entropy/hres_timer/hres_timer.cpp
bedf031
+    uint32_t lo = 0, hi = 0;
bedf031
+    asm volatile("mftbu %0; mftb %1" : "=r" (hi), "=r" (lo));
bedf031
+    return (((uint64_t)hi << 32) | lo);
bedf031
 #else
bedf031
-#error No high-precision counter available for your OS/arch
bedf031
+#warning No high-precision counter available for your OS/arch
bedf031
+    return 0;
bedf031
 #endif
bedf031
   }
bedf031