summaryrefslogtreecommitdiffstats
path: root/clang/test/Analysis/malloc.c
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2012-05-01 21:58:29 +0000
committerTed Kremenek <kremenek@apple.com>2012-05-01 21:58:29 +0000
commitf56d4f2991a79131f1670132a8bafcbdccb7e27b (patch)
tree61a0e3f6f879ab4cadc043f4c465865a74eb0805 /clang/test/Analysis/malloc.c
parent2565c596316978c5658cd474710dd7696edb0dc3 (diff)
downloadbcm5719-llvm-f56d4f2991a79131f1670132a8bafcbdccb7e27b.tar.gz
bcm5719-llvm-f56d4f2991a79131f1670132a8bafcbdccb7e27b.zip
Teach SValBuilder to handle casts of symbolic pointer values to an integer twice. Fixes <rdar://problem/11212866>.
llvm-svn: 155950
Diffstat (limited to 'clang/test/Analysis/malloc.c')
-rw-r--r--clang/test/Analysis/malloc.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/clang/test/Analysis/malloc.c b/clang/test/Analysis/malloc.c
index c19ee3259ca..c7ac56a3d07 100644
--- a/clang/test/Analysis/malloc.c
+++ b/clang/test/Analysis/malloc.c
@@ -839,3 +839,17 @@ void localArrayTest() {
ArrayL[0] = p;
}
+// Test double assignment through integers.
+static long glob;
+void test_double_assign_ints()
+{
+ void *ptr = malloc (16); // no-warning
+ glob = (long)(unsigned long)ptr;
+}
+
+void test_double_assign_ints_positive()
+{
+ void *ptr = malloc(16);
+ (void*)(long)(unsigned long)ptr; // expected-warning {{unused}} expected-warning {{leak}}
+}
+
OpenPOWER on IntegriCloud