Module Name: src
Committed By: pgoyette
Date: Thu Jan 5 23:24:39 UTC 2017
Modified Files:
src/sys/sys: time.h
Log Message:
Define macros for the time conversion magic numbers.
To generate a diff of this commit:
cvs rdiff -u -r1.75 -r1.76 src/sys/sys/time.h
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/sys/time.h
diff -u src/sys/sys/time.h:1.75 src/sys/sys/time.h:1.76
--- src/sys/sys/time.h:1.75 Thu Jan 5 22:51:15 2017
+++ src/sys/sys/time.h Thu Jan 5 23:24:39 2017
@@ -1,4 +1,4 @@
-/* $NetBSD: time.h,v 1.75 2017/01/05 22:51:15 pgoyette Exp $ */
+/* $NetBSD: time.h,v 1.76 2017/01/05 23:24:39 pgoyette Exp $ */
/*
* Copyright (c) 1982, 1986, 1993
@@ -159,13 +159,18 @@ bintime_sub(struct bintime *bt, const st
*/
/*
- * The magic numbers for converting to fraction:
- *
- * 1 ms = int(2^64 / 1000) = 18446744073709551
- * 1 us = int(2^64 / 1000000) = 18446744073709
- * 1 ns = int(2^64 / 1000000000) = 18446744073
+ * The magic numbers for converting ms/us/ns to fractions
*/
+/* 1ms = (2^64) / 1000 */
+#define BINTIME_SCALE_MS ((uint64_t)18446744073709551ULL)
+
+/* 1us = (2^64) / 1000000 */
+#define BINTIME_SCALE_US ((uint64_t)18446744073709ULL)
+
+/* 1ns = (2^64) / 1000000000 */
+#define BINTIME_SCALE_NS ((uint64_t)18446744073ULL)
+
static __inline void
bintime2timespec(const struct bintime *bt, struct timespec *ts)
{
@@ -180,7 +185,7 @@ timespec2bintime(const struct timespec *
{
bt->sec = ts->tv_sec;
- bt->frac = (uint64_t)ts->tv_nsec * (uint64_t)18446744073ULL;
+ bt->frac = (uint64_t)ts->tv_nsec * (uint64_t)BINTIME_SCALE_NS;
}
static __inline void
@@ -197,7 +202,7 @@ timeval2bintime(const struct timeval *tv
{
bt->sec = tv->tv_sec;
- bt->frac = (uint64_t)tv->tv_usec * (uint64_t)18446744073709ULL;
+ bt->frac = (uint64_t)tv->tv_usec * (uint64_t)BINTIME_SCALE_US;
}
static __inline struct bintime
@@ -206,7 +211,7 @@ ms2bintime(uint64_t ms)
struct bintime bt;
bt.sec = (time_t)(ms / 1000U);
- bt.frac = (uint64_t)(ms % 1000U) * (uint64_t)18446744073709551ULL;
+ bt.frac = (uint64_t)(ms % 1000U) * (uint64_t)BINTIME_SCALE_MS;
return bt;
}
@@ -217,7 +222,7 @@ us2bintime(uint64_t us)
struct bintime bt;
bt.sec = (time_t)(us / 1000000U);
- bt.frac = (uint64_t)(us % 1000000U) * (uint64_t)18446744073709ULL;
+ bt.frac = (uint64_t)(us % 1000000U) * (uint64_t)BINTIME_SCALE_US;
return bt;
}
@@ -228,7 +233,7 @@ ns2bintime(uint64_t ns)
struct bintime bt;
bt.sec = (time_t)(ns / 1000000000U);
- bt.frac = (uint64_t)(ns % 1000000000U) * (uint64_t)18446744073ULL;
+ bt.frac = (uint64_t)(ns % 1000000000U) * (uint64_t)BINTIME_SCALE_NS;
return bt;
}