diff options
| author | Anna Zaks <ganna@apple.com> | 2015-06-26 17:42:58 +0000 |
|---|---|---|
| committer | Anna Zaks <ganna@apple.com> | 2015-06-26 17:42:58 +0000 |
| commit | 3849dea8c97be08a4c80787d00893f52145328f3 (patch) | |
| tree | 74f9c7e7f307accf7cf2714542dbf71a79a2aa71 /clang/test | |
| parent | bced3032e02b95433b9ab576f030f20a687657cd (diff) | |
| download | bcm5719-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.cpp | 13 | ||||
| -rw-r--r-- | clang/test/Analysis/test-include-cpp.h | 9 | ||||
| -rw-r--r-- | clang/test/Analysis/test-include.c | 21 | ||||
| -rw-r--r-- | clang/test/Analysis/test-include.h | 2 |
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 |

