RIOT/sys/include/timex.h
Oleg Hahm 67f82fcee0 timex: replace print by a to_str function
Instead of printing the timestamp, it's more flexible to convert it into
a string.
2014-10-28 14:25:34 +01:00

107 lines
2.5 KiB
C

/*
* Copyright (C) 2010 Kaspar Schleiser
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @defgroup sys_timex Timex
* @ingroup sys
* @brief Utility library for comparing and computing timestamps
*/
#ifndef __TIMEX_H
#define __TIMEX_H
#include <stdint.h>
#include <stdio.h>
#include <inttypes.h>
// mspgcc bug : PRIxxx macros not defined before mid-2011 versions
#ifndef PRIu32
#define PRIu32 "lu"
#endif
#define SEC_IN_USEC 1000000
#define TIMEX_MAX_STR_LEN (18)
typedef struct timex_t {
uint32_t seconds;
uint32_t microseconds;
} timex_t;
/* a+b */
timex_t timex_add(const timex_t a, const timex_t b);
/* a-b*/
timex_t timex_sub(const timex_t a, const timex_t b);
timex_t timex_set(uint32_t seconds, uint32_t microseconds);
/**
* @brief Compares two timex values.
*
* @return -1 when a is smaller, 0 if equal, 1 if a is bigger
*/
int timex_cmp(const timex_t a, const timex_t b);
/**
* @brief Corrects timex_t structure so that microseconds < 1000000
*/
static inline void timex_normalize(timex_t *time)
{
time->seconds += (time->microseconds / SEC_IN_USEC);
time->microseconds %= SEC_IN_USEC;
}
/**
* @brief Tests a timex_t for normalization
*
* @return true for a normalized timex_t, false otherwise
*/
static inline int timex_isnormalized(timex_t *time)
{
return (time->microseconds < SEC_IN_USEC);
}
/**
* @brief Denormalizes a timex_t to a uint64_t
*
* @return timex representation as uint64_t
*/
static inline uint64_t timex_uint64(const timex_t a)
{
return (uint64_t) a.seconds * SEC_IN_USEC + a.microseconds;
}
/**
* @brief Converts a uint64_t of microseconds to a timex_t
*
* @return a timex representation of an uint64 timestamp.
*/
static inline timex_t timex_from_uint64(const uint64_t timestamp)
{
return timex_set(timestamp / SEC_IN_USEC, timestamp % SEC_IN_USEC);
}
/**
* @brief Converts a timex_t to a struct
*/
static inline const char *timex_to_str(timex_t t, char *timestamp)
{
timex_normalize(&t);
/* 2^32 seconds have maximum 10 digits, microseconds are always < 1000000
* in a normalized timestamp, plus two chars for the point and terminator
* => 10 + 6 + 2 = 20 */
/* TODO: replace call to snprintf by something more efficient */
snprintf(timestamp, TIMEX_MAX_STR_LEN, "%" PRIu32 ".%06" PRIu32 " s",
t.seconds, t.microseconds);
return timestamp;
}
#endif /* __TIMEX_H */