Merged revisions 205215 via svnmerge from
[asterisk/asterisk.git] / include / asterisk / time.h
old mode 100755 (executable)
new mode 100644 (file)
index dbdfb44..fa8006e
@@ -1,18 +1,31 @@
 /*
- * Asterisk -- A telephony toolkit for Linux.
+ * Asterisk -- An open source telephony toolkit.
  *
- * Time-related functions and macros
+ * Copyright (C) 1999 - 2005, Digium, Inc.
  *
- * Copyright (C) 2004 - 2005, Digium, Inc.
+ * Mark Spencer <markster@digium.com>
+ *
+ * See http://www.asterisk.org for more information about
+ * the Asterisk project. Please do not directly contact
+ * any of the maintainers of this project for assistance;
+ * the project provides a web site, mailing lists and IRC
+ * channels for your use.
  *
  * This program is free software, distributed under the terms of
- * the GNU General Public License
+ * the GNU General Public License Version 2. See the LICENSE file
+ * at the top of the source tree.
+ */
+
+/*! \file
+ * \brief Time-related functions and macros
  */
 
 #ifndef _ASTERISK_TIME_H
 #define _ASTERISK_TIME_H
 
+#ifdef HAVE_SYS_TIME_H
 #include <sys/time.h>
+#endif
 
 #include "asterisk/inline_api.h"
 
@@ -24,9 +37,42 @@ typedef typeof(tv.tv_sec) ast_time_t;
 typedef typeof(tv.tv_usec) ast_suseconds_t;
 
 /*!
+ * \brief Computes the difference (in seconds) between two \c struct \c timeval instances.
+ * \param end the end of the time period
+ * \param start the beginning of the time period
+ * \return the difference in seconds
+ */
+AST_INLINE_API(
+int ast_tvdiff_sec(struct timeval end, struct timeval start),
+{
+       int result = end.tv_sec - start.tv_sec;
+       if (result > 0 && end.tv_usec < start.tv_usec)
+               result--;
+       else if (result < 0 && end.tv_usec > start.tv_usec)
+               result++;
+
+       return result;
+}
+)
+
+/*!
+ * \brief Computes the difference (in microseconds) between two \c struct \c timeval instances.
+ * \param end the end of the time period
+ * \param start the beginning of the time period
+ * \return the difference in microseconds
+ */
+AST_INLINE_API(
+int64_t ast_tvdiff_us(struct timeval end, struct timeval start),
+{
+       return (end.tv_sec - start.tv_sec) * (int64_t) 1000000 +
+               end.tv_usec - start.tv_usec;
+}
+)
+
+/*!
  * \brief Computes the difference (in milliseconds) between two \c struct \c timeval instances.
- * \param end the beginning of the time period
- * \param start the end of the time period
+ * \param end end of the time period
+ * \param start beginning of the time period
  * \return the difference in milliseconds
  */
 AST_INLINE_API(
@@ -107,15 +153,6 @@ struct timeval ast_tvsub(struct timeval a, struct timeval b);
 /*!
  * \brief Returns a timeval from sec, usec
  */
-#if 0
-AST_INLINE_API(
-struct timeval ast_tv(int sec, int usec),
-{
-       struct timeval t = { sec, usec};
-       return t;
-}
-)
-#endif
 AST_INLINE_API(
 struct timeval ast_tv(ast_time_t sec, ast_suseconds_t usec),
 {
@@ -134,7 +171,7 @@ struct timeval ast_tv(ast_time_t sec, ast_suseconds_t usec),
 AST_INLINE_API(
 struct timeval ast_samp2tv(unsigned int _nsamp, unsigned int _rate),
 {
-       return ast_tv(_nsamp / _rate, (_nsamp % _rate) * (1000000 / _rate));
+       return ast_tv(_nsamp / _rate, (_nsamp % _rate) * (1000000 / (float) _rate));
 }
 )