]> granicus.if.org Git - clang/commitdiff
Fixed UninitializedValues to properly propagate uninitialized "taint"
authorTed Kremenek <kremenek@apple.com>
Fri, 28 Sep 2007 21:08:51 +0000 (21:08 +0000)
committerTed Kremenek <kremenek@apple.com>
Fri, 28 Sep 2007 21:08:51 +0000 (21:08 +0000)
in assignment operations of the form +=, -=, *=, etc.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@42449 91177308-0d34-0410-b5e6-96231b3b80d8

Analysis/UninitializedValues.cpp

index a7c7ccbc1db90121a239079d62f3680e76ccd7ec..58b95fcffb557cc3f62b1d22b6b8904867baf204 100644 (file)
@@ -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);
 }