Correct LinuxTimer time calculations

Changes to CLOCK_MONOTONIC as CLOCK_PROCESS_CPUTIME counts only
user time and not kernel time.

BUG=angleproject:892

Change-Id: I3d5aee26ee2bacd7449fdd7795ad8c2b289d7324
Reviewed-on: https://chromium-review.googlesource.com/272652
Reviewed-by: Jamie Madill <jmadill@chromium.org>
Reviewed-by: Geoff Lang <geofflang@chromium.org>
Tested-by: Corentin Wallez <cwallez@chromium.org>
This commit is contained in:
Corentin Wallez 2015-05-21 15:26:15 -04:00
Родитель 1b21fd396b
Коммит 5b2545bf24
1 изменённых файлов: 7 добавлений и 4 удалений

Просмотреть файл

@ -7,6 +7,7 @@
// LinuxTimer.cpp: Implementation of a high precision timer class on Linux
#include "linux/LinuxTimer.h"
#include <iostream>
LinuxTimer::LinuxTimer()
: mRunning(false)
@ -15,13 +16,13 @@ LinuxTimer::LinuxTimer()
void LinuxTimer::start()
{
clock_gettime(CLOCK_PROCESS_CPUTIME_ID, &mStartTime);
clock_gettime(CLOCK_MONOTONIC, &mStartTime);
mRunning = true;
}
void LinuxTimer::stop()
{
clock_gettime(CLOCK_PROCESS_CPUTIME_ID, &mStopTime);
clock_gettime(CLOCK_MONOTONIC, &mStopTime);
mRunning = false;
}
@ -30,14 +31,16 @@ double LinuxTimer::getElapsedTime() const
struct timespec endTime;
if (mRunning)
{
clock_gettime(CLOCK_PROCESS_CPUTIME_ID, &endTime);
clock_gettime(CLOCK_MONOTONIC, &endTime);
}
else
{
endTime = mStopTime;
}
return endTime.tv_sec + (1.0 / 1000000000) * endTime.tv_nsec;
double startSeconds = mStartTime.tv_sec + (1.0 / 1000000000) * mStartTime.tv_nsec;
double endSeconds = endTime.tv_sec + (1.0 / 1000000000) * endTime.tv_nsec;
return endSeconds - startSeconds;
}
Timer *CreateTimer()