sd_event_now systemd Developer Lennart Poettering lennart@poettering.net sd_event_now 3 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 *usec Description sd_event_now() returns the timestamp the most recent event loop iteration began. This timestamp is taken right after returning from the event sleep, and before dispatching any event sources. The event parameter takes the even 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 its equivalent CLOCK_REALTIME_ALARM), CLOCK_MONOTONIC or CLOCK_BOOTTIME (or its equivalent CLOCK_BOOTTIME_ALARM), see clock_gettime2 for more information on the various clocks. The retrieved timestamp is stored in the usec 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 non-zero in this case, while it is zero when the returned timestamp refers to the actual event loop iteration. Return Value If the first event loop iteration has not run yet sd_event_now() returns the requested timestamp in usec and returns a positive, non-zero return value. Otherwise, on success it will return the iteration's timestamp in usec and 0 as return value. On failure, the call returns a negative errno-style error code. Errors Returned errors may indicate the following problems: -EINVAL An invalid parameter was passed. -EOPNOTSUPP Unsupported clock type. -ECHILD The event loop object was created in a different process. See Also systemd1, sd-event3, sd_event_new3, sd_event_add_time3, clock_gettime2