summaryrefslogtreecommitdiffstats
path: root/clang/test
diff options
context:
space:
mode:
authorJordan Rose <jordan_rose@apple.com>2013-04-29 17:23:03 +0000
committerJordan Rose <jordan_rose@apple.com>2013-04-29 17:23:03 +0000
commit49f888bbab84f3463940aa5cd251fc6b63c14da1 (patch)
tree67e9008836051f10c59b72d60eda22cc66885cdc /clang/test
parenta44c1e6b63930c2e380d4c1f09ac47984ad67775 (diff)
downloadbcm5719-llvm-49f888bbab84f3463940aa5cd251fc6b63c14da1.tar.gz
bcm5719-llvm-49f888bbab84f3463940aa5cd251fc6b63c14da1.zip
Revert "[analyzer] Model casts to bool differently from other numbers."
This seems to be causing quite a slowdown on our internal analyzer bot, and I'm not sure why. Needs further investigation. This reverts r180638 / 9e161ea981f22ae017b6af09d660bfc3ddf16a09. llvm-svn: 180714
Diffstat (limited to 'clang/test')
-rw-r--r--clang/test/Analysis/bool-assignment.c16
-rw-r--r--clang/test/Analysis/casts.c38
-rw-r--r--clang/test/Analysis/stack-addr-ps.cpp41
-rw-r--r--clang/test/Analysis/stackaddrleak.c28
4 files changed, 12 insertions, 111 deletions
diff --git a/clang/test/Analysis/bool-assignment.c b/clang/test/Analysis/bool-assignment.c
index 0f782fbfd9a..86a581def64 100644
--- a/clang/test/Analysis/bool-assignment.c
+++ b/clang/test/Analysis/bool-assignment.c
@@ -1,19 +1,15 @@
// RUN: %clang_cc1 -analyze -analyzer-checker=core,alpha.core.BoolAssignment -analyzer-store=region -verify -std=c99 -Dbool=_Bool %s
// RUN: %clang_cc1 -analyze -analyzer-checker=core,alpha.core.BoolAssignment -analyzer-store=region -verify -x c++ %s
-// Test C++'s bool and C's _Bool.
-// FIXME: We stopped warning on these when SValBuilder got smarter about
-// casts to bool. Arguably, however, these conversions are okay; the result
-// is always 'true' or 'false'.
+// Test C++'s bool and C's _Bool
void test_stdbool_initialization(int y) {
- bool constant = 2; // no-warning
if (y < 0) {
- bool x = y; // no-warning
+ bool x = y; // expected-warning {{Assignment of a non-Boolean value}}
return;
}
if (y > 1) {
- bool x = y; // no-warning
+ bool x = y; // expected-warning {{Assignment of a non-Boolean value}}
return;
}
bool x = y; // no-warning
@@ -22,11 +18,11 @@ void test_stdbool_initialization(int y) {
void test_stdbool_assignment(int y) {
bool x = 0; // no-warning
if (y < 0) {
- x = y; // no-warning
+ x = y; // expected-warning {{Assignment of a non-Boolean value}}
return;
}
if (y > 1) {
- x = y; // no-warning
+ x = y; // expected-warning {{Assignment of a non-Boolean value}}
return;
}
x = y; // no-warning
@@ -37,7 +33,6 @@ void test_stdbool_assignment(int y) {
typedef signed char BOOL;
void test_BOOL_initialization(int y) {
- BOOL constant = 2; // expected-warning {{Assignment of a non-Boolean value}}
if (y < 0) {
BOOL x = y; // expected-warning {{Assignment of a non-Boolean value}}
return;
@@ -68,7 +63,6 @@ void test_BOOL_assignment(int y) {
typedef unsigned char Boolean;
void test_Boolean_initialization(int y) {
- Boolean constant = 2; // expected-warning {{Assignment of a non-Boolean value}}
if (y < 0) {
Boolean x = y; // expected-warning {{Assignment of a non-Boolean value}}
return;
diff --git a/clang/test/Analysis/casts.c b/clang/test/Analysis/casts.c
index 3e2f8077ede..087bd978e11 100644
--- a/clang/test/Analysis/casts.c
+++ b/clang/test/Analysis/casts.c
@@ -1,7 +1,6 @@
-// RUN: %clang_cc1 -triple x86_64-apple-darwin9 -analyze -analyzer-checker=core,alpha.core,debug.ExprInspection -analyzer-store=region -verify %s
-// RUN: %clang_cc1 -triple i386-apple-darwin9 -analyze -analyzer-checker=core,alpha.core,debug.ExprInspection -analyzer-store=region -verify %s
-
-extern void clang_analyzer_eval(_Bool);
+// RUN: %clang_cc1 -triple x86_64-apple-darwin9 -analyze -analyzer-checker=core,alpha.core -analyzer-store=region -verify %s
+// RUN: %clang_cc1 -triple i386-apple-darwin9 -analyze -analyzer-checker=core,alpha.core -analyzer-store=region -verify %s
+// expected-no-diagnostics
// Test if the 'storage' region gets properly initialized after it is cast to
// 'struct sockaddr *'.
@@ -86,34 +85,3 @@ int foo (int* p) {
}
return 0;
}
-
-void castsToBool() {
- clang_analyzer_eval(0); // expected-warning{{FALSE}}
- clang_analyzer_eval(0U); // expected-warning{{FALSE}}
- clang_analyzer_eval((void *)0); // expected-warning{{FALSE}}
-
- clang_analyzer_eval(1); // expected-warning{{TRUE}}
- clang_analyzer_eval(1U); // expected-warning{{TRUE}}
- clang_analyzer_eval(-1); // expected-warning{{TRUE}}
- clang_analyzer_eval(0x100); // expected-warning{{TRUE}}
- clang_analyzer_eval(0x100U); // expected-warning{{TRUE}}
- clang_analyzer_eval((void *)0x100); // expected-warning{{TRUE}}
-
- extern int symbolicInt;
- clang_analyzer_eval(symbolicInt); // expected-warning{{UNKNOWN}}
- if (symbolicInt)
- clang_analyzer_eval(symbolicInt); // expected-warning{{TRUE}}
-
- extern void *symbolicPointer;
- clang_analyzer_eval(symbolicPointer); // expected-warning{{UNKNOWN}}
- if (symbolicPointer)
- clang_analyzer_eval(symbolicPointer); // expected-warning{{TRUE}}
-
- int localInt;
- clang_analyzer_eval(&localInt); // expected-warning{{TRUE}}
- clang_analyzer_eval(&castsToBool); // expected-warning{{TRUE}}
- clang_analyzer_eval("abc"); // expected-warning{{TRUE}}
-
- extern float globalFloat;
- clang_analyzer_eval(globalFloat); // expected-warning{{UNKNOWN}}
-}
diff --git a/clang/test/Analysis/stack-addr-ps.cpp b/clang/test/Analysis/stack-addr-ps.cpp
index 65d757154c8..7aefea5095c 100644
--- a/clang/test/Analysis/stack-addr-ps.cpp
+++ b/clang/test/Analysis/stack-addr-ps.cpp
@@ -1,7 +1,7 @@
// RUN: %clang_cc1 -analyze -analyzer-checker=core -analyzer-store=region -verify %s
-typedef __INTPTR_TYPE__ intptr_t;
-
+// FIXME: Only the stack-address checking in Sema catches this right now, and
+// the stack analyzer doesn't handle the ImplicitCastExpr (lvalue).
const int& g() {
int s;
return s; // expected-warning{{Address of stack memory associated with local variable 's' returned}} expected-warning{{reference to stack memory associated with local variable 's' returned}}
@@ -96,40 +96,3 @@ void *radar13226577() {
return p; // expected-warning {{stack memory associated with local variable 'p' returned to caller}}
}
-namespace rdar13296133 {
- class ConvertsToBool {
- public:
- operator bool() const { return this; }
- };
-
- class ConvertsToIntptr {
- public:
- operator intptr_t() const { return reinterpret_cast<intptr_t>(this); }
- };
-
- class ConvertsToPointer {
- public:
- operator const void *() const { return this; }
- };
-
- intptr_t returnAsNonLoc() {
- ConvertsToIntptr obj;
- return obj; // expected-warning{{Address of stack memory associated with local variable 'obj' returned to caller}}
- }
-
- bool returnAsBool() {
- ConvertsToBool obj;
- return obj; // no-warning
- }
-
- intptr_t returnAsNonLocViaPointer() {
- ConvertsToPointer obj;
- return reinterpret_cast<intptr_t>(static_cast<const void *>(obj)); // expected-warning{{Address of stack memory associated with local variable 'obj' returned to caller}}
- }
-
- bool returnAsBoolViaPointer() {
- ConvertsToPointer obj;
- return obj; // no-warning
- }
-}
-
diff --git a/clang/test/Analysis/stackaddrleak.c b/clang/test/Analysis/stackaddrleak.c
index 4f81f6623e5..10564faff38 100644
--- a/clang/test/Analysis/stackaddrleak.c
+++ b/clang/test/Analysis/stackaddrleak.c
@@ -1,7 +1,5 @@
-// RUN: %clang_cc1 -analyze -analyzer-checker=core -verify -std=c99 -Dbool=_Bool %s
-// RUN: %clang_cc1 -analyze -analyzer-checker=core -verify -x c++ %s
+// RUN: %clang_cc1 -analyze -analyzer-checker=core -analyzer-store region -verify %s
-typedef __INTPTR_TYPE__ intptr_t;
char const *p;
void f0() {
@@ -17,7 +15,7 @@ void f1() {
void f2() {
p = (const char *) __builtin_alloca(12);
-} // expected-warning{{Address of stack memory allocated by call to alloca() on line 19 is still referred to by the global variable 'p' upon returning to the caller. This will be a dangling reference}}
+} // expected-warning{{Address of stack memory allocated by call to alloca() on line 17 is still referred to by the global variable 'p' upon returning to the caller. This will be a dangling reference}}
// PR 7383 - previosly the stack address checker would crash on this example
// because it would attempt to do a direct load from 'pr7383_list'.
@@ -34,25 +32,3 @@ void test_multi_return() {
a = &x;
b = &x;
} // expected-warning{{Address of stack memory associated with local variable 'x' is still referred to by the global variable 'a' upon returning}} expected-warning{{Address of stack memory associated with local variable 'x' is still referred to by the global variable 'b' upon returning}}
-
-intptr_t returnAsNonLoc() {
- int x;
- return (intptr_t)&x; // expected-warning{{Address of stack memory associated with local variable 'x' returned to caller}}
-}
-
-bool returnAsBool() {
- int x;
- return &x; // no-warning
-}
-
-void assignAsNonLoc() {
- extern intptr_t ip;
- int x;
- ip = (intptr_t)&x;
-} // expected-warning{{Address of stack memory associated with local variable 'x' is still referred to by the global variable 'ip' upon returning}}
-
-void assignAsBool() {
- extern bool b;
- int x;
- b = &x;
-} // no-warning
OpenPOWER on IntegriCloud