summaryrefslogtreecommitdiffstats
path: root/clang/lib/StaticAnalyzer/Core/SValBuilder.cpp
diff options
context:
space:
mode:
authorAnna Zaks <ganna@apple.com>2011-12-09 03:34:02 +0000
committerAnna Zaks <ganna@apple.com>2011-12-09 03:34:02 +0000
commit6af472aa3bd50463ab8a366eb424f14bcda8d494 (patch)
tree8c7527e4f18b7c5db84366efb3cb291eb7fff7ef /clang/lib/StaticAnalyzer/Core/SValBuilder.cpp
parent98e642db2c27d89e50ec5c2e70bffd09d5bc5d5c (diff)
downloadbcm5719-llvm-6af472aa3bd50463ab8a366eb424f14bcda8d494.tar.gz
bcm5719-llvm-6af472aa3bd50463ab8a366eb424f14bcda8d494.zip
[analyzer] Fix inconsistency on when SValBuilder assumes that 2
types are equivalent. + A taint test which tests bitwise operations and which was triggering an assertion due to presence of the integer to integer cast. llvm-svn: 146240
Diffstat (limited to 'clang/lib/StaticAnalyzer/Core/SValBuilder.cpp')
-rw-r--r--clang/lib/StaticAnalyzer/Core/SValBuilder.cpp3
1 files changed, 1 insertions, 2 deletions
diff --git a/clang/lib/StaticAnalyzer/Core/SValBuilder.cpp b/clang/lib/StaticAnalyzer/Core/SValBuilder.cpp
index ff0a85a5723..f381f1a5ad9 100644
--- a/clang/lib/StaticAnalyzer/Core/SValBuilder.cpp
+++ b/clang/lib/StaticAnalyzer/Core/SValBuilder.cpp
@@ -37,7 +37,6 @@ DefinedOrUnknownSVal SValBuilder::makeZeroVal(QualType type) {
return UnknownVal();
}
-
NonLoc SValBuilder::makeNonLoc(const SymExpr *lhs, BinaryOperator::Opcode op,
const llvm::APSInt& rhs, QualType type) {
// The Environment ensures we always get a persistent APSInt in
@@ -51,7 +50,7 @@ NonLoc SValBuilder::makeNonLoc(const SymExpr *lhs, BinaryOperator::Opcode op,
NonLoc SValBuilder::makeNonLoc(const SymExpr *lhs, BinaryOperator::Opcode op,
const SymExpr *rhs, QualType type) {
assert(lhs && rhs);
- assert(SymMgr.getType(lhs) == SymMgr.getType(rhs));
+ assert(haveSameType(lhs->getType(Context), rhs->getType(Context)) == true);
assert(!Loc::isLocType(type));
return nonloc::SymbolVal(SymMgr.getSymSymExpr(lhs, op, rhs, type));
}
OpenPOWER on IntegriCloud