summaryrefslogtreecommitdiffstats
path: root/clang/Analysis/UninitializedValues.cpp
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2007-09-28 21:08:51 +0000
committerTed Kremenek <kremenek@apple.com>2007-09-28 21:08:51 +0000
commita1c256dd0eeec8d0897d1f2dab8a027148f0c2fe (patch)
tree22890486e65c0c614be8f33a12563e04256fc3c6 /clang/Analysis/UninitializedValues.cpp
parent8861abe6f2be9bc3f8cacebd4608908cf4fbe31c (diff)
downloadbcm5719-llvm-a1c256dd0eeec8d0897d1f2dab8a027148f0c2fe.tar.gz
bcm5719-llvm-a1c256dd0eeec8d0897d1f2dab8a027148f0c2fe.zip
Fixed UninitializedValues to properly propagate uninitialized "taint"
in assignment operations of the form +=, -=, *=, etc. llvm-svn: 42449
Diffstat (limited to 'clang/Analysis/UninitializedValues.cpp')
-rw-r--r--clang/Analysis/UninitializedValues.cpp18
1 files changed, 14 insertions, 4 deletions
diff --git a/clang/Analysis/UninitializedValues.cpp b/clang/Analysis/UninitializedValues.cpp
index a7c7ccbc1db..58b95fcffb5 100644
--- a/clang/Analysis/UninitializedValues.cpp
+++ b/clang/Analysis/UninitializedValues.cpp
@@ -106,10 +106,20 @@ BlockVarDecl* TransferFuncs::FindBlockVarDecl(Stmt *S) {
}
bool TransferFuncs::VisitBinaryOperator(BinaryOperator* B) {
- if (B->isAssignmentOp())
- if (BlockVarDecl* VD = FindBlockVarDecl(B->getLHS()))
- return V(VD,AD) = AD.FullUninitTaint ? Visit(B->getRHS()) : Initialized;
-
+ if (BlockVarDecl* VD = FindBlockVarDecl(B->getLHS()))
+ if (B->isAssignmentOp()) {
+ if (AD.FullUninitTaint) {
+ if (B->getOpcode() == BinaryOperator::Assign)
+ return V(VD,AD) = Visit(B->getRHS());
+ else // Handle +=, -=, *=, etc. We do want '&', not '&&'.
+ return V(VD,AD) = Visit(B->getLHS()) & Visit(B->getRHS());
+ }
+ else {
+ Visit(B->getLHS()); Visit(B->getRHS());
+ return Initialized;
+ }
+ }
+
return VisitStmt(B);
}
OpenPOWER on IntegriCloud