@@ -466,6 +466,12 @@ unsigned long long ts_usec(const struct timespec *ts)
(unsigned long long) ts->tv_nsec / NSEC_PER_USEC;
}
+unsigned long long ts_msec(const struct timespec *ts)
+{
+ return (unsigned long long) ts->tv_sec * MSEC_PER_SEC +
+ (unsigned long long) ts->tv_nsec / NSEC_PER_MSEC;
+}
+
unsigned long long now_usec(void)
{
struct timespec ts;
@@ -476,6 +482,16 @@ unsigned long long now_usec(void)
return ts_usec(&ts);
}
+unsigned long long now_msec(void)
+{
+ struct timespec ts;
+
+ if (clock_gettime(CLOCK_MONOTONIC, &ts) != 0)
+ return 0;
+
+ return ts_msec(&ts);
+}
+
unsigned long long stat_mstamp(const struct stat *st)
{
#ifdef HAVE_STRUCT_STAT_ST_MTIM
@@ -48,9 +48,13 @@ unsigned long long stat_mstamp(const struct stat *st);
* ************************************************************************ */
#define USEC_PER_SEC 1000000ULL
#define USEC_PER_MSEC 1000ULL
+#define MSEC_PER_SEC 1000ULL
+#define NSEC_PER_MSEC 1000000ULL
unsigned long long ts_usec(const struct timespec *ts);
+unsigned long long ts_msec(const struct timespec *ts);
unsigned long long now_usec(void);
+unsigned long long now_msec(void);
/* endianess and alignments */
/* ************************************************************************ */
Signed-off-by: Lucas De Marchi <lucas.de.marchi@gmail.com> --- shared/util.c | 16 ++++++++++++++++ shared/util.h | 4 ++++ 2 files changed, 20 insertions(+)