blob: fab657a8c36cbbb0f871e9bc96263d00f77fa33f [file] [log] [blame]
mtklein9e64b782014-06-20 10:43:07 -07001
2/*
3 * Copyright 2011 Google Inc.
4 *
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
7 */
8#include "BenchSysTimer_windows.h"
9
10//Time
11#define WIN32_LEAN_AND_MEAN 1
12#include <windows.h>
13
14static ULONGLONG winCpuTime() {
15 FILETIME createTime;
16 FILETIME exitTime;
17 FILETIME usrTime;
18 FILETIME sysTime;
19 if (0 == GetProcessTimes(GetCurrentProcess()
20 , &createTime, &exitTime
21 , &sysTime, &usrTime))
22 {
23 return 0;
24 }
25 ULARGE_INTEGER start_cpu_sys;
26 ULARGE_INTEGER start_cpu_usr;
27 start_cpu_sys.LowPart = sysTime.dwLowDateTime;
28 start_cpu_sys.HighPart = sysTime.dwHighDateTime;
29 start_cpu_usr.LowPart = usrTime.dwLowDateTime;
30 start_cpu_usr.HighPart = usrTime.dwHighDateTime;
31 return start_cpu_sys.QuadPart + start_cpu_usr.QuadPart;
32}
33
34void BenchSysTimer::startWall() {
35 if (0 == ::QueryPerformanceCounter(&this->fStartWall)) {
36 this->fStartWall.QuadPart = 0;
37 }
38}
39void BenchSysTimer::startCpu() {
40 this->fStartCpu = winCpuTime();
41}
42
43double BenchSysTimer::endCpu() {
44 ULONGLONG end_cpu = winCpuTime();
45 return static_cast<double>((end_cpu - this->fStartCpu)) / 10000.0L;
46}
47double BenchSysTimer::endWall() {
48 LARGE_INTEGER end_wall;
49 if (0 == ::QueryPerformanceCounter(&end_wall)) {
50 end_wall.QuadPart = 0;
51 }
52
53 LARGE_INTEGER ticks_elapsed;
54 ticks_elapsed.QuadPart = end_wall.QuadPart - this->fStartWall.QuadPart;
55
56 LARGE_INTEGER frequency;
57 if (0 == ::QueryPerformanceFrequency(&frequency)) {
58 return 0.0L;
59 } else {
60 return static_cast<double>(ticks_elapsed.QuadPart)
61 / static_cast<double>(frequency.QuadPart)
62 * 1000.0L;
63 }
64}