diff options
author | Ted Kremenek <kremenek@apple.com> | 2008-06-18 05:34:07 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2008-06-18 05:34:07 +0000 |
commit | 331b0ac44b9eb0ffcba66b4f3f3f9adb27c2434f (patch) | |
tree | ffb6b8127a7735a6996f4777740a1c8a135530a8 /lib/Analysis/GRExprEngine.cpp | |
parent | 60c5e4263b5146aa6c82ef1b6c1dbd391a285c95 (diff) |
Added a new ProgramPoint: PostPurgeDeadSymbols. This new program point distinguishes between the cases when we just evaluated the transfer function of a Stmt* (PostStmt) or performed a load (PostLoad). This solves a caching bug observed in a recent bug report.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@52443 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/GRExprEngine.cpp')
-rw-r--r-- | lib/Analysis/GRExprEngine.cpp | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/lib/Analysis/GRExprEngine.cpp b/lib/Analysis/GRExprEngine.cpp index 837d910091..2580172d53 100644 --- a/lib/Analysis/GRExprEngine.cpp +++ b/lib/Analysis/GRExprEngine.cpp @@ -214,6 +214,9 @@ void GRExprEngine::ProcessStmt(Stmt* S, StmtNodeBuilder& builder) { SaveAndRestore<bool> OldSink(Builder->BuildSinks); SaveOr OldHasGen(Builder->HasGeneratedNode); + SaveAndRestore<bool> OldPurgeDeadSymbols(Builder->PurgingDeadSymbols); + Builder->PurgingDeadSymbols = true; + TF->EvalDeadSymbols(Tmp, *this, *Builder, EntryNode, S, CleanedState, DeadSymbols); @@ -965,7 +968,10 @@ ValueState* GRExprEngine::EvalLocation(Expr* Ex, NodeTy* Pred, // Check for loads/stores from/to undefined values. if (location.isUndef()) { - if (NodeTy* Succ = Builder->generateNode(Ex, St, Pred, isLoad)) { + ProgramPoint::Kind K = + isLoad ? ProgramPoint::PostLoadKind : ProgramPoint::PostStmtKind; + + if (NodeTy* Succ = Builder->generateNode(Ex, St, Pred, K)) { Succ->markAsSink(); UndefDeref.insert(Succ); } @@ -1000,7 +1006,10 @@ ValueState* GRExprEngine::EvalLocation(Expr* Ex, NodeTy* Pred, // We don't use "MakeNode" here because the node will be a sink // and we have no intention of processing it later. - NodeTy* NullNode = Builder->generateNode(Ex, StNull, Pred, isLoad); + ProgramPoint::Kind K = + isLoad ? ProgramPoint::PostLoadKind : ProgramPoint::PostStmtKind; + + NodeTy* NullNode = Builder->generateNode(Ex, StNull, Pred, K); if (NullNode) { @@ -2437,6 +2446,7 @@ struct VISIBILITY_HIDDEN DOTGraphTraits<GRExprEngine::NodeTy*> : break; case ProgramPoint::PostLoadKind: + case ProgramPoint::PostPurgeDeadSymbolsKind: case ProgramPoint::PostStmtKind: { const PostStmt& L = cast<PostStmt>(Loc); Stmt* S = L.getStmt(); |