]> git.cworth.org Git - apitrace/blob - common/trace_profiler.cpp
fdc0fd4a2f748c170c464bbd7af12e6852d4f68b
[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(const Call& call)
40 {
41     if (baseTime == 0)
42         baseTime = call.gpu.start;
43
44     std::cout << "call "
45               << call.no << " "
46               << (call.gpu.start - baseTime) << " "
47               << call.gpu.duration << " "
48               << call.name << std::endl;
49 }
50
51 void Profiler::addFrame(const Frame& frame)
52 {
53     if (baseTime == 0)
54         baseTime = frame.gpu.start;
55
56     std::cout << "frame "
57               << frame.no << " "
58               << (frame.gpu.start - baseTime) << " "
59               << frame.gpu.duration << std::endl;
60 }
61 }