summaryrefslogtreecommitdiffstats
path: root/clang/lib/Analysis/GRExprEngine.cpp
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2008-06-18 05:34:07 +0000
committerTed Kremenek <kremenek@apple.com>2008-06-18 05:34:07 +0000
commit9a935fbdebc51d86802ceab7738c4dff4e8d4425 (patch)
tree566580cf1c4b180d94d002aafdbd6999263effaf /clang/lib/Analysis/GRExprEngine.cpp
parentef36dcd10b053c114cf80964ae901d762c685c42 (diff)
downloadbcm5719-llvm-9a935fbdebc51d86802ceab7738c4dff4e8d4425.tar.gz
bcm5719-llvm-9a935fbdebc51d86802ceab7738c4dff4e8d4425.zip
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.
llvm-svn: 52443
Diffstat (limited to 'clang/lib/Analysis/GRExprEngine.cpp')
-rw-r--r--clang/lib/Analysis/GRExprEngine.cpp14
1 files changed, 12 insertions, 2 deletions
diff --git a/clang/lib/Analysis/GRExprEngine.cpp b/clang/lib/Analysis/GRExprEngine.cpp
index 837d9100914..2580172d530 100644
--- a/clang/lib/Analysis/GRExprEngine.cpp
+++ b/clang/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();
OpenPOWER on IntegriCloud