1 // RUN: %clang_analyze_cc1 -Wno-int-to-pointer-cast -analyzer-checker=alpha.security.taint,debug.TaintTest %s -verify
3 #include "Inputs/system-header-simulator.h"
14 void taintTracking(int x
) {
16 int *addr
= &Buffer
[0];
18 addr
+= n
;// expected-warning + {{tainted}}
19 *addr
= n
; // expected-warning + {{tainted}}
21 double tdiv
= n
/ 30; // expected-warning+ {{tainted}}
22 char *loc_cast
= (char *) n
; // expected-warning +{{tainted}}
23 char tinc
= tdiv
++; // expected-warning + {{tainted}}
24 int tincdec
= (char)tinc
--; // expected-warning+{{tainted}}
26 // Tainted ptr arithmetic/array element address.
27 int tprtarithmetic1
= *(addr
+1); // expected-warning + {{tainted}}
32 int ptrDeref
= *ptr
; // expected-warning + {{tainted}}
33 int _ptrDeref
= ptrDeref
+ 13; // expected-warning + {{tainted}}
35 // Pointer arithmetic + dereferencing.
36 // FIXME: We fail to propagate the taint here because RegionStore does not
37 // handle ElementRegions with symbolic indexes.
38 int addrDeref
= *addr
; // expected-warning + {{tainted}}
39 int _addrDeref
= addrDeref
; // expected-warning + {{tainted}}
41 // Tainted struct address, casts.
42 struct XYStruct
*xyPtr
= 0;
44 void *tXYStructPtr
= xyPtr
; // expected-warning + {{tainted}}
45 struct XYStruct
*xyPtrCopy
= tXYStructPtr
; // expected-warning + {{tainted}}
46 int ptrtx
= xyPtr
->x
;// expected-warning + {{tainted}}
47 int ptrty
= xyPtr
->y
;// expected-warning + {{tainted}}
49 // Taint on fields of a struct.
50 struct XYStruct xy
= {2, 3, 11};
53 int tx
= xy
.x
; // expected-warning + {{tainted}}
54 int ty
= xy
.y
; // FIXME: This should be tainted as well.
55 char ntz
= xy
.z
;// no warning
56 // Now, scanf scans both.
57 scanf("%d %d", &xy
.y
, &xy
.x
);
58 int ttx
= xy
.x
; // expected-warning + {{tainted}}
59 int tty
= xy
.y
; // expected-warning + {{tainted}}
62 void BitwiseOp(int in
, char inn
, int zz
) {
63 // Taint on bitwise operations, integer to integer cast.
67 int y
= (in
<< (x
<< in
)) * 5;// expected-warning + {{tainted}}
68 // The next line tests integer to integer cast.
69 int z
= y
& inn
; // expected-warning + {{tainted}}
70 if (y
== zz
) { // expected-warning + {{tainted}}
71 m
= z
| z
;// expected-warning + {{tainted}}
75 int mm
= m
; // expected-warning 1 {{tainted}}
79 char *getenv(const char *name
);
80 void getenvTest(char *home
) {
81 home
= getenv("HOME"); // expected-warning + {{tainted}}
82 if (home
!= 0) { // expected-warning + {{tainted}}
83 char d
= home
[0]; // expected-warning + {{tainted}}
87 int fscanfTest(void) {
92 // Check if stdin is treated as tainted.
93 fscanf(stdin
, "%s %d", s
, &t
);
94 // Note, here, s is not tainted, but the data s points to is tainted.
96 char tss
= s
[0]; // expected-warning + {{tainted}}
97 int tt
= t
; // expected-warning + {{tainted}}
98 if((fp
=fopen("test", "w")) == 0) // expected-warning + {{tainted}}
100 fprintf(fp
, "%s %d", s
, t
); // expected-warning + {{tainted}}
101 fclose(fp
); // expected-warning + {{tainted}}
103 // Test fscanf and fopen.
104 if((fp
=fopen("test","r")) == 0) // expected-warning + {{tainted}}
106 fscanf(fp
, "%s%d", s
, &t
); // expected-warning + {{tainted}}
107 fprintf(stdout
, "%s %d", s
, t
); // expected-warning + {{tainted}}
111 // Check if we propagate taint from stdin when it's used in an assignment.
112 void stdinTest1(void) {
114 fscanf(stdin
, "%d", &i
);
115 int j
= i
; // expected-warning + {{tainted}}
117 void stdinTest2(FILE *pIn
) {
122 fscanf(pp
, "%d", &ii
);
123 int jj
= ii
;// expected-warning + {{tainted}}
125 fscanf(p
, "%d", &ii
);// expected-warning + {{tainted}}
126 int jj2
= ii
;// expected-warning + {{tainted}}
129 int jj3
= ii
;// no warning
132 fscanf(p
, "%d", &ii
);
133 int jj4
= ii
;// no warning
136 void stdinTest3(void) {
139 fscanf(*ppp
, "%d", &iii
);
140 int jjj
= iii
;// expected-warning + {{tainted}}
143 // Test that stdin does not get invalidated by calls.
145 void stdinTest4(void) {
147 fscanf(stdin
, "%d", &i
);
149 int j
= i
; // expected-warning + {{tainted}}
153 void getwTest(void) {
154 int i
= getw(stdin
); // expected-warning + {{tainted}}
157 typedef long ssize_t
;
158 ssize_t
getline(char ** __restrict
, size_t * __restrict
, FILE * __restrict
);
159 int printf(const char * __restrict
, ...);
160 void free(void *ptr
);
161 void getlineTest(void) {
166 while ((read
= getline(&line
, &len
, stdin
)) != -1) {
167 printf("%s", line
); // expected-warning + {{tainted}}
169 free(line
); // expected-warning + {{tainted}}
172 // Test propagation functions - the ones that propagate taint from arguments to
173 // return value, ptr arguments.
175 int atoi(const char *nptr
);
176 long atol(const char *nptr
);
177 long long atoll(const char *nptr
);
179 void atoiTest(void) {
182 int d
= atoi(s
); // expected-warning + {{tainted}}
183 int td
= d
; // expected-warning + {{tainted}}
185 long l
= atol(s
); // expected-warning + {{tainted}}
186 int tl
= l
; // expected-warning + {{tainted}}
188 long long ll
= atoll(s
); // expected-warning + {{tainted}}
189 int tll
= ll
; // expected-warning + {{tainted}}
195 void noCrashTest(void) {
197 __builtin___memcpy_chk(pointer2
, pointer1
, 0, 0); // no-crash