X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=gettime.h;h=c55f5cba779f5269e6fbc6b96c1e85e419d40683;hb=d05db492c6bc4263fba1088b33850bda35dc325b;hp=11e2a7b9c26c0216ee4b2124f6dff929cf50175d;hpb=8b6a404cdd2c40715885e562416c3db039912773;p=fio.git diff --git a/gettime.h b/gettime.h index 11e2a7b9..c55f5cba 100644 --- a/gettime.h +++ b/gettime.h @@ -1,7 +1,10 @@ #ifndef FIO_GETTIME_H #define FIO_GETTIME_H +#include + #include "arch/arch.h" +#include "lib/seqlock.h" /* * Clock sources @@ -18,22 +21,24 @@ extern void fio_gtod_init(void); extern void fio_clock_init(void); extern int fio_start_gtod_thread(void); extern int fio_monotonic_clocktest(int debug); -extern void fio_local_clock_init(int); +extern void fio_local_clock_init(void); -extern struct timespec *fio_ts; +extern struct fio_ts { + struct seqlock seqlock; + struct timespec ts; +} *fio_ts; static inline int fio_gettime_offload(struct timespec *ts) { - time_t last_sec; + unsigned int seq; if (!fio_ts) return 0; do { - read_barrier(); - last_sec = ts->tv_sec = fio_ts->tv_sec; - ts->tv_nsec = fio_ts->tv_nsec; - } while (fio_ts->tv_sec != last_sec); + seq = read_seqlock_begin(&fio_ts->seqlock); + *ts = fio_ts->ts; + } while (read_seqlock_retry(&fio_ts->seqlock, seq)); return 1; }