aboutsummaryrefslogtreecommitdiff
path: root/platform/linux-generic/odp_time.c
diff options
context:
space:
mode:
authorMike Holmes <mike.holmes@linaro.org>2015-04-06 15:34:59 -0400
committerMaxim Uvarov <maxim.uvarov@linaro.org>2015-04-10 19:00:19 +0300
commitbe57a997211c1cef9a3c10cb2e9dd9754aa9dc6b (patch)
tree4a6d00e6d25849f32b84eecfce24e6c96c5966d4 /platform/linux-generic/odp_time.c
parenta2383e6d72e9fc498986658a17bdbcd7c2ca46fe (diff)
linux-generic: use arch optimisations for time
Switch to using configure time optimizations from compile time Signed-off-by: Mike Holmes <mike.holmes@linaro.org> Reviewed-by: Anders Roxell <anders.roxell@linaro.org> Signed-off-by: Maxim Uvarov <maxim.uvarov@linaro.org>
Diffstat (limited to 'platform/linux-generic/odp_time.c')
-rw-r--r--platform/linux-generic/odp_time.c64
1 files changed, 0 insertions, 64 deletions
diff --git a/platform/linux-generic/odp_time.c b/platform/linux-generic/odp_time.c
index 31d6656e6..a08833d0e 100644
--- a/platform/linux-generic/odp_time.c
+++ b/platform/linux-generic/odp_time.c
@@ -12,70 +12,6 @@
#define GIGA 1000000000
-#if defined __x86_64__ || defined __i386__
-
-uint64_t odp_time_cycles(void)
-{
- union {
- uint64_t tsc_64;
- struct {
- uint32_t lo_32;
- uint32_t hi_32;
- };
- } tsc;
-
- __asm__ __volatile__ ("rdtsc" :
- "=a" (tsc.lo_32),
- "=d" (tsc.hi_32) : : "memory");
-
- return tsc.tsc_64;
-}
-
-
-#elif defined __OCTEON__
-
-uint64_t odp_time_cycles(void)
-{
- #define CVMX_TMP_STR(x) CVMX_TMP_STR2(x)
- #define CVMX_TMP_STR2(x) #x
- uint64_t cycle;
-
- __asm__ __volatile__ ("rdhwr %[rt],$" CVMX_TMP_STR(31) :
- [rt] "=d" (cycle) : : "memory");
-
- return cycle;
-}
-
-#else
-
-#include <time.h>
-#include <stdlib.h>
-#include <odp_debug_internal.h>
-
-uint64_t odp_time_cycles(void)
-{
- struct timespec time;
- uint64_t sec, ns, hz, cycles;
- int ret;
-
- ret = clock_gettime(CLOCK_MONOTONIC_RAW, &time);
-
- if (ret != 0) {
- ODP_ABORT("clock_gettime failed\n");
- }
-
- hz = odp_sys_cpu_hz();
- sec = (uint64_t) time.tv_sec;
- ns = (uint64_t) time.tv_nsec;
-
- cycles = sec * hz;
- cycles += (ns * hz) / GIGA;
-
- return cycles;
-}
-
-#endif
-
uint64_t odp_time_diff_cycles(uint64_t t1, uint64_t t2)
{
if (odp_likely(t2 > t1))