aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorDevang Patel <dpatel@apple.com>2006-12-13 20:03:48 +0000
committerDevang Patel <dpatel@apple.com>2006-12-13 20:03:48 +0000
commit45dc02d6f97447785ee7ffe08c36a34bc8921b0b (patch)
tree597178ed261e10f01592a41c65bb7ed1cced8194 /lib
parentf92b25ed4a2670ec9d4f5f746cf50ae337c0e0b8 (diff)
downloadexternal_llvm-45dc02d6f97447785ee7ffe08c36a34bc8921b0b.tar.gz
external_llvm-45dc02d6f97447785ee7ffe08c36a34bc8921b0b.tar.bz2
external_llvm-45dc02d6f97447785ee7ffe08c36a34bc8921b0b.zip
Move enum PassDebugLevel from PassManagerT.h to Pass.h.
Use PDL as the prefix for these enums. Define and use PassDebugging_New in new PassManager. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@32554 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r--lib/VMCore/Pass.cpp8
-rw-r--r--lib/VMCore/PassManager.cpp26
-rw-r--r--lib/VMCore/PassManagerT.h29
3 files changed, 42 insertions, 21 deletions
diff --git a/lib/VMCore/Pass.cpp b/lib/VMCore/Pass.cpp
index 8c5a2f760e..650a7e6191 100644
--- a/lib/VMCore/Pass.cpp
+++ b/lib/VMCore/Pass.cpp
@@ -122,7 +122,7 @@ void PMDebug::PrintArgumentInformation(const Pass *P) {
void PMDebug::PrintPassInformation(unsigned Depth, const char *Action,
Pass *P, Module *M) {
- if (PassDebugging >= Executions) {
+ if (PassDebugging >= PDLExecutions) {
cerr << (void*)P << std::string(Depth*2+1, ' ') << Action << " '"
<< P->getPassName();
if (M) cerr << "' on Module '" << M->getModuleIdentifier() << "'\n";
@@ -132,7 +132,7 @@ void PMDebug::PrintPassInformation(unsigned Depth, const char *Action,
void PMDebug::PrintPassInformation(unsigned Depth, const char *Action,
Pass *P, Function *F) {
- if (PassDebugging >= Executions) {
+ if (PassDebugging >= PDLExecutions) {
cerr << (void*)P << std::string(Depth*2+1, ' ') << Action << " '"
<< P->getPassName();
if (F) cerr << "' on Function '" << F->getName();
@@ -142,7 +142,7 @@ void PMDebug::PrintPassInformation(unsigned Depth, const char *Action,
void PMDebug::PrintPassInformation(unsigned Depth, const char *Action,
Pass *P, BasicBlock *BB) {
- if (PassDebugging >= Executions) {
+ if (PassDebugging >= PDLExecutions) {
cerr << (void*)P << std::string(Depth*2+1, ' ') << Action << " '"
<< P->getPassName();
if (BB) cerr << "' on BasicBlock '" << BB->getName();
@@ -152,7 +152,7 @@ void PMDebug::PrintPassInformation(unsigned Depth, const char *Action,
void PMDebug::PrintAnalysisSetInfo(unsigned Depth, const char *Msg,
Pass *P, const std::vector<AnalysisID> &Set){
- if (PassDebugging >= Details && !Set.empty()) {
+ if (PassDebugging >= PDLDetails && !Set.empty()) {
cerr << (void*)P << std::string(Depth*2+3, ' ') << Msg << " Analyses:";
for (unsigned i = 0; i != Set.size(); ++i) {
if (i) cerr << ",";
diff --git a/lib/VMCore/PassManager.cpp b/lib/VMCore/PassManager.cpp
index d67d25a3f4..056a2a87c2 100644
--- a/lib/VMCore/PassManager.cpp
+++ b/lib/VMCore/PassManager.cpp
@@ -13,6 +13,7 @@
#include "llvm/PassManager.h"
+#include "llvm/Support/CommandLine.h"
#include "llvm/Module.h"
#include "llvm/ModuleProvider.h"
#include "llvm/Support/Streams.h"
@@ -84,6 +85,27 @@ using namespace llvm;
// ModulePassManagers.
//===----------------------------------------------------------------------===//
+namespace llvm {
+
+//===----------------------------------------------------------------------===//
+// Pass debugging information. Often it is useful to find out what pass is
+// running when a crash occurs in a utility. When this library is compiled with
+// debugging on, a command line option (--debug-pass) is enabled that causes the
+// pass name to be printed before it executes.
+//
+
+static cl::opt<enum PassDebugLevel>
+PassDebugging_New("debug-pass", cl::Hidden,
+ cl::desc("Print PassManager debugging information"),
+ cl::values(
+ clEnumVal(PDLNone , "disable debug output"),
+ clEnumVal(PDLArguments , "print pass arguments to pass to 'opt'"),
+ clEnumVal(PDLStructure , "print pass structure before run()"),
+ clEnumVal(PDLExecutions, "print pass name before it is executed"),
+ clEnumVal(PDLDetails , "print pass details when it is executed"),
+ clEnumValEnd));
+} // End of llvm namespace
+
#ifndef USE_OLD_PASSMANAGER
namespace llvm {
@@ -1241,6 +1263,10 @@ bool PassManagerImpl_New::addPass(Pass *P) {
bool PassManagerImpl_New::run(Module &M) {
bool Changed = false;
+
+ if (PassDebugging_New >= PDLStructure)
+ dumpPasses();
+
for (std::vector<Pass *>::iterator I = passManagersBegin(),
E = passManagersEnd(); I != E; ++I) {
ModulePassManager *MP = dynamic_cast<ModulePassManager *>(*I);
diff --git a/lib/VMCore/PassManagerT.h b/lib/VMCore/PassManagerT.h
index 62a340beb8..bb04cc1ba5 100644
--- a/lib/VMCore/PassManagerT.h
+++ b/lib/VMCore/PassManagerT.h
@@ -37,21 +37,16 @@ namespace llvm {
// pass name to be printed before it executes.
//
-// Different debug levels that can be enabled...
-enum PassDebugLevel {
- None, Arguments, Structure, Executions, Details
-};
-
static cl::opt<enum PassDebugLevel>
PassDebugging("debug-pass", cl::Hidden,
- cl::desc("Print PassManager debugging information"),
- cl::values(
- clEnumVal(None , "disable debug output"),
- clEnumVal(Arguments , "print pass arguments to pass to 'opt'"),
- clEnumVal(Structure , "print pass structure before run()"),
- clEnumVal(Executions, "print pass name before it is executed"),
- clEnumVal(Details , "print pass details when it is executed"),
- clEnumValEnd));
+ cl::desc("Print PassManager debugging information"),
+ cl::values(
+ clEnumVal(PDLNone , "disable debug output"),
+ clEnumVal(PDLArguments , "print pass arguments to pass to 'opt'"),
+ clEnumVal(PDLStructure , "print pass structure before run()"),
+ clEnumVal(PDLExecutions, "print pass name before it is executed"),
+ clEnumVal(PDLDetails , "print pass details when it is executed"),
+ clEnumValEnd));
//===----------------------------------------------------------------------===//
// PMDebug class - a set of debugging functions, that are not to be
@@ -60,13 +55,13 @@ PassDebugging("debug-pass", cl::Hidden,
struct PMDebug {
static void PerformPassStartupStuff(Pass *P) {
// If debugging is enabled, print out argument information...
- if (PassDebugging >= Arguments) {
+ if (PassDebugging >= PDLArguments) {
cerr << "Pass Arguments: ";
PrintArgumentInformation(P);
cerr << "\n";
// Print the pass execution structure
- if (PassDebugging >= Structure)
+ if (PassDebugging >= PDLStructure)
P->dumpPassStructure();
}
}
@@ -546,7 +541,7 @@ public:
cerr << "Analysis '" << (*I)->getPassName()
<< "' used but not available!";
assert(0 && "Analysis used but not available!");
- } else if (PassDebugging == Details) {
+ } else if (PassDebugging == PDLDetails) {
if ((*I)->getPassName() != std::string(Impl->getPassName()))
cerr << " Interface '" << (*I)->getPassName()
<< "' implemented by '" << Impl->getPassName() << "'\n";
@@ -635,7 +630,7 @@ private:
cerr << "Analysis '" << (*I)->getPassName()
<< "' used but not available!";
assert(0 && "Analysis used but not available!");
- } else if (PassDebugging == Details) {
+ } else if (PassDebugging == PDLDetails) {
if ((*I)->getPassName() != std::string(Impl->getPassName()))
cerr << " Interface '" << (*I)->getPassName()
<< "' implemented by '" << Impl->getPassName() << "'\n";