X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fbasic%2Ftime-util.h;h=6feb75cc7acfb2483ddcc37d5dd1c9f9424b8da4;hb=71227310a62a616a0d9356fe0506e01f47c76eb3;hp=61f263baeaaeb666c1002e702766df7517335177;hpb=5986f533c144a8142b5e047223e7a6f85c20b98b;p=elogind.git diff --git a/src/basic/time-util.h b/src/basic/time-util.h index 61f263bae..6feb75cc7 100644 --- a/src/basic/time-util.h +++ b/src/basic/time-util.h @@ -1,5 +1,3 @@ -/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/ - #pragma once /*** @@ -96,8 +94,6 @@ struct timespec *timespec_store(struct timespec *ts, usec_t u); usec_t timeval_load(const struct timeval *tv) _pure_; struct timeval *timeval_store(struct timeval *tv, usec_t u); -nsec_t timespec_load_nsec(const struct timespec *ts) _pure_; - char *format_timestamp(char *buf, size_t l, usec_t t); #if 0 /// UNNEEDED by elogind char *format_timestamp_utc(char *buf, size_t l, usec_t t); @@ -112,7 +108,10 @@ char *format_timespan(char *buf, size_t l, usec_t t, usec_t accuracy); #if 0 /// UNNEEDED by elogind void dual_timestamp_serialize(FILE *f, const char *name, dual_timestamp *t); int dual_timestamp_deserialize(const char *value, dual_timestamp *t); +#endif // 0 +int timestamp_deserialize(const char *value, usec_t *timestamp); +#if 0 /// UNNEEDED by elogind int parse_timestamp(const char *t, usec_t *usec); #endif // 0 @@ -126,6 +125,9 @@ bool ntp_synced(void); int get_timezones(char ***l); bool timezone_is_valid(const char *name); +#endif // 0 +bool clock_boottime_supported(void); +#if 0 /// UNNEEDED by elogind clockid_t clock_boottime_or_monotonic(void); #endif // 0 @@ -143,3 +145,29 @@ struct tm *localtime_or_gmtime_r(const time_t *t, struct tm *tm, bool utc); #if 0 /// UNNEEDED by elogind unsigned long usec_to_jiffies(usec_t usec); #endif // 0 + +static inline usec_t usec_add(usec_t a, usec_t b) { + usec_t c; + + /* Adds two time values, and makes sure USEC_INFINITY as input results as USEC_INFINITY in output, and doesn't + * overflow. */ + + c = a + b; + if (c < a || c < b) /* overflow check */ + return USEC_INFINITY; + + return c; +} + +static inline usec_t usec_sub(usec_t timestamp, int64_t delta) { + if (delta < 0) + return usec_add(timestamp, (usec_t) (-delta)); + + if (timestamp == USEC_INFINITY) /* Make sure infinity doesn't degrade */ + return USEC_INFINITY; + + if (timestamp < (usec_t) delta) + return 0; + + return timestamp - delta; +}