summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2007-11-24 20:07:36 +0000
committerTed Kremenek <kremenek@apple.com>2007-11-24 20:07:36 +0000
commit2e04d73d8353fe0103647668445432aaccb21c62 (patch)
tree232e2bc1970585369a2b309b1b44a7c016753af4
parent33407b333871f7ac3b4d9aa5a98c6af9a43865c6 (diff)
downloadbcm5719-llvm-2e04d73d8353fe0103647668445432aaccb21c62.tar.gz
bcm5719-llvm-2e04d73d8353fe0103647668445432aaccb21c62.zip
Fixed bogus culling of uninitialized-values "taint" propagation during assignments.
We accidentally were throttling the propagation of uninitialized state across assignments (e.g. x = y). Thanks to Anders Carlsson for spotting this problem. Added test cases to test suite to provide regression testing for the uninitialized values analysis. llvm-svn: 44306
-rw-r--r--clang/Analysis/UninitializedValues.cpp16
-rw-r--r--clang/test/Analysis/uninit-vals.c29
2 files changed, 35 insertions, 10 deletions
diff --git a/clang/Analysis/UninitializedValues.cpp b/clang/Analysis/UninitializedValues.cpp
index 0a496595f63..8a27b71b8fd 100644
--- a/clang/Analysis/UninitializedValues.cpp
+++ b/clang/Analysis/UninitializedValues.cpp
@@ -101,6 +101,8 @@ BlockVarDecl* TransferFuncs::FindBlockVarDecl(Stmt *S) {
else if (DeclRefExpr* DR = dyn_cast<DeclRefExpr>(S)) {
if (BlockVarDecl* VD = dyn_cast<BlockVarDecl>(DR->getDecl()))
return VD;
+ else
+ return NULL;
}
else return NULL;
}
@@ -108,16 +110,10 @@ BlockVarDecl* TransferFuncs::FindBlockVarDecl(Stmt *S) {
bool TransferFuncs::VisitBinaryOperator(BinaryOperator* B) {
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;
- }
+ 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());
}
return VisitStmt(B);
diff --git a/clang/test/Analysis/uninit-vals.c b/clang/test/Analysis/uninit-vals.c
new file mode 100644
index 00000000000..641acd1df0c
--- /dev/null
+++ b/clang/test/Analysis/uninit-vals.c
@@ -0,0 +1,29 @@
+// RUN: clang -warn-uninit-values -verify %s
+
+int f1() {
+ int x;
+ return x; // expected-warning{use of uninitialized variable}
+}
+
+int f2(int x) {
+ int y;
+ int z = x + y; // expected-warning {use of uninitialized variable}
+ return z;
+}
+
+
+int f3(int x) {
+ int y;
+ return x ? 1 : y; // expected-warning {use of uninitialized variable}
+}
+
+int f4(int x) {
+ int y;
+ if (x) y = 1;
+ return y; // no-warning
+}
+
+int f5() {
+ int a;
+ a = 30; // no-warning
+}
OpenPOWER on IntegriCloud