1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-15 19:32:46 +01:00
RIOT/sys/include/timex.h

208 lines
4.6 KiB
C
Raw Normal View History

/*
2014-10-19 20:44:10 +02:00
* Copyright (C) 2010 Kaspar Schleiser <kaspar@schleiser.de>
* Copyright (C) 2014 Oliver Hahm <oliver.hahm@inria.fr>
*
* 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
* @brief Timestamp representation, computation, and conversion
* @ingroup sys
*
* @{
* @file
* @brief Utility library for comparing and computing timestamps
*/
2016-10-26 21:53:58 +02:00
#ifndef TIMEX_H
#define TIMEX_H
2010-12-01 17:13:37 +01:00
#include <stdint.h>
#include <inttypes.h>
2014-10-10 11:51:11 +02:00
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief The number of microseconds per second
*/
#define US_PER_SEC (1000000LU)
2016-12-14 16:21:56 +01:00
/**
* @brief The number of seconds per minute
*/
#define SEC_PER_MIN (60LU)
2016-12-14 16:21:56 +01:00
/**
* @brief The number of centiseconds per second
*/
#define CS_PER_SEC (100LU)
2016-12-14 16:21:56 +01:00
/**
* @brief The number of milliseconds per second
*/
#define MS_PER_SEC (1000LU)
/**
* @brief The number of microseconds per millisecond
*/
#define US_PER_MS (1000LU)
/**
* @brief The number of microseconds per centisecond
*/
#define US_PER_CS (10000U)
2021-07-21 12:09:49 +02:00
/**
* @brief The number of milliseconds per centisecond
*/
#define MS_PER_CS (10U)
2015-10-15 17:20:09 +02:00
/**
* @brief The number of nanoseconds per microsecond
*/
#define NS_PER_US (1000LU)
2015-10-15 17:20:09 +02:00
2020-03-11 12:40:12 +01:00
/**
* @brief The number of nanoseconds per second
*/
#define NS_PER_SEC (1000000000LLU)
2020-03-11 12:40:12 +01:00
/**
* @brief The maximum length of the string representation of a timex timestamp
*/
#define TIMEX_MAX_STR_LEN (20)
/* 20 =
* + 10 byte: 2^32-1 for seconds
* + 1 byte: decimal point
* + 6 byte: microseconds (normalized)
* + 2 byte: " s" (unit)
* + 1 byte: '\0'
*/
/**
* @brief A timex timestamp
*
* @note If a timestamp is not normalized, the number of microseconds might be
* > 1000000
*/
typedef struct {
uint32_t seconds; /**< number of seconds */
uint32_t microseconds; /**< number of microseconds */
2010-12-01 17:13:37 +01:00
} timex_t;
/**
* @brief Adds two timestamps
*
* @param[in] a First summand
* @param[in] b Second summand
*
* @return The sum of the two timestamps
*/
timex_t timex_add(const timex_t a, const timex_t b);
2010-12-01 17:13:37 +01:00
/**
* @brief Subtracts two timestamps
*
* @param[in] a The minuend
* @param[in] b The subtrahend
*
* @return The difference a - b
*/
2010-12-01 17:23:28 +01:00
timex_t timex_sub(const timex_t a, const timex_t b);
/**
* @brief Initializes a timex timestamp
*
* @param[in] seconds Number of seconds to set
* @param[in] microseconds Number of microseconds to set
*
* @return The initialized timex timestamp
*/
2011-12-01 13:01:36 +01:00
timex_t timex_set(uint32_t seconds, uint32_t microseconds);
2010-12-01 17:23:28 +01:00
/**
* @brief Compares two timex timestamps
*
* @param[in] a The first timestamp to compare to
* @param[in] b The second timestamp to compare with
*
* @return -1 when a is smaller
* @return 0 if equal
* @return 1 if a is bigger
*/
int timex_cmp(const timex_t a, const timex_t b);
/**
* @brief Corrects timex structure so that microseconds < 1000000
*
* @param[in, out] time Pointer to the timestamp to normalize
*/
static inline void timex_normalize(timex_t *time)
{
time->seconds += (time->microseconds / US_PER_SEC);
time->microseconds %= US_PER_SEC;
}
2013-12-25 18:13:55 +01:00
/**
* @brief Tests a timex timestamp for normalization
*
* @param[in] time Pointer to the timestamp to check
2013-12-25 18:13:55 +01:00
*
* @return true for a normalized timex_t
* @return false otherwise
2013-12-25 18:13:55 +01:00
*/
static inline int timex_isnormalized(const timex_t *time)
{
return (time->microseconds < US_PER_SEC);
}
2013-12-25 18:13:55 +01:00
2013-12-25 17:01:55 +01:00
/**
* @brief Converts a timex timestamp to a 64 bit value
*
* @param[in] a The timestamp to convert
2013-12-25 17:01:55 +01:00
*
* @return timex representation as uint64_t
*/
static inline uint64_t timex_uint64(const timex_t a)
{
return (uint64_t) a.seconds * US_PER_SEC + a.microseconds;
}
2013-12-25 17:01:55 +01:00
/**
* @brief Converts a 64 bit value of microseconds to a timex timestamp
*
* @param[in] timestamp The timestamp to convert.
*
* @return a timex representation of an uint64 timestamp.
*/
static inline timex_t timex_from_uint64(const uint64_t timestamp)
{
return timex_set(timestamp / US_PER_SEC, timestamp % US_PER_SEC);
}
/**
* @brief Converts a timex timestamp to a string
*
* @pre memory at timestamp >= TIMEX_MAX_STR_LEN
*
* @param[in] t The timestamp to convert
* @param[out] timestamp The output char buffer for the converted timestamp
*
* @note The timestamp will be normalized
*
* @return A pointer to the string representation of the timestamp
*/
const char *timex_to_str(timex_t t, char *timestamp);
2014-10-10 11:51:11 +02:00
#ifdef __cplusplus
}
#endif
/** @} */
2016-10-26 21:53:58 +02:00
#endif /* TIMEX_H */