From: Lennart Poettering Date: Mon, 11 Nov 2013 02:03:17 +0000 (+0100) Subject: timer: consider (usec_t) -1 an invalid timestamp X-Git-Tag: v209~1473 X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=966204e010ed432a1d7a0481d41a326d8ec7b0c8 timer: consider (usec_t) -1 an invalid timestamp --- diff --git a/TODO b/TODO index fe5d2f588..efc7e2a1e 100644 --- a/TODO +++ b/TODO @@ -43,6 +43,8 @@ CGroup Rework Completion: Features: +* be more careful what we export on the bus as (usec_t) 0 and (usec_t) -1 + * check :no-sender logic after PID 1 conversion * increase journal files by a few MB each time, instead of piecemeal diff --git a/src/shared/time-util.c b/src/shared/time-util.c index b29d8c6e4..55428c4ce 100644 --- a/src/shared/time-util.c +++ b/src/shared/time-util.c @@ -158,7 +158,7 @@ char *format_timestamp(char *buf, size_t l, usec_t t) { assert(buf); assert(l > 0); - if (t <= 0) + if (t <= 0 || t == (usec_t) -1) return NULL; sec = (time_t) (t / USEC_PER_SEC); @@ -176,7 +176,7 @@ char *format_timestamp_us(char *buf, size_t l, usec_t t) { assert(buf); assert(l > 0); - if (t <= 0) + if (t <= 0 || t == (usec_t) -1) return NULL; sec = (time_t) (t / USEC_PER_SEC); diff --git a/src/shared/time-util.h b/src/shared/time-util.h index a51317dbd..0a3a98b18 100644 --- a/src/shared/time-util.h +++ b/src/shared/time-util.h @@ -64,7 +64,10 @@ dual_timestamp* dual_timestamp_get(dual_timestamp *ts); dual_timestamp* dual_timestamp_from_realtime(dual_timestamp *ts, usec_t u); dual_timestamp* dual_timestamp_from_monotonic(dual_timestamp *ts, usec_t u); -#define dual_timestamp_is_set(ts) ((ts)->realtime > 0) +static inline bool dual_timestamp_is_set(dual_timestamp *ts) { + return ((ts->realtime > 0 && ts->realtime != (usec_t) -1) || + (ts->monotonic > 0 && ts->monotonic != (usec_t) -1)); +} usec_t timespec_load(const struct timespec *ts) _pure_; struct timespec *timespec_store(struct timespec *ts, usec_t u);