diff options
| author | Ted Kremenek <kremenek@apple.com> | 2007-09-28 21:08:51 +0000 |
|---|---|---|
| committer | Ted Kremenek <kremenek@apple.com> | 2007-09-28 21:08:51 +0000 |
| commit | a1c256dd0eeec8d0897d1f2dab8a027148f0c2fe (patch) | |
| tree | 22890486e65c0c614be8f33a12563e04256fc3c6 /clang/Analysis/UninitializedValues.cpp | |
| parent | 8861abe6f2be9bc3f8cacebd4608908cf4fbe31c (diff) | |
| download | bcm5719-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.cpp | 18 |
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); } |

