aboutsummaryrefslogtreecommitdiff
path: root/lib/Analysis/GRExprEngine.cpp
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2008-04-29 23:24:44 +0000
committerTed Kremenek <kremenek@apple.com>2008-04-29 23:24:44 +0000
commit4d0348b6c74d2710a3693bbfbcfc5fcb3bc132ee (patch)
tree3a3564e3748b4dc19c0e87a10784c572da17538f /lib/Analysis/GRExprEngine.cpp
parentaa847fe3c88ee5e8d180e48537c58b805d48d95d (diff)
Add lval::ArrayOffset, which represent the locations of entries in an array.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@50453 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/GRExprEngine.cpp')
-rw-r--r--lib/Analysis/GRExprEngine.cpp88
1 files changed, 26 insertions, 62 deletions
diff --git a/lib/Analysis/GRExprEngine.cpp b/lib/Analysis/GRExprEngine.cpp
index a4f1a0512d..a7b31d5b6d 100644
--- a/lib/Analysis/GRExprEngine.cpp
+++ b/lib/Analysis/GRExprEngine.cpp
@@ -780,6 +780,7 @@ void GRExprEngine::VisitArraySubscriptExpr(ArraySubscriptExpr* A, NodeTy* Pred,
NodeSet& Dst, bool asLVal) {
Expr* Base = A->getBase()->IgnoreParens();
+ Expr* Idx = A->getIdx()->IgnoreParens();
// Always visit the base as an LVal expression. This computes the
// abstract address of the base object.
@@ -790,47 +791,25 @@ void GRExprEngine::VisitArraySubscriptExpr(ArraySubscriptExpr* A, NodeTy* Pred,
else
VisitLVal(Base, Pred, Tmp);
- // TODO: Compute the LVal for the entry. This will enable array sensitivity
- // for the analysis.
-
- // Return the LVal of the array entry.
- if (asLVal) {
+ for (NodeSet::iterator I1=Tmp.begin(), E1=Tmp.end(); I1!=E1; ++I1) {
- // This is a redunant copy; we do this as a placeholder for future logic.
- for (NodeSet::iterator I=Tmp.begin(), E=Tmp.end(); I!=E; ++I) {
-
- ValueState* St = GetState(*I);
- RVal V = GetRVal(St, Base);
-
- // TODO: Compute the LVal for the entry. This will enable array sensitivity
- // for the analysis.
-
- if (!(V.isUndef() || V.isUnknown() || isa<lval::ConcreteInt>(V)))
- V = UnknownVal();
+ // Evaluate the index.
+
+ NodeSet Tmp2;
+ Visit(Idx, *I1, Tmp2);
- MakeNode(Dst, A, *I, SetRVal(St, A, V));
- }
-
- return;
- }
-
- // We are doing a load. Check for a bad dereference. In the future we
- // will check the actual entry lval; for now, check the Base LVal. For now
- // the load will just return "UnknownVal" (since we don't have array
- // sensitivity), but it will perform a null check.
-
- for (NodeSet::iterator I=Tmp.begin(), E=Tmp.end(); I!=E; ++I) {
+ for (NodeSet::iterator I2=Tmp2.begin(), E2=Tmp2.end(); I2!=E2; ++I2) {
- ValueState* St = GetState(*I);
- RVal V = GetRVal(St, Base);
-
- // TODO: Compute the LVal for the entry. This will enable array sensitivity
- // for the analysis.
-
- if (!(V.isUndef() || V.isUnknown() || isa<lval::ConcreteInt>(V)))
- V = UnknownVal();
-
- EvalLoad(Dst, A, *I, St, GetRVal(St, Base), true);
+ ValueState* St = GetState(*I2);
+ RVal BaseV = GetRVal(St, Base);
+ RVal IdxV = GetRVal(St, Idx);
+ RVal V = lval::ArrayOffset::Make(BasicVals, BaseV, IdxV);
+
+ if (asLVal)
+ MakeNode(Dst, A, *I2, SetRVal(St, A, V));
+ else
+ EvalLoad(Dst, A, *I2, St, V);
+ }
}
}
@@ -849,36 +828,17 @@ void GRExprEngine::VisitMemberExpr(MemberExpr* M, NodeTy* Pred,
else
VisitLVal(Base, Pred, Tmp);
-
- // Return the LVal of the field access.
- if (asLVal) {
-
- // This is a redunant copy; we do this as a placeholder for future logic.
- for (NodeSet::iterator I=Tmp.begin(), E=Tmp.end(); I!=E; ++I) {
- ValueState* St = GetState(*I);
- RVal BaseV = GetRVal(St, Base);
-
- RVal V = lval::FieldOffset::Make(BasicVals, GetRVal(St, Base),
- M->getMemberDecl());
-
- MakeNode(Dst, M, *I, SetRVal(St, M, V));
- }
-
- return;
- }
-
- // We are doing a load. Check for a bad dereference. In the future we
- // will check the actual field lval; for now, check the Base LVal. For now
- // the load will just return "UnknownVal" (since we don't have field
- // sensitivity), but it will perform a null check.
-
for (NodeSet::iterator I=Tmp.begin(), E=Tmp.end(); I!=E; ++I) {
ValueState* St = GetState(*I);
+ RVal BaseV = GetRVal(St, Base);
RVal V = lval::FieldOffset::Make(BasicVals, GetRVal(St, Base),
M->getMemberDecl());
- EvalLoad(Dst, M, *I, St, V, true);
+ if (asLVal)
+ MakeNode(Dst, M, *I, SetRVal(St, M, V));
+ else
+ EvalLoad(Dst, M, *I, St, V);
}
}
@@ -2030,6 +1990,10 @@ ValueState* GRExprEngine::AssumeAux(ValueState* St, LVal Cond,
return AssumeAux(St, cast<lval::FieldOffset>(Cond).getBase(),
Assumption, isFeasible);
+ case lval::ArrayOffsetKind:
+ return AssumeAux(St, cast<lval::ArrayOffset>(Cond).getBase(),
+ Assumption, isFeasible);
+
case lval::ConcreteIntKind: {
bool b = cast<lval::ConcreteInt>(Cond).getValue() != 0;
isFeasible = b ? Assumption : !Assumption;