-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathcallstack.cpp
More file actions
131 lines (115 loc) · 4.06 KB
/
callstack.cpp
File metadata and controls
131 lines (115 loc) · 4.06 KB
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
/*
__ __ ______ _______ _______ ______ ________
/ \ / | / \ / \ / \ / \ / |
$$ \ /$$ |/$$$$$$ |$$$$$$$ |$$$$$$$ |/$$$$$$ |$$$$$$$$/
$$$ \ /$$$ |$$ | $$/ $$ |__$$ |$$ |__$$ |$$ | $$ |$$ |__
$$$$ /$$$$ |$$ | $$ $$/ $$ $$< $$ | $$ |$$ |
$$ $$ $$/$$ |$$ | __ $$$$$$$/ $$$$$$$ |$$ | $$ |$$$$$/
$$ |$$$/ $$ |$$ \__/ |$$ | $$ | $$ |$$ \__$$ |$$ |
$$ | $/ $$ |$$ $$/ $$ | $$ | $$ |$$ $$/ $$ |
$$/ $$/ $$$$$$/ $$/ $$/ $$/ $$$$$$/ $$/
A Memory and Communication Profiler
* This file is a part of MCPROF.
* https://bitbucket.org/imranashraf/mcprof
*
* Copyright (c) 2014-2016 TU Delft, The Netherlands.
* All rights reserved.
*
* MCPROF is free software: you can redistribute it and/or modify it under the
* terms of the GNU Lesser General Public License as published by the
* Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* MCPROF is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with MCPROF. If not, see <http://www.gnu.org/licenses/>.
*
* Authors: Imran Ashraf
*
*/
#include "globals.h"
#include "shadow.h"
#include "callstack.h"
#include "commatrix.h"
extern std::map <std::string,IDNoType> FuncName2ID;
extern Symbols symTable;
extern LocationList Locations;
void CallStackType::Print()
{
string stackftns("");
D2ECHO( VAR( stack.size() ) );
for ( u16 ftn=1; ftn < stack.size(); ftn++)
stackftns += symTable.GetSymName(stack[ftn]) + " ";
ECHO("Call Stack: " << stackftns);
}
void CallStackType::Print(ofstream& fout)
{
#if 1
string stackftns("");
if( !stack.empty() )
{
stackftns += symTable.GetSymName( stack[ stack.size()-1 ] );
}
fout << stackftns;
#else
// The following is the detailed printing of callstack
if( !stack.empty() )
{
stackftns += symTable.GetSymName(stack[0]);
}
u16 ftn=1;
while( ftn < stack.size() )
{
if( stack[ftn] == stack[ftn-1] ) // check for recursion
{
stackftns += " > " + symTable.GetSymName(stack[ftn]) + " > ... > ";
// do not print all functions in recursion.
while( stack[ftn] == stack[ftn-1] && ftn < stack.size() )
{
ftn++; // simply increment to skip
}
stackftns += symTable.GetSymName(stack[ftn-1]);
ftn++;
}
else
{
stackftns += " > " + symTable.GetSymName(stack[ftn]);
ftn++;
}
}
fout << "Call Stack: " << stackftns << "\n";
D1ECHO("Call Stack: " << stackftns);
#endif
}
void CallSiteStackType::GetCallSites(u32 lastCallLocIndex, string& callsites)
{
for (u32 loc=1; loc < sites.size(); loc++) // first callsite will be of call to main
callsites += to_string( (long long) sites[loc]); // arbitrary formula to combine call sites
callsites += to_string( (long long) lastCallLocIndex); // also add the effect of lastCallLocIndex
}
string CallSiteStackType::GetCallSitesString()
{
string callsites("");
for ( u16 loc=1; loc < sites.size(); loc++)
callsites += Locations.GetLocation(sites[loc]).toString() + " ";
return callsites;
}
void CallSiteStackType::Print()
{
string callsites("");
D2ECHO( VAR( sites.size() ) );
for ( u16 loc=1; loc < sites.size(); loc++)
callsites += Locations.GetLocation(sites[loc]).toString() + " ";
ECHO("Call sites: " << callsites);
}
void CallSiteStackType::Print(ofstream& fout)
{
string callsites("");
for ( u16 loc=1; loc < sites.size(); loc++)
callsites += Locations.GetLocation(sites[loc]).toString();
fout << "Call sites: " << callsites << "\n";
}