Hash :
3ce69ba3
Author :
Date :
2018-10-26T11:25:32
Fix Win32Timer's Frequency init. This could cause some problems on the perf bots. Bug: angleproject:2908 Change-Id: If12e5939ba80b3fd0b9609e7b76df6045e60cb94 Reviewed-on: https://chromium-review.googlesource.com/c/1301849 Reviewed-by: Jamie Madill <jmadill@chromium.org> Reviewed-by: Shahbaz Youssefi <syoussefi@chromium.org> Commit-Queue: Jamie Madill <jmadill@chromium.org>
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
//
// Copyright (c) 2014 The ANGLE Project Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
//
// WindowsTimer.cpp: Implementation of a high precision timer class on Windows
#include "windows/WindowsTimer.h"
WindowsTimer::WindowsTimer() : mRunning(false), mStartTime(0), mStopTime(0), mFrequency(0)
{
}
LONGLONG WindowsTimer::getFrequency()
{
if (mFrequency == 0)
{
LARGE_INTEGER frequency = {};
QueryPerformanceFrequency(&frequency);
mFrequency = frequency.QuadPart;
}
return mFrequency;
}
void WindowsTimer::start()
{
LARGE_INTEGER curTime;
QueryPerformanceCounter(&curTime);
mStartTime = curTime.QuadPart;
// Cache the frequency
getFrequency();
mRunning = true;
}
void WindowsTimer::stop()
{
LARGE_INTEGER curTime;
QueryPerformanceCounter(&curTime);
mStopTime = curTime.QuadPart;
mRunning = false;
}
double WindowsTimer::getElapsedTime() const
{
LONGLONG endTime;
if (mRunning)
{
LARGE_INTEGER curTime;
QueryPerformanceCounter(&curTime);
endTime = curTime.QuadPart;
}
else
{
endTime = mStopTime;
}
return static_cast<double>(endTime - mStartTime) / mFrequency;
}
double WindowsTimer::getAbsoluteTime()
{
LARGE_INTEGER curTime;
QueryPerformanceCounter(&curTime);
return static_cast<double>(curTime.QuadPart) / getFrequency();
}
Timer *CreateTimer()
{
return new WindowsTimer();
}