blob: 2d9c8b99625fadaffcb90d6cdfc7d443e0aa732b [file] [log] [blame]
Dan Gohmanf17a25c2007-07-18 16:29:46 +00001//===- ProfileInfoLoaderPass.cpp - LLVM Pass to load profile info ---------===//
2//
3// The LLVM Compiler Infrastructure
4//
Chris Lattner081ce942007-12-29 20:36:04 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Dan Gohmanf17a25c2007-07-18 16:29:46 +00007//
8//===----------------------------------------------------------------------===//
9//
10// This file implements a concrete implementation of profiling information that
11// loads the information from a profile dump file.
12//
13//===----------------------------------------------------------------------===//
14
15#include "llvm/BasicBlock.h"
16#include "llvm/InstrTypes.h"
Daniel Dunbar13021f12009-08-05 15:55:56 +000017#include "llvm/Module.h"
Dan Gohmanf17a25c2007-07-18 16:29:46 +000018#include "llvm/Pass.h"
19#include "llvm/Analysis/Passes.h"
20#include "llvm/Analysis/ProfileInfo.h"
21#include "llvm/Analysis/ProfileInfoLoader.h"
22#include "llvm/Support/CommandLine.h"
23#include "llvm/Support/Compiler.h"
24#include "llvm/Support/Streams.h"
25using namespace llvm;
26
Dan Gohman089efff2008-05-13 00:00:25 +000027static cl::opt<std::string>
28ProfileInfoFilename("profile-info-file", cl::init("llvmprof.out"),
29 cl::value_desc("filename"),
30 cl::desc("Profile file loaded by -profile-loader"));
Dan Gohmanf17a25c2007-07-18 16:29:46 +000031
Dan Gohman089efff2008-05-13 00:00:25 +000032namespace {
Dan Gohmanf17a25c2007-07-18 16:29:46 +000033 class VISIBILITY_HIDDEN LoaderPass : public ModulePass, public ProfileInfo {
34 std::string Filename;
35 public:
36 static char ID; // Class identification, replacement for typeinfo
Dan Gohman34c280e2007-08-01 15:32:29 +000037 explicit LoaderPass(const std::string &filename = "")
Dan Gohman26f8c272008-09-04 17:05:41 +000038 : ModulePass(&ID), Filename(filename) {
Dan Gohmanf17a25c2007-07-18 16:29:46 +000039 if (filename.empty()) Filename = ProfileInfoFilename;
40 }
41
42 virtual void getAnalysisUsage(AnalysisUsage &AU) const {
43 AU.setPreservesAll();
44 }
45
46 virtual const char *getPassName() const {
47 return "Profiling information loader";
48 }
49
Dan Gohmanf17a25c2007-07-18 16:29:46 +000050 /// run - Load the profile information from the specified file.
51 virtual bool runOnModule(Module &M);
52 };
Dan Gohmanf17a25c2007-07-18 16:29:46 +000053} // End of anonymous namespace
54
Dan Gohman089efff2008-05-13 00:00:25 +000055char LoaderPass::ID = 0;
56static RegisterPass<LoaderPass>
57X("profile-loader", "Load profile information from llvmprof.out", false, true);
58
59static RegisterAnalysisGroup<ProfileInfo> Y(X);
60
Dan Gohmanf17a25c2007-07-18 16:29:46 +000061ModulePass *llvm::createProfileLoaderPass() { return new LoaderPass(); }
62
63/// createProfileLoaderPass - This function returns a Pass that loads the
64/// profiling information for the module from the specified filename, making it
65/// available to the optimizers.
66Pass *llvm::createProfileLoaderPass(const std::string &Filename) {
67 return new LoaderPass(Filename);
68}
69
70bool LoaderPass::runOnModule(Module &M) {
71 ProfileInfoLoader PIL("profile-loader", Filename, M);
72 EdgeCounts.clear();
Dan Gohmanf17a25c2007-07-18 16:29:46 +000073
Daniel Dunbar13021f12009-08-05 15:55:56 +000074 std::vector<unsigned> ECs = PIL.getRawEdgeCounts();
75 // Instrument all of the edges...
76 unsigned i = 0;
77 for (Module::iterator F = M.begin(), E = M.end(); F != E; ++F)
78 for (Function::iterator BB = F->begin(), E = F->end(); BB != E; ++BB) {
79 // Okay, we have to add a counter of each outgoing edge. If the
80 // outgoing edge is not critical don't split it, just insert the counter
81 // in the source or destination of the edge.
82 TerminatorInst *TI = BB->getTerminator();
83 for (unsigned s = 0, e = TI->getNumSuccessors(); s != e; ++s) {
84 if (i < ECs.size())
85 EdgeCounts[std::make_pair(BB, TI->getSuccessor(s))]+= ECs[i++];
Dan Gohmanf17a25c2007-07-18 16:29:46 +000086 }
Dan Gohmanf17a25c2007-07-18 16:29:46 +000087 }
Daniel Dunbar13021f12009-08-05 15:55:56 +000088
89 if (i != ECs.size()) {
90 cerr << "WARNING: profile information is inconsistent with "
91 << "the current program!\n";
Dan Gohmanf17a25c2007-07-18 16:29:46 +000092 }
93
94 return false;
95}