X-Git-Url: http://git.liburcu.org/?p=urcu.git;a=blobdiff_plain;f=urcu%2Farch%2Fgeneric.h;h=d42359557ef9147eafed2f2f077954e4246138ed;hp=5ec3a114763e458869a62d2518a1cf9dc2ce7050;hb=3fa182868e25068413fdaa1bef290365e99ab246;hpb=d0bbd9c2e8322f036e0a0a70091cae98cad7e390 diff --git a/urcu/arch/generic.h b/urcu/arch/generic.h index 5ec3a11..d423595 100644 --- a/urcu/arch/generic.h +++ b/urcu/arch/generic.h @@ -23,6 +23,7 @@ #include #include +#include #ifdef __cplusplus extern "C" { @@ -61,7 +62,7 @@ extern "C" { /* * Architectures without cache coherency need something like the following: * - * #define cmm_mc() arch_cache_flush() + * #define cmm_mc() arch_cache_flush() * #define cmm_rmc() arch_cache_flush_read() * #define cmm_wmc() arch_cache_flush_write() * @@ -149,6 +150,24 @@ extern "C" { #define caa_cpu_relax() cmm_barrier() #endif +#ifndef HAS_CAA_GET_CYCLES +#define HAS_CAA_GET_CYCLES + +#include +#include + +typedef uint64_t caa_cycles_t; + +static inline caa_cycles_t caa_get_cycles (void) +{ + struct timespec ts; + + if (caa_unlikely(clock_gettime(CLOCK_MONOTONIC, &ts))) + return -1ULL; + return ((uint64_t) ts.tv_sec * 1000000000ULL) + ts.tv_nsec; +} +#endif /* HAS_CAA_GET_CYCLES */ + #ifdef __cplusplus } #endif