summaryrefslogtreecommitdiff
path: root/tools
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-10-28 21:25:23 +0000
committerChris Lattner <sabre@nondot.org>2003-10-28 21:25:23 +0000
commit33f1ca7d8a86ce4933e89ddb6671924b3ec03923 (patch)
tree0df9151c0b9f8b0e7f862c4895a216738c012285 /tools
parentb9e578934f903ff9bec7b19f9592a76f378ff0f7 (diff)
downloadllvm-33f1ca7d8a86ce4933e89ddb6671924b3ec03923.tar.gz
llvm-33f1ca7d8a86ce4933e89ddb6671924b3ec03923.tar.bz2
llvm-33f1ca7d8a86ce4933e89ddb6671924b3ec03923.tar.xz
Add support for reading block frequencies. Fix bug in attribution of counts
to functions git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@9559 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'tools')
-rw-r--r--tools/llvm-prof/ProfileInfo.cpp25
-rw-r--r--tools/llvm-prof/ProfileInfo.h13
-rw-r--r--tools/llvm-prof/llvm-prof.cpp12
3 files changed, 48 insertions, 2 deletions
diff --git a/tools/llvm-prof/ProfileInfo.cpp b/tools/llvm-prof/ProfileInfo.cpp
index 2341db0bb9..4c31138aa3 100644
--- a/tools/llvm-prof/ProfileInfo.cpp
+++ b/tools/llvm-prof/ProfileInfo.cpp
@@ -148,7 +148,28 @@ void ProfileInfo::getFunctionCounts(std::vector<std::pair<Function*,
unsigned Counter = 0;
for (Module::iterator I = M.begin(), E = M.end();
- I != E && Counter != FunctionCounts.size(); ++I, ++Counter)
+ I != E && Counter != FunctionCounts.size(); ++I)
if (!I->isExternal())
- Counts.push_back(std::make_pair(I, FunctionCounts[Counter]));
+ Counts.push_back(std::make_pair(I, FunctionCounts[Counter++]));
+}
+
+// getBlockCounts - This method is used by consumers of block counting
+// information. If we do not directly have block count information, we
+// compute it from other, more refined, types of profile information.
+//
+void ProfileInfo::getBlockCounts(std::vector<std::pair<BasicBlock*,
+ unsigned> > &Counts) {
+ if (BlockCounts.empty()) {
+ std::cerr << "Block counts not available, and no synthesis "
+ << "is implemented yet!\n";
+ return;
+ }
+
+ unsigned Counter = 0;
+ for (Module::iterator F = M.begin(), E = M.end(); F != E; ++F)
+ for (Function::iterator BB = F->begin(), E = F->end(); BB != E; ++BB) {
+ Counts.push_back(std::make_pair(BB, BlockCounts[Counter++]));
+ if (Counter == BlockCounts.size())
+ return;
+ }
}
diff --git a/tools/llvm-prof/ProfileInfo.h b/tools/llvm-prof/ProfileInfo.h
index 360d5fa1c9..eab9bc9781 100644
--- a/tools/llvm-prof/ProfileInfo.h
+++ b/tools/llvm-prof/ProfileInfo.h
@@ -20,6 +20,7 @@
#include <utility>
class Module;
class Function;
+class BasicBlock;
class ProfileInfo {
Module &M;
@@ -37,6 +38,18 @@ public:
//
void getFunctionCounts(std::vector<std::pair<Function*, unsigned> > &Counts);
+ // hasAccurateBlockCounts - Return true if we can synthesize accurate block
+ // frequency information from whatever we have.
+ //
+ bool hasAccurateBlockCounts() const {
+ return !BlockCounts.empty();
+ }
+
+ // getBlockCounts - This method is used by consumers of block counting
+ // information. If we do not directly have block count information, we
+ // compute it from other, more refined, types of profile information.
+ //
+ void getBlockCounts(std::vector<std::pair<BasicBlock*, unsigned> > &Counts);
};
#endif
diff --git a/tools/llvm-prof/llvm-prof.cpp b/tools/llvm-prof/llvm-prof.cpp
index cb907258e5..2b6730ec64 100644
--- a/tools/llvm-prof/llvm-prof.cpp
+++ b/tools/llvm-prof/llvm-prof.cpp
@@ -19,6 +19,7 @@
#include "Support/CommandLine.h"
#include <iostream>
#include <cstdio>
+#include <map>
namespace {
cl::opt<std::string>
@@ -77,5 +78,16 @@ int main(int argc, char **argv) {
for (unsigned i = 0, e = FunctionCounts.size(); i != e; ++i)
printf("%3d. %5d/%d %s\n", i, FunctionCounts[i].second, TotalExecutions,
FunctionCounts[i].first->getName().c_str());
+
+
+ // If we have block count information, print out the LLVM module with
+ // frequency annotations.
+ if (PI.hasAccurateBlockCounts()) {
+ std::vector<std::pair<BasicBlock*, unsigned> > Counts;
+ PI.getBlockCounts(Counts);
+ std::map<BasicBlock*, unsigned> BlockFreqs(Counts.begin(), Counts.end());
+
+ }
+
return 0;
}