diff options
author | Ted Kremenek <kremenek@apple.com> | 2008-09-19 18:00:36 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2008-09-19 18:00:36 +0000 |
commit | 0a41e5a03a2753e736dece6fc6847e6de2dedec1 (patch) | |
tree | 42d69fc79d2bc7ea35d9aeb2a456f56358c3efcd | |
parent | 69d349a8743f156b965141cda80520bddda84601 (diff) |
Fixed logic error in BasicConstraintManager pointed out by Zhongxing Xu.
For checking if a symbol >= value, we need to check if symbol == value || symbol
> value. When checking symbol > value and we know that symbol != value, the path
is infeasible only if value == maximum integer.
For checking if a symbol <= value, we need to check if symbol == value || symbol
< value. When checking symbol < value and we know that symbol != value, the path
is infeasible only if value == minimum integer.
Updated test case exercising this logic: we only prune paths if the values are
unsigned.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@56354 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Analysis/BasicConstraintManager.cpp | 27 | ||||
-rw-r--r-- | test/Analysis/null-deref-ps.c | 8 |
2 files changed, 11 insertions, 24 deletions
diff --git a/lib/Analysis/BasicConstraintManager.cpp b/lib/Analysis/BasicConstraintManager.cpp index 9ff44e0112..0576eaf2a1 100644 --- a/lib/Analysis/BasicConstraintManager.cpp +++ b/lib/Analysis/BasicConstraintManager.cpp @@ -320,24 +320,9 @@ BasicConstraintManager::AssumeSymGE(const GRState* St, SymbolID sym, return St; } - // sym is not a constant, but it might be not-equal to a constant. - // Observe: V >= sym is the same as sym <= V. - // check: is sym != V? - // check: is sym > V? - // if both are true, the path is infeasible. - - if (isNotEqual(St, sym, V)) { - // Is sym > V? - // - // We're not doing heavy range analysis yet, so all we can accurately - // reason about are the edge cases. - // - // If V == 0, since we know that sym != V, we also know that sym > V. - isFeasible = V != 0; - } - else - isFeasible = true; - + isFeasible = !isNotEqual(St, sym, V) || + (V != llvm::APSInt::getMaxValue(V.getBitWidth(), V.isSigned())); + return St; } @@ -352,8 +337,10 @@ BasicConstraintManager::AssumeSymLE(const GRState* St, SymbolID sym, isFeasible = *X <= V; return St; } - - isFeasible = true; + + isFeasible = !isNotEqual(St, sym, V) || + (V != llvm::APSInt::getMinValue(V.getBitWidth(), V.isSigned())); + return St; } diff --git a/test/Analysis/null-deref-ps.c b/test/Analysis/null-deref-ps.c index 0f86acdabc..1fdcd06d43 100644 --- a/test/Analysis/null-deref-ps.c +++ b/test/Analysis/null-deref-ps.c @@ -91,21 +91,21 @@ int f8(int *p, int *q) { int* qux(); -int f9(int len) { +int f9(unsigned len) { assert (len != 0); int *p = 0; - for (int i = 0; i < len; ++i) + for (unsigned i = 0; i < len; ++i) p = qux(i); return *p++; // no-warning } -int f9b(int len) { +int f9b(unsigned len) { assert (len > 0); // note use of '>' int *p = 0; - for (int i = 0; i < len; ++i) + for (unsigned i = 0; i < len; ++i) p = qux(i); return *p++; // no-warning |