@@ -529,6 +529,7 @@ global:
l_timeout_create_ms;
l_timeout_modify;
l_timeout_modify_ms;
+ l_timeout_remaining;
l_timeout_remove;
l_timeout_set_callback;
/* tls */
@@ -23,6 +23,7 @@
#include "timeout.h"
#include "main-private.h"
#include "private.h"
+#include "time-private.h"
/**
* SECTION:timeout
@@ -298,3 +299,31 @@ LIB_EXPORT void l_timeout_set_callback(struct l_timeout *timeout,
timeout->user_data = user_data;
timeout->destroy = destroy;
}
+
+/**
+ * l_timeout_get_remaining:
+ *
+ * Get the remaining time for a timeout in microseconds
+ *
+ * @timeout: timeout object
+ * @remaining: microseconds remaining on timer
+ *
+ * Returns: True if successfully got remaining time
+ * False if failure to get remaining time
+ **/
+LIB_EXPORT bool l_timeout_remaining(struct l_timeout *timeout,
+ uint64_t *remaining)
+{
+ struct itimerspec current;
+
+ if (unlikely(!timeout))
+ return false;
+
+ if (timerfd_gettime(timeout->fd, ¤t) < 0)
+ return false;
+
+ if (remaining)
+ *remaining = _time_from_timespec(¤t.it_value);
+
+ return true;
+}
@@ -34,7 +34,8 @@ void l_timeout_remove(struct l_timeout *timeout);
void l_timeout_set_callback(struct l_timeout *timeout,
l_timeout_notify_cb_t callback, void *user_data,
l_timeout_destroy_cb_t destroy);
-
+bool l_timeout_remaining(struct l_timeout *timeout,
+ uint64_t *remaining);
#ifdef __cplusplus
}
#endif
From: James Prestwood <prestwoj@gmail.com> Gets the remaining microseconds left on a timer. Microseconds were chosen in order to be easily compatible with l_time APIs. --- ell/ell.sym | 1 + ell/timeout.c | 29 +++++++++++++++++++++++++++++ ell/timeout.h | 3 ++- 3 files changed, 32 insertions(+), 1 deletion(-)