sd_event_now — Retrieve current event loop iteration timestamp
#include <systemd/sd-event.h>
| int sd_event_now( | sd_event *event, | 
| clockid_t clock, | |
| uint64_t *ret ); | 
sd_event_now() returns the time when
    the most recent event loop iteration began. A timestamp
    is taken right after returning from the event sleep, and before
    dispatching any event sources. The event
    parameter specifies the event loop object to retrieve the timestamp
    from. The clock parameter specifies the clock to
    retrieve the timestamp for, and is one of
    CLOCK_REALTIME (or equivalently
    CLOCK_REALTIME_ALARM),
    CLOCK_MONOTONIC, or
    CLOCK_BOOTTIME (or equivalently
    CLOCK_BOOTTIME_ALARM), see
    clock_gettime(2)
    for more information on the various clocks. The retrieved
    timestamp is stored in the ret parameter,
    in μs since the clock's epoch. If this function is invoked before
    the first event loop iteration, the current time is returned, as
    reported by clock_gettime(). To distinguish
    this case from a regular invocation the return value will be
    positive, and zero when the returned timestamp refers to an actual
    event loop iteration.
If the first event loop iteration has not run yet sd_event_now() writes
    current time to ret and returns a positive return value.  Otherwise, it will
    write the requested timestamp to ret and return 0. On failure, the call returns a
    negative errno-style error code.
Functions described here are available as a shared
  library, which can be compiled against and linked to with the
  libsystemd pkg-config(1)
  file.
The code described here uses
  getenv(3),
  which is declared to be not multi-thread-safe. This means that the code calling the functions described
  here must not call
  setenv(3)
  from a parallel thread. It is recommended to only do calls to setenv()
  from an early phase of the program when no other threads have been started.