diff options
-rw-r--r-- | lib/VMCore/PassManager.cpp | 26 |
1 files changed, 8 insertions, 18 deletions
diff --git a/lib/VMCore/PassManager.cpp b/lib/VMCore/PassManager.cpp index 00f08cac9e..d71192689a 100644 --- a/lib/VMCore/PassManager.cpp +++ b/lib/VMCore/PassManager.cpp @@ -1686,17 +1686,14 @@ void PMStack::handleLastUserOverflow() { /// add self into that manager. void ModulePass::assignPassManager(PMStack &PMS) { - MPPassManager *MPP = NULL; - // Find Module Pass Manager while(!PMS.empty()) { - - MPP = dynamic_cast<MPPassManager *>(PMS.top()); - if (MPP) - break; // Found it - else + if (PMS.top()->getPassManagerType() > PMT_ModulePassManager) PMS.pop(); // Pop children pass managers + else + break; } + MPPassManager *MPP = dynamic_cast<MPPassManager *>(PMS.top()); assert(MPP && "Unable to find Module Pass Manager"); MPP->addPassToManager(this); @@ -1706,21 +1703,14 @@ void ModulePass::assignPassManager(PMStack &PMS) { /// in the PM Stack and add self into that manager. void FunctionPass::assignPassManager(PMStack &PMS) { - FPPassManager *FPP = NULL; - // Find Module Pass Manager (TODO : Or Call Graph Pass Manager) while(!PMS.empty()) { - - FPP = dynamic_cast<FPPassManager *>(PMS.top()); - if (FPP) - break; // Found Function Pass Manager - else if (dynamic_cast<BBPassManager *>(PMS.top())) - PMS.pop(); // Pop Basic Block Pass Manager - // TODO : else if Pop Loop Pass Manager + if (PMS.top()->getPassManagerType() > PMT_FunctionPassManager) + PMS.pop(); else - break; // PMS.top() is either Module Pass Manager or Call Graph - // Pass Manager + break; } + FPPassManager *FPP = dynamic_cast<FPPassManager *>(PMS.top()); // Create new Function Pass Manager if (!FPP) { |