summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Analysis/ProfileInfoLoader.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-03-08 18:20:18 +0000
committerChris Lattner <sabre@nondot.org>2004-03-08 18:20:18 +0000
commit8b8a0641a14fc210b5f9ded4454df66f45c7c3f8 (patch)
tree543a489914ea4a4fb9488db71932cd5acf966002 /llvm/lib/Analysis/ProfileInfoLoader.cpp
parent178608ee2bfef54038b53daff7b14058a1f4cfe7 (diff)
downloadbcm5719-llvm-8b8a0641a14fc210b5f9ded4454df66f45c7c3f8.tar.gz
bcm5719-llvm-8b8a0641a14fc210b5f9ded4454df66f45c7c3f8.zip
Add initial support for reading edge counts. This will be improved to enable
translation of edge counts into block/function counts when possible. llvm-svn: 12229
Diffstat (limited to 'llvm/lib/Analysis/ProfileInfoLoader.cpp')
-rw-r--r--llvm/lib/Analysis/ProfileInfoLoader.cpp29
1 files changed, 29 insertions, 0 deletions
diff --git a/llvm/lib/Analysis/ProfileInfoLoader.cpp b/llvm/lib/Analysis/ProfileInfoLoader.cpp
index 39d2b6e0366..cef0897983e 100644
--- a/llvm/lib/Analysis/ProfileInfoLoader.cpp
+++ b/llvm/lib/Analysis/ProfileInfoLoader.cpp
@@ -14,6 +14,7 @@
#include "llvm/Analysis/ProfileInfoLoader.h"
#include "llvm/Module.h"
+#include "llvm/InstrTypes.h"
#include <cstdio>
using namespace llvm;
@@ -21,6 +22,7 @@ enum ProfilingType {
ArgumentInfo = 1, // The command line argument block
FunctionInfo = 2, // Function profiling information
BlockInfo = 3, // Block profiling information
+ EdgeInfo = 4, // Edge profiling information
};
// ByteSwap - Byteswap 'Var' if 'Really' is true.
@@ -122,6 +124,10 @@ ProfileInfoLoader::ProfileInfoLoader(const char *ToolName,
ReadProfilingBlock(ToolName, F, ShouldByteSwap, BlockCounts);
break;
+ case EdgeInfo:
+ ReadProfilingBlock(ToolName, F, ShouldByteSwap, EdgeCounts);
+ break;
+
default:
std::cerr << ToolName << ": Unknown packet type #" << PacketType << "!\n";
exit(1);
@@ -178,3 +184,26 @@ void ProfileInfoLoader::getBlockCounts(std::vector<std::pair<BasicBlock*,
return;
}
}
+
+// getEdgeCounts - This method is used by consumers of edge counting
+// information. If we do not directly have edge count information, we compute
+// it from other, more refined, types of profile information.
+//
+void ProfileInfoLoader::getEdgeCounts(std::vector<std::pair<Edge,
+ unsigned> > &Counts) {
+ if (EdgeCounts.empty()) {
+ std::cerr << "Edge 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)
+ for (unsigned i = 0, e = BB->getTerminator()->getNumSuccessors();
+ i != e; ++i) {
+ Counts.push_back(std::make_pair(Edge(BB, i), EdgeCounts[Counter++]));
+ if (Counter == EdgeCounts.size())
+ return;
+ }
+}
OpenPOWER on IntegriCloud