diff options
Diffstat (limited to 'llvm')
-rw-r--r-- | llvm/include/llvm/Pass.h | 10 | ||||
-rw-r--r-- | llvm/lib/VMCore/PassManager.cpp | 3 |
2 files changed, 8 insertions, 5 deletions
diff --git a/llvm/include/llvm/Pass.h b/llvm/include/llvm/Pass.h index cee635bd8a5..a5a98f53131 100644 --- a/llvm/include/llvm/Pass.h +++ b/llvm/include/llvm/Pass.h @@ -130,8 +130,14 @@ public: } // Access AnalysisResolver - inline void setResolver(AnalysisResolver *AR) { Resolver = AR; } - inline AnalysisResolver *getResolver() { return Resolver; } + inline void setResolver(AnalysisResolver *AR) { + assert (!Resolver && "Resolver is already set"); + Resolver = AR; + } + inline AnalysisResolver *getResolver() { + assert (Resolver && "Resolver is not set"); + return Resolver; + } /// getAnalysisUsage - This function should be overriden by passes that need /// analysis information to do their job. If a pass specifies that it uses a diff --git a/llvm/lib/VMCore/PassManager.cpp b/llvm/lib/VMCore/PassManager.cpp index 23e45c0b958..af3cfb025dc 100644 --- a/llvm/lib/VMCore/PassManager.cpp +++ b/llvm/lib/VMCore/PassManager.cpp @@ -1380,9 +1380,6 @@ void PMStack::push(Pass *P) { PM->setTopLevelManager(TPM); } - AnalysisResolver *AR = new AnalysisResolver(*Top); - P->setResolver(AR); - S.push_back(PM); } |