123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- /*
- * Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
- *
- * SPDX-License-Identifier: BSD-2-Clause
- */
- #pragma once
- #include <Kernel/API/POSIX/sys/time.h>
- #include <sys/cdefs.h>
- #include <time.h>
- __BEGIN_DECLS
- struct timezone {
- int tz_minuteswest;
- int tz_dsttime;
- };
- int adjtime(const struct timeval* delta, struct timeval* old_delta);
- int gettimeofday(struct timeval* __restrict__, void* __restrict__);
- int settimeofday(struct timeval* __restrict__, void* __restrict__);
- int utimes(char const* pathname, const struct timeval[2]);
- 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)->tv_nsec cmp(us)->tv_nsec) : ((ts)->tv_sec cmp(us)->tv_sec))
- __END_DECLS
|