mirror of https://github.com/YosysHQ/yosys.git
- kernel/log.h: add rusage()-based fallback for systems without clock_gettime().
This commit is contained in:
parent
40e0b79495
commit
8111938e96
16
kernel/log.h
16
kernel/log.h
|
@ -23,6 +23,8 @@
|
||||||
#include "kernel/rtlil.h"
|
#include "kernel/rtlil.h"
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
|
#include <sys/time.h>
|
||||||
|
#include <sys/resource.h>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
extern std::vector<FILE*> log_files;
|
extern std::vector<FILE*> log_files;
|
||||||
|
@ -65,9 +67,23 @@ struct PerformanceTimer
|
||||||
}
|
}
|
||||||
|
|
||||||
static int64_t query() {
|
static int64_t query() {
|
||||||
|
#if defined(_POSIX_TIMERS) && (_POSIX_TIMERS > 0)
|
||||||
struct timespec ts;
|
struct timespec ts;
|
||||||
clock_gettime(CLOCK_PROCESS_CPUTIME_ID, &ts);
|
clock_gettime(CLOCK_PROCESS_CPUTIME_ID, &ts);
|
||||||
return int64_t(ts.tv_sec)*1000000000 + ts.tv_nsec;
|
return int64_t(ts.tv_sec)*1000000000 + ts.tv_nsec;
|
||||||
|
#elif defined(RUSAGE_SELF)
|
||||||
|
struct rusage rusage;
|
||||||
|
int64_t t;
|
||||||
|
if (getrusage(RUSAGE_SELF, &rusage) == -1) {
|
||||||
|
log_cmd_error("getrusage failed!\n");
|
||||||
|
log_abort();
|
||||||
|
}
|
||||||
|
t = 1000000000ULL * (int64_t) rusage.ru_utime.tv_sec + (int64_t) rusage.ru_utime.tv_usec * 1000ULL;
|
||||||
|
t += 1000000000ULL * (int64_t) rusage.ru_stime.tv_sec + (int64_t) rusage.ru_stime.tv_usec * 1000ULL;
|
||||||
|
return t;
|
||||||
|
#else
|
||||||
|
#error Dont know how to measure per-process CPU time. Need alternative method (times()/clocks()/gettimeofday()?).
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void reset() {
|
void reset() {
|
||||||
|
|
Loading…
Reference in New Issue