mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-21 06:01:43 +00:00
a/os: Rearrange time header to get the docs outside of the ifdefs.
Easier to read, easure to be sure we don't accidentally miss something for doxygen.
This commit is contained in:
parent
60f0d50c67
commit
fd25fc75bc
|
@ -1,4 +1,4 @@
|
||||||
// Copyright 2019-2020, Collabora, Ltd.
|
// Copyright 2019-2022, Collabora, Ltd.
|
||||||
// SPDX-License-Identifier: BSL-1.0
|
// SPDX-License-Identifier: BSL-1.0
|
||||||
/*!
|
/*!
|
||||||
* @file
|
* @file
|
||||||
|
@ -10,6 +10,7 @@
|
||||||
*
|
*
|
||||||
* @author Drew DeVault <sir@cmpwn.com>
|
* @author Drew DeVault <sir@cmpwn.com>
|
||||||
* @author Jakob Bornecrantz <jakob@collabora.com>
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
||||||
|
* @author Ryan Pavlik <ryan.pavlik@collabora.com>
|
||||||
*
|
*
|
||||||
* @ingroup aux_os
|
* @ingroup aux_os
|
||||||
*/
|
*/
|
||||||
|
@ -61,14 +62,106 @@ extern "C" {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* @brief Sleep the given number of nanoseconds.
|
* Return a monotonic clock in nanoseconds.
|
||||||
|
* @ingroup aux_os_time
|
||||||
|
*/
|
||||||
|
static inline uint64_t
|
||||||
|
os_monotonic_get_ns(void);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Sleep the given number of nanoseconds.
|
||||||
*
|
*
|
||||||
* Note that on some platforms, this may be somewhat less accurate than you might want.
|
* Note that on some platforms, this may be somewhat less accurate than you might want.
|
||||||
* On all platforms, the system scheduler has the final say.
|
* On all platforms, the system scheduler has the final say.
|
||||||
*
|
*
|
||||||
|
* @see os_precise_sleeper
|
||||||
|
*
|
||||||
* @ingroup aux_os_time
|
* @ingroup aux_os_time
|
||||||
*/
|
*/
|
||||||
static inline void
|
static inline void
|
||||||
|
os_nanosleep(int64_t nsec);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* A structure for storing state as needed for more precise sleeping, mostly for compositor use.
|
||||||
|
* @ingroup aux_os_time
|
||||||
|
*/
|
||||||
|
struct os_precise_sleeper;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Initialize members of @ref os_precise_sleeper.
|
||||||
|
* @public @memberof os_precise_sleeper
|
||||||
|
*/
|
||||||
|
static inline void
|
||||||
|
os_precise_sleeper_init(struct os_precise_sleeper *ops);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* De-initialize members of @ref os_precise_sleeper, and free resources, without actually freeing the given
|
||||||
|
* pointer.
|
||||||
|
* @public @memberof os_precise_sleeper
|
||||||
|
*/
|
||||||
|
static inline void
|
||||||
|
os_precise_sleeper_deinit(struct os_precise_sleeper *ops);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Sleep the given number of nanoseconds, trying harder to be precise.
|
||||||
|
*
|
||||||
|
* On some platforms, there is no way to improve sleep precision easily with some OS-specific state, so we forward
|
||||||
|
* to os_nanosleep().
|
||||||
|
*
|
||||||
|
* Note that on all platforms, the system scheduler has the final say.
|
||||||
|
*
|
||||||
|
* @public @memberof os_precise_sleeper
|
||||||
|
*/
|
||||||
|
static inline void
|
||||||
|
os_precise_sleeper_nanosleep(struct os_precise_sleeper *ops, int32_t nsec);
|
||||||
|
|
||||||
|
#if defined(XRT_HAVE_TIMESPEC) || defined(XRT_DOXYGEN)
|
||||||
|
/*!
|
||||||
|
* Convert a timespec struct to nanoseconds.
|
||||||
|
*
|
||||||
|
* Note that this only does the value combining, no adjustment for epochs is performed.
|
||||||
|
*
|
||||||
|
* @ingroup aux_os_time_extra
|
||||||
|
*/
|
||||||
|
static inline uint64_t
|
||||||
|
os_timespec_to_ns(const struct timespec *spec);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Convert an nanosecond integer to a timespec struct.
|
||||||
|
*
|
||||||
|
* Note that this only does the value splitting, no adjustment for epochs is performed.
|
||||||
|
* @ingroup aux_os_time_extra
|
||||||
|
*/
|
||||||
|
static inline void
|
||||||
|
os_ns_to_timespec(uint64_t ns, struct timespec *spec);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(XRT_HAVE_TIMEVAL) || defined(XRT_DOXYGEN)
|
||||||
|
/*!
|
||||||
|
* Convert a timeval struct to nanoseconds.
|
||||||
|
* @ingroup aux_os_time_extra
|
||||||
|
*/
|
||||||
|
static inline uint64_t
|
||||||
|
os_timeval_to_ns(struct timeval *val);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(XRT_OS_LINUX) || defined(XRT_DOXYGEN)
|
||||||
|
/*!
|
||||||
|
* Return a realtime clock in nanoseconds (Linux-only)
|
||||||
|
*
|
||||||
|
* @ingroup aux_os_time_extra
|
||||||
|
*/
|
||||||
|
static inline uint64_t
|
||||||
|
os_realtime_get_ns(void);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
* implementations follow
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
static inline void
|
||||||
os_nanosleep(int64_t nsec)
|
os_nanosleep(int64_t nsec)
|
||||||
{
|
{
|
||||||
#if defined(XRT_OS_LINUX)
|
#if defined(XRT_OS_LINUX)
|
||||||
|
@ -81,10 +174,6 @@ os_nanosleep(int64_t nsec)
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
|
||||||
* @brief A structure for storing state as needed for more precise sleeping, mostly for compositor use.
|
|
||||||
* @ingroup aux_os_time
|
|
||||||
*/
|
|
||||||
struct os_precise_sleeper
|
struct os_precise_sleeper
|
||||||
{
|
{
|
||||||
#if defined(XRT_OS_WINDOWS)
|
#if defined(XRT_OS_WINDOWS)
|
||||||
|
@ -94,10 +183,6 @@ struct os_precise_sleeper
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
/*!
|
|
||||||
* @brief Initialize members of @ref os_precise_sleeper.
|
|
||||||
* @public @memberof os_precise_sleeper
|
|
||||||
*/
|
|
||||||
static inline void
|
static inline void
|
||||||
os_precise_sleeper_init(struct os_precise_sleeper *ops)
|
os_precise_sleeper_init(struct os_precise_sleeper *ops)
|
||||||
{
|
{
|
||||||
|
@ -106,11 +191,6 @@ os_precise_sleeper_init(struct os_precise_sleeper *ops)
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
|
||||||
* @brief De-initialize members of @ref os_precise_sleeper, and free resources, without actually freeing the given
|
|
||||||
* pointer.
|
|
||||||
* @public @memberof os_precise_sleeper
|
|
||||||
*/
|
|
||||||
static inline void
|
static inline void
|
||||||
os_precise_sleeper_deinit(struct os_precise_sleeper *ops)
|
os_precise_sleeper_deinit(struct os_precise_sleeper *ops)
|
||||||
{
|
{
|
||||||
|
@ -122,16 +202,6 @@ os_precise_sleeper_deinit(struct os_precise_sleeper *ops)
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
|
||||||
* @brief Sleep the given number of nanoseconds, trying harder to be precise.
|
|
||||||
*
|
|
||||||
* On some platforms, there is no way to improve sleep precision easily with some OS-specific state, so we forward
|
|
||||||
* to os_nanosleep().
|
|
||||||
*
|
|
||||||
* Note that on all platforms, the system scheduler has the final say.
|
|
||||||
*
|
|
||||||
* @public @memberof os_precise_sleeper
|
|
||||||
*/
|
|
||||||
static inline void
|
static inline void
|
||||||
os_precise_sleeper_nanosleep(struct os_precise_sleeper *ops, int32_t nsec)
|
os_precise_sleeper_nanosleep(struct os_precise_sleeper *ops, int32_t nsec)
|
||||||
{
|
{
|
||||||
|
@ -152,13 +222,6 @@ os_precise_sleeper_nanosleep(struct os_precise_sleeper *ops, int32_t nsec)
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(XRT_HAVE_TIMESPEC)
|
#if defined(XRT_HAVE_TIMESPEC)
|
||||||
/*!
|
|
||||||
* @brief Convert a timespec struct to nanoseconds.
|
|
||||||
*
|
|
||||||
* Note that this does the value combining, no adjustment for epochs is performed.
|
|
||||||
*
|
|
||||||
* @ingroup aux_os_time_extra
|
|
||||||
*/
|
|
||||||
static inline uint64_t
|
static inline uint64_t
|
||||||
os_timespec_to_ns(const struct timespec *spec)
|
os_timespec_to_ns(const struct timespec *spec)
|
||||||
{
|
{
|
||||||
|
@ -168,12 +231,6 @@ os_timespec_to_ns(const struct timespec *spec)
|
||||||
return ns;
|
return ns;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
|
||||||
* @brief Convert an nanosecond integer to a timespec struct.
|
|
||||||
*
|
|
||||||
* Note that this does the value splitting, no adjustment for epochs is performed.
|
|
||||||
* @ingroup aux_os_time_extra
|
|
||||||
*/
|
|
||||||
static inline void
|
static inline void
|
||||||
os_ns_to_timespec(uint64_t ns, struct timespec *spec)
|
os_ns_to_timespec(uint64_t ns, struct timespec *spec)
|
||||||
{
|
{
|
||||||
|
@ -187,10 +244,6 @@ os_ns_to_timespec(uint64_t ns, struct timespec *spec)
|
||||||
|
|
||||||
#define OS_NS_PER_USEC (1000)
|
#define OS_NS_PER_USEC (1000)
|
||||||
|
|
||||||
/*!
|
|
||||||
* @brief Convert a timeval struct to nanoseconds.
|
|
||||||
* @ingroup aux_os_time_extra
|
|
||||||
*/
|
|
||||||
static inline uint64_t
|
static inline uint64_t
|
||||||
os_timeval_to_ns(struct timeval *val)
|
os_timeval_to_ns(struct timeval *val)
|
||||||
{
|
{
|
||||||
|
@ -199,12 +252,9 @@ os_timeval_to_ns(struct timeval *val)
|
||||||
ns += (uint64_t)val->tv_usec * OS_NS_PER_USEC;
|
ns += (uint64_t)val->tv_usec * OS_NS_PER_USEC;
|
||||||
return ns;
|
return ns;
|
||||||
}
|
}
|
||||||
#endif // XRT_HAVE_TIMEVAL
|
#endif // defined(XRT_HAVE_TIMEVAL) && defined(XRT_OS_LINUX)
|
||||||
|
|
||||||
|
|
||||||
/*!
|
|
||||||
* @brief Return a monotonic clock in nanoseconds.
|
|
||||||
* @ingroup aux_os_time
|
|
||||||
*/
|
|
||||||
static inline uint64_t
|
static inline uint64_t
|
||||||
os_monotonic_get_ns(void)
|
os_monotonic_get_ns(void)
|
||||||
{
|
{
|
||||||
|
@ -233,10 +283,6 @@ os_monotonic_get_ns(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef XRT_OS_LINUX
|
#ifdef XRT_OS_LINUX
|
||||||
/*!
|
|
||||||
* @brief Return a realtime clock in nanoseconds.
|
|
||||||
* @ingroup aux_os_time
|
|
||||||
*/
|
|
||||||
static inline uint64_t
|
static inline uint64_t
|
||||||
os_realtime_get_ns(void)
|
os_realtime_get_ns(void)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue