aboutsummaryrefslogtreecommitdiffhomepage
path: root/tools/timer/Timer.cpp
blob: b59988ca2642f5f3330d05ba849cdde8c4c49e0d (plain)
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
/*
 * Copyright 2011 Google Inc.
 *
 * Use of this source code is governed by a BSD-style license that can be
 * found in the LICENSE file.
 */
#include "Timer.h"

Timer::Timer(SkGLContext* gl)
        : fCpu(-1.0)
        , fWall(-1.0)
        , fTruncatedCpu(-1.0)
        , fTruncatedWall(-1.0)
        , fGpu(-1.0)
#if SK_SUPPORT_GPU
        , fGpuTimer(gl)
#endif
        {}

void Timer::start() {
    fSysTimer.startWall();
    fTruncatedSysTimer.startWall();
#if SK_SUPPORT_GPU
    fGpuTimer.start();
#endif
    fSysTimer.startCpu();
    fTruncatedSysTimer.startCpu();
}

void Timer::end() {
    fCpu = fSysTimer.endCpu();
#if SK_SUPPORT_GPU
    //It is important to stop the cpu clocks first,
    //as the following will cpu wait for the gpu to finish.
    fGpu = fGpuTimer.end();
#endif
    fWall = fSysTimer.endWall();
}

void Timer::truncatedEnd() {
    fTruncatedCpu = fTruncatedSysTimer.endCpu();
    fTruncatedWall = fTruncatedSysTimer.endWall();
}

WallTimer::WallTimer() : fWall(-1.0) {}

void WallTimer::start() {
    fSysTimer.startWall();
}

void WallTimer::end() {
    fWall = fSysTimer.endWall();
}

SkString HumanizeMs(double ms) {
    if (ms > 60e+3)  return SkStringPrintf("%.3gm", ms/60e+3);
    if (ms >  1e+3)  return SkStringPrintf("%.3gs",  ms/1e+3);
    if (ms <  1e-3)  return SkStringPrintf("%.3gns", ms*1e+6);
#ifdef SK_BUILD_FOR_WIN
    if (ms < 1)      return SkStringPrintf("%.3gus", ms*1e+3);
#else
    if (ms < 1)      return SkStringPrintf("%.3gµs", ms*1e+3);
#endif
    return SkStringPrintf("%.3gms", ms);
}