summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDevang Patel <dpatel@apple.com>2007-07-05 15:32:03 +0000
committerDevang Patel <dpatel@apple.com>2007-07-05 15:32:03 +0000
commitf5a15dd9da014a1585addb27729cccce3fd04244 (patch)
tree80b3454e227cca15911bdec37b5b0784e52e4d10
parent4836e3a6f88e1e5c3831856fb0a2e9b6c984164d (diff)
downloadbcm5719-llvm-f5a15dd9da014a1585addb27729cccce3fd04244.tar.gz
bcm5719-llvm-f5a15dd9da014a1585addb27729cccce3fd04244.zip
Fix PR1539. Add LoopPassPrinter.
llvm-svn: 37909
-rw-r--r--llvm/test/Other/2007-06-28-PassManager.ll2
-rw-r--r--llvm/tools/opt/opt.cpp29
2 files changed, 31 insertions, 0 deletions
diff --git a/llvm/test/Other/2007-06-28-PassManager.ll b/llvm/test/Other/2007-06-28-PassManager.ll
index b0d83d0a0c6..5968d8c68bc 100644
--- a/llvm/test/Other/2007-06-28-PassManager.ll
+++ b/llvm/test/Other/2007-06-28-PassManager.ll
@@ -1,5 +1,7 @@
; RUN: llvm-as < %s | opt -analyze -inline -disable-output
; PR 1526
+; RUN: llvm-as < %s | opt -analyze -indvars -disable-output
+; PR 1539
define i32 @test1() {
ret i32 0;
}
diff --git a/llvm/tools/opt/opt.cpp b/llvm/tools/opt/opt.cpp
index e6ff5ec4a25..ace0d3c9bc9 100644
--- a/llvm/tools/opt/opt.cpp
+++ b/llvm/tools/opt/opt.cpp
@@ -176,6 +176,33 @@ struct FunctionPassPrinter : public FunctionPass {
};
char FunctionPassPrinter::ID = 0;
+
+struct LoopPassPrinter : public LoopPass {
+ static char ID;
+ const PassInfo *PassToPrint;
+ LoopPassPrinter(const PassInfo *PI) :
+ LoopPass((intptr_t)&ID), PassToPrint(PI) {}
+
+ virtual bool runOnLoop(Loop *L, LPPassManager &LPM) {
+ if (!Quiet) {
+ cout << "Printing analysis '" << PassToPrint->getPassName() << "':\n";
+ getAnalysisID<Pass>(PassToPrint).print(cout,
+ L->getHeader()->getParent()->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 LoopPassPrinter::ID = 0;
+
struct BasicBlockPassPrinter : public BasicBlockPass {
const PassInfo *PassToPrint;
static char ID;
@@ -372,6 +399,8 @@ int main(int argc, char **argv) {
if (AnalyzeOnly) {
if (dynamic_cast<BasicBlockPass*>(P))
Passes.add(new BasicBlockPassPrinter(PassInf));
+ else if (dynamic_cast<LoopPass*>(P))
+ Passes.add(new LoopPassPrinter(PassInf));
else if (dynamic_cast<FunctionPass*>(P))
Passes.add(new FunctionPassPrinter(PassInf));
else if (dynamic_cast<CallGraphSCCPass*>(P))
OpenPOWER on IntegriCloud