diff options
| author | Devang Patel <dpatel@apple.com> | 2007-07-09 20:52:39 +0000 | 
|---|---|---|
| committer | Devang Patel <dpatel@apple.com> | 2007-07-09 20:52:39 +0000 | 
| commit | 94d0fbe1a600aa50814a2b05dbe5ae0c53b20cc7 (patch) | |
| tree | 6fae5dbbe335af4985afc88099f6ce3840047350 | |
| parent | 6decfbf1332dda75c05d49d241409bc95ae7cf0e (diff) | |
| download | bcm5719-llvm-94d0fbe1a600aa50814a2b05dbe5ae0c53b20cc7.tar.gz bcm5719-llvm-94d0fbe1a600aa50814a2b05dbe5ae0c53b20cc7.zip  | |
Fix memory leak.
llvm-svn: 38469
| -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);  }  | 

