X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=gettime.h;h=11e2a7b9c26c0216ee4b2124f6dff929cf50175d;hp=f5412286e3bad41dd32111f8885d647af20fad75;hb=44bb11426e9fe13c509594bc205e4b61225e7483;hpb=27325ed5a4f770b681c6847352c547d51dbdeb62 diff --git a/gettime.h b/gettime.h index f5412286..11e2a7b9 100644 --- a/gettime.h +++ b/gettime.h @@ -13,29 +13,31 @@ enum fio_cs { CS_INVAL, }; -extern void fio_gettime(struct timeval *, void *); +extern void fio_gettime(struct timespec *, void *); extern void fio_gtod_init(void); extern void fio_clock_init(void); extern int fio_start_gtod_thread(void); -extern int fio_monotonic_clocktest(void); +extern int fio_monotonic_clocktest(int debug); extern void fio_local_clock_init(int); -extern struct timeval *fio_tv; +extern struct timespec *fio_ts; -static inline int fio_gettime_offload(struct timeval *tv) +static inline int fio_gettime_offload(struct timespec *ts) { - size_t last_sec; + time_t last_sec; - if (!fio_tv) + if (!fio_ts) return 0; do { read_barrier(); - last_sec = tv->tv_sec = fio_tv->tv_sec; - tv->tv_usec = fio_tv->tv_usec; - } while (fio_tv->tv_sec != last_sec); + last_sec = ts->tv_sec = fio_ts->tv_sec; + ts->tv_nsec = fio_ts->tv_nsec; + } while (fio_ts->tv_sec != last_sec); return 1; } +extern void fio_gtod_set_cpu(unsigned int cpu); + #endif