diff options
| author | Devang Patel <dpatel@apple.com> | 2007-06-28 23:09:25 +0000 |
|---|---|---|
| committer | Devang Patel <dpatel@apple.com> | 2007-06-28 23:09:25 +0000 |
| commit | 9a259a20b3f025454dd5d11db7928d6439134585 (patch) | |
| tree | d78b78c79ee9dee9a626ae5fdda41c94bc17de88 /llvm/tools/opt/opt.cpp | |
| parent | 5f1a2052cdaca8663536d14174d676e12e390a42 (diff) | |
| download | bcm5719-llvm-9a259a20b3f025454dd5d11db7928d6439134585.tar.gz bcm5719-llvm-9a259a20b3f025454dd5d11db7928d6439134585.zip | |
Fix PR 1526.
llvm-svn: 37780
Diffstat (limited to 'llvm/tools/opt/opt.cpp')
| -rw-r--r-- | llvm/tools/opt/opt.cpp | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/llvm/tools/opt/opt.cpp b/llvm/tools/opt/opt.cpp index 14e02d0e467..e6ff5ec4a25 100644 --- a/llvm/tools/opt/opt.cpp +++ b/llvm/tools/opt/opt.cpp @@ -14,10 +14,12 @@ #include "llvm/Module.h" #include "llvm/PassManager.h" +#include "llvm/CallGraphSCCPass.h" #include "llvm/Bitcode/ReaderWriter.h" #include "llvm/Assembly/PrintModulePass.h" #include "llvm/Analysis/Verifier.h" #include "llvm/Analysis/LoopPass.h" +#include "llvm/Analysis/CallGraph.h" #include "llvm/Target/TargetData.h" #include "llvm/Target/TargetMachine.h" #include "llvm/Support/PassNameParser.h" @@ -94,6 +96,36 @@ AnalyzeOnly("analyze", cl::desc("Only perform analysis, no optimization")); // ---------- Define Printers for module and function passes ------------ namespace { +struct CallGraphSCCPassPrinter : public CallGraphSCCPass { + static char ID; + const PassInfo *PassToPrint; + CallGraphSCCPassPrinter(const PassInfo *PI) : + CallGraphSCCPass((intptr_t)&ID), PassToPrint(PI) {} + + virtual bool runOnSCC(const std::vector<CallGraphNode *>&SCC) { + if (!Quiet) { + cout << "Printing analysis '" << PassToPrint->getPassName() << "':\n"; + + for (unsigned i = 0, e = SCC.size(); i != e; ++i) { + Function *F = SCC[i]->getFunction(); + if (F) + getAnalysisID<Pass>(PassToPrint).print(cout, F->getParent()); + } + } + // Get and print pass... + return false; + } + + virtual const char *getPassName() const { return "'Pass' Printer"; } + + virtual void getAnalysisUsage(AnalysisUsage &AU) const { + AU.addRequiredID(PassToPrint); + AU.setPreservesAll(); + } +}; + +char CallGraphSCCPassPrinter::ID = 0; + struct ModulePassPrinter : public ModulePass { static char ID; const PassInfo *PassToPrint; @@ -342,6 +374,8 @@ int main(int argc, char **argv) { Passes.add(new BasicBlockPassPrinter(PassInf)); else if (dynamic_cast<FunctionPass*>(P)) Passes.add(new FunctionPassPrinter(PassInf)); + else if (dynamic_cast<CallGraphSCCPass*>(P)) + Passes.add(new CallGraphSCCPassPrinter(PassInf)); else Passes.add(new ModulePassPrinter(PassInf)); } |

