X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Fbasic%2Ftime-util.c;h=6c8973ce31e5fa63669a88cfb53a533b489d695a;hp=ecca227c74bb718cb2b1fc872200ad23b1b7b626;hb=903ff64069e63a831ad1036182d4e56421e0dc86;hpb=1cfc78c91965df340cdde100ad6cb3ed50b28927 diff --git a/src/basic/time-util.c b/src/basic/time-util.c index ecca227c7..6c8973ce3 100644 --- a/src/basic/time-util.c +++ b/src/basic/time-util.c @@ -67,6 +67,8 @@ dual_timestamp* dual_timestamp_from_realtime(dual_timestamp *ts, usec_t u) { return ts; } +/// UNNEEDED by elogind +#if 0 dual_timestamp* dual_timestamp_from_monotonic(dual_timestamp *ts, usec_t u) { int64_t delta; assert(ts); @@ -87,6 +89,33 @@ dual_timestamp* dual_timestamp_from_monotonic(dual_timestamp *ts, usec_t u) { return ts; } +#endif // 0 + +dual_timestamp* dual_timestamp_from_boottime_or_monotonic(dual_timestamp *ts, usec_t u) { + int64_t delta; + + if (u == USEC_INFINITY) { + ts->realtime = ts->monotonic = USEC_INFINITY; + return ts; + } + ts->realtime = now(CLOCK_REALTIME); + ts->monotonic = now(CLOCK_MONOTONIC); + + delta = (int64_t) now(clock_boottime_or_monotonic()) - (int64_t) u; + + if ((int64_t) ts->realtime > delta) + ts->realtime -= delta; + else + ts->realtime = 0; + + if ((int64_t) ts->monotonic > delta) + ts->monotonic -= delta; + else + ts->monotonic = 0; + + return ts; +} + usec_t timespec_load(const struct timespec *ts) { assert(ts); @@ -209,9 +238,12 @@ char *format_timestamp_us(char *buf, size_t l, usec_t t) { return format_timestamp_internal_us(buf, l, t, false); } +/// UNNEEDED by elogind +#if 0 char *format_timestamp_us_utc(char *buf, size_t l, usec_t t) { return format_timestamp_internal_us(buf, l, t, true); } +#endif // 0 char *format_timestamp_relative(char *buf, size_t l, usec_t t) { const char *s; @@ -386,6 +418,8 @@ char *format_timespan(char *buf, size_t l, usec_t t, usec_t accuracy) { return buf; } +/// UNNEEDED by elogind +#if 0 void dual_timestamp_serialize(FILE *f, const char *name, dual_timestamp *t) { assert(f); @@ -418,8 +452,6 @@ int dual_timestamp_deserialize(const char *value, dual_timestamp *t) { return 0; } -/// UNNEEDED by elogind -#if 0 int parse_timestamp(const char *t, usec_t *usec) { static const struct { const char *name;