]> git.cworth.org Git - apitrace/blob - common/trace_profiler.cpp
Improved GPU profiling code.
[apitrace] / common / trace_profiler.cpp
1 /**************************************************************************
2  *
3  * Copyright 2012 VMware, Inc.
4  * All Rights Reserved.
5  *
6  * Permission is hereby granted, free of charge, to any person obtaining a copy
7  * of this software and associated documentation files (the "Software"), to deal
8  * in the Software without restriction, including without limitation the rights
9  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10  * copies of the Software, and to permit persons to whom the Software is
11  * furnished to do so, subject to the following conditions:
12  *
13  * The above copyright notice and this permission notice shall be included in
14  * all copies or substantial portions of the Software.
15  *
16  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
22  * THE SOFTWARE.
23  *
24  **************************************************************************/
25
26 #include "trace_profiler.hpp"
27 #include <iostream>
28
29 namespace trace {
30 Profiler::Profiler()
31     : baseTime(0)
32 {
33 }
34
35 Profiler::~Profiler()
36 {
37 }
38
39 void Profiler::addCall(unsigned no, const char *name, uint64_t gpu_start, uint64_t gpu_duration)
40 {
41     if (baseTime == 0)
42         baseTime = gpu_start;
43
44     std::cout << "call "
45               << no << " "
46               << (gpu_start - baseTime) << " "
47               << gpu_duration << " "
48               << name << std::endl;
49 }
50
51 void Profiler::addFrameStart(unsigned no, uint64_t timestamp)
52 {
53     if (baseTime == 0)
54         baseTime = timestamp;
55
56     lastFrame.no = no;
57     lastFrame.start = timestamp - baseTime;
58
59     std::cout << "frame begin "
60               << lastFrame.no << " "
61               << lastFrame.start << std::endl;
62 }
63
64 void Profiler::addFrameEnd(uint64_t timestamp)
65 {
66     if (baseTime == 0)
67         baseTime = timestamp;
68
69     lastFrame.end = timestamp - baseTime;
70
71     std::cout << "frame end "
72               << lastFrame.no << " "
73               << lastFrame.end << " "
74               << (lastFrame.end - lastFrame.start) << std::endl;
75 }
76 }