153a5a1b3Sopenharmony_ci#ifndef footimevalhfoo
253a5a1b3Sopenharmony_ci#define footimevalhfoo
353a5a1b3Sopenharmony_ci
453a5a1b3Sopenharmony_ci/***
553a5a1b3Sopenharmony_ci  This file is part of PulseAudio.
653a5a1b3Sopenharmony_ci
753a5a1b3Sopenharmony_ci  Copyright 2004-2006 Lennart Poettering
853a5a1b3Sopenharmony_ci  Copyright 2006 Pierre Ossman <ossman@cendio.se> for Cendio AB
953a5a1b3Sopenharmony_ci
1053a5a1b3Sopenharmony_ci  PulseAudio is free software; you can redistribute it and/or modify
1153a5a1b3Sopenharmony_ci  it under the terms of the GNU Lesser General Public License as
1253a5a1b3Sopenharmony_ci  published by the Free Software Foundation; either version 2.1 of the
1353a5a1b3Sopenharmony_ci  License, or (at your option) any later version.
1453a5a1b3Sopenharmony_ci
1553a5a1b3Sopenharmony_ci  PulseAudio is distributed in the hope that it will be useful, but
1653a5a1b3Sopenharmony_ci  WITHOUT ANY WARRANTY; without even the implied warranty of
1753a5a1b3Sopenharmony_ci  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
1853a5a1b3Sopenharmony_ci  Lesser General Public License for more details.
1953a5a1b3Sopenharmony_ci
2053a5a1b3Sopenharmony_ci  You should have received a copy of the GNU Lesser General Public
2153a5a1b3Sopenharmony_ci  License along with PulseAudio; if not, see <http://www.gnu.org/licenses/>.
2253a5a1b3Sopenharmony_ci***/
2353a5a1b3Sopenharmony_ci
2453a5a1b3Sopenharmony_ci#include <pulse/cdecl.h>
2553a5a1b3Sopenharmony_ci#include <pulse/gccmacro.h>
2653a5a1b3Sopenharmony_ci#include <pulse/sample.h>
2753a5a1b3Sopenharmony_ci#include <pulse/version.h>
2853a5a1b3Sopenharmony_ci
2953a5a1b3Sopenharmony_ci/** \file
3053a5a1b3Sopenharmony_ci * Utility functions for handling timeval calculations */
3153a5a1b3Sopenharmony_ci
3253a5a1b3Sopenharmony_ciPA_C_DECL_BEGIN
3353a5a1b3Sopenharmony_ci
3453a5a1b3Sopenharmony_ci/** The number of milliseconds in a second */
3553a5a1b3Sopenharmony_ci#define PA_MSEC_PER_SEC ((pa_usec_t) 1000ULL)
3653a5a1b3Sopenharmony_ci
3753a5a1b3Sopenharmony_ci/** The number of microseconds in a second */
3853a5a1b3Sopenharmony_ci#define PA_USEC_PER_SEC ((pa_usec_t) 1000000ULL)
3953a5a1b3Sopenharmony_ci
4053a5a1b3Sopenharmony_ci/** The number of nanoseconds in a second */
4153a5a1b3Sopenharmony_ci#define PA_NSEC_PER_SEC ((unsigned long long) 1000000000ULL)
4253a5a1b3Sopenharmony_ci
4353a5a1b3Sopenharmony_ci/** The number of microseconds in a millisecond */
4453a5a1b3Sopenharmony_ci#define PA_USEC_PER_MSEC ((pa_usec_t) 1000ULL)
4553a5a1b3Sopenharmony_ci
4653a5a1b3Sopenharmony_ci/** The number of nanoseconds in a millisecond */
4753a5a1b3Sopenharmony_ci#define PA_NSEC_PER_MSEC ((unsigned long long) 1000000ULL)
4853a5a1b3Sopenharmony_ci
4953a5a1b3Sopenharmony_ci/** The number of nanoseconds in a microsecond */
5053a5a1b3Sopenharmony_ci#define PA_NSEC_PER_USEC ((unsigned long long) 1000ULL)
5153a5a1b3Sopenharmony_ci
5253a5a1b3Sopenharmony_ci/** Invalid time in usec. \since 0.9.15 */
5353a5a1b3Sopenharmony_ci#define PA_USEC_INVALID ((pa_usec_t) -1)
5453a5a1b3Sopenharmony_ci
5553a5a1b3Sopenharmony_ci/** Biggest time in usec. \since 0.9.18 */
5653a5a1b3Sopenharmony_ci#define PA_USEC_MAX ((pa_usec_t) -2)
5753a5a1b3Sopenharmony_ci
5853a5a1b3Sopenharmony_cistruct timeval;
5953a5a1b3Sopenharmony_ci
6053a5a1b3Sopenharmony_ci/** Return the current wallclock timestamp, just like UNIX gettimeofday(). */
6153a5a1b3Sopenharmony_cistruct timeval *pa_gettimeofday(struct timeval *tv);
6253a5a1b3Sopenharmony_ci
6353a5a1b3Sopenharmony_ci/** Calculate the difference between the two specified timeval
6453a5a1b3Sopenharmony_ci * structs. */
6553a5a1b3Sopenharmony_cipa_usec_t pa_timeval_diff(const struct timeval *a, const struct timeval *b) PA_GCC_PURE;
6653a5a1b3Sopenharmony_ci
6753a5a1b3Sopenharmony_ci/** Compare the two timeval structs and return 0 when equal, negative when a < b, positive otherwise */
6853a5a1b3Sopenharmony_ciint pa_timeval_cmp(const struct timeval *a, const struct timeval *b) PA_GCC_PURE;
6953a5a1b3Sopenharmony_ci
7053a5a1b3Sopenharmony_ci/** Return the time difference between now and the specified timestamp */
7153a5a1b3Sopenharmony_cipa_usec_t pa_timeval_age(const struct timeval *tv);
7253a5a1b3Sopenharmony_ci
7353a5a1b3Sopenharmony_ci/** Add the specified time in microseconds to the specified timeval structure */
7453a5a1b3Sopenharmony_cistruct timeval* pa_timeval_add(struct timeval *tv, pa_usec_t v);
7553a5a1b3Sopenharmony_ci
7653a5a1b3Sopenharmony_ci/** Subtract the specified time in microseconds to the specified timeval structure. \since 0.9.11 */
7753a5a1b3Sopenharmony_cistruct timeval* pa_timeval_sub(struct timeval *tv, pa_usec_t v);
7853a5a1b3Sopenharmony_ci
7953a5a1b3Sopenharmony_ci/** Store the specified usec value in the timeval struct. \since 0.9.7 */
8053a5a1b3Sopenharmony_cistruct timeval* pa_timeval_store(struct timeval *tv, pa_usec_t v);
8153a5a1b3Sopenharmony_ci
8253a5a1b3Sopenharmony_ci/** Load the specified tv value and return it in usec. \since 0.9.7 */
8353a5a1b3Sopenharmony_cipa_usec_t pa_timeval_load(const struct timeval *tv);
8453a5a1b3Sopenharmony_ci
8553a5a1b3Sopenharmony_ciPA_C_DECL_END
8653a5a1b3Sopenharmony_ci
8753a5a1b3Sopenharmony_ci#endif
88