blob: e19c6761784c854e3ab06fc50705f3e97fcf220c [file] [log] [blame]
Gabor Horvathdbf27902017-03-07 16:04:23 +00001// RUN: %clang_analyze_cc1 -triple hexagon-unknown-linux -analyzer-checker=core,valist.Unterminated,valist.CopyToSelf -analyzer-output=text -analyzer-store=region -verify %s
2// RUN: %clang_analyze_cc1 -triple x86_64-pc-linux-gnu -analyzer-checker=core,valist.Unterminated,valist.CopyToSelf -analyzer-output=text -analyzer-store=region -verify %s
Gabor Horvathb59b2702016-08-22 11:21:30 +00003
4#include "Inputs/system-header-simulator-for-valist.h"
5
6void f1(int fst, ...) {
7 va_list va;
8 va_start(va, fst); // expected-note{{Initialized va_list}}
Gabor Horvathdbf27902017-03-07 16:04:23 +00009 return; // expected-warning{{Initialized va_list 'va' is leaked}}
10 // expected-note@-1{{Initialized va_list 'va' is leaked}}
Gabor Horvathb59b2702016-08-22 11:21:30 +000011}
12
13void f2(int fst, ...) {
14 va_list va;
15 va_start(va, fst); // expected-note{{Initialized va_list}}
16 va_end(va); // expected-note{{Ended va_list}}
17 va_start(va, fst); // expected-note{{Initialized va_list}}
Gabor Horvathdbf27902017-03-07 16:04:23 +000018} // expected-warning{{Initialized va_list 'va' is leaked}}
19 // expected-note@-1{{Initialized va_list 'va' is leaked}}
Gabor Horvathb59b2702016-08-22 11:21:30 +000020
21void f3(int fst, ...) {
22 va_list va, va2;
23 va_start(va, fst);
24 va_copy(va2, va); // expected-note{{Initialized va_list}}
Gabor Horvathdbf27902017-03-07 16:04:23 +000025 va_end(va); // expected-warning{{Initialized va_list 'va2' is leaked}}
26 // expected-note@-1{{Initialized va_list 'va2' is leaked}}
Gabor Horvathb59b2702016-08-22 11:21:30 +000027}
28
29void f4(va_list *fst, ...) {
30 va_start(*fst, fst); // expected-note{{Initialized va_list}}
Gabor Horvathdbf27902017-03-07 16:04:23 +000031 return; // expected-warning{{Initialized va_list is leaked}}
32 // expected-note@-1{{Initialized va_list is leaked}}
Gabor Horvathb59b2702016-08-22 11:21:30 +000033}
34
35void f5(va_list fst, ...) {
Gabor Horvathdbf27902017-03-07 16:04:23 +000036 va_start(fst, fst); // expected-note{{Initialized va_list}}
37} // expected-warning{{Initialized va_list}}
38 // expected-note@-1{{Initialized va_list}}
Gabor Horvathb59b2702016-08-22 11:21:30 +000039
40void f6(va_list *fst, ...) {
41 va_start(*fst, fst); // expected-note{{Initialized va_list}}
42 (void)va_arg(*fst, int);
43 //FIXME: this should NOT cause a warning
Gabor Horvathdbf27902017-03-07 16:04:23 +000044 va_end(*fst); // expected-warning{{Initialized va_list is leaked}}
45 // expected-note@-1{{Initialized va_list is leaked}}
Gabor Horvathb59b2702016-08-22 11:21:30 +000046}
47
48void f7(int *fst, ...) {
49 va_list x;
50 va_list *y = &x;
51 va_start(*y,fst); // expected-note{{Initialized va_list}}
Gabor Horvathdbf27902017-03-07 16:04:23 +000052} // expected-warning{{Initialized va_list 'x' is leaked}}
53 // expected-note@-1{{Initialized va_list 'x' is leaked}}
Gabor Horvathb59b2702016-08-22 11:21:30 +000054
55void f8(int *fst, ...) {
56 va_list x;
57 va_list *y = &x;
58 va_start(*y,fst);
59 va_end(x);
60} // no-warning
61
62void reinit(int *fst, ...) {
63 va_list va;
Gabor Horvathdbf27902017-03-07 16:04:23 +000064 va_start(va, fst); // expected-note{{Initialized va_list}}
65 // expected-note@-1{{Initialized va_list}}
66 va_start(va, fst); // expected-warning{{Initialized va_list 'va' is initialized again}}
67 // expected-note@-1{{Initialized va_list 'va' is initialized again}}
68} // expected-warning{{Initialized va_list 'va' is leaked}}
69 // expected-note@-1{{Initialized va_list 'va' is leaked}}
Gabor Horvathb59b2702016-08-22 11:21:30 +000070
71void reinitOk(int *fst, ...) {
72 va_list va;
73 va_start(va, fst);
74 va_end(va);
75 va_start(va, fst);
76 va_end(va);
77} // no-warning
78
79void copyself(int fst, ...) {
80 va_list va;
81 va_start(va, fst); // expected-note{{Initialized va_list}}
Gabor Horvathdbf27902017-03-07 16:04:23 +000082 va_copy(va, va); // expected-warning{{va_list 'va' is copied onto itself}}
83 // expected-note@-1{{va_list 'va' is copied onto itself}}
Gabor Horvathb59b2702016-08-22 11:21:30 +000084 va_end(va);
Gabor Horvathdbf27902017-03-07 16:04:23 +000085}
Gabor Horvathb59b2702016-08-22 11:21:30 +000086
87void copyselfUninit(int fst, ...) {
88 va_list va;
Gabor Horvathdbf27902017-03-07 16:04:23 +000089 va_copy(va, va); // expected-warning{{va_list 'va' is copied onto itself}}
90 // expected-note@-1{{va_list 'va' is copied onto itself}}
91}
Gabor Horvathb59b2702016-08-22 11:21:30 +000092
93void copyOverwrite(int fst, ...) {
94 va_list va, va2;
95 va_start(va, fst); // expected-note{{Initialized va_list}}
Gabor Horvathdbf27902017-03-07 16:04:23 +000096 va_copy(va, va2); // expected-warning{{Initialized va_list 'va' is overwritten by an uninitialized one}}
97 // expected-note@-1{{Initialized va_list 'va' is overwritten by an uninitialized one}}
98}
Gabor Horvathb59b2702016-08-22 11:21:30 +000099
100//This only generates a warning for the valist.Uninitialized checker
101void copyUnint(int fst, ...) {
102 va_list va, va2;
103 va_copy(va, va2);
104} // no-warning
105
106void recopy(int fst, ...) {
107 va_list va, va2;
108 va_start(va, fst);
109 va_copy(va2, va); // expected-note{{Initialized va_list}}
Gabor Horvathdbf27902017-03-07 16:04:23 +0000110 va_copy(va2, va); // expected-warning{{Initialized va_list 'va2' is initialized again}}
111 // expected-note@-1{{Initialized va_list 'va2' is initialized again}}
Gabor Horvathb59b2702016-08-22 11:21:30 +0000112 va_end(va);
113 va_end(va2);
Gabor Horvathdbf27902017-03-07 16:04:23 +0000114}
Gabor Horvathb59b2702016-08-22 11:21:30 +0000115
116void doublemsg(int fst, ...) {
117 va_list va, va2;
Gabor Horvathdbf27902017-03-07 16:04:23 +0000118 va_start(va, fst), va_start(va2, fst); // expected-warning{{Initialized va_list 'va' is leaked}}
119 // expected-warning@-1{{Initialized va_list 'va2' is leaked}}
120 // expected-note@-2{{Initialized va_list}}
121 // expected-note@-3{{Initialized va_list}}
122 // expected-note@-4{{Initialized va_list}}
123 // expected-note@-5{{Initialized va_list 'va' is leaked}}
Gabor Horvathb59b2702016-08-22 11:21:30 +0000124}
125
126void in_array(int fst, ...) {
127 va_list va_array[8];
128 va_start(va_array[3], fst); // expected-note{{Initialized va_list}}
Gabor Horvathdbf27902017-03-07 16:04:23 +0000129} // expected-warning{{Initialized va_list 'va_array[3]' is leaked}}
130 // expected-note@-1{{Initialized va_list 'va_array[3]' is leaked}}
Gabor Horvathb59b2702016-08-22 11:21:30 +0000131
132struct containing_a_valist {
133 va_list vafield;
134 int foobar;
135};
136
137void in_struct(int fst, ...) {
138 struct containing_a_valist s;
139 va_start(s.vafield, fst); // expected-note{{Initialized va_list}}
Gabor Horvathdbf27902017-03-07 16:04:23 +0000140} // expected-warning{{Initialized va_list 's.vafield' is leaked}}
141 // expected-note@-1{{Initialized va_list 's.vafield' is leaked}}
Gabor Horvathb59b2702016-08-22 11:21:30 +0000142
143void casting(int fst, ...) {
144 char mem[sizeof(va_list)];
145 va_start(*(va_list *) mem, fst); // expected-note{{Initialized va_list}}
Gabor Horvathdbf27902017-03-07 16:04:23 +0000146} // expected-warning{{Initialized va_list 'mem[0]' is leaked}}
147 // expected-note@-1{{Initialized va_list 'mem[0]' is leaked}}
Gabor Horvathb59b2702016-08-22 11:21:30 +0000148
149
150void castingOk(int fst, ...) {
151 char mem[sizeof(va_list)];
152 va_start(*(va_list *) mem, fst);
153 va_end(*(va_list *) mem);
154} // no-warning
155