diff options
author | David Monniaux <david.monniaux@univ-grenoble-alpes.fr> | 2020-03-03 08:17:40 +0100 |
---|---|---|
committer | David Monniaux <david.monniaux@univ-grenoble-alpes.fr> | 2020-03-03 08:17:40 +0100 |
commit | 1ab7b51c30e1b10ac45b0bd64cefdc01da0f7f68 (patch) | |
tree | 210ffc156c83f04fb0c61a40b4f9037d7ba8a7e1 /test/monniaux/cycles.h | |
parent | 222c9047d61961db9c6b19fed5ca49829223fd33 (diff) | |
parent | 12be46d59a2483a10d77fa8ee67f7e0ca1bd702f (diff) | |
download | compcert-kvx-1ab7b51c30e1b10ac45b0bd64cefdc01da0f7f68.tar.gz compcert-kvx-1ab7b51c30e1b10ac45b0bd64cefdc01da0f7f68.zip |
Merge branch 'mppa-cse2' of gricad-gitlab.univ-grenoble-alpes.fr:sixcy/CompCert into mppa-work
Diffstat (limited to 'test/monniaux/cycles.h')
-rw-r--r-- | test/monniaux/cycles.h | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/test/monniaux/cycles.h b/test/monniaux/cycles.h new file mode 100644 index 00000000..21541145 --- /dev/null +++ b/test/monniaux/cycles.h @@ -0,0 +1,50 @@ +#include <inttypes.h> +#include <stdio.h> +typedef unsigned long cycle_t; + +#ifdef MAX_MEASURES + static cycle_t _last_stop[MAX_MEASURES] = {0}; + static cycle_t _total_cycles[MAX_MEASURES] = {0}; +#endif + +#ifdef __K1C__ +#include <../../k1-cos/include/hal/cos_registers.h> + +static inline void cycle_count_config(void) +{ + /* config pmc for cycle count */ + cycle_t pmc_value = __builtin_k1_get(COS_SFR_PMC); + + pmc_value &= ~(0xfULL); + __builtin_k1_set(COS_SFR_PMC, pmc_value); +} + +static inline cycle_t get_cycle(void) +{ + return __builtin_k1_get(COS_SFR_PM0); +} + +#else // not K1C +static inline void cycle_count_config(void) { } + +#ifdef __x86_64__ +#include <x86intrin.h> +static inline cycle_t get_cycle(void) { return __rdtsc(); } + +#elif __riscv +static inline cycle_t get_cycle(void) { + cycle_t cycles; + asm volatile ("rdcycle %0" : "=r" (cycles)); + return cycles; +} + +#else +static inline cycle_t get_cycle(void) { return 0; } +#endif +#endif + +#ifdef MAX_MEASURES + #define TIMEINIT(i) {_last_stop[i] = get_cycle();} + #define TIMESTOP(i) {cycle_t cur = get_cycle(); _total_cycles[i] += cur - _last_stop[i]; _last_stop[i] = cur;} + #define TIMEPRINT(n) { for (int i = 0; i <= n; i++) printf("%d cycles: %" PRIu64 "\n", i, _total_cycles[i]); } +#endif |