2010-05-18 11:58:33 -04:00
|
|
|
/*
|
2010-09-09 08:16:39 -04:00
|
|
|
* Copyright (c) 2010 The WebM project authors. All Rights Reserved.
|
2010-05-18 11:58:33 -04:00
|
|
|
*
|
2010-06-18 12:39:21 -04:00
|
|
|
* Use of this source code is governed by a BSD-style license
|
2010-06-04 16:19:40 -04:00
|
|
|
* that can be found in the LICENSE file in the root of the source
|
|
|
|
* tree. An additional intellectual property rights grant can be found
|
2010-06-18 12:39:21 -04:00
|
|
|
* in the file PATENTS. All contributing project authors may
|
2010-06-04 16:19:40 -04:00
|
|
|
* be found in the AUTHORS file in the root of the source tree.
|
2010-05-18 11:58:33 -04:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef VPX_TIMER_H
|
|
|
|
#define VPX_TIMER_H
|
|
|
|
|
2010-09-02 12:03:51 -04:00
|
|
|
#if defined(_WIN32)
|
2010-05-18 11:58:33 -04:00
|
|
|
/*
|
|
|
|
* Win32 specific includes
|
|
|
|
*/
|
|
|
|
#ifndef WIN32_LEAN_AND_MEAN
|
|
|
|
#define WIN32_LEAN_AND_MEAN
|
|
|
|
#endif
|
|
|
|
#include <windows.h>
|
|
|
|
#else
|
|
|
|
/*
|
|
|
|
* POSIX specific includes
|
|
|
|
*/
|
|
|
|
#include <sys/time.h>
|
|
|
|
|
|
|
|
/* timersub is not provided by msys at this time. */
|
|
|
|
#ifndef timersub
|
|
|
|
#define timersub(a, b, result) \
|
|
|
|
do { \
|
|
|
|
(result)->tv_sec = (a)->tv_sec - (b)->tv_sec; \
|
|
|
|
(result)->tv_usec = (a)->tv_usec - (b)->tv_usec; \
|
|
|
|
if ((result)->tv_usec < 0) { \
|
|
|
|
--(result)->tv_sec; \
|
|
|
|
(result)->tv_usec += 1000000; \
|
|
|
|
} \
|
|
|
|
} while (0)
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
struct vpx_usec_timer
|
|
|
|
{
|
2010-09-02 12:03:51 -04:00
|
|
|
#if defined(_WIN32)
|
2010-05-18 11:58:33 -04:00
|
|
|
LARGE_INTEGER begin, end;
|
|
|
|
#else
|
|
|
|
struct timeval begin, end;
|
|
|
|
#endif
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2010-06-24 09:02:48 -04:00
|
|
|
static void
|
2010-05-18 11:58:33 -04:00
|
|
|
vpx_usec_timer_start(struct vpx_usec_timer *t)
|
|
|
|
{
|
2010-09-02 12:03:51 -04:00
|
|
|
#if defined(_WIN32)
|
2010-05-18 11:58:33 -04:00
|
|
|
QueryPerformanceCounter(&t->begin);
|
|
|
|
#else
|
|
|
|
gettimeofday(&t->begin, NULL);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-06-24 09:02:48 -04:00
|
|
|
static void
|
2010-05-18 11:58:33 -04:00
|
|
|
vpx_usec_timer_mark(struct vpx_usec_timer *t)
|
|
|
|
{
|
2010-09-02 12:03:51 -04:00
|
|
|
#if defined(_WIN32)
|
2010-05-18 11:58:33 -04:00
|
|
|
QueryPerformanceCounter(&t->end);
|
|
|
|
#else
|
|
|
|
gettimeofday(&t->end, NULL);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-06-24 09:02:48 -04:00
|
|
|
static long
|
2010-05-18 11:58:33 -04:00
|
|
|
vpx_usec_timer_elapsed(struct vpx_usec_timer *t)
|
|
|
|
{
|
2010-09-02 12:03:51 -04:00
|
|
|
#if defined(_WIN32)
|
2010-05-18 11:58:33 -04:00
|
|
|
LARGE_INTEGER freq, diff;
|
|
|
|
|
|
|
|
diff.QuadPart = t->end.QuadPart - t->begin.QuadPart;
|
|
|
|
|
|
|
|
if (QueryPerformanceFrequency(&freq) && diff.QuadPart < freq.QuadPart)
|
|
|
|
return (long)(diff.QuadPart * 1000000 / freq.QuadPart);
|
|
|
|
|
|
|
|
return 1000000;
|
|
|
|
#else
|
|
|
|
struct timeval diff;
|
|
|
|
|
|
|
|
timersub(&t->end, &t->begin, &diff);
|
|
|
|
return diff.tv_sec ? 1000000 : diff.tv_usec;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|