1*67e74705SXin Li // RUN: %clang_cc1 -fsyntax-only -verify %s
2*67e74705SXin Li // rdar://9584012
3*67e74705SXin Li
4*67e74705SXin Li typedef struct {
5*67e74705SXin Li char *str;
6*67e74705SXin Li } Class;
7*67e74705SXin Li
8*67e74705SXin Li typedef union {
9*67e74705SXin Li Class *object;
10*67e74705SXin Li } Instance __attribute__((transparent_union));
11*67e74705SXin Li
Class_init(Instance this,char * str)12*67e74705SXin Li __attribute__((nonnull(1))) void Class_init(Instance this, char *str) {
13*67e74705SXin Li this.object->str = str;
14*67e74705SXin Li }
15*67e74705SXin Li
main(void)16*67e74705SXin Li int main(void) {
17*67e74705SXin Li Class *obj;
18*67e74705SXin Li Class_init(0, "Hello World"); // expected-warning {{null passed to a callee that requires a non-null argument}}
19*67e74705SXin Li Class_init(obj, "Hello World");
20*67e74705SXin Li }
21*67e74705SXin Li
22*67e74705SXin Li void foo(const char *str) __attribute__((nonnull("foo"))); // expected-error{{'nonnull' attribute requires parameter 1 to be an integer constant}}
23*67e74705SXin Li void bar(int i) __attribute__((nonnull(1))); // expected-warning {{'nonnull' attribute only applies to pointer arguments}} expected-warning {{'nonnull' attribute applied to function with no pointer arguments}}
24*67e74705SXin Li
25*67e74705SXin Li void baz(__attribute__((nonnull)) const char *str);
26*67e74705SXin Li void baz2(__attribute__((nonnull(1))) const char *str); // expected-warning {{'nonnull' attribute when used on parameters takes no arguments}}
27*67e74705SXin Li void baz3(__attribute__((nonnull)) int x); // expected-warning {{'nonnull' attribute only applies to pointer arguments}}
28*67e74705SXin Li
test_baz()29*67e74705SXin Li void test_baz() {
30*67e74705SXin Li baz(0); // expected-warning {{null passed to a callee that requires a non-null argument}}
31*67e74705SXin Li baz2(0); // no-warning
32*67e74705SXin Li baz3(0); // no-warning
33*67e74705SXin Li }
34*67e74705SXin Li
35*67e74705SXin Li void test_void_returns_nonnull(void) __attribute__((returns_nonnull)); // expected-warning {{'returns_nonnull' attribute only applies to return values that are pointers}}
36*67e74705SXin Li int test_int_returns_nonnull(void) __attribute__((returns_nonnull)); // expected-warning {{'returns_nonnull' attribute only applies to return values that are pointers}}
37*67e74705SXin Li void *test_ptr_returns_nonnull(void) __attribute__((returns_nonnull)); // no-warning
38*67e74705SXin Li
39*67e74705SXin Li int i __attribute__((nonnull)); // expected-warning {{'nonnull' attribute only applies to functions, methods, and parameters}}
40*67e74705SXin Li int j __attribute__((returns_nonnull)); // expected-warning {{'returns_nonnull' attribute only applies to functions and methods}}
41*67e74705SXin Li void *test_no_fn_proto() __attribute__((returns_nonnull)); // no-warning
42*67e74705SXin Li void *test_with_fn_proto(void) __attribute__((returns_nonnull)); // no-warning
43*67e74705SXin Li
44*67e74705SXin Li __attribute__((returns_nonnull))
test_bad_returns_null(void)45*67e74705SXin Li void *test_bad_returns_null(void) {
46*67e74705SXin Li return 0; // expected-warning {{null returned from function that requires a non-null return value}}
47*67e74705SXin Li }
48*67e74705SXin Li
PR18795(int (* g)(const char * h,...))49*67e74705SXin Li void PR18795(int (*g)(const char *h, ...) __attribute__((nonnull(1))) __attribute__((nonnull))) {
50*67e74705SXin Li g(0); // expected-warning{{null passed to a callee that requires a non-null argument}}
51*67e74705SXin Li }
PR18795_helper()52*67e74705SXin Li void PR18795_helper() {
53*67e74705SXin Li PR18795(0); // expected-warning{{null passed to a callee that requires a non-null argument}}
54*67e74705SXin Li }
55*67e74705SXin Li
56*67e74705SXin Li void vararg1(int n, ...) __attribute__((nonnull(2)));
vararg1_test()57*67e74705SXin Li void vararg1_test() {
58*67e74705SXin Li vararg1(0);
59*67e74705SXin Li vararg1(1, (void*)0); // expected-warning{{null passed}}
60*67e74705SXin Li vararg1(2, (void*)0, (void*)0); // expected-warning{{null passed}}
61*67e74705SXin Li vararg1(2, (void*)&vararg1, (void*)0);
62*67e74705SXin Li }
63*67e74705SXin Li
64*67e74705SXin Li void vararg2(int n, ...) __attribute__((nonnull, nonnull, nonnull));
vararg2_test()65*67e74705SXin Li void vararg2_test() {
66*67e74705SXin Li vararg2(0);
67*67e74705SXin Li vararg2(1, (void*)0); // expected-warning{{null passed}}
68*67e74705SXin Li vararg2(2, (void*)0, (void*)0); // expected-warning 2{{null passed}}
69*67e74705SXin Li }
70*67e74705SXin Li
71*67e74705SXin Li void vararg3(int n, ...) __attribute__((nonnull, nonnull(2), nonnull(3)));
vararg3_test()72*67e74705SXin Li void vararg3_test() {
73*67e74705SXin Li vararg3(0);
74*67e74705SXin Li vararg3(1, (void*)0); // expected-warning{{null passed}}
75*67e74705SXin Li vararg3(2, (void*)0, (void*)0); // expected-warning 2{{null passed}}
76*67e74705SXin Li }
77*67e74705SXin Li
78*67e74705SXin Li void redecl(void *, void *);
79*67e74705SXin Li void redecl(void *, void *) __attribute__((nonnull(1)));
80*67e74705SXin Li void redecl(void *, void *) __attribute__((nonnull(2)));
81*67e74705SXin Li void redecl(void *, void *);
redecl_test(void * p)82*67e74705SXin Li void redecl_test(void *p) {
83*67e74705SXin Li redecl(p, 0); // expected-warning{{null passed}}
84*67e74705SXin Li redecl(0, p); // expected-warning{{null passed}}
85*67e74705SXin Li }
86*67e74705SXin Li
87*67e74705SXin Li // rdar://18712242
88*67e74705SXin Li #define NULL (void*)0
89*67e74705SXin Li __attribute__((__nonnull__)) // expected-note 2{{declared 'nonnull' here}}
evil_nonnull_func(int * pointer,void * pv)90*67e74705SXin Li int evil_nonnull_func(int* pointer, void * pv)
91*67e74705SXin Li {
92*67e74705SXin Li if (pointer == NULL) { // expected-warning {{comparison of nonnull parameter 'pointer' equal to a null pointer is 'false' on first encounter}}
93*67e74705SXin Li return 0;
94*67e74705SXin Li } else {
95*67e74705SXin Li return *pointer;
96*67e74705SXin Li }
97*67e74705SXin Li
98*67e74705SXin Li pointer = pv;
99*67e74705SXin Li if (!pointer)
100*67e74705SXin Li return 0;
101*67e74705SXin Li else
102*67e74705SXin Li return *pointer;
103*67e74705SXin Li
104*67e74705SXin Li if (pv == NULL) {} // expected-warning {{comparison of nonnull parameter 'pv' equal to a null pointer is 'false' on first encounter}}
105*67e74705SXin Li }
106*67e74705SXin Li
107*67e74705SXin Li void set_param_to_null(int**);
108*67e74705SXin Li int another_evil_nonnull_func(int* pointer, char ch, void * pv) __attribute__((nonnull(1, 3))); // expected-note 2{{declared 'nonnull' here}}
another_evil_nonnull_func(int * pointer,char ch,void * pv)109*67e74705SXin Li int another_evil_nonnull_func(int* pointer, char ch, void * pv) {
110*67e74705SXin Li if (pointer == NULL) { // expected-warning {{comparison of nonnull parameter 'pointer' equal to a null pointer is 'false' on first encounter}}
111*67e74705SXin Li return 0;
112*67e74705SXin Li } else {
113*67e74705SXin Li return *pointer;
114*67e74705SXin Li }
115*67e74705SXin Li
116*67e74705SXin Li set_param_to_null(&pointer);
117*67e74705SXin Li if (!pointer)
118*67e74705SXin Li return 0;
119*67e74705SXin Li else
120*67e74705SXin Li return *pointer;
121*67e74705SXin Li
122*67e74705SXin Li if (pv == NULL) {} // expected-warning {{comparison of nonnull parameter 'pv' equal to a null pointer is 'false' on first encounter}}
123*67e74705SXin Li }
124*67e74705SXin Li
125*67e74705SXin Li extern void *returns_null(void**);
126*67e74705SXin Li extern void FOO();
127*67e74705SXin Li extern void FEE();
128*67e74705SXin Li
129*67e74705SXin Li extern void *pv;
130*67e74705SXin Li __attribute__((__nonnull__)) // expected-note {{declared 'nonnull' here}}
yet_another_evil_nonnull_func(int * pointer)131*67e74705SXin Li void yet_another_evil_nonnull_func(int* pointer)
132*67e74705SXin Li {
133*67e74705SXin Li while (pv) {
134*67e74705SXin Li // This comparison will not be optimized away.
135*67e74705SXin Li if (pointer) { // expected-warning {{nonnull parameter 'pointer' will evaluate to 'true' on first encounter}}
136*67e74705SXin Li FOO();
137*67e74705SXin Li } else {
138*67e74705SXin Li FEE();
139*67e74705SXin Li }
140*67e74705SXin Li pointer = returns_null(&pv);
141*67e74705SXin Li }
142*67e74705SXin Li }
143*67e74705SXin Li
pr21668_1(const char * p,const char * s)144*67e74705SXin Li void pr21668_1(__attribute__((nonnull)) const char *p, const char *s) { // expected-note {{declared 'nonnull' here}}
145*67e74705SXin Li if (p) // expected-warning {{nonnull parameter 'p' will evaluate to 'true' on first encounter}}
146*67e74705SXin Li ;
147*67e74705SXin Li if (s) // No warning
148*67e74705SXin Li ;
149*67e74705SXin Li }
150*67e74705SXin Li
pr21668_2(const char * p)151*67e74705SXin Li void pr21668_2(__attribute__((nonnull)) const char *p) {
152*67e74705SXin Li p = 0;
153*67e74705SXin Li if (p) // No warning
154*67e74705SXin Li ;
155*67e74705SXin Li }
156*67e74705SXin Li
157*67e74705SXin Li __attribute__((returns_nonnull)) void *returns_nonnull_whee(); // expected-note 6{{declared 'returns_nonnull' here}}
158*67e74705SXin Li
returns_nonnull_warning_tests()159*67e74705SXin Li void returns_nonnull_warning_tests() {
160*67e74705SXin Li if (returns_nonnull_whee() == NULL) {} // expected-warning {{comparison of nonnull function call 'returns_nonnull_whee()' equal to a null pointer is 'false' on first encounter}}
161*67e74705SXin Li
162*67e74705SXin Li if (returns_nonnull_whee() != NULL) {} // expected-warning {{comparison of nonnull function call 'returns_nonnull_whee()' not equal to a null pointer is 'true' on first encounter}}
163*67e74705SXin Li
164*67e74705SXin Li if (returns_nonnull_whee()) {} // expected-warning {{nonnull function call 'returns_nonnull_whee()' will evaluate to 'true' on first encounter}}
165*67e74705SXin Li if (!returns_nonnull_whee()) {} // expected-warning {{nonnull function call 'returns_nonnull_whee()' will evaluate to 'true' on first encounter}}
166*67e74705SXin Li
167*67e74705SXin Li int and_again = !returns_nonnull_whee(); // expected-warning {{nonnull function call 'returns_nonnull_whee()' will evaluate to 'true' on first encounter}}
168*67e74705SXin Li and_again = !returns_nonnull_whee(); // expected-warning {{nonnull function call 'returns_nonnull_whee()' will evaluate to 'true' on first encounter}}
169*67e74705SXin Li }
170