summaryrefslogtreecommitdiffstats
path: root/clang/test
diff options
context:
space:
mode:
authorAnna Zaks <ganna@apple.com>2015-06-26 17:42:58 +0000
committerAnna Zaks <ganna@apple.com>2015-06-26 17:42:58 +0000
commit3849dea8c97be08a4c80787d00893f52145328f3 (patch)
tree74f9c7e7f307accf7cf2714542dbf71a79a2aa71 /clang/test
parentbced3032e02b95433b9ab576f030f20a687657cd (diff)
downloadbcm5719-llvm-3849dea8c97be08a4c80787d00893f52145328f3.tar.gz
bcm5719-llvm-3849dea8c97be08a4c80787d00893f52145328f3.zip
[static analyzer] Analyzer is skipping forward declared C/C++ functions
A patch by Karthik Bhat! This patch fixes a regression introduced by r224398. Prior to r224398 we were able to analyze the following code in test-include.c and report a null deref in this case. But post r224398 this analysis is being skipped. E.g. // test-include.c #include "test-include.h" void test(int * data) { data = 0; *data = 1; } // test-include.h void test(int * data); This patch uses the function body (instead of its declaration) as the location of the function when deciding if the Decl should be analyzed with path-sensitive analysis. (Prior to r224398, the call graph was guaranteed to have a definition when available.) llvm-svn: 240800
Diffstat (limited to 'clang/test')
-rw-r--r--clang/test/Analysis/test-include-cpp.cpp13
-rw-r--r--clang/test/Analysis/test-include-cpp.h9
-rw-r--r--clang/test/Analysis/test-include.c21
-rw-r--r--clang/test/Analysis/test-include.h2
4 files changed, 45 insertions, 0 deletions
diff --git a/clang/test/Analysis/test-include-cpp.cpp b/clang/test/Analysis/test-include-cpp.cpp
new file mode 100644
index 00000000000..2ac5e11c997
--- /dev/null
+++ b/clang/test/Analysis/test-include-cpp.cpp
@@ -0,0 +1,13 @@
+// RUN: %clang_cc1 -analyze -analyzer-checker=core -verify %s
+
+#include "test-include-cpp.h"
+
+int TestIncludeClass::test1(int *p) {
+ p = 0;
+ return *p; // expected-warning{{Dereference of null pointer}}
+}
+
+int TestIncludeClass::test2(int *p) {
+ p = 0;
+ return *p; // expected-warning{{Dereference of null pointer}}
+}
diff --git a/clang/test/Analysis/test-include-cpp.h b/clang/test/Analysis/test-include-cpp.h
new file mode 100644
index 00000000000..90ec27acd5d
--- /dev/null
+++ b/clang/test/Analysis/test-include-cpp.h
@@ -0,0 +1,9 @@
+#ifndef TEST_INCLUDE_CPP_H
+#define TEST_INCLUDE_CPP_H
+
+class TestIncludeClass {
+ int test1(int *);
+ static int test2(int *);
+};
+
+#endif
diff --git a/clang/test/Analysis/test-include.c b/clang/test/Analysis/test-include.c
new file mode 100644
index 00000000000..6aa80b96426
--- /dev/null
+++ b/clang/test/Analysis/test-include.c
@@ -0,0 +1,21 @@
+// RUN: %clang_cc1 -analyze -analyzer-checker=core -verify %s
+
+#include "test-include.h"
+#define DIVYX(X,Y) Y/X
+
+void test_01(int *data) {
+ data = 0;
+ *data = 1; // expected-warning{{Dereference of null pointer}}
+}
+
+int test_02() {
+ int res = DIVXY(1,0); // expected-warning{{Division by zero}}
+ // expected-warning@-1{{division by zero is undefined}}
+ return res;
+}
+
+int test_03() {
+ int res = DIVYX(0,1); // expected-warning{{Division by zero}}
+ // expected-warning@-1{{division by zero is undefined}}
+ return res;
+} \ No newline at end of file
diff --git a/clang/test/Analysis/test-include.h b/clang/test/Analysis/test-include.h
new file mode 100644
index 00000000000..07cd1c9dca1
--- /dev/null
+++ b/clang/test/Analysis/test-include.h
@@ -0,0 +1,2 @@
+void test_01(int * data);
+#define DIVXY(X,Y) X/Y
OpenPOWER on IntegriCloud