summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNico Weber <thakis@chromium.org>2020-06-21 13:42:21 -0400
committerAndreas Kling <kling@serenityos.org>2020-06-22 16:00:20 +0200
commit29f509a2a09028950824742f7d23daa3d409ada3 (patch)
tree180264bc269f7b593ad31f0389242fea704dc5df
parent9256757b591c36eafd35bddb75d28fccd138e0f7 (diff)
downloadserenity-29f509a2a09028950824742f7d23daa3d409ada3.zip
LibC: Add timespec functions to sys/time.h
And rewrite the timeval functions as inline functions. Also add the non-standard but fairly common and useful TIMEVAL_TO_TIMESPEC / TIMESPEC_TO_TIMEVAL functions.
-rw-r--r--Libraries/LibC/sys/time.h110
1 files changed, 87 insertions, 23 deletions
diff --git a/Libraries/LibC/sys/time.h b/Libraries/LibC/sys/time.h
index fa84efb2b2..f660c2b24a 100644
--- a/Libraries/LibC/sys/time.h
+++ b/Libraries/LibC/sys/time.h
@@ -28,32 +28,10 @@
#include <sys/cdefs.h>
#include <sys/types.h>
+#include <time.h>
__BEGIN_DECLS
-#define timerclear(tvp) (tvp)->tv_sec = (tvp)->tv_usec = 0
-#define timerisset(tvp) ((tvp)->tv_sec || (tvp)->tv_usec)
-#define timercmp(tvp, uvp, cmp) \
- (((tvp)->tv_sec == (uvp)->tv_sec) ? ((tvp)->tv_usec cmp(uvp)->tv_usec) : ((tvp)->tv_sec cmp(uvp)->tv_sec))
-#define timeradd(a, b, out) \
- do { \
- (out)->tv_sec = (a)->tv_sec + (b)->tv_sec; \
- (out)->tv_usec = (a)->tv_usec + (b)->tv_usec; \
- if ((out)->tv_usec >= 1000000) { \
- (out)->tv_sec++; \
- (out)->tv_usec -= 1000000; \
- } \
- } while (0)
-#define timersub(a, b, out) \
- do { \
- (out)->tv_sec = (a)->tv_sec - (b)->tv_sec; \
- (out)->tv_usec = (a)->tv_usec - (b)->tv_usec; \
- if ((out)->tv_usec < 0) { \
- (out)->tv_sec--; \
- (out)->tv_usec += 1000000; \
- } \
- } while (0)
-
struct timeval {
time_t tv_sec;
suseconds_t tv_usec;
@@ -66,4 +44,90 @@ struct timezone {
int gettimeofday(struct timeval* __restrict__, void* __restrict__) __attribute__((nonnull(1)));
+static inline void timeradd(const struct timeval* a, const struct timeval* b, struct timeval* out)
+{
+ out->tv_sec = a->tv_sec + b->tv_sec;
+ out->tv_usec = a->tv_usec + b->tv_usec;
+ if (out->tv_usec >= 1000 * 1000) {
+ out->tv_sec++;
+ out->tv_usec -= 1000 * 1000;
+ }
+}
+
+static inline void timersub(const struct timeval* a, const struct timeval* b, struct timeval* out)
+{
+ out->tv_sec = a->tv_sec - b->tv_sec;
+ out->tv_usec = a->tv_usec - b->tv_usec;
+ if (out->tv_usec < 0) {
+ out->tv_sec--;
+ out->tv_usec += 1000 * 1000;
+ }
+}
+
+static inline void timerclear(struct timeval* out)
+{
+ out->tv_sec = out->tv_usec = 0;
+}
+
+static inline int timerisset(const struct timeval* tv)
+{
+ return tv->tv_sec || tv->tv_usec;
+}
+
+#define timeradd timeradd
+#define timersub timersub
+#define timerclear timerclear
+#define timerisset timerisset
+#define timercmp(tvp, uvp, cmp) \
+ (((tvp)->tv_sec == (uvp)->tv_sec) ? ((tvp)->tv_usec cmp(uvp)->tv_usec) : ((tvp)->tv_sec cmp(uvp)->tv_sec))
+
+static inline void timespecadd(const struct timespec* a, const struct timespec* b, struct timespec* out)
+{
+ out->tv_sec = a->tv_sec + b->tv_sec;
+ out->tv_nsec = a->tv_nsec + b->tv_nsec;
+ if (out->tv_nsec >= 1000 * 1000 * 1000) {
+ out->tv_sec++;
+ out->tv_nsec -= 1000 * 1000 * 1000;
+ }
+}
+
+static inline void timespecsub(const struct timespec* a, const struct timespec* b, struct timespec* out)
+{
+ out->tv_sec = a->tv_sec - b->tv_sec;
+ out->tv_nsec = a->tv_nsec - b->tv_nsec;
+ if (out->tv_nsec < 0) {
+ out->tv_sec--;
+ out->tv_nsec += 1000 * 1000 * 1000;
+ }
+}
+
+static inline void timespecclear(struct timespec* out)
+{
+ out->tv_sec = out->tv_nsec = 0;
+}
+
+static inline int timespecisset(const struct timespec* ts)
+{
+ return ts->tv_sec || ts->tv_nsec;
+}
+
+static inline void TIMEVAL_TO_TIMESPEC(const struct timeval* tv, struct timespec* ts)
+{
+ ts->tv_sec = tv->tv_sec;
+ ts->tv_nsec = tv->tv_usec * 1000;
+}
+
+static inline void TIMESPEC_TO_TIMEVAL(struct timeval* tv, const struct timespec* ts)
+{
+ tv->tv_sec = ts->tv_sec;
+ tv->tv_usec = ts->tv_nsec / 1000;
+}
+
+#define timespecadd timespecadd
+#define timespecsub timespecsub
+#define timespecclear timespecclear
+#define timespecisset timespecisset
+#define timespeccmp(ts, us, cmp) \
+ (((ts)->tv_sec == (us)->tv_sec) ? ((ts)->vf_nsec cmp(us)->tv_nsec) : ((ts)->tv_sec cmp(us)->tv_sec))
+
__END_DECLS