blob: b814ff8d8dada4f8dfb753d2b06e2224c2c9e09c [file] [log] [blame]
Yann Collet59a71162019-04-10 12:37:03 -07001/*
Elliott Hughes44aba642023-09-12 20:18:59 +00002 * Copyright (c) Meta Platforms, Inc. and affiliates.
Yann Collet59a71162019-04-10 12:37:03 -07003 * All rights reserved.
4 *
5 * This source code is licensed under both the BSD-style license (found in the
6 * LICENSE file in the root directory of this source tree) and the GPLv2 (found
7 * in the COPYING file in the root directory of this source tree).
8 * You may select, at your option, one of the above-listed licenses.
9 */
10
11#ifndef TIME_FN_H_MODULE_287987
12#define TIME_FN_H_MODULE_287987
13
14#if defined (__cplusplus)
15extern "C" {
16#endif
17
18
Yann Collet59a71162019-04-10 12:37:03 -070019
20/*-****************************************
Elliott Hughes44aba642023-09-12 20:18:59 +000021* Types
Yann Collet59a71162019-04-10 12:37:03 -070022******************************************/
23
24#if !defined (__VMS) && (defined (__cplusplus) || (defined (__STDC_VERSION__) && (__STDC_VERSION__ >= 199901L) /* C99 */) )
Like Macc907772020-08-26 03:10:06 +080025# if defined(_AIX)
26# include <inttypes.h>
27# else
Elliott Hughes44aba642023-09-12 20:18:59 +000028# include <stdint.h> /* uint64_t */
Like Macc907772020-08-26 03:10:06 +080029# endif
Yann Collet4b8185c2019-04-10 13:26:27 -070030 typedef uint64_t PTime; /* Precise Time */
Yann Collet59a71162019-04-10 12:37:03 -070031#else
Yann Collet4b8185c2019-04-10 13:26:27 -070032 typedef unsigned long long PTime; /* does not support compilers without long long support */
Yann Collet59a71162019-04-10 12:37:03 -070033#endif
34
Elliott Hughes44aba642023-09-12 20:18:59 +000035/* UTIL_time_t contains a nanosecond time counter.
36 * The absolute value is not meaningful.
37 * It's only valid to compute the difference between 2 measurements. */
38typedef struct { PTime t; } UTIL_time_t;
39#define UTIL_TIME_INITIALIZER { 0 }
Yann Collet59a71162019-04-10 12:37:03 -070040
Yann Collet4b8185c2019-04-10 13:26:27 -070041
Yann Collet8b130002023-01-06 15:25:36 -080042/*-****************************************
43* Time functions
44******************************************/
Yann Collet59a71162019-04-10 12:37:03 -070045
Yann Collet8b130002023-01-06 15:25:36 -080046UTIL_time_t UTIL_getTime(void);
Evan Witt79934932023-09-06 22:46:11 +000047
Elliott Hughes44aba642023-09-12 20:18:59 +000048/* Timer resolution can be low on some platforms.
49 * To improve accuracy, it's recommended to wait for a new tick
50 * before starting benchmark measurements */
51void UTIL_waitForNextTick(void);
52/* tells if timefn will return correct time measurements
53 * in presence of multi-threaded workload.
54 * note : this is not the case if only C90 clock_t measurements are available */
55int UTIL_support_MT_measurements(void);
56
57PTime UTIL_getSpanTimeNano(UTIL_time_t clockStart, UTIL_time_t clockEnd);
Yann Collet59a71162019-04-10 12:37:03 -070058PTime UTIL_clockSpanNano(UTIL_time_t clockStart);
59
Elliott Hughes44aba642023-09-12 20:18:59 +000060PTime UTIL_getSpanTimeMicro(UTIL_time_t clockStart, UTIL_time_t clockEnd);
61PTime UTIL_clockSpanMicro(UTIL_time_t clockStart);
62
63#define SEC_TO_MICRO ((PTime)1000000) /* nb of microseconds in a second */
Yann Collet59a71162019-04-10 12:37:03 -070064
65
66#if defined (__cplusplus)
67}
68#endif
69
70#endif /* TIME_FN_H_MODULE_287987 */