Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(101)

Side by Side Diff: bench/BenchSysTimer_windows.cpp

Issue 344213003: Move BenchTimer to tools as Timer (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: fixes Created 6 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1
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
14 static 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
34 void BenchSysTimer::startWall() {
35 if (0 == ::QueryPerformanceCounter(&this->fStartWall)) {
36 this->fStartWall.QuadPart = 0;
37 }
38 }
39 void BenchSysTimer::startCpu() {
40 this->fStartCpu = winCpuTime();
41 }
42
43 double BenchSysTimer::endCpu() {
44 ULONGLONG end_cpu = winCpuTime();
45 return static_cast<double>((end_cpu - this->fStartCpu)) / 10000.0L;
46 }
47 double 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 }
OLDNEW
« no previous file with comments | « bench/BenchSysTimer_windows.h ('k') | bench/BenchTimer.h » ('j') | tools/timer/GpuTimer.cpp » ('J')

Powered by Google App Engine
This is Rietveld 408576698