Mercurial > hg > CbC > CbC_llvm
comparison clang/test/Preprocessor/predefined-arch-macros.c @ 150:1d019706d866
LLVM10
author | anatofuz |
---|---|
date | Thu, 13 Feb 2020 15:10:13 +0900 |
parents | |
children | 2e18cbf3894f |
comparison
equal
deleted
inserted
replaced
147:c2174574ed3a | 150:1d019706d866 |
---|---|
1 // Begin X86/GCC/Linux tests ---------------- | |
2 | |
3 // RUN: %clang -march=i386 -m32 -E -dM %s -o - 2>&1 \ | |
4 // RUN: -target i386-unknown-linux \ | |
5 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I386_M32 | |
6 // CHECK_I386_M32: #define __i386 1 | |
7 // CHECK_I386_M32: #define __i386__ 1 | |
8 // CHECK_I386_M32: #define __tune_i386__ 1 | |
9 // CHECK_I386_M32: #define i386 1 | |
10 // RUN: not %clang -march=i386 -m64 -E -dM %s -o - 2>&1 \ | |
11 // RUN: -target i386-unknown-linux \ | |
12 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I386_M64 | |
13 // CHECK_I386_M64: error: {{.*}} | |
14 | |
15 // RUN: %clang -march=i486 -m32 -E -dM %s -o - 2>&1 \ | |
16 // RUN: -target i386-unknown-linux \ | |
17 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I486_M32 | |
18 // CHECK_I486_M32: #define __i386 1 | |
19 // CHECK_I486_M32: #define __i386__ 1 | |
20 // CHECK_I486_M32: #define __i486 1 | |
21 // CHECK_I486_M32: #define __i486__ 1 | |
22 // CHECK_I486_M32: #define __tune_i486__ 1 | |
23 // CHECK_I486_M32: #define i386 1 | |
24 // RUN: not %clang -march=i486 -m64 -E -dM %s -o - 2>&1 \ | |
25 // RUN: -target i386-unknown-linux \ | |
26 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I486_M64 | |
27 // CHECK_I486_M64: error: {{.*}} | |
28 | |
29 // RUN: %clang -march=i586 -m32 -E -dM %s -o - 2>&1 \ | |
30 // RUN: -target i386-unknown-linux \ | |
31 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I586_M32 | |
32 // CHECK_I586_M32: #define __i386 1 | |
33 // CHECK_I586_M32: #define __i386__ 1 | |
34 // CHECK_I586_M32: #define __i586 1 | |
35 // CHECK_I586_M32: #define __i586__ 1 | |
36 // CHECK_I586_M32: #define __pentium 1 | |
37 // CHECK_I586_M32: #define __pentium__ 1 | |
38 // CHECK_I586_M32: #define __tune_i586__ 1 | |
39 // CHECK_I586_M32: #define __tune_pentium__ 1 | |
40 // CHECK_I586_M32: #define i386 1 | |
41 // RUN: not %clang -march=i586 -m64 -E -dM %s -o - 2>&1 \ | |
42 // RUN: -target i386-unknown-linux \ | |
43 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I586_M64 | |
44 // CHECK_I586_M64: error: {{.*}} | |
45 | |
46 // RUN: %clang -march=pentium -m32 -E -dM %s -o - 2>&1 \ | |
47 // RUN: -target i386-unknown-linux \ | |
48 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM_M32 | |
49 // CHECK_PENTIUM_M32: #define __i386 1 | |
50 // CHECK_PENTIUM_M32: #define __i386__ 1 | |
51 // CHECK_PENTIUM_M32: #define __i586 1 | |
52 // CHECK_PENTIUM_M32: #define __i586__ 1 | |
53 // CHECK_PENTIUM_M32: #define __pentium 1 | |
54 // CHECK_PENTIUM_M32: #define __pentium__ 1 | |
55 // CHECK_PENTIUM_M32: #define __tune_i586__ 1 | |
56 // CHECK_PENTIUM_M32: #define __tune_pentium__ 1 | |
57 // CHECK_PENTIUM_M32: #define i386 1 | |
58 // RUN: not %clang -march=pentium -m64 -E -dM %s -o - 2>&1 \ | |
59 // RUN: -target i386-unknown-linux \ | |
60 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM_M64 | |
61 // CHECK_PENTIUM_M64: error: {{.*}} | |
62 | |
63 // RUN: %clang -march=pentium-mmx -m32 -E -dM %s -o - 2>&1 \ | |
64 // RUN: -target i386-unknown-linux \ | |
65 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM_MMX_M32 | |
66 // CHECK_PENTIUM_MMX_M32: #define __MMX__ 1 | |
67 // CHECK_PENTIUM_MMX_M32: #define __i386 1 | |
68 // CHECK_PENTIUM_MMX_M32: #define __i386__ 1 | |
69 // CHECK_PENTIUM_MMX_M32: #define __i586 1 | |
70 // CHECK_PENTIUM_MMX_M32: #define __i586__ 1 | |
71 // CHECK_PENTIUM_MMX_M32: #define __pentium 1 | |
72 // CHECK_PENTIUM_MMX_M32: #define __pentium__ 1 | |
73 // CHECK_PENTIUM_MMX_M32: #define __pentium_mmx__ 1 | |
74 // CHECK_PENTIUM_MMX_M32: #define __tune_i586__ 1 | |
75 // CHECK_PENTIUM_MMX_M32: #define __tune_pentium__ 1 | |
76 // CHECK_PENTIUM_MMX_M32: #define __tune_pentium_mmx__ 1 | |
77 // CHECK_PENTIUM_MMX_M32: #define i386 1 | |
78 // RUN: not %clang -march=pentium-mmx -m64 -E -dM %s -o - 2>&1 \ | |
79 // RUN: -target i386-unknown-linux \ | |
80 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM_MMX_M64 | |
81 // CHECK_PENTIUM_MMX_M64: error: {{.*}} | |
82 | |
83 // RUN: %clang -march=winchip-c6 -m32 -E -dM %s -o - 2>&1 \ | |
84 // RUN: -target i386-unknown-linux \ | |
85 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_WINCHIP_C6_M32 | |
86 // CHECK_WINCHIP_C6_M32: #define __MMX__ 1 | |
87 // CHECK_WINCHIP_C6_M32: #define __i386 1 | |
88 // CHECK_WINCHIP_C6_M32: #define __i386__ 1 | |
89 // CHECK_WINCHIP_C6_M32: #define __i486 1 | |
90 // CHECK_WINCHIP_C6_M32: #define __i486__ 1 | |
91 // CHECK_WINCHIP_C6_M32: #define __tune_i486__ 1 | |
92 // CHECK_WINCHIP_C6_M32: #define i386 1 | |
93 // RUN: not %clang -march=winchip-c6 -m64 -E -dM %s -o - 2>&1 \ | |
94 // RUN: -target i386-unknown-linux \ | |
95 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_WINCHIP_C6_M64 | |
96 // CHECK_WINCHIP_C6_M64: error: {{.*}} | |
97 | |
98 // RUN: %clang -march=winchip2 -m32 -E -dM %s -o - 2>&1 \ | |
99 // RUN: -target i386-unknown-linux \ | |
100 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_WINCHIP2_M32 | |
101 // CHECK_WINCHIP2_M32: #define __3dNOW__ 1 | |
102 // CHECK_WINCHIP2_M32: #define __MMX__ 1 | |
103 // CHECK_WINCHIP2_M32: #define __i386 1 | |
104 // CHECK_WINCHIP2_M32: #define __i386__ 1 | |
105 // CHECK_WINCHIP2_M32: #define __i486 1 | |
106 // CHECK_WINCHIP2_M32: #define __i486__ 1 | |
107 // CHECK_WINCHIP2_M32: #define __tune_i486__ 1 | |
108 // CHECK_WINCHIP2_M32: #define i386 1 | |
109 // RUN: not %clang -march=winchip2 -m64 -E -dM %s -o - 2>&1 \ | |
110 // RUN: -target i386-unknown-linux \ | |
111 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_WINCHIP2_M64 | |
112 // CHECK_WINCHIP2_M64: error: {{.*}} | |
113 | |
114 // RUN: %clang -march=c3 -m32 -E -dM %s -o - 2>&1 \ | |
115 // RUN: -target i386-unknown-linux \ | |
116 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_C3_M32 | |
117 // CHECK_C3_M32: #define __3dNOW__ 1 | |
118 // CHECK_C3_M32: #define __MMX__ 1 | |
119 // CHECK_C3_M32: #define __i386 1 | |
120 // CHECK_C3_M32: #define __i386__ 1 | |
121 // CHECK_C3_M32: #define __i486 1 | |
122 // CHECK_C3_M32: #define __i486__ 1 | |
123 // CHECK_C3_M32: #define __tune_i486__ 1 | |
124 // CHECK_C3_M32: #define i386 1 | |
125 // RUN: not %clang -march=c3 -m64 -E -dM %s -o - 2>&1 \ | |
126 // RUN: -target i386-unknown-linux \ | |
127 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_C3_M64 | |
128 // CHECK_C3_M64: error: {{.*}} | |
129 | |
130 // RUN: %clang -march=c3-2 -m32 -E -dM %s -o - 2>&1 \ | |
131 // RUN: -target i386-unknown-linux \ | |
132 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_C3_2_M32 | |
133 // CHECK_C3_2_M32: #define __MMX__ 1 | |
134 // CHECK_C3_2_M32: #define __SSE__ 1 | |
135 // CHECK_C3_2_M32: #define __i386 1 | |
136 // CHECK_C3_2_M32: #define __i386__ 1 | |
137 // CHECK_C3_2_M32: #define __i686 1 | |
138 // CHECK_C3_2_M32: #define __i686__ 1 | |
139 // CHECK_C3_2_M32: #define __pentiumpro 1 | |
140 // CHECK_C3_2_M32: #define __pentiumpro__ 1 | |
141 // CHECK_C3_2_M32: #define __tune_i686__ 1 | |
142 // CHECK_C3_2_M32: #define __tune_pentium2__ 1 | |
143 // CHECK_C3_2_M32: #define __tune_pentiumpro__ 1 | |
144 // CHECK_C3_2_M32: #define i386 1 | |
145 // RUN: not %clang -march=c3-2 -m64 -E -dM %s -o - 2>&1 \ | |
146 // RUN: -target i386-unknown-linux \ | |
147 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_C3_2_M64 | |
148 // CHECK_C3_2_M64: error: {{.*}} | |
149 | |
150 // RUN: %clang -march=i686 -m32 -E -dM %s -o - 2>&1 \ | |
151 // RUN: -target i386-unknown-linux \ | |
152 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I686_M32 | |
153 // CHECK_I686_M32: #define __i386 1 | |
154 // CHECK_I686_M32: #define __i386__ 1 | |
155 // CHECK_I686_M32: #define __i686 1 | |
156 // CHECK_I686_M32: #define __i686__ 1 | |
157 // CHECK_I686_M32: #define __pentiumpro 1 | |
158 // CHECK_I686_M32: #define __pentiumpro__ 1 | |
159 // CHECK_I686_M32: #define __tune_i686__ 1 | |
160 // CHECK_I686_M32: #define __tune_pentiumpro__ 1 | |
161 // CHECK_I686_M32: #define i386 1 | |
162 // RUN: not %clang -march=i686 -m64 -E -dM %s -o - 2>&1 \ | |
163 // RUN: -target i386-unknown-linux \ | |
164 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I686_M64 | |
165 // CHECK_I686_M64: error: {{.*}} | |
166 | |
167 // RUN: %clang -march=pentiumpro -m32 -E -dM %s -o - 2>&1 \ | |
168 // RUN: -target i386-unknown-linux \ | |
169 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUMPRO_M32 | |
170 // CHECK_PENTIUMPRO_M32: #define __i386 1 | |
171 // CHECK_PENTIUMPRO_M32: #define __i386__ 1 | |
172 // CHECK_PENTIUMPRO_M32: #define __i686 1 | |
173 // CHECK_PENTIUMPRO_M32: #define __i686__ 1 | |
174 // CHECK_PENTIUMPRO_M32: #define __pentiumpro 1 | |
175 // CHECK_PENTIUMPRO_M32: #define __pentiumpro__ 1 | |
176 // CHECK_PENTIUMPRO_M32: #define __tune_i686__ 1 | |
177 // CHECK_PENTIUMPRO_M32: #define __tune_pentiumpro__ 1 | |
178 // CHECK_PENTIUMPRO_M32: #define i386 1 | |
179 // RUN: not %clang -march=pentiumpro -m64 -E -dM %s -o - 2>&1 \ | |
180 // RUN: -target i386-unknown-linux \ | |
181 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUMPRO_M64 | |
182 // CHECK_PENTIUMPRO_M64: error: {{.*}} | |
183 | |
184 // RUN: %clang -march=pentium2 -m32 -E -dM %s -o - 2>&1 \ | |
185 // RUN: -target i386-unknown-linux \ | |
186 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM2_M32 | |
187 // CHECK_PENTIUM2_M32: #define __FXSR__ 1 | |
188 // CHECK_PENTIUM2_M32: #define __MMX__ 1 | |
189 // CHECK_PENTIUM2_M32: #define __i386 1 | |
190 // CHECK_PENTIUM2_M32: #define __i386__ 1 | |
191 // CHECK_PENTIUM2_M32: #define __i686 1 | |
192 // CHECK_PENTIUM2_M32: #define __i686__ 1 | |
193 // CHECK_PENTIUM2_M32: #define __pentiumpro 1 | |
194 // CHECK_PENTIUM2_M32: #define __pentiumpro__ 1 | |
195 // CHECK_PENTIUM2_M32: #define __tune_i686__ 1 | |
196 // CHECK_PENTIUM2_M32: #define __tune_pentium2__ 1 | |
197 // CHECK_PENTIUM2_M32: #define __tune_pentiumpro__ 1 | |
198 // CHECK_PENTIUM2_M32: #define i386 1 | |
199 // RUN: not %clang -march=pentium2 -m64 -E -dM %s -o - 2>&1 \ | |
200 // RUN: -target i386-unknown-linux \ | |
201 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM2_M64 | |
202 // CHECK_PENTIUM2_M64: error: {{.*}} | |
203 | |
204 // RUN: %clang -march=pentium3 -m32 -E -dM %s -o - 2>&1 \ | |
205 // RUN: -target i386-unknown-linux \ | |
206 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM3_M32 | |
207 // CHECK_PENTIUM3_M32: #define __MMX__ 1 | |
208 // CHECK_PENTIUM3_M32: #define __SSE__ 1 | |
209 // CHECK_PENTIUM3_M32: #define __i386 1 | |
210 // CHECK_PENTIUM3_M32: #define __i386__ 1 | |
211 // CHECK_PENTIUM3_M32: #define __i686 1 | |
212 // CHECK_PENTIUM3_M32: #define __i686__ 1 | |
213 // CHECK_PENTIUM3_M32: #define __pentiumpro 1 | |
214 // CHECK_PENTIUM3_M32: #define __pentiumpro__ 1 | |
215 // CHECK_PENTIUM3_M32: #define __tune_i686__ 1 | |
216 // CHECK_PENTIUM3_M32: #define __tune_pentium2__ 1 | |
217 // CHECK_PENTIUM3_M32: #define __tune_pentium3__ 1 | |
218 // CHECK_PENTIUM3_M32: #define __tune_pentiumpro__ 1 | |
219 // CHECK_PENTIUM3_M32: #define i386 1 | |
220 // RUN: not %clang -march=pentium3 -m64 -E -dM %s -o - 2>&1 \ | |
221 // RUN: -target i386-unknown-linux \ | |
222 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM3_M64 | |
223 // CHECK_PENTIUM3_M64: error: {{.*}} | |
224 | |
225 // RUN: %clang -march=pentium3m -m32 -E -dM %s -o - 2>&1 \ | |
226 // RUN: -target i386-unknown-linux \ | |
227 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM3M_M32 | |
228 // CHECK_PENTIUM3M_M32: #define __MMX__ 1 | |
229 // CHECK_PENTIUM3M_M32: #define __SSE__ 1 | |
230 // CHECK_PENTIUM3M_M32: #define __i386 1 | |
231 // CHECK_PENTIUM3M_M32: #define __i386__ 1 | |
232 // CHECK_PENTIUM3M_M32: #define __i686 1 | |
233 // CHECK_PENTIUM3M_M32: #define __i686__ 1 | |
234 // CHECK_PENTIUM3M_M32: #define __pentiumpro 1 | |
235 // CHECK_PENTIUM3M_M32: #define __pentiumpro__ 1 | |
236 // CHECK_PENTIUM3M_M32: #define __tune_i686__ 1 | |
237 // CHECK_PENTIUM3M_M32: #define __tune_pentiumpro__ 1 | |
238 // CHECK_PENTIUM3M_M32: #define i386 1 | |
239 // RUN: not %clang -march=pentium3m -m64 -E -dM %s -o - 2>&1 \ | |
240 // RUN: -target i386-unknown-linux \ | |
241 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM3M_M64 | |
242 // CHECK_PENTIUM3M_M64: error: {{.*}} | |
243 | |
244 // RUN: %clang -march=pentium-m -m32 -E -dM %s -o - 2>&1 \ | |
245 // RUN: -target i386-unknown-linux \ | |
246 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM_M_M32 | |
247 // CHECK_PENTIUM_M_M32: #define __MMX__ 1 | |
248 // CHECK_PENTIUM_M_M32: #define __SSE2__ 1 | |
249 // CHECK_PENTIUM_M_M32: #define __SSE__ 1 | |
250 // CHECK_PENTIUM_M_M32: #define __i386 1 | |
251 // CHECK_PENTIUM_M_M32: #define __i386__ 1 | |
252 // CHECK_PENTIUM_M_M32: #define __i686 1 | |
253 // CHECK_PENTIUM_M_M32: #define __i686__ 1 | |
254 // CHECK_PENTIUM_M_M32: #define __pentiumpro 1 | |
255 // CHECK_PENTIUM_M_M32: #define __pentiumpro__ 1 | |
256 // CHECK_PENTIUM_M_M32: #define __tune_i686__ 1 | |
257 // CHECK_PENTIUM_M_M32: #define __tune_pentiumpro__ 1 | |
258 // CHECK_PENTIUM_M_M32: #define i386 1 | |
259 // RUN: not %clang -march=pentium-m -m64 -E -dM %s -o - 2>&1 \ | |
260 // RUN: -target i386-unknown-linux \ | |
261 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM_M_M64 | |
262 // CHECK_PENTIUM_M_M64: error: {{.*}} | |
263 | |
264 // RUN: %clang -march=pentium4 -m32 -E -dM %s -o - 2>&1 \ | |
265 // RUN: -target i386-unknown-linux \ | |
266 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM4_M32 | |
267 // CHECK_PENTIUM4_M32: #define __MMX__ 1 | |
268 // CHECK_PENTIUM4_M32: #define __SSE2__ 1 | |
269 // CHECK_PENTIUM4_M32: #define __SSE__ 1 | |
270 // CHECK_PENTIUM4_M32: #define __i386 1 | |
271 // CHECK_PENTIUM4_M32: #define __i386__ 1 | |
272 // CHECK_PENTIUM4_M32: #define __pentium4 1 | |
273 // CHECK_PENTIUM4_M32: #define __pentium4__ 1 | |
274 // CHECK_PENTIUM4_M32: #define __tune_pentium4__ 1 | |
275 // CHECK_PENTIUM4_M32: #define i386 1 | |
276 // RUN: not %clang -march=pentium4 -m64 -E -dM %s -o - 2>&1 \ | |
277 // RUN: -target i386-unknown-linux \ | |
278 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM4_M64 | |
279 // CHECK_PENTIUM4_M64: error: {{.*}} | |
280 | |
281 // RUN: %clang -march=pentium4m -m32 -E -dM %s -o - 2>&1 \ | |
282 // RUN: -target i386-unknown-linux \ | |
283 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM4M_M32 | |
284 // CHECK_PENTIUM4M_M32: #define __MMX__ 1 | |
285 // CHECK_PENTIUM4M_M32: #define __SSE2__ 1 | |
286 // CHECK_PENTIUM4M_M32: #define __SSE__ 1 | |
287 // CHECK_PENTIUM4M_M32: #define __i386 1 | |
288 // CHECK_PENTIUM4M_M32: #define __i386__ 1 | |
289 // CHECK_PENTIUM4M_M32: #define __pentium4 1 | |
290 // CHECK_PENTIUM4M_M32: #define __pentium4__ 1 | |
291 // CHECK_PENTIUM4M_M32: #define __tune_pentium4__ 1 | |
292 // CHECK_PENTIUM4M_M32: #define i386 1 | |
293 // RUN: not %clang -march=pentium4m -m64 -E -dM %s -o - 2>&1 \ | |
294 // RUN: -target i386-unknown-linux \ | |
295 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM4M_M64 | |
296 // CHECK_PENTIUM4M_M64: error: {{.*}} | |
297 | |
298 // RUN: %clang -march=yonah -m32 -E -dM %s -o - 2>&1 \ | |
299 // RUN: -target i386-unknown-linux \ | |
300 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_YONAH_M32 | |
301 // CHECK_YONAH_M32: #define __MMX__ 1 | |
302 // CHECK_YONAH_M32: #define __SSE2__ 1 | |
303 // CHECK_YONAH_M32: #define __SSE3__ 1 | |
304 // CHECK_YONAH_M32: #define __SSE__ 1 | |
305 // CHECK_YONAH_M32: #define __i386 1 | |
306 // CHECK_YONAH_M32: #define __i386__ 1 | |
307 // CHECK_YONAH_M32: #define __nocona 1 | |
308 // CHECK_YONAH_M32: #define __nocona__ 1 | |
309 // CHECK_YONAH_M32: #define __tune_nocona__ 1 | |
310 // CHECK_YONAH_M32: #define i386 1 | |
311 // RUN: not %clang -march=yonah -m64 -E -dM %s -o - 2>&1 \ | |
312 // RUN: -target i386-unknown-linux \ | |
313 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_YONAH_M64 | |
314 // CHECK_YONAH_M64: error: {{.*}} | |
315 | |
316 // RUN: %clang -march=prescott -m32 -E -dM %s -o - 2>&1 \ | |
317 // RUN: -target i386-unknown-linux \ | |
318 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PRESCOTT_M32 | |
319 // CHECK_PRESCOTT_M32: #define __MMX__ 1 | |
320 // CHECK_PRESCOTT_M32: #define __SSE2__ 1 | |
321 // CHECK_PRESCOTT_M32: #define __SSE3__ 1 | |
322 // CHECK_PRESCOTT_M32: #define __SSE__ 1 | |
323 // CHECK_PRESCOTT_M32: #define __i386 1 | |
324 // CHECK_PRESCOTT_M32: #define __i386__ 1 | |
325 // CHECK_PRESCOTT_M32: #define __nocona 1 | |
326 // CHECK_PRESCOTT_M32: #define __nocona__ 1 | |
327 // CHECK_PRESCOTT_M32: #define __tune_nocona__ 1 | |
328 // CHECK_PRESCOTT_M32: #define i386 1 | |
329 // RUN: not %clang -march=prescott -m64 -E -dM %s -o - 2>&1 \ | |
330 // RUN: -target i386-unknown-linux \ | |
331 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PRESCOTT_M64 | |
332 // CHECK_PRESCOTT_M64: error: {{.*}} | |
333 | |
334 // RUN: %clang -march=nocona -m32 -E -dM %s -o - 2>&1 \ | |
335 // RUN: -target i386-unknown-linux \ | |
336 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_NOCONA_M32 | |
337 // CHECK_NOCONA_M32: #define __MMX__ 1 | |
338 // CHECK_NOCONA_M32: #define __SSE2__ 1 | |
339 // CHECK_NOCONA_M32: #define __SSE3__ 1 | |
340 // CHECK_NOCONA_M32: #define __SSE__ 1 | |
341 // CHECK_NOCONA_M32: #define __i386 1 | |
342 // CHECK_NOCONA_M32: #define __i386__ 1 | |
343 // CHECK_NOCONA_M32: #define __nocona 1 | |
344 // CHECK_NOCONA_M32: #define __nocona__ 1 | |
345 // CHECK_NOCONA_M32: #define __tune_nocona__ 1 | |
346 // CHECK_NOCONA_M32: #define i386 1 | |
347 // RUN: %clang -march=nocona -m64 -E -dM %s -o - 2>&1 \ | |
348 // RUN: -target i386-unknown-linux \ | |
349 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_NOCONA_M64 | |
350 // CHECK_NOCONA_M64: #define __MMX__ 1 | |
351 // CHECK_NOCONA_M64: #define __SSE2_MATH__ 1 | |
352 // CHECK_NOCONA_M64: #define __SSE2__ 1 | |
353 // CHECK_NOCONA_M64: #define __SSE3__ 1 | |
354 // CHECK_NOCONA_M64: #define __SSE_MATH__ 1 | |
355 // CHECK_NOCONA_M64: #define __SSE__ 1 | |
356 // CHECK_NOCONA_M64: #define __amd64 1 | |
357 // CHECK_NOCONA_M64: #define __amd64__ 1 | |
358 // CHECK_NOCONA_M64: #define __nocona 1 | |
359 // CHECK_NOCONA_M64: #define __nocona__ 1 | |
360 // CHECK_NOCONA_M64: #define __tune_nocona__ 1 | |
361 // CHECK_NOCONA_M64: #define __x86_64 1 | |
362 // CHECK_NOCONA_M64: #define __x86_64__ 1 | |
363 | |
364 // RUN: %clang -march=core2 -m32 -E -dM %s -o - 2>&1 \ | |
365 // RUN: -target i386-unknown-linux \ | |
366 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE2_M32 | |
367 // CHECK_CORE2_M32: #define __MMX__ 1 | |
368 // CHECK_CORE2_M32: #define __SSE2__ 1 | |
369 // CHECK_CORE2_M32: #define __SSE3__ 1 | |
370 // CHECK_CORE2_M32: #define __SSE__ 1 | |
371 // CHECK_CORE2_M32: #define __SSSE3__ 1 | |
372 // CHECK_CORE2_M32: #define __core2 1 | |
373 // CHECK_CORE2_M32: #define __core2__ 1 | |
374 // CHECK_CORE2_M32: #define __i386 1 | |
375 // CHECK_CORE2_M32: #define __i386__ 1 | |
376 // CHECK_CORE2_M32: #define __tune_core2__ 1 | |
377 // CHECK_CORE2_M32: #define i386 1 | |
378 | |
379 // RUN: %clang -march=core2 -m64 -E -dM %s -o - 2>&1 \ | |
380 // RUN: -target i386-unknown-linux \ | |
381 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE2_M64 | |
382 // CHECK_CORE2_M64: #define __MMX__ 1 | |
383 // CHECK_CORE2_M64: #define __SSE2_MATH__ 1 | |
384 // CHECK_CORE2_M64: #define __SSE2__ 1 | |
385 // CHECK_CORE2_M64: #define __SSE3__ 1 | |
386 // CHECK_CORE2_M64: #define __SSE_MATH__ 1 | |
387 // CHECK_CORE2_M64: #define __SSE__ 1 | |
388 // CHECK_CORE2_M64: #define __SSSE3__ 1 | |
389 // CHECK_CORE2_M64: #define __amd64 1 | |
390 // CHECK_CORE2_M64: #define __amd64__ 1 | |
391 // CHECK_CORE2_M64: #define __core2 1 | |
392 // CHECK_CORE2_M64: #define __core2__ 1 | |
393 // CHECK_CORE2_M64: #define __tune_core2__ 1 | |
394 // CHECK_CORE2_M64: #define __x86_64 1 | |
395 // CHECK_CORE2_M64: #define __x86_64__ 1 | |
396 | |
397 // RUN: %clang -march=corei7 -m32 -E -dM %s -o - 2>&1 \ | |
398 // RUN: -target i386-unknown-linux \ | |
399 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_COREI7_M32 | |
400 // CHECK_COREI7_M32: #define __MMX__ 1 | |
401 // CHECK_COREI7_M32: #define __POPCNT__ 1 | |
402 // CHECK_COREI7_M32: #define __SSE2__ 1 | |
403 // CHECK_COREI7_M32: #define __SSE3__ 1 | |
404 // CHECK_COREI7_M32: #define __SSE4_1__ 1 | |
405 // CHECK_COREI7_M32: #define __SSE4_2__ 1 | |
406 // CHECK_COREI7_M32: #define __SSE__ 1 | |
407 // CHECK_COREI7_M32: #define __SSSE3__ 1 | |
408 // CHECK_COREI7_M32: #define __corei7 1 | |
409 // CHECK_COREI7_M32: #define __corei7__ 1 | |
410 // CHECK_COREI7_M32: #define __i386 1 | |
411 // CHECK_COREI7_M32: #define __i386__ 1 | |
412 // CHECK_COREI7_M32: #define __tune_corei7__ 1 | |
413 // CHECK_COREI7_M32: #define i386 1 | |
414 | |
415 // RUN: %clang -march=corei7 -m64 -E -dM %s -o - 2>&1 \ | |
416 // RUN: -target i386-unknown-linux \ | |
417 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_COREI7_M64 | |
418 // CHECK_COREI7_M64: #define __MMX__ 1 | |
419 // CHECK_COREI7_M64: #define __POPCNT__ 1 | |
420 // CHECK_COREI7_M64: #define __SSE2_MATH__ 1 | |
421 // CHECK_COREI7_M64: #define __SSE2__ 1 | |
422 // CHECK_COREI7_M64: #define __SSE3__ 1 | |
423 // CHECK_COREI7_M64: #define __SSE4_1__ 1 | |
424 // CHECK_COREI7_M64: #define __SSE4_2__ 1 | |
425 // CHECK_COREI7_M64: #define __SSE_MATH__ 1 | |
426 // CHECK_COREI7_M64: #define __SSE__ 1 | |
427 // CHECK_COREI7_M64: #define __SSSE3__ 1 | |
428 // CHECK_COREI7_M64: #define __amd64 1 | |
429 // CHECK_COREI7_M64: #define __amd64__ 1 | |
430 // CHECK_COREI7_M64: #define __corei7 1 | |
431 // CHECK_COREI7_M64: #define __corei7__ 1 | |
432 // CHECK_COREI7_M64: #define __tune_corei7__ 1 | |
433 // CHECK_COREI7_M64: #define __x86_64 1 | |
434 // CHECK_COREI7_M64: #define __x86_64__ 1 | |
435 | |
436 // RUN: %clang -march=corei7-avx -m32 -E -dM %s -o - 2>&1 \ | |
437 // RUN: -target i386-unknown-linux \ | |
438 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_COREI7_AVX_M32 | |
439 // CHECK_COREI7_AVX_M32: #define __AVX__ 1 | |
440 // CHECK_COREI7_AVX_M32: #define __MMX__ 1 | |
441 // CHECK_COREI7_AVX_M32: #define __PCLMUL__ 1 | |
442 // CHECK_COREI7_AVX_M32-NOT: __RDRND__ | |
443 // CHECK_COREI7_AVX_M32: #define __POPCNT__ 1 | |
444 // CHECK_COREI7_AVX_M32: #define __SSE2__ 1 | |
445 // CHECK_COREI7_AVX_M32: #define __SSE3__ 1 | |
446 // CHECK_COREI7_AVX_M32: #define __SSE4_1__ 1 | |
447 // CHECK_COREI7_AVX_M32: #define __SSE4_2__ 1 | |
448 // CHECK_COREI7_AVX_M32: #define __SSE__ 1 | |
449 // CHECK_COREI7_AVX_M32: #define __SSSE3__ 1 | |
450 // CHECK_COREI7_AVX_M32: #define __XSAVEOPT__ 1 | |
451 // CHECK_COREI7_AVX_M32: #define __XSAVE__ 1 | |
452 // CHECK_COREI7_AVX_M32: #define __corei7 1 | |
453 // CHECK_COREI7_AVX_M32: #define __corei7__ 1 | |
454 // CHECK_COREI7_AVX_M32: #define __i386 1 | |
455 // CHECK_COREI7_AVX_M32: #define __i386__ 1 | |
456 // CHECK_COREI7_AVX_M32: #define __tune_corei7__ 1 | |
457 // CHECK_COREI7_AVX_M32: #define i386 1 | |
458 | |
459 // RUN: %clang -march=corei7-avx -m64 -E -dM %s -o - 2>&1 \ | |
460 // RUN: -target i386-unknown-linux \ | |
461 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_COREI7_AVX_M64 | |
462 // CHECK_COREI7_AVX_M64: #define __AVX__ 1 | |
463 // CHECK_COREI7_AVX_M64: #define __MMX__ 1 | |
464 // CHECK_COREI7_AVX_M64: #define __PCLMUL__ 1 | |
465 // CHECK_COREI7_AVX_M64-NOT: __RDRND__ | |
466 // CHECK_COREI7_AVX_M64: #define __POPCNT__ 1 | |
467 // CHECK_COREI7_AVX_M64: #define __SSE2_MATH__ 1 | |
468 // CHECK_COREI7_AVX_M64: #define __SSE2__ 1 | |
469 // CHECK_COREI7_AVX_M64: #define __SSE3__ 1 | |
470 // CHECK_COREI7_AVX_M64: #define __SSE4_1__ 1 | |
471 // CHECK_COREI7_AVX_M64: #define __SSE4_2__ 1 | |
472 // CHECK_COREI7_AVX_M64: #define __SSE_MATH__ 1 | |
473 // CHECK_COREI7_AVX_M64: #define __SSE__ 1 | |
474 // CHECK_COREI7_AVX_M64: #define __SSSE3__ 1 | |
475 // CHECK_COREI7_AVX_M64: #define __XSAVEOPT__ 1 | |
476 // CHECK_COREI7_AVX_M64: #define __XSAVE__ 1 | |
477 // CHECK_COREI7_AVX_M64: #define __amd64 1 | |
478 // CHECK_COREI7_AVX_M64: #define __amd64__ 1 | |
479 // CHECK_COREI7_AVX_M64: #define __corei7 1 | |
480 // CHECK_COREI7_AVX_M64: #define __corei7__ 1 | |
481 // CHECK_COREI7_AVX_M64: #define __tune_corei7__ 1 | |
482 // CHECK_COREI7_AVX_M64: #define __x86_64 1 | |
483 // CHECK_COREI7_AVX_M64: #define __x86_64__ 1 | |
484 | |
485 // RUN: %clang -march=core-avx-i -m32 -E -dM %s -o - 2>&1 \ | |
486 // RUN: -target i386-unknown-linux \ | |
487 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE_AVX_I_M32 | |
488 // CHECK_CORE_AVX_I_M32: #define __AVX__ 1 | |
489 // CHECK_CORE_AVX_I_M32: #define __F16C__ 1 | |
490 // CHECK_CORE_AVX_I_M32: #define __MMX__ 1 | |
491 // CHECK_CORE_AVX_I_M32: #define __PCLMUL__ 1 | |
492 // CHECK_CORE_AVX_I_M32: #define __RDRND__ 1 | |
493 // CHECK_CORE_AVX_I_M32: #define __SSE2__ 1 | |
494 // CHECK_CORE_AVX_I_M32: #define __SSE3__ 1 | |
495 // CHECK_CORE_AVX_I_M32: #define __SSE4_1__ 1 | |
496 // CHECK_CORE_AVX_I_M32: #define __SSE4_2__ 1 | |
497 // CHECK_CORE_AVX_I_M32: #define __SSE__ 1 | |
498 // CHECK_CORE_AVX_I_M32: #define __SSSE3__ 1 | |
499 // CHECK_CORE_AVX_I_M32: #define __XSAVEOPT__ 1 | |
500 // CHECK_CORE_AVX_I_M32: #define __XSAVE__ 1 | |
501 // CHECK_CORE_AVX_I_M32: #define __corei7 1 | |
502 // CHECK_CORE_AVX_I_M32: #define __corei7__ 1 | |
503 // CHECK_CORE_AVX_I_M32: #define __i386 1 | |
504 // CHECK_CORE_AVX_I_M32: #define __i386__ 1 | |
505 // CHECK_CORE_AVX_I_M32: #define __tune_corei7__ 1 | |
506 // CHECK_CORE_AVX_I_M32: #define i386 1 | |
507 | |
508 // RUN: %clang -march=core-avx-i -m64 -E -dM %s -o - 2>&1 \ | |
509 // RUN: -target i386-unknown-linux \ | |
510 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE_AVX_I_M64 | |
511 // CHECK_CORE_AVX_I_M64: #define __AVX__ 1 | |
512 // CHECK_CORE_AVX_I_M64: #define __F16C__ 1 | |
513 // CHECK_CORE_AVX_I_M64: #define __MMX__ 1 | |
514 // CHECK_CORE_AVX_I_M64: #define __PCLMUL__ 1 | |
515 // CHECK_CORE_AVX_I_M64: #define __RDRND__ 1 | |
516 // CHECK_CORE_AVX_I_M64: #define __SSE2_MATH__ 1 | |
517 // CHECK_CORE_AVX_I_M64: #define __SSE2__ 1 | |
518 // CHECK_CORE_AVX_I_M64: #define __SSE3__ 1 | |
519 // CHECK_CORE_AVX_I_M64: #define __SSE4_1__ 1 | |
520 // CHECK_CORE_AVX_I_M64: #define __SSE4_2__ 1 | |
521 // CHECK_CORE_AVX_I_M64: #define __SSE_MATH__ 1 | |
522 // CHECK_CORE_AVX_I_M64: #define __SSE__ 1 | |
523 // CHECK_CORE_AVX_I_M64: #define __SSSE3__ 1 | |
524 // CHECK_CORE_AVX_I_M64: #define __XSAVEOPT__ 1 | |
525 // CHECK_CORE_AVX_I_M64: #define __XSAVE__ 1 | |
526 // CHECK_CORE_AVX_I_M64: #define __amd64 1 | |
527 // CHECK_CORE_AVX_I_M64: #define __amd64__ 1 | |
528 // CHECK_CORE_AVX_I_M64: #define __corei7 1 | |
529 // CHECK_CORE_AVX_I_M64: #define __corei7__ 1 | |
530 // CHECK_CORE_AVX_I_M64: #define __tune_corei7__ 1 | |
531 // CHECK_CORE_AVX_I_M64: #define __x86_64 1 | |
532 // CHECK_CORE_AVX_I_M64: #define __x86_64__ 1 | |
533 | |
534 // RUN: %clang -march=core-avx2 -m32 -E -dM %s -o - 2>&1 \ | |
535 // RUN: -target i386-unknown-linux \ | |
536 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE_AVX2_M32 | |
537 // CHECK_CORE_AVX2_M32: #define __AVX2__ 1 | |
538 // CHECK_CORE_AVX2_M32: #define __AVX__ 1 | |
539 // CHECK_CORE_AVX2_M32: #define __BMI2__ 1 | |
540 // CHECK_CORE_AVX2_M32: #define __BMI__ 1 | |
541 // CHECK_CORE_AVX2_M32: #define __F16C__ 1 | |
542 // CHECK_CORE_AVX2_M32: #define __FMA__ 1 | |
543 // CHECK_CORE_AVX2_M32: #define __INVPCID__ 1 | |
544 // CHECK_CORE_AVX2_M32: #define __LZCNT__ 1 | |
545 // CHECK_CORE_AVX2_M32: #define __MMX__ 1 | |
546 // CHECK_CORE_AVX2_M32: #define __MOVBE__ 1 | |
547 // CHECK_CORE_AVX2_M32: #define __PCLMUL__ 1 | |
548 // CHECK_CORE_AVX2_M32: #define __POPCNT__ 1 | |
549 // CHECK_CORE_AVX2_M32: #define __RDRND__ 1 | |
550 // CHECK_CORE_AVX2_M32: #define __SSE2__ 1 | |
551 // CHECK_CORE_AVX2_M32: #define __SSE3__ 1 | |
552 // CHECK_CORE_AVX2_M32: #define __SSE4_1__ 1 | |
553 // CHECK_CORE_AVX2_M32: #define __SSE4_2__ 1 | |
554 // CHECK_CORE_AVX2_M32: #define __SSE__ 1 | |
555 // CHECK_CORE_AVX2_M32: #define __SSSE3__ 1 | |
556 // CHECK_CORE_AVX2_M32: #define __XSAVEOPT__ 1 | |
557 // CHECK_CORE_AVX2_M32: #define __XSAVE__ 1 | |
558 // CHECK_CORE_AVX2_M32: #define __corei7 1 | |
559 // CHECK_CORE_AVX2_M32: #define __corei7__ 1 | |
560 // CHECK_CORE_AVX2_M32: #define __i386 1 | |
561 // CHECK_CORE_AVX2_M32: #define __i386__ 1 | |
562 // CHECK_CORE_AVX2_M32: #define __tune_corei7__ 1 | |
563 // CHECK_CORE_AVX2_M32: #define i386 1 | |
564 | |
565 // RUN: %clang -march=core-avx2 -m64 -E -dM %s -o - 2>&1 \ | |
566 // RUN: -target i386-unknown-linux \ | |
567 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE_AVX2_M64 | |
568 // CHECK_CORE_AVX2_M64: #define __AVX2__ 1 | |
569 // CHECK_CORE_AVX2_M64: #define __AVX__ 1 | |
570 // CHECK_CORE_AVX2_M64: #define __BMI2__ 1 | |
571 // CHECK_CORE_AVX2_M64: #define __BMI__ 1 | |
572 // CHECK_CORE_AVX2_M64: #define __F16C__ 1 | |
573 // CHECK_CORE_AVX2_M64: #define __FMA__ 1 | |
574 // CHECK_CORE_AVX2_M64: #define __INVPCID__ 1 | |
575 // CHECK_CORE_AVX2_M64: #define __LZCNT__ 1 | |
576 // CHECK_CORE_AVX2_M64: #define __MMX__ 1 | |
577 // CHECK_CORE_AVX2_M64: #define __MOVBE__ 1 | |
578 // CHECK_CORE_AVX2_M64: #define __PCLMUL__ 1 | |
579 // CHECK_CORE_AVX2_M64: #define __POPCNT__ 1 | |
580 // CHECK_CORE_AVX2_M64: #define __RDRND__ 1 | |
581 // CHECK_CORE_AVX2_M64: #define __SSE2_MATH__ 1 | |
582 // CHECK_CORE_AVX2_M64: #define __SSE2__ 1 | |
583 // CHECK_CORE_AVX2_M64: #define __SSE3__ 1 | |
584 // CHECK_CORE_AVX2_M64: #define __SSE4_1__ 1 | |
585 // CHECK_CORE_AVX2_M64: #define __SSE4_2__ 1 | |
586 // CHECK_CORE_AVX2_M64: #define __SSE_MATH__ 1 | |
587 // CHECK_CORE_AVX2_M64: #define __SSE__ 1 | |
588 // CHECK_CORE_AVX2_M64: #define __SSSE3__ 1 | |
589 // CHECK_CORE_AVX2_M64: #define __XSAVEOPT__ 1 | |
590 // CHECK_CORE_AVX2_M64: #define __XSAVE__ 1 | |
591 // CHECK_CORE_AVX2_M64: #define __amd64 1 | |
592 // CHECK_CORE_AVX2_M64: #define __amd64__ 1 | |
593 // CHECK_CORE_AVX2_M64: #define __corei7 1 | |
594 // CHECK_CORE_AVX2_M64: #define __corei7__ 1 | |
595 // CHECK_CORE_AVX2_M64: #define __tune_corei7__ 1 | |
596 // CHECK_CORE_AVX2_M64: #define __x86_64 1 | |
597 // CHECK_CORE_AVX2_M64: #define __x86_64__ 1 | |
598 | |
599 // RUN: %clang -march=broadwell -m32 -E -dM %s -o - 2>&1 \ | |
600 // RUN: -target i386-unknown-linux \ | |
601 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BROADWELL_M32 | |
602 // CHECK_BROADWELL_M32: #define __ADX__ 1 | |
603 // CHECK_BROADWELL_M32: #define __AVX2__ 1 | |
604 // CHECK_BROADWELL_M32: #define __AVX__ 1 | |
605 // CHECK_BROADWELL_M32: #define __BMI2__ 1 | |
606 // CHECK_BROADWELL_M32: #define __BMI__ 1 | |
607 // CHECK_BROADWELL_M32: #define __F16C__ 1 | |
608 // CHECK_BROADWELL_M32: #define __FMA__ 1 | |
609 // CHECK_BROADWELL_M32: #define __INVPCID__ 1 | |
610 // CHECK_BROADWELL_M32: #define __LZCNT__ 1 | |
611 // CHECK_BROADWELL_M32: #define __MMX__ 1 | |
612 // CHECK_BROADWELL_M32: #define __MOVBE__ 1 | |
613 // CHECK_BROADWELL_M32: #define __PCLMUL__ 1 | |
614 // CHECK_BROADWELL_M32: #define __POPCNT__ 1 | |
615 // CHECK_BROADWELL_M32: #define __PRFCHW__ 1 | |
616 // CHECK_BROADWELL_M32: #define __RDRND__ 1 | |
617 // CHECK_BROADWELL_M32: #define __RDSEED__ 1 | |
618 // CHECK_BROADWELL_M32: #define __SSE2__ 1 | |
619 // CHECK_BROADWELL_M32: #define __SSE3__ 1 | |
620 // CHECK_BROADWELL_M32: #define __SSE4_1__ 1 | |
621 // CHECK_BROADWELL_M32: #define __SSE4_2__ 1 | |
622 // CHECK_BROADWELL_M32: #define __SSE__ 1 | |
623 // CHECK_BROADWELL_M32: #define __SSSE3__ 1 | |
624 // CHECK_BROADWELL_M32: #define __XSAVEOPT__ 1 | |
625 // CHECK_BROADWELL_M32: #define __XSAVE__ 1 | |
626 // CHECK_BROADWELL_M32: #define __corei7 1 | |
627 // CHECK_BROADWELL_M32: #define __corei7__ 1 | |
628 // CHECK_BROADWELL_M32: #define __i386 1 | |
629 // CHECK_BROADWELL_M32: #define __i386__ 1 | |
630 // CHECK_BROADWELL_M32: #define __tune_corei7__ 1 | |
631 // CHECK_BROADWELL_M32: #define i386 1 | |
632 | |
633 // RUN: %clang -march=broadwell -m64 -E -dM %s -o - 2>&1 \ | |
634 // RUN: -target i386-unknown-linux \ | |
635 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BROADWELL_M64 | |
636 // CHECK_BROADWELL_M64: #define __ADX__ 1 | |
637 // CHECK_BROADWELL_M64: #define __AVX2__ 1 | |
638 // CHECK_BROADWELL_M64: #define __AVX__ 1 | |
639 // CHECK_BROADWELL_M64: #define __BMI2__ 1 | |
640 // CHECK_BROADWELL_M64: #define __BMI__ 1 | |
641 // CHECK_BROADWELL_M64: #define __F16C__ 1 | |
642 // CHECK_BROADWELL_M64: #define __FMA__ 1 | |
643 // CHECK_BROADWELL_M64: #define __INVPCID__ 1 | |
644 // CHECK_BROADWELL_M64: #define __LZCNT__ 1 | |
645 // CHECK_BROADWELL_M64: #define __MMX__ 1 | |
646 // CHECK_BROADWELL_M64: #define __MOVBE__ 1 | |
647 // CHECK_BROADWELL_M64: #define __PCLMUL__ 1 | |
648 // CHECK_BROADWELL_M64: #define __POPCNT__ 1 | |
649 // CHECK_BROADWELL_M64: #define __PRFCHW__ 1 | |
650 // CHECK_BROADWELL_M64: #define __RDRND__ 1 | |
651 // CHECK_BROADWELL_M64: #define __RDSEED__ 1 | |
652 // CHECK_BROADWELL_M64: #define __SSE2_MATH__ 1 | |
653 // CHECK_BROADWELL_M64: #define __SSE2__ 1 | |
654 // CHECK_BROADWELL_M64: #define __SSE3__ 1 | |
655 // CHECK_BROADWELL_M64: #define __SSE4_1__ 1 | |
656 // CHECK_BROADWELL_M64: #define __SSE4_2__ 1 | |
657 // CHECK_BROADWELL_M64: #define __SSE_MATH__ 1 | |
658 // CHECK_BROADWELL_M64: #define __SSE__ 1 | |
659 // CHECK_BROADWELL_M64: #define __SSSE3__ 1 | |
660 // CHECK_BROADWELL_M64: #define __XSAVEOPT__ 1 | |
661 // CHECK_BROADWELL_M64: #define __XSAVE__ 1 | |
662 // CHECK_BROADWELL_M64: #define __amd64 1 | |
663 // CHECK_BROADWELL_M64: #define __amd64__ 1 | |
664 // CHECK_BROADWELL_M64: #define __corei7 1 | |
665 // CHECK_BROADWELL_M64: #define __corei7__ 1 | |
666 // CHECK_BROADWELL_M64: #define __tune_corei7__ 1 | |
667 // CHECK_BROADWELL_M64: #define __x86_64 1 | |
668 // CHECK_BROADWELL_M64: #define __x86_64__ 1 | |
669 | |
670 // RUN: %clang -march=skylake -m32 -E -dM %s -o - 2>&1 \ | |
671 // RUN: -target i386-unknown-linux \ | |
672 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SKL_M32 | |
673 // CHECK_SKL_M32: #define __ADX__ 1 | |
674 // CHECK_SKL_M32: #define __AES__ 1 | |
675 // CHECK_SKL_M32: #define __AVX2__ 1 | |
676 // CHECK_SKL_M32: #define __AVX__ 1 | |
677 // CHECK_SKL_M32: #define __BMI2__ 1 | |
678 // CHECK_SKL_M32: #define __BMI__ 1 | |
679 // CHECK_SKL_M32: #define __CLFLUSHOPT__ 1 | |
680 // CHECK_SKL_M32: #define __F16C__ 1 | |
681 // CHECK_SKL_M32: #define __FMA__ 1 | |
682 // CHECK_SKL_M32: #define __INVPCID__ 1 | |
683 // CHECK_SKL_M32: #define __LZCNT__ 1 | |
684 // CHECK_SKL_M32: #define __MMX__ 1 | |
685 // CHECK_SKL_M32: #define __MOVBE__ 1 | |
686 // CHECK_SKL_M32: #define __PCLMUL__ 1 | |
687 // CHECK_SKL_M32: #define __POPCNT__ 1 | |
688 // CHECK_SKL_M32: #define __PRFCHW__ 1 | |
689 // CHECK_SKL_M32: #define __RDRND__ 1 | |
690 // CHECK_SKL_M32: #define __RDSEED__ 1 | |
691 // CHECK_SKL_M32: #define __SGX__ 1 | |
692 // CHECK_SKL_M32: #define __SSE2__ 1 | |
693 // CHECK_SKL_M32: #define __SSE3__ 1 | |
694 // CHECK_SKL_M32: #define __SSE4_1__ 1 | |
695 // CHECK_SKL_M32: #define __SSE4_2__ 1 | |
696 // CHECK_SKL_M32: #define __SSE__ 1 | |
697 // CHECK_SKL_M32: #define __SSSE3__ 1 | |
698 // CHECK_SKL_M32: #define __XSAVEC__ 1 | |
699 // CHECK_SKL_M32: #define __XSAVEOPT__ 1 | |
700 // CHECK_SKL_M32: #define __XSAVES__ 1 | |
701 // CHECK_SKL_M32: #define __XSAVE__ 1 | |
702 // CHECK_SKL_M32: #define i386 1 | |
703 | |
704 // RUN: %clang -march=skylake -m64 -E -dM %s -o - 2>&1 \ | |
705 // RUN: -target i386-unknown-linux \ | |
706 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SKL_M64 | |
707 // CHECK_SKL_M64: #define __ADX__ 1 | |
708 // CHECK_SKL_M64: #define __AES__ 1 | |
709 // CHECK_SKL_M64: #define __AVX2__ 1 | |
710 // CHECK_SKL_M64: #define __AVX__ 1 | |
711 // CHECK_SKL_M64: #define __BMI2__ 1 | |
712 // CHECK_SKL_M64: #define __BMI__ 1 | |
713 // CHECK_SKL_M64: #define __CLFLUSHOPT__ 1 | |
714 // CHECK_SKL_M64: #define __F16C__ 1 | |
715 // CHECK_SKL_M64: #define __FMA__ 1 | |
716 // CHECK_SKL_M64: #define __INVPCID__ 1 | |
717 // CHECK_SKL_M64: #define __LZCNT__ 1 | |
718 // CHECK_SKL_M64: #define __MMX__ 1 | |
719 // CHECK_SKL_M64: #define __MOVBE__ 1 | |
720 // CHECK_SKL_M64: #define __PCLMUL__ 1 | |
721 // CHECK_SKL_M64: #define __POPCNT__ 1 | |
722 // CHECK_SKL_M64: #define __PRFCHW__ 1 | |
723 // CHECK_SKL_M64: #define __RDRND__ 1 | |
724 // CHECK_SKL_M64: #define __RDSEED__ 1 | |
725 // CHECK_SKL_M64: #define __SGX__ 1 | |
726 // CHECK_SKL_M64: #define __SSE2_MATH__ 1 | |
727 // CHECK_SKL_M64: #define __SSE2__ 1 | |
728 // CHECK_SKL_M64: #define __SSE3__ 1 | |
729 // CHECK_SKL_M64: #define __SSE4_1__ 1 | |
730 // CHECK_SKL_M64: #define __SSE4_2__ 1 | |
731 // CHECK_SKL_M64: #define __SSE_MATH__ 1 | |
732 // CHECK_SKL_M64: #define __SSE__ 1 | |
733 // CHECK_SKL_M64: #define __SSSE3__ 1 | |
734 // CHECK_SKL_M64: #define __XSAVEC__ 1 | |
735 // CHECK_SKL_M64: #define __XSAVEOPT__ 1 | |
736 // CHECK_SKL_M64: #define __XSAVES__ 1 | |
737 // CHECK_SKL_M64: #define __XSAVE__ 1 | |
738 // CHECK_SKL_M64: #define __amd64 1 | |
739 // CHECK_SKL_M64: #define __amd64__ 1 | |
740 // CHECK_SKL_M64: #define __x86_64 1 | |
741 // CHECK_SKL_M64: #define __x86_64__ 1 | |
742 | |
743 // RUN: %clang -march=knl -m32 -E -dM %s -o - 2>&1 \ | |
744 // RUN: -target i386-unknown-linux \ | |
745 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_KNL_M32 | |
746 // CHECK_KNL_M32: #define __AES__ 1 | |
747 // CHECK_KNL_M32: #define __AVX2__ 1 | |
748 // CHECK_KNL_M32: #define __AVX512CD__ 1 | |
749 // CHECK_KNL_M32: #define __AVX512ER__ 1 | |
750 // CHECK_KNL_M32: #define __AVX512F__ 1 | |
751 // CHECK_KNL_M32: #define __AVX512PF__ 1 | |
752 // CHECK_KNL_M32: #define __AVX__ 1 | |
753 // CHECK_KNL_M32: #define __BMI2__ 1 | |
754 // CHECK_KNL_M32: #define __BMI__ 1 | |
755 // CHECK_KNL_M32: #define __F16C__ 1 | |
756 // CHECK_KNL_M32: #define __FMA__ 1 | |
757 // CHECK_KNL_M32: #define __LZCNT__ 1 | |
758 // CHECK_KNL_M32: #define __MMX__ 1 | |
759 // CHECK_KNL_M32: #define __MOVBE__ 1 | |
760 // CHECK_KNL_M32: #define __PCLMUL__ 1 | |
761 // CHECK_KNL_M32: #define __POPCNT__ 1 | |
762 // CHECK_KNL_M32: #define __PREFETCHWT1__ 1 | |
763 // CHECK_KNL_M32: #define __PRFCHW__ 1 | |
764 // CHECK_KNL_M32: #define __RDRND__ 1 | |
765 // CHECK_KNL_M32: #define __SSE2__ 1 | |
766 // CHECK_KNL_M32: #define __SSE3__ 1 | |
767 // CHECK_KNL_M32: #define __SSE4_1__ 1 | |
768 // CHECK_KNL_M32: #define __SSE4_2__ 1 | |
769 // CHECK_KNL_M32: #define __SSE__ 1 | |
770 // CHECK_KNL_M32: #define __SSSE3__ 1 | |
771 // CHECK_KNL_M32: #define __XSAVEOPT__ 1 | |
772 // CHECK_KNL_M32: #define __XSAVE__ 1 | |
773 // CHECK_KNL_M32: #define __i386 1 | |
774 // CHECK_KNL_M32: #define __i386__ 1 | |
775 // CHECK_KNL_M32: #define __knl 1 | |
776 // CHECK_KNL_M32: #define __knl__ 1 | |
777 // CHECK_KNL_M32: #define __tune_knl__ 1 | |
778 // CHECK_KNL_M32: #define i386 1 | |
779 | |
780 // RUN: %clang -march=knl -m64 -E -dM %s -o - 2>&1 \ | |
781 // RUN: -target i386-unknown-linux \ | |
782 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_KNL_M64 | |
783 // CHECK_KNL_M64: #define __AES__ 1 | |
784 // CHECK_KNL_M64: #define __AVX2__ 1 | |
785 // CHECK_KNL_M64: #define __AVX512CD__ 1 | |
786 // CHECK_KNL_M64: #define __AVX512ER__ 1 | |
787 // CHECK_KNL_M64: #define __AVX512F__ 1 | |
788 // CHECK_KNL_M64: #define __AVX512PF__ 1 | |
789 // CHECK_KNL_M64: #define __AVX__ 1 | |
790 // CHECK_KNL_M64: #define __BMI2__ 1 | |
791 // CHECK_KNL_M64: #define __BMI__ 1 | |
792 // CHECK_KNL_M64: #define __F16C__ 1 | |
793 // CHECK_KNL_M64: #define __FMA__ 1 | |
794 // CHECK_KNL_M64: #define __LZCNT__ 1 | |
795 // CHECK_KNL_M64: #define __MMX__ 1 | |
796 // CHECK_KNL_M64: #define __MOVBE__ 1 | |
797 // CHECK_KNL_M64: #define __PCLMUL__ 1 | |
798 // CHECK_KNL_M64: #define __POPCNT__ 1 | |
799 // CHECK_KNL_M64: #define __PREFETCHWT1__ 1 | |
800 // CHECK_KNL_M64: #define __PRFCHW__ 1 | |
801 // CHECK_KNL_M64: #define __RDRND__ 1 | |
802 // CHECK_KNL_M64: #define __SSE2_MATH__ 1 | |
803 // CHECK_KNL_M64: #define __SSE2__ 1 | |
804 // CHECK_KNL_M64: #define __SSE3__ 1 | |
805 // CHECK_KNL_M64: #define __SSE4_1__ 1 | |
806 // CHECK_KNL_M64: #define __SSE4_2__ 1 | |
807 // CHECK_KNL_M64: #define __SSE_MATH__ 1 | |
808 // CHECK_KNL_M64: #define __SSE__ 1 | |
809 // CHECK_KNL_M64: #define __SSSE3__ 1 | |
810 // CHECK_KNL_M64: #define __XSAVEOPT__ 1 | |
811 // CHECK_KNL_M64: #define __XSAVE__ 1 | |
812 // CHECK_KNL_M64: #define __amd64 1 | |
813 // CHECK_KNL_M64: #define __amd64__ 1 | |
814 // CHECK_KNL_M64: #define __knl 1 | |
815 // CHECK_KNL_M64: #define __knl__ 1 | |
816 // CHECK_KNL_M64: #define __tune_knl__ 1 | |
817 // CHECK_KNL_M64: #define __x86_64 1 | |
818 // CHECK_KNL_M64: #define __x86_64__ 1 | |
819 | |
820 // RUN: %clang -march=knm -m32 -E -dM %s -o - 2>&1 \ | |
821 // RUN: -target i386-unknown-linux \ | |
822 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_KNM_M32 | |
823 // CHECK_KNM_M32: #define __AES__ 1 | |
824 // CHECK_KNM_M32: #define __AVX2__ 1 | |
825 // CHECK_KNM_M32: #define __AVX512CD__ 1 | |
826 // CHECK_KNM_M32: #define __AVX512ER__ 1 | |
827 // CHECK_KNM_M32: #define __AVX512F__ 1 | |
828 // CHECK_KNM_M32: #define __AVX512PF__ 1 | |
829 // CHECK_KNM_M32: #define __AVX512VPOPCNTDQ__ 1 | |
830 // CHECK_KNM_M32: #define __AVX__ 1 | |
831 // CHECK_KNM_M32: #define __BMI2__ 1 | |
832 // CHECK_KNM_M32: #define __BMI__ 1 | |
833 // CHECK_KNM_M32: #define __F16C__ 1 | |
834 // CHECK_KNM_M32: #define __FMA__ 1 | |
835 // CHECK_KNM_M32: #define __LZCNT__ 1 | |
836 // CHECK_KNM_M32: #define __MMX__ 1 | |
837 // CHECK_KNM_M32: #define __MOVBE__ 1 | |
838 // CHECK_KNM_M32: #define __PCLMUL__ 1 | |
839 // CHECK_KNM_M32: #define __POPCNT__ 1 | |
840 // CHECK_KNM_M32: #define __PREFETCHWT1__ 1 | |
841 // CHECK_KNM_M32: #define __PRFCHW__ 1 | |
842 // CHECK_KNM_M32: #define __RDRND__ 1 | |
843 // CHECK_KNM_M32: #define __SSE2__ 1 | |
844 // CHECK_KNM_M32: #define __SSE3__ 1 | |
845 // CHECK_KNM_M32: #define __SSE4_1__ 1 | |
846 // CHECK_KNM_M32: #define __SSE4_2__ 1 | |
847 // CHECK_KNM_M32: #define __SSE__ 1 | |
848 // CHECK_KNM_M32: #define __SSSE3__ 1 | |
849 // CHECK_KNM_M32: #define __XSAVEOPT__ 1 | |
850 // CHECK_KNM_M32: #define __XSAVE__ 1 | |
851 // CHECK_KNM_M32: #define __i386 1 | |
852 // CHECK_KNM_M32: #define __i386__ 1 | |
853 // CHECK_KNM_M32: #define i386 1 | |
854 | |
855 // RUN: %clang -march=knm -m64 -E -dM %s -o - 2>&1 \ | |
856 // RUN: -target i386-unknown-linux \ | |
857 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_KNM_M64 | |
858 // CHECK_KNM_M64: #define __AES__ 1 | |
859 // CHECK_KNM_M64: #define __AVX2__ 1 | |
860 // CHECK_KNM_M64: #define __AVX512CD__ 1 | |
861 // CHECK_KNM_M64: #define __AVX512ER__ 1 | |
862 // CHECK_KNM_M64: #define __AVX512F__ 1 | |
863 // CHECK_KNM_M64: #define __AVX512PF__ 1 | |
864 // CHECK_KNM_M64: #define __AVX512VPOPCNTDQ__ 1 | |
865 // CHECK_KNM_M64: #define __AVX__ 1 | |
866 // CHECK_KNM_M64: #define __BMI2__ 1 | |
867 // CHECK_KNM_M64: #define __BMI__ 1 | |
868 // CHECK_KNM_M64: #define __F16C__ 1 | |
869 // CHECK_KNM_M64: #define __FMA__ 1 | |
870 // CHECK_KNM_M64: #define __LZCNT__ 1 | |
871 // CHECK_KNM_M64: #define __MMX__ 1 | |
872 // CHECK_KNM_M64: #define __MOVBE__ 1 | |
873 // CHECK_KNM_M64: #define __PCLMUL__ 1 | |
874 // CHECK_KNM_M64: #define __POPCNT__ 1 | |
875 // CHECK_KNM_M64: #define __PREFETCHWT1__ 1 | |
876 // CHECK_KNM_M64: #define __PRFCHW__ 1 | |
877 // CHECK_KNM_M64: #define __RDRND__ 1 | |
878 // CHECK_KNM_M64: #define __SSE2_MATH__ 1 | |
879 // CHECK_KNM_M64: #define __SSE2__ 1 | |
880 // CHECK_KNM_M64: #define __SSE3__ 1 | |
881 // CHECK_KNM_M64: #define __SSE4_1__ 1 | |
882 // CHECK_KNM_M64: #define __SSE4_2__ 1 | |
883 // CHECK_KNM_M64: #define __SSE_MATH__ 1 | |
884 // CHECK_KNM_M64: #define __SSE__ 1 | |
885 // CHECK_KNM_M64: #define __SSSE3__ 1 | |
886 // CHECK_KNM_M64: #define __XSAVEOPT__ 1 | |
887 // CHECK_KNM_M64: #define __XSAVE__ 1 | |
888 // CHECK_KNM_M64: #define __amd64 1 | |
889 // CHECK_KNM_M64: #define __amd64__ 1 | |
890 // CHECK_KNM_M64: #define __x86_64 1 | |
891 // CHECK_KNM_M64: #define __x86_64__ 1 | |
892 | |
893 // RUN: %clang -march=skylake-avx512 -m32 -E -dM %s -o - 2>&1 \ | |
894 // RUN: -target i386-unknown-linux \ | |
895 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SKX_M32 | |
896 // CHECK_SKX_M32: #define __AES__ 1 | |
897 // CHECK_SKX_M32: #define __AVX2__ 1 | |
898 // CHECK_SKX_M32: #define __AVX512BW__ 1 | |
899 // CHECK_SKX_M32: #define __AVX512CD__ 1 | |
900 // CHECK_SKX_M32: #define __AVX512DQ__ 1 | |
901 // CHECK_SKX_M32: #define __AVX512F__ 1 | |
902 // CHECK_SKX_M32: #define __AVX512VL__ 1 | |
903 // CHECK_SKX_M32: #define __AVX__ 1 | |
904 // CHECK_SKX_M32: #define __BMI2__ 1 | |
905 // CHECK_SKX_M32: #define __BMI__ 1 | |
906 // CHECK_SKX_M32: #define __CLFLUSHOPT__ 1 | |
907 // CHECK_SKX_M32: #define __CLWB__ 1 | |
908 // CHECK_SKX_M32: #define __F16C__ 1 | |
909 // CHECK_SKX_M32: #define __FMA__ 1 | |
910 // CHECK_SKX_M32: #define __INVPCID__ 1 | |
911 // CHECK_SKX_M32: #define __LZCNT__ 1 | |
912 // CHECK_SKX_M32: #define __MMX__ 1 | |
913 // CHECK_SKX_M32: #define __MOVBE__ 1 | |
914 // CHECK_SKX_M32: #define __PCLMUL__ 1 | |
915 // CHECK_SKX_M32: #define __PKU__ 1 | |
916 // CHECK_SKX_M32: #define __POPCNT__ 1 | |
917 // CHECK_SKX_M32: #define __PRFCHW__ 1 | |
918 // CHECK_SKX_M32: #define __RDRND__ 1 | |
919 // CHECK_SKX_M32: #define __RDSEED__ 1 | |
920 // CHECK_SKX_M32-NOT: #define __SGX__ 1 | |
921 // CHECK_SKX_M32: #define __SSE2__ 1 | |
922 // CHECK_SKX_M32: #define __SSE3__ 1 | |
923 // CHECK_SKX_M32: #define __SSE4_1__ 1 | |
924 // CHECK_SKX_M32: #define __SSE4_2__ 1 | |
925 // CHECK_SKX_M32: #define __SSE__ 1 | |
926 // CHECK_SKX_M32: #define __SSSE3__ 1 | |
927 // CHECK_SKX_M32: #define __XSAVEC__ 1 | |
928 // CHECK_SKX_M32: #define __XSAVEOPT__ 1 | |
929 // CHECK_SKX_M32: #define __XSAVES__ 1 | |
930 // CHECK_SKX_M32: #define __XSAVE__ 1 | |
931 // CHECK_SKX_M32: #define __corei7 1 | |
932 // CHECK_SKX_M32: #define __corei7__ 1 | |
933 // CHECK_SKX_M32: #define __i386 1 | |
934 // CHECK_SKX_M32: #define __i386__ 1 | |
935 // CHECK_SKX_M32: #define __tune_corei7__ 1 | |
936 // CHECK_SKX_M32: #define i386 1 | |
937 | |
938 // RUN: %clang -march=skylake-avx512 -m64 -E -dM %s -o - 2>&1 \ | |
939 // RUN: -target i386-unknown-linux \ | |
940 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SKX_M64 | |
941 // CHECK_SKX_M64: #define __AES__ 1 | |
942 // CHECK_SKX_M64: #define __AVX2__ 1 | |
943 // CHECK_SKX_M64: #define __AVX512BW__ 1 | |
944 // CHECK_SKX_M64: #define __AVX512CD__ 1 | |
945 // CHECK_SKX_M64: #define __AVX512DQ__ 1 | |
946 // CHECK_SKX_M64: #define __AVX512F__ 1 | |
947 // CHECK_SKX_M64: #define __AVX512VL__ 1 | |
948 // CHECK_SKX_M64: #define __AVX__ 1 | |
949 // CHECK_SKX_M64: #define __BMI2__ 1 | |
950 // CHECK_SKX_M64: #define __BMI__ 1 | |
951 // CHECK_SKX_M64: #define __CLFLUSHOPT__ 1 | |
952 // CHECK_SKX_M64: #define __CLWB__ 1 | |
953 // CHECK_SKX_M64: #define __F16C__ 1 | |
954 // CHECK_SKX_M64: #define __FMA__ 1 | |
955 // CHECK_SKX_M64: #define __INVPCID__ 1 | |
956 // CHECK_SKX_M64: #define __LZCNT__ 1 | |
957 // CHECK_SKX_M64: #define __MMX__ 1 | |
958 // CHECK_SKX_M64: #define __MOVBE__ 1 | |
959 // CHECK_SKX_M64: #define __PCLMUL__ 1 | |
960 // CHECK_SKX_M64: #define __PKU__ 1 | |
961 // CHECK_SKX_M64: #define __POPCNT__ 1 | |
962 // CHECK_SKX_M64: #define __PRFCHW__ 1 | |
963 // CHECK_SKX_M64: #define __RDRND__ 1 | |
964 // CHECK_SKX_M64: #define __RDSEED__ 1 | |
965 // CHECK_SKX_M64-NOT: #define __SGX__ 1 | |
966 // CHECK_SKX_M64: #define __SSE2_MATH__ 1 | |
967 // CHECK_SKX_M64: #define __SSE2__ 1 | |
968 // CHECK_SKX_M64: #define __SSE3__ 1 | |
969 // CHECK_SKX_M64: #define __SSE4_1__ 1 | |
970 // CHECK_SKX_M64: #define __SSE4_2__ 1 | |
971 // CHECK_SKX_M64: #define __SSE_MATH__ 1 | |
972 // CHECK_SKX_M64: #define __SSE__ 1 | |
973 // CHECK_SKX_M64: #define __SSSE3__ 1 | |
974 // CHECK_SKX_M64: #define __XSAVEC__ 1 | |
975 // CHECK_SKX_M64: #define __XSAVEOPT__ 1 | |
976 // CHECK_SKX_M64: #define __XSAVES__ 1 | |
977 // CHECK_SKX_M64: #define __XSAVE__ 1 | |
978 // CHECK_SKX_M64: #define __amd64 1 | |
979 // CHECK_SKX_M64: #define __amd64__ 1 | |
980 // CHECK_SKX_M64: #define __corei7 1 | |
981 // CHECK_SKX_M64: #define __corei7__ 1 | |
982 // CHECK_SKX_M64: #define __tune_corei7__ 1 | |
983 // CHECK_SKX_M64: #define __x86_64 1 | |
984 // CHECK_SKX_M64: #define __x86_64__ 1 | |
985 | |
986 // RUN: %clang -march=cascadelake -m32 -E -dM %s -o - 2>&1 \ | |
987 // RUN: -target i386-unknown-linux \ | |
988 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CLX_M32 | |
989 // CHECK_CLX_M32: #define __AES__ 1 | |
990 // CHECK_CLX_M32: #define __AVX2__ 1 | |
991 // CHECK_CLX_M32: #define __AVX512BW__ 1 | |
992 // CHECK_CLX_M32: #define __AVX512CD__ 1 | |
993 // CHECK_CLX_M32: #define __AVX512DQ__ 1 | |
994 // CHECK_CLX_M32: #define __AVX512F__ 1 | |
995 // CHECK_CLX_M32: #define __AVX512VL__ 1 | |
996 // CHECK_CLX_M32: #define __AVX512VNNI__ 1 | |
997 // CHECK_CLX_M32: #define __AVX__ 1 | |
998 // CHECK_CLX_M32: #define __BMI2__ 1 | |
999 // CHECK_CLX_M32: #define __BMI__ 1 | |
1000 // CHECK_CLX_M32: #define __CLFLUSHOPT__ 1 | |
1001 // CHECK_CLX_M32: #define __CLWB__ 1 | |
1002 // CHECK_CLX_M32: #define __F16C__ 1 | |
1003 // CHECK_CLX_M32: #define __FMA__ 1 | |
1004 // CHECK_CLX_M32: #define __INVPCID__ 1 | |
1005 // CHECK_CLX_M32: #define __LZCNT__ 1 | |
1006 // CHECK_CLX_M32: #define __MMX__ 1 | |
1007 // CHECK_CLX_M32: #define __MOVBE__ 1 | |
1008 // CHECK_CLX_M32: #define __PCLMUL__ 1 | |
1009 // CHECK_CLX_M32: #define __PKU__ 1 | |
1010 // CHECK_CLX_M32: #define __POPCNT__ 1 | |
1011 // CHECK_CLX_M32: #define __PRFCHW__ 1 | |
1012 // CHECK_CLX_M32: #define __RDRND__ 1 | |
1013 // CHECK_CLX_M32: #define __RDSEED__ 1 | |
1014 // CHECK_CLX_M32-NOT: #define __SGX__ 1 | |
1015 // CHECK_CLX_M32: #define __SSE2__ 1 | |
1016 // CHECK_CLX_M32: #define __SSE3__ 1 | |
1017 // CHECK_CLX_M32: #define __SSE4_1__ 1 | |
1018 // CHECK_CLX_M32: #define __SSE4_2__ 1 | |
1019 // CHECK_CLX_M32: #define __SSE__ 1 | |
1020 // CHECK_CLX_M32: #define __SSSE3__ 1 | |
1021 // CHECK_CLX_M32: #define __XSAVEC__ 1 | |
1022 // CHECK_CLX_M32: #define __XSAVEOPT__ 1 | |
1023 // CHECK_CLX_M32: #define __XSAVES__ 1 | |
1024 // CHECK_CLX_M32: #define __XSAVE__ 1 | |
1025 // CHECK_CLX_M32: #define __corei7 1 | |
1026 // CHECK_CLX_M32: #define __corei7__ 1 | |
1027 // CHECK_CLX_M32: #define __i386 1 | |
1028 // CHECK_CLX_M32: #define __i386__ 1 | |
1029 // CHECK_CLX_M32: #define __tune_corei7__ 1 | |
1030 // CHECK_CLX_M32: #define i386 1 | |
1031 | |
1032 // RUN: %clang -march=cascadelake -m64 -E -dM %s -o - 2>&1 \ | |
1033 // RUN: -target i386-unknown-linux \ | |
1034 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CLX_M64 | |
1035 // CHECK_CLX_M64: #define __AES__ 1 | |
1036 // CHECK_CLX_M64: #define __AVX2__ 1 | |
1037 // CHECK_CLX_M64: #define __AVX512BW__ 1 | |
1038 // CHECK_CLX_M64: #define __AVX512CD__ 1 | |
1039 // CHECK_CLX_M64: #define __AVX512DQ__ 1 | |
1040 // CHECK_CLX_M64: #define __AVX512F__ 1 | |
1041 // CHECK_CLX_M64: #define __AVX512VL__ 1 | |
1042 // CHECK_CLX_M64: #define __AVX512VNNI__ 1 | |
1043 // CHECK_CLX_M64: #define __AVX__ 1 | |
1044 // CHECK_CLX_M64: #define __BMI2__ 1 | |
1045 // CHECK_CLX_M64: #define __BMI__ 1 | |
1046 // CHECK_CLX_M64: #define __CLFLUSHOPT__ 1 | |
1047 // CHECK_CLX_M64: #define __CLWB__ 1 | |
1048 // CHECK_CLX_M64: #define __F16C__ 1 | |
1049 // CHECK_CLX_M64: #define __FMA__ 1 | |
1050 // CHECK_CLX_M64: #define __INVPCID__ 1 | |
1051 // CHECK_CLX_M64: #define __LZCNT__ 1 | |
1052 // CHECK_CLX_M64: #define __MMX__ 1 | |
1053 // CHECK_CLX_M64: #define __MOVBE__ 1 | |
1054 // CHECK_CLX_M64: #define __PCLMUL__ 1 | |
1055 // CHECK_CLX_M64: #define __PKU__ 1 | |
1056 // CHECK_CLX_M64: #define __POPCNT__ 1 | |
1057 // CHECK_CLX_M64: #define __PRFCHW__ 1 | |
1058 // CHECK_CLX_M64: #define __RDRND__ 1 | |
1059 // CHECK_CLX_M64: #define __RDSEED__ 1 | |
1060 // CHECK_CLX_M64-NOT: #define __SGX__ 1 | |
1061 // CHECK_CLX_M64: #define __SSE2_MATH__ 1 | |
1062 // CHECK_CLX_M64: #define __SSE2__ 1 | |
1063 // CHECK_CLX_M64: #define __SSE3__ 1 | |
1064 // CHECK_CLX_M64: #define __SSE4_1__ 1 | |
1065 // CHECK_CLX_M64: #define __SSE4_2__ 1 | |
1066 // CHECK_CLX_M64: #define __SSE_MATH__ 1 | |
1067 // CHECK_CLX_M64: #define __SSE__ 1 | |
1068 // CHECK_CLX_M64: #define __SSSE3__ 1 | |
1069 // CHECK_CLX_M64: #define __XSAVEC__ 1 | |
1070 // CHECK_CLX_M64: #define __XSAVEOPT__ 1 | |
1071 // CHECK_CLX_M64: #define __XSAVES__ 1 | |
1072 // CHECK_CLX_M64: #define __XSAVE__ 1 | |
1073 // CHECK_CLX_M64: #define __amd64 1 | |
1074 // CHECK_CLX_M64: #define __amd64__ 1 | |
1075 // CHECK_CLX_M64: #define __corei7 1 | |
1076 // CHECK_CLX_M64: #define __corei7__ 1 | |
1077 // CHECK_CLX_M64: #define __tune_corei7__ 1 | |
1078 // CHECK_CLX_M64: #define __x86_64 1 | |
1079 // CHECK_CLX_M64: #define __x86_64__ 1 | |
1080 | |
1081 // RUN: %clang -march=cooperlake -m32 -E -dM %s -o - 2>&1 \ | |
1082 // RUN: -target i386-unknown-linux \ | |
1083 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CPX_M32 | |
1084 // CHECK_CPX_M32: #define __AES__ 1 | |
1085 // CHECK_CPX_M32: #define __AVX2__ 1 | |
1086 // CHECK_CPX_M32: #define __AVX512BF16__ 1 | |
1087 // CHECK_CPX_M32: #define __AVX512BW__ 1 | |
1088 // CHECK_CPX_M32: #define __AVX512CD__ 1 | |
1089 // CHECK_CPX_M32: #define __AVX512DQ__ 1 | |
1090 // CHECK_CPX_M32: #define __AVX512F__ 1 | |
1091 // CHECK_CPX_M32: #define __AVX512VL__ 1 | |
1092 // CHECK_CPX_M32: #define __AVX512VNNI__ 1 | |
1093 // CHECK_CPX_M32: #define __AVX__ 1 | |
1094 // CHECK_CPX_M32: #define __BMI2__ 1 | |
1095 // CHECK_CPX_M32: #define __BMI__ 1 | |
1096 // CHECK_CPX_M32: #define __CLFLUSHOPT__ 1 | |
1097 // CHECK_CPX_M32: #define __CLWB__ 1 | |
1098 // CHECK_CPX_M32: #define __F16C__ 1 | |
1099 // CHECK_CPX_M32: #define __FMA__ 1 | |
1100 // CHECK_CPX_M32: #define __INVPCID__ 1 | |
1101 // CHECK_CPX_M32: #define __LZCNT__ 1 | |
1102 // CHECK_CPX_M32: #define __MMX__ 1 | |
1103 // CHECK_CPX_M32: #define __MOVBE__ 1 | |
1104 // CHECK_CPX_M32: #define __PCLMUL__ 1 | |
1105 // CHECK_CPX_M32: #define __PKU__ 1 | |
1106 // CHECK_CPX_M32: #define __POPCNT__ 1 | |
1107 // CHECK_CPX_M32: #define __PRFCHW__ 1 | |
1108 // CHECK_CPX_M32: #define __RDRND__ 1 | |
1109 // CHECK_CPX_M32: #define __RDSEED__ 1 | |
1110 // CHECK_CPX_M32-NOT: #define __SGX__ 1 | |
1111 // CHECK_CPX_M32: #define __SSE2__ 1 | |
1112 // CHECK_CPX_M32: #define __SSE3__ 1 | |
1113 // CHECK_CPX_M32: #define __SSE4_1__ 1 | |
1114 // CHECK_CPX_M32: #define __SSE4_2__ 1 | |
1115 // CHECK_CPX_M32: #define __SSE__ 1 | |
1116 // CHECK_CPX_M32: #define __SSSE3__ 1 | |
1117 // CHECK_CPX_M32: #define __XSAVEC__ 1 | |
1118 // CHECK_CPX_M32: #define __XSAVEOPT__ 1 | |
1119 // CHECK_CPX_M32: #define __XSAVES__ 1 | |
1120 // CHECK_CPX_M32: #define __XSAVE__ 1 | |
1121 // CHECK_CPX_M32: #define __corei7 1 | |
1122 // CHECK_CPX_M32: #define __corei7__ 1 | |
1123 // CHECK_CPX_M32: #define __i386 1 | |
1124 // CHECK_CPX_M32: #define __i386__ 1 | |
1125 // CHECK_CPX_M32: #define __tune_corei7__ 1 | |
1126 // CHECK_CPX_M32: #define i386 1 | |
1127 | |
1128 // RUN: %clang -march=cooperlake -m64 -E -dM %s -o - 2>&1 \ | |
1129 // RUN: -target i386-unknown-linux \ | |
1130 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CPX_M64 | |
1131 // CHECK_CPX_M64: #define __AES__ 1 | |
1132 // CHECK_CPX_M64: #define __AVX2__ 1 | |
1133 // CHECK_CPX_M64: #define __AVX512BF16__ 1 | |
1134 // CHECK_CPX_M64: #define __AVX512BW__ 1 | |
1135 // CHECK_CPX_M64: #define __AVX512CD__ 1 | |
1136 // CHECK_CPX_M64: #define __AVX512DQ__ 1 | |
1137 // CHECK_CPX_M64: #define __AVX512F__ 1 | |
1138 // CHECK_CPX_M64: #define __AVX512VL__ 1 | |
1139 // CHECK_CPX_M64: #define __AVX512VNNI__ 1 | |
1140 // CHECK_CPX_M64: #define __AVX__ 1 | |
1141 // CHECK_CPX_M64: #define __BMI2__ 1 | |
1142 // CHECK_CPX_M64: #define __BMI__ 1 | |
1143 // CHECK_CPX_M64: #define __CLFLUSHOPT__ 1 | |
1144 // CHECK_CPX_M64: #define __CLWB__ 1 | |
1145 // CHECK_CPX_M64: #define __F16C__ 1 | |
1146 // CHECK_CPX_M64: #define __FMA__ 1 | |
1147 // CHECK_CPX_M64: #define __INVPCID__ 1 | |
1148 // CHECK_CPX_M64: #define __LZCNT__ 1 | |
1149 // CHECK_CPX_M64: #define __MMX__ 1 | |
1150 // CHECK_CPX_M64: #define __MOVBE__ 1 | |
1151 // CHECK_CPX_M64: #define __PCLMUL__ 1 | |
1152 // CHECK_CPX_M64: #define __PKU__ 1 | |
1153 // CHECK_CPX_M64: #define __POPCNT__ 1 | |
1154 // CHECK_CPX_M64: #define __PRFCHW__ 1 | |
1155 // CHECK_CPX_M64: #define __RDRND__ 1 | |
1156 // CHECK_CPX_M64: #define __RDSEED__ 1 | |
1157 // CHECK_CPX_M64-NOT: #define __SGX__ 1 | |
1158 // CHECK_CPX_M64: #define __SSE2_MATH__ 1 | |
1159 // CHECK_CPX_M64: #define __SSE2__ 1 | |
1160 // CHECK_CPX_M64: #define __SSE3__ 1 | |
1161 // CHECK_CPX_M64: #define __SSE4_1__ 1 | |
1162 // CHECK_CPX_M64: #define __SSE4_2__ 1 | |
1163 // CHECK_CPX_M64: #define __SSE_MATH__ 1 | |
1164 // CHECK_CPX_M64: #define __SSE__ 1 | |
1165 // CHECK_CPX_M64: #define __SSSE3__ 1 | |
1166 // CHECK_CPX_M64: #define __XSAVEC__ 1 | |
1167 // CHECK_CPX_M64: #define __XSAVEOPT__ 1 | |
1168 // CHECK_CPX_M64: #define __XSAVES__ 1 | |
1169 // CHECK_CPX_M64: #define __XSAVE__ 1 | |
1170 // CHECK_CPX_M64: #define __amd64 1 | |
1171 // CHECK_CPX_M64: #define __amd64__ 1 | |
1172 // CHECK_CPX_M64: #define __corei7 1 | |
1173 // CHECK_CPX_M64: #define __corei7__ 1 | |
1174 // CHECK_CPX_M64: #define __tune_corei7__ 1 | |
1175 // CHECK_CPX_M64: #define __x86_64 1 | |
1176 // CHECK_CPX_M64: #define __x86_64__ 1 | |
1177 | |
1178 // RUN: %clang -march=cannonlake -m32 -E -dM %s -o - 2>&1 \ | |
1179 // RUN: -target i386-unknown-linux \ | |
1180 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CNL_M32 | |
1181 // CHECK_CNL_M32: #define __AES__ 1 | |
1182 // CHECK_CNL_M32: #define __AVX2__ 1 | |
1183 // CHECK_CNL_M32: #define __AVX512BW__ 1 | |
1184 // CHECK_CNL_M32: #define __AVX512CD__ 1 | |
1185 // CHECK_CNL_M32: #define __AVX512DQ__ 1 | |
1186 // CHECK_CNL_M32: #define __AVX512F__ 1 | |
1187 // CHECK_CNL_M32: #define __AVX512IFMA__ 1 | |
1188 // CHECK_CNL_M32: #define __AVX512VBMI__ 1 | |
1189 // CHECK_CNL_M32: #define __AVX512VL__ 1 | |
1190 // CHECK_CNL_M32: #define __AVX__ 1 | |
1191 // CHECK_CNL_M32: #define __BMI2__ 1 | |
1192 // CHECK_CNL_M32: #define __BMI__ 1 | |
1193 // CHECK_CNL_M32: #define __CLFLUSHOPT__ 1 | |
1194 // CHECK_CNL_M32-NOT: #define __CLWB__ 1 | |
1195 // CHECK_CNL_M32: #define __F16C__ 1 | |
1196 // CHECK_CNL_M32: #define __FMA__ 1 | |
1197 // CHECK_CNL_M32: #define __INVPCID__ 1 | |
1198 // CHECK_CNL_M32: #define __LZCNT__ 1 | |
1199 // CHECK_CNL_M32: #define __MMX__ 1 | |
1200 // CHECK_CNL_M32: #define __MOVBE__ 1 | |
1201 // CHECK_CNL_M32: #define __PCLMUL__ 1 | |
1202 // CHECK_CNL_M32: #define __PKU__ 1 | |
1203 // CHECK_CNL_M32: #define __POPCNT__ 1 | |
1204 // CHECK_CNL_M32: #define __PRFCHW__ 1 | |
1205 // CHECK_CNL_M32: #define __RDRND__ 1 | |
1206 // CHECK_CNL_M32: #define __RDSEED__ 1 | |
1207 // CHECK_CNL_M32: #define __SGX__ 1 | |
1208 // CHECK_CNL_M32: #define __SHA__ 1 | |
1209 // CHECK_CNL_M32: #define __SSE2__ 1 | |
1210 // CHECK_CNL_M32: #define __SSE3__ 1 | |
1211 // CHECK_CNL_M32: #define __SSE4_1__ 1 | |
1212 // CHECK_CNL_M32: #define __SSE4_2__ 1 | |
1213 // CHECK_CNL_M32: #define __SSE__ 1 | |
1214 // CHECK_CNL_M32: #define __SSSE3__ 1 | |
1215 // CHECK_CNL_M32: #define __XSAVEC__ 1 | |
1216 // CHECK_CNL_M32: #define __XSAVEOPT__ 1 | |
1217 // CHECK_CNL_M32: #define __XSAVES__ 1 | |
1218 // CHECK_CNL_M32: #define __XSAVE__ 1 | |
1219 // CHECK_CNL_M32: #define __corei7 1 | |
1220 // CHECK_CNL_M32: #define __corei7__ 1 | |
1221 // CHECK_CNL_M32: #define __i386 1 | |
1222 // CHECK_CNL_M32: #define __i386__ 1 | |
1223 // CHECK_CNL_M32: #define __tune_corei7__ 1 | |
1224 // CHECK_CNL_M32: #define i386 1 | |
1225 | |
1226 // RUN: %clang -march=cannonlake -m64 -E -dM %s -o - 2>&1 \ | |
1227 // RUN: -target i386-unknown-linux \ | |
1228 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CNL_M64 | |
1229 // CHECK_CNL_M64: #define __AES__ 1 | |
1230 // CHECK_CNL_M64: #define __AVX2__ 1 | |
1231 // CHECK_CNL_M64: #define __AVX512BW__ 1 | |
1232 // CHECK_CNL_M64: #define __AVX512CD__ 1 | |
1233 // CHECK_CNL_M64: #define __AVX512DQ__ 1 | |
1234 // CHECK_CNL_M64: #define __AVX512F__ 1 | |
1235 // CHECK_CNL_M64: #define __AVX512IFMA__ 1 | |
1236 // CHECK_CNL_M64: #define __AVX512VBMI__ 1 | |
1237 // CHECK_CNL_M64: #define __AVX512VL__ 1 | |
1238 // CHECK_CNL_M64: #define __AVX__ 1 | |
1239 // CHECK_CNL_M64: #define __BMI2__ 1 | |
1240 // CHECK_CNL_M64: #define __BMI__ 1 | |
1241 // CHECK_CNL_M64: #define __CLFLUSHOPT__ 1 | |
1242 // CHECK_CNL_M64-NOT: #define __CLWB__ 1 | |
1243 // CHECK_CNL_M64: #define __F16C__ 1 | |
1244 // CHECK_CNL_M64: #define __FMA__ 1 | |
1245 // CHECK_CNL_M64: #define __INVPCID__ 1 | |
1246 // CHECK_CNL_M64: #define __LZCNT__ 1 | |
1247 // CHECK_CNL_M64: #define __MMX__ 1 | |
1248 // CHECK_CNL_M64: #define __MOVBE__ 1 | |
1249 // CHECK_CNL_M64: #define __PCLMUL__ 1 | |
1250 // CHECK_CNL_M64: #define __PKU__ 1 | |
1251 // CHECK_CNL_M64: #define __POPCNT__ 1 | |
1252 // CHECK_CNL_M64: #define __PRFCHW__ 1 | |
1253 // CHECK_CNL_M64: #define __RDRND__ 1 | |
1254 // CHECK_CNL_M64: #define __RDSEED__ 1 | |
1255 // CHECK_CNL_M64: #define __SGX__ 1 | |
1256 // CHECK_CNL_M64: #define __SHA__ 1 | |
1257 // CHECK_CNL_M64: #define __SSE2__ 1 | |
1258 // CHECK_CNL_M64: #define __SSE3__ 1 | |
1259 // CHECK_CNL_M64: #define __SSE4_1__ 1 | |
1260 // CHECK_CNL_M64: #define __SSE4_2__ 1 | |
1261 // CHECK_CNL_M64: #define __SSE__ 1 | |
1262 // CHECK_CNL_M64: #define __SSSE3__ 1 | |
1263 // CHECK_CNL_M64: #define __XSAVEC__ 1 | |
1264 // CHECK_CNL_M64: #define __XSAVEOPT__ 1 | |
1265 // CHECK_CNL_M64: #define __XSAVES__ 1 | |
1266 // CHECK_CNL_M64: #define __XSAVE__ 1 | |
1267 // CHECK_CNL_M64: #define __amd64 1 | |
1268 // CHECK_CNL_M64: #define __amd64__ 1 | |
1269 // CHECK_CNL_M64: #define __corei7 1 | |
1270 // CHECK_CNL_M64: #define __corei7__ 1 | |
1271 // CHECK_CNL_M64: #define __tune_corei7__ 1 | |
1272 // CHECK_CNL_M64: #define __x86_64 1 | |
1273 // CHECK_CNL_M64: #define __x86_64__ 1 | |
1274 | |
1275 // RUN: %clang -march=icelake-client -m32 -E -dM %s -o - 2>&1 \ | |
1276 // RUN: -target i386-unknown-linux \ | |
1277 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ICL_M32 | |
1278 // CHECK_ICL_M32: #define __AES__ 1 | |
1279 // CHECK_ICL_M32: #define __AVX2__ 1 | |
1280 // CHECK_ICL_M32: #define __AVX512BITALG__ 1 | |
1281 // CHECK_ICL_M32: #define __AVX512BW__ 1 | |
1282 // CHECK_ICL_M32: #define __AVX512CD__ 1 | |
1283 // CHECK_ICL_M32: #define __AVX512DQ__ 1 | |
1284 // CHECK_ICL_M32: #define __AVX512F__ 1 | |
1285 // CHECK_ICL_M32: #define __AVX512IFMA__ 1 | |
1286 // CHECK_ICL_M32: #define __AVX512VBMI2__ 1 | |
1287 // CHECK_ICL_M32: #define __AVX512VBMI__ 1 | |
1288 // CHECK_ICL_M32: #define __AVX512VL__ 1 | |
1289 // CHECK_ICL_M32: #define __AVX512VNNI__ 1 | |
1290 // CHECK_ICL_M32: #define __AVX512VPOPCNTDQ__ 1 | |
1291 // CHECK_ICL_M32: #define __AVX__ 1 | |
1292 // CHECK_ICL_M32: #define __BMI2__ 1 | |
1293 // CHECK_ICL_M32: #define __BMI__ 1 | |
1294 // CHECK_ICL_M32: #define __CLFLUSHOPT__ 1 | |
1295 // CHECK_ICL_M32: #define __CLWB__ 1 | |
1296 // CHECK_ICL_M32: #define __F16C__ 1 | |
1297 // CHECK_ICL_M32: #define __FMA__ 1 | |
1298 // CHECK_ICL_M32: #define __GFNI__ 1 | |
1299 // CHECK_ICL_M32: #define __INVPCID__ 1 | |
1300 // CHECK_ICL_M32: #define __LZCNT__ 1 | |
1301 // CHECK_ICL_M32: #define __MMX__ 1 | |
1302 // CHECK_ICL_M32: #define __MOVBE__ 1 | |
1303 // CHECK_ICL_M32: #define __PCLMUL__ 1 | |
1304 // CHECK_ICL_M32: #define __PKU__ 1 | |
1305 // CHECK_ICL_M32: #define __POPCNT__ 1 | |
1306 // CHECK_ICL_M32: #define __PRFCHW__ 1 | |
1307 // CHECK_ICL_M32: #define __RDPID__ 1 | |
1308 // CHECK_ICL_M32: #define __RDRND__ 1 | |
1309 // CHECK_ICL_M32: #define __RDSEED__ 1 | |
1310 // CHECK_ICL_M32: #define __SGX__ 1 | |
1311 // CHECK_ICL_M32: #define __SHA__ 1 | |
1312 // CHECK_ICL_M32: #define __SSE2__ 1 | |
1313 // CHECK_ICL_M32: #define __SSE3__ 1 | |
1314 // CHECK_ICL_M32: #define __SSE4_1__ 1 | |
1315 // CHECK_ICL_M32: #define __SSE4_2__ 1 | |
1316 // CHECK_ICL_M32: #define __SSE__ 1 | |
1317 // CHECK_ICL_M32: #define __SSSE3__ 1 | |
1318 // CHECK_ICL_M32: #define __VAES__ 1 | |
1319 // CHECK_ICL_M32: #define __VPCLMULQDQ__ 1 | |
1320 // CHECK_ICL_M32-NOT: #define __WBNOINVD__ 1 | |
1321 // CHECK_ICL_M32: #define __XSAVEC__ 1 | |
1322 // CHECK_ICL_M32: #define __XSAVEOPT__ 1 | |
1323 // CHECK_ICL_M32: #define __XSAVES__ 1 | |
1324 // CHECK_ICL_M32: #define __XSAVE__ 1 | |
1325 // CHECK_ICL_M32: #define __corei7 1 | |
1326 // CHECK_ICL_M32: #define __corei7__ 1 | |
1327 // CHECK_ICL_M32: #define __i386 1 | |
1328 // CHECK_ICL_M32: #define __i386__ 1 | |
1329 // CHECK_ICL_M32: #define __tune_corei7__ 1 | |
1330 // CHECK_ICL_M32: #define i386 1 | |
1331 | |
1332 // RUN: %clang -march=icelake-client -m64 -E -dM %s -o - 2>&1 \ | |
1333 // RUN: -target i386-unknown-linux \ | |
1334 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ICL_M64 | |
1335 // CHECK_ICL_M64: #define __AES__ 1 | |
1336 // CHECK_ICL_M64: #define __AVX2__ 1 | |
1337 // CHECK_ICL_M64: #define __AVX512BITALG__ 1 | |
1338 // CHECK_ICL_M64: #define __AVX512BW__ 1 | |
1339 // CHECK_ICL_M64: #define __AVX512CD__ 1 | |
1340 // CHECK_ICL_M64: #define __AVX512DQ__ 1 | |
1341 // CHECK_ICL_M64: #define __AVX512F__ 1 | |
1342 // CHECK_ICL_M64: #define __AVX512IFMA__ 1 | |
1343 // CHECK_ICL_M64: #define __AVX512VBMI2__ 1 | |
1344 // CHECK_ICL_M64: #define __AVX512VBMI__ 1 | |
1345 // CHECK_ICL_M64: #define __AVX512VL__ 1 | |
1346 // CHECK_ICL_M64: #define __AVX512VNNI__ 1 | |
1347 // CHECK_ICL_M64: #define __AVX512VPOPCNTDQ__ 1 | |
1348 // CHECK_ICL_M64: #define __AVX__ 1 | |
1349 // CHECK_ICL_M64: #define __BMI2__ 1 | |
1350 // CHECK_ICL_M64: #define __BMI__ 1 | |
1351 // CHECK_ICL_M64: #define __CLFLUSHOPT__ 1 | |
1352 // CHECK_ICL_M64: #define __CLWB__ 1 | |
1353 // CHECK_ICL_M64: #define __F16C__ 1 | |
1354 // CHECK_ICL_M64: #define __FMA__ 1 | |
1355 // CHECK_ICL_M64: #define __GFNI__ 1 | |
1356 // CHECK_ICL_M64: #define __INVPCID__ 1 | |
1357 // CHECK_ICL_M64: #define __LZCNT__ 1 | |
1358 // CHECK_ICL_M64: #define __MMX__ 1 | |
1359 // CHECK_ICL_M64: #define __MOVBE__ 1 | |
1360 // CHECK_ICL_M64: #define __PCLMUL__ 1 | |
1361 // CHECK_ICL_M64: #define __PKU__ 1 | |
1362 // CHECK_ICL_M64: #define __POPCNT__ 1 | |
1363 // CHECK_ICL_M64: #define __PRFCHW__ 1 | |
1364 // CHECK_ICL_M64: #define __RDPID__ 1 | |
1365 // CHECK_ICL_M64: #define __RDRND__ 1 | |
1366 // CHECK_ICL_M64: #define __RDSEED__ 1 | |
1367 // CHECK_ICL_M64: #define __SGX__ 1 | |
1368 // CHECK_ICL_M64: #define __SHA__ 1 | |
1369 // CHECK_ICL_M64: #define __SSE2__ 1 | |
1370 // CHECK_ICL_M64: #define __SSE3__ 1 | |
1371 // CHECK_ICL_M64: #define __SSE4_1__ 1 | |
1372 // CHECK_ICL_M64: #define __SSE4_2__ 1 | |
1373 // CHECK_ICL_M64: #define __SSE__ 1 | |
1374 // CHECK_ICL_M64: #define __SSSE3__ 1 | |
1375 // CHECK_ICL_M64: #define __VAES__ 1 | |
1376 // CHECK_ICL_M64: #define __VPCLMULQDQ__ 1 | |
1377 // CHECK_ICL_M64-NOT: #define __WBNOINVD__ 1 | |
1378 // CHECK_ICL_M64: #define __XSAVEC__ 1 | |
1379 // CHECK_ICL_M64: #define __XSAVEOPT__ 1 | |
1380 // CHECK_ICL_M64: #define __XSAVES__ 1 | |
1381 // CHECK_ICL_M64: #define __XSAVE__ 1 | |
1382 // CHECK_ICL_M64: #define __amd64 1 | |
1383 // CHECK_ICL_M64: #define __amd64__ 1 | |
1384 // CHECK_ICL_M64: #define __corei7 1 | |
1385 // CHECK_ICL_M64: #define __corei7__ 1 | |
1386 // CHECK_ICL_M64: #define __tune_corei7__ 1 | |
1387 // CHECK_ICL_M64: #define __x86_64 1 | |
1388 // CHECK_ICL_M64: #define __x86_64__ 1 | |
1389 | |
1390 // RUN: %clang -march=icelake-server -m32 -E -dM %s -o - 2>&1 \ | |
1391 // RUN: -target i386-unknown-linux \ | |
1392 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ICX_M32 | |
1393 // CHECK_ICX_M32: #define __AES__ 1 | |
1394 // CHECK_ICX_M32: #define __AVX2__ 1 | |
1395 // CHECK_ICX_M32: #define __AVX512BITALG__ 1 | |
1396 // CHECK_ICX_M32: #define __AVX512BW__ 1 | |
1397 // CHECK_ICX_M32: #define __AVX512CD__ 1 | |
1398 // CHECK_ICX_M32: #define __AVX512DQ__ 1 | |
1399 // CHECK_ICX_M32: #define __AVX512F__ 1 | |
1400 // CHECK_ICX_M32: #define __AVX512IFMA__ 1 | |
1401 // CHECK_ICX_M32: #define __AVX512VBMI2__ 1 | |
1402 // CHECK_ICX_M32: #define __AVX512VBMI__ 1 | |
1403 // CHECK_ICX_M32: #define __AVX512VL__ 1 | |
1404 // CHECK_ICX_M32: #define __AVX512VNNI__ 1 | |
1405 // CHECK_ICX_M32: #define __AVX512VPOPCNTDQ__ 1 | |
1406 // CHECK_ICX_M32: #define __AVX__ 1 | |
1407 // CHECK_ICX_M32: #define __BMI2__ 1 | |
1408 // CHECK_ICX_M32: #define __BMI__ 1 | |
1409 // CHECK_ICX_M32: #define __CLFLUSHOPT__ 1 | |
1410 // CHECK_ICX_M32: #define __CLWB__ 1 | |
1411 // CHECK_ICX_M32: #define __F16C__ 1 | |
1412 // CHECK_ICX_M32: #define __FMA__ 1 | |
1413 // CHECK_ICX_M32: #define __GFNI__ 1 | |
1414 // CHECK_ICX_M32: #define __INVPCID__ 1 | |
1415 // CHECK_ICX_M32: #define __LZCNT__ 1 | |
1416 // CHECK_ICX_M32: #define __MMX__ 1 | |
1417 // CHECK_ICX_M32: #define __MOVBE__ 1 | |
1418 // CHECK_ICX_M32: #define __PCLMUL__ 1 | |
1419 // CHECK_ICX_M32: #define __PCONFIG__ 1 | |
1420 // CHECK_ICX_M32: #define __PKU__ 1 | |
1421 // CHECK_ICX_M32: #define __POPCNT__ 1 | |
1422 // CHECK_ICX_M32: #define __PRFCHW__ 1 | |
1423 // CHECK_ICX_M32: #define __RDPID__ 1 | |
1424 // CHECK_ICX_M32: #define __RDRND__ 1 | |
1425 // CHECK_ICX_M32: #define __RDSEED__ 1 | |
1426 // CHECK_ICX_M32: #define __SGX__ 1 | |
1427 // CHECK_ICX_M32: #define __SHA__ 1 | |
1428 // CHECK_ICX_M32: #define __SSE2__ 1 | |
1429 // CHECK_ICX_M32: #define __SSE3__ 1 | |
1430 // CHECK_ICX_M32: #define __SSE4_1__ 1 | |
1431 // CHECK_ICX_M32: #define __SSE4_2__ 1 | |
1432 // CHECK_ICX_M32: #define __SSE__ 1 | |
1433 // CHECK_ICX_M32: #define __SSSE3__ 1 | |
1434 // CHECK_ICX_M32: #define __VAES__ 1 | |
1435 // CHECK_ICX_M32: #define __VPCLMULQDQ__ 1 | |
1436 // CHECK_ICX_M32: #define __WBNOINVD__ 1 | |
1437 // CHECK_ICX_M32: #define __XSAVEC__ 1 | |
1438 // CHECK_ICX_M32: #define __XSAVEOPT__ 1 | |
1439 // CHECK_ICX_M32: #define __XSAVES__ 1 | |
1440 // CHECK_ICX_M32: #define __XSAVE__ 1 | |
1441 // CHECK_ICX_M32: #define __corei7 1 | |
1442 // CHECK_ICX_M32: #define __corei7__ 1 | |
1443 // CHECK_ICX_M32: #define __i386 1 | |
1444 // CHECK_ICX_M32: #define __i386__ 1 | |
1445 // CHECK_ICX_M32: #define __tune_corei7__ 1 | |
1446 // CHECK_ICX_M32: #define i386 1 | |
1447 | |
1448 // RUN: %clang -march=icelake-server -m64 -E -dM %s -o - 2>&1 \ | |
1449 // RUN: -target i386-unknown-linux \ | |
1450 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ICX_M64 | |
1451 // CHECK_ICX_M64: #define __AES__ 1 | |
1452 // CHECK_ICX_M64: #define __AVX2__ 1 | |
1453 // CHECK_ICX_M64: #define __AVX512BITALG__ 1 | |
1454 // CHECK_ICX_M64: #define __AVX512BW__ 1 | |
1455 // CHECK_ICX_M64: #define __AVX512CD__ 1 | |
1456 // CHECK_ICX_M64: #define __AVX512DQ__ 1 | |
1457 // CHECK_ICX_M64: #define __AVX512F__ 1 | |
1458 // CHECK_ICX_M64: #define __AVX512IFMA__ 1 | |
1459 // CHECK_ICX_M64: #define __AVX512VBMI2__ 1 | |
1460 // CHECK_ICX_M64: #define __AVX512VBMI__ 1 | |
1461 // CHECK_ICX_M64: #define __AVX512VL__ 1 | |
1462 // CHECK_ICX_M64: #define __AVX512VNNI__ 1 | |
1463 // CHECK_ICX_M64: #define __AVX512VPOPCNTDQ__ 1 | |
1464 // CHECK_ICX_M64: #define __AVX__ 1 | |
1465 // CHECK_ICX_M64: #define __BMI2__ 1 | |
1466 // CHECK_ICX_M64: #define __BMI__ 1 | |
1467 // CHECK_ICX_M64: #define __CLFLUSHOPT__ 1 | |
1468 // CHECK_ICX_M64: #define __CLWB__ 1 | |
1469 // CHECK_ICX_M64: #define __F16C__ 1 | |
1470 // CHECK_ICX_M64: #define __FMA__ 1 | |
1471 // CHECK_ICX_M64: #define __GFNI__ 1 | |
1472 // CHECK_ICX_M64: #define __INVPCID__ 1 | |
1473 // CHECK_ICX_M64: #define __LZCNT__ 1 | |
1474 // CHECK_ICX_M64: #define __MMX__ 1 | |
1475 // CHECK_ICX_M64: #define __MOVBE__ 1 | |
1476 // CHECK_ICX_M64: #define __PCLMUL__ 1 | |
1477 // CHECK_ICX_M64: #define __PCONFIG__ 1 | |
1478 // CHECK_ICX_M64: #define __PKU__ 1 | |
1479 // CHECK_ICX_M64: #define __POPCNT__ 1 | |
1480 // CHECK_ICX_M64: #define __PRFCHW__ 1 | |
1481 // CHECK_ICX_M64: #define __RDPID__ 1 | |
1482 // CHECK_ICX_M64: #define __RDRND__ 1 | |
1483 // CHECK_ICX_M64: #define __RDSEED__ 1 | |
1484 // CHECK_ICX_M64: #define __SGX__ 1 | |
1485 // CHECK_ICX_M64: #define __SHA__ 1 | |
1486 // CHECK_ICX_M64: #define __SSE2__ 1 | |
1487 // CHECK_ICX_M64: #define __SSE3__ 1 | |
1488 // CHECK_ICX_M64: #define __SSE4_1__ 1 | |
1489 // CHECK_ICX_M64: #define __SSE4_2__ 1 | |
1490 // CHECK_ICX_M64: #define __SSE__ 1 | |
1491 // CHECK_ICX_M64: #define __SSSE3__ 1 | |
1492 // CHECK_ICX_M64: #define __VAES__ 1 | |
1493 // CHECK_ICX_M64: #define __VPCLMULQDQ__ 1 | |
1494 // CHECK_ICX_M64: #define __WBNOINVD__ 1 | |
1495 // CHECK_ICX_M64: #define __XSAVEC__ 1 | |
1496 // CHECK_ICX_M64: #define __XSAVEOPT__ 1 | |
1497 // CHECK_ICX_M64: #define __XSAVES__ 1 | |
1498 // CHECK_ICX_M64: #define __XSAVE__ 1 | |
1499 // CHECK_ICX_M64: #define __amd64 1 | |
1500 // CHECK_ICX_M64: #define __amd64__ 1 | |
1501 // CHECK_ICX_M64: #define __corei7 1 | |
1502 // CHECK_ICX_M64: #define __corei7__ 1 | |
1503 // CHECK_ICX_M64: #define __tune_corei7__ 1 | |
1504 // CHECK_ICX_M64: #define __x86_64 1 | |
1505 // CHECK_ICX_M64: #define __x86_64__ 1 | |
1506 | |
1507 // RUN: %clang -march=tigerlake -m32 -E -dM %s -o - 2>&1 \ | |
1508 // RUN: -target i386-unknown-linux \ | |
1509 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_TGL_M32 | |
1510 // CHECK_TGL_M32: #define __AES__ 1 | |
1511 // CHECK_TGL_M32: #define __AVX2__ 1 | |
1512 // CHECK_TGL_M32: #define __AVX512BITALG__ 1 | |
1513 // CHECK_TGL_M32: #define __AVX512BW__ 1 | |
1514 // CHECK_TGL_M32: #define __AVX512CD__ 1 | |
1515 // CHECK_TGL_M32: #define __AVX512DQ__ 1 | |
1516 // CHECK_TGL_M32: #define __AVX512F__ 1 | |
1517 // CHECK_TGL_M32: #define __AVX512IFMA__ 1 | |
1518 // CHECK_TGL_M32: #define __AVX512VBMI2__ 1 | |
1519 // CHECK_TGL_M32: #define __AVX512VBMI__ 1 | |
1520 // CHECK_TGL_M32: #define __AVX512VL__ 1 | |
1521 // CHECK_TGL_M32: #define __AVX512VNNI__ 1 | |
1522 // CHECK_TGL_M32: #define __AVX512VP2INTERSECT__ 1 | |
1523 // CHECK_TGL_M32: #define __AVX512VPOPCNTDQ__ 1 | |
1524 // CHECK_TGL_M32: #define __AVX__ 1 | |
1525 // CHECK_TGL_M32: #define __BMI2__ 1 | |
1526 // CHECK_TGL_M32: #define __BMI__ 1 | |
1527 // CHECK_TGL_M32: #define __CLFLUSHOPT__ 1 | |
1528 // CHECK_TGL_M32: #define __CLWB__ 1 | |
1529 // CHECK_TGL_M32: #define __F16C__ 1 | |
1530 // CHECK_TGL_M32: #define __FMA__ 1 | |
1531 // CHECK_TGL_M32: #define __GFNI__ 1 | |
1532 // CHECK_TGL_M32: #define __INVPCID__ 1 | |
1533 // CHECK_TGL_M32: #define __LZCNT__ 1 | |
1534 // CHECK_TGL_M32: #define __MMX__ 1 | |
1535 // CHECK_TGL_M32: #define __MOVBE__ 1 | |
1536 // CHECK_TGL_M32: #define __MOVDIR64B__ 1 | |
1537 // CHECK_TGL_M32: #define __MOVDIRI__ 1 | |
1538 // CHECK_TGL_M32: #define __PCLMUL__ 1 | |
1539 // CHECK_TGL_M32-NOT: #define __PCONFIG__ 1 | |
1540 // CHECK_TGL_M32: #define __PKU__ 1 | |
1541 // CHECK_TGL_M32: #define __POPCNT__ 1 | |
1542 // CHECK_TGL_M32: #define __PRFCHW__ 1 | |
1543 // CHECK_TGL_M32: #define __RDPID__ 1 | |
1544 // CHECK_TGL_M32: #define __RDRND__ 1 | |
1545 // CHECK_TGL_M32: #define __RDSEED__ 1 | |
1546 // CHECK_TGL_M32: #define __SGX__ 1 | |
1547 // CHECK_TGL_M32: #define __SHA__ 1 | |
1548 // CHECK_TGL_M32: #define __SHSTK__ 1 | |
1549 // CHECK_TGL_M32: #define __SSE2__ 1 | |
1550 // CHECK_TGL_M32: #define __SSE3__ 1 | |
1551 // CHECK_TGL_M32: #define __SSE4_1__ 1 | |
1552 // CHECK_TGL_M32: #define __SSE4_2__ 1 | |
1553 // CHECK_TGL_M32: #define __SSE__ 1 | |
1554 // CHECK_TGL_M32: #define __SSSE3__ 1 | |
1555 // CHECK_TGL_M32: #define __VAES__ 1 | |
1556 // CHECK_TGL_M32: #define __VPCLMULQDQ__ 1 | |
1557 // CHECK_TGL_M32-NOT: #define __WBNOINVD__ 1 | |
1558 // CHECK_TGL_M32: #define __XSAVEC__ 1 | |
1559 // CHECK_TGL_M32: #define __XSAVEOPT__ 1 | |
1560 // CHECK_TGL_M32: #define __XSAVES__ 1 | |
1561 // CHECK_TGL_M32: #define __XSAVE__ 1 | |
1562 // CHECK_TGL_M32: #define __corei7 1 | |
1563 // CHECK_TGL_M32: #define __corei7__ 1 | |
1564 // CHECK_TGL_M32: #define __i386 1 | |
1565 // CHECK_TGL_M32: #define __i386__ 1 | |
1566 // CHECK_TGL_M32: #define __tune_corei7__ 1 | |
1567 // CHECK_TGL_M32: #define i386 1 | |
1568 | |
1569 // RUN: %clang -march=tigerlake -m64 -E -dM %s -o - 2>&1 \ | |
1570 // RUN: -target i386-unknown-linux \ | |
1571 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_TGL_M64 | |
1572 // CHECK_TGL_M64: #define __AES__ 1 | |
1573 // CHECK_TGL_M64: #define __AVX2__ 1 | |
1574 // CHECK_TGL_M64: #define __AVX512BITALG__ 1 | |
1575 // CHECK_TGL_M64: #define __AVX512BW__ 1 | |
1576 // CHECK_TGL_M64: #define __AVX512CD__ 1 | |
1577 // CHECK_TGL_M64: #define __AVX512DQ__ 1 | |
1578 // CHECK_TGL_M64: #define __AVX512F__ 1 | |
1579 // CHECK_TGL_M64: #define __AVX512IFMA__ 1 | |
1580 // CHECK_TGL_M64: #define __AVX512VBMI2__ 1 | |
1581 // CHECK_TGL_M64: #define __AVX512VBMI__ 1 | |
1582 // CHECK_TGL_M64: #define __AVX512VL__ 1 | |
1583 // CHECK_TGL_M64: #define __AVX512VNNI__ 1 | |
1584 // CHECK_TGL_M64: #define __AVX512VP2INTERSECT__ 1 | |
1585 // CHECK_TGL_M64: #define __AVX512VPOPCNTDQ__ 1 | |
1586 // CHECK_TGL_M64: #define __AVX__ 1 | |
1587 // CHECK_TGL_M64: #define __BMI2__ 1 | |
1588 // CHECK_TGL_M64: #define __BMI__ 1 | |
1589 // CHECK_TGL_M64: #define __CLFLUSHOPT__ 1 | |
1590 // CHECK_TGL_M64: #define __CLWB__ 1 | |
1591 // CHECK_TGL_M64: #define __F16C__ 1 | |
1592 // CHECK_TGL_M64: #define __FMA__ 1 | |
1593 // CHECK_TGL_M64: #define __GFNI__ 1 | |
1594 // CHECK_TGL_M64: #define __INVPCID__ 1 | |
1595 // CHECK_TGL_M64: #define __LZCNT__ 1 | |
1596 // CHECK_TGL_M64: #define __MMX__ 1 | |
1597 // CHECK_TGL_M64: #define __MOVBE__ 1 | |
1598 // CHECK_TGL_M64: #define __MOVDIR64B__ 1 | |
1599 // CHECK_TGL_M64: #define __MOVDIRI__ 1 | |
1600 // CHECK_TGL_M64: #define __PCLMUL__ 1 | |
1601 // CHECK_TGL_M64-NOT: #define __PCONFIG__ 1 | |
1602 // CHECK_TGL_M64: #define __PKU__ 1 | |
1603 // CHECK_TGL_M64: #define __POPCNT__ 1 | |
1604 // CHECK_TGL_M64: #define __PRFCHW__ 1 | |
1605 // CHECK_TGL_M64: #define __RDPID__ 1 | |
1606 // CHECK_TGL_M64: #define __RDRND__ 1 | |
1607 // CHECK_TGL_M64: #define __RDSEED__ 1 | |
1608 // CHECK_TGL_M64: #define __SGX__ 1 | |
1609 // CHECK_TGL_M64: #define __SHA__ 1 | |
1610 // CHECK_TGL_M64: #define __SHSTK__ 1 | |
1611 // CHECK_TGL_M64: #define __SSE2__ 1 | |
1612 // CHECK_TGL_M64: #define __SSE3__ 1 | |
1613 // CHECK_TGL_M64: #define __SSE4_1__ 1 | |
1614 // CHECK_TGL_M64: #define __SSE4_2__ 1 | |
1615 // CHECK_TGL_M64: #define __SSE__ 1 | |
1616 // CHECK_TGL_M64: #define __SSSE3__ 1 | |
1617 // CHECK_TGL_M64: #define __VAES__ 1 | |
1618 // CHECK_TGL_M64: #define __VPCLMULQDQ__ 1 | |
1619 // CHECK_TGL_M64-NOT: #define __WBNOINVD__ 1 | |
1620 // CHECK_TGL_M64: #define __XSAVEC__ 1 | |
1621 // CHECK_TGL_M64: #define __XSAVEOPT__ 1 | |
1622 // CHECK_TGL_M64: #define __XSAVES__ 1 | |
1623 // CHECK_TGL_M64: #define __XSAVE__ 1 | |
1624 // CHECK_TGL_M64: #define __amd64 1 | |
1625 // CHECK_TGL_M64: #define __amd64__ 1 | |
1626 // CHECK_TGL_M64: #define __corei7 1 | |
1627 // CHECK_TGL_M64: #define __corei7__ 1 | |
1628 // CHECK_TGL_M64: #define __tune_corei7__ 1 | |
1629 // CHECK_TGL_M64: #define __x86_64 1 | |
1630 // CHECK_TGL_M64: #define __x86_64__ 1 | |
1631 | |
1632 // RUN: %clang -march=atom -m32 -E -dM %s -o - 2>&1 \ | |
1633 // RUN: -target i386-unknown-linux \ | |
1634 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATOM_M32 | |
1635 // CHECK_ATOM_M32: #define __MMX__ 1 | |
1636 // CHECK_ATOM_M32: #define __MOVBE__ 1 | |
1637 // CHECK_ATOM_M32: #define __SSE2__ 1 | |
1638 // CHECK_ATOM_M32: #define __SSE3__ 1 | |
1639 // CHECK_ATOM_M32: #define __SSE__ 1 | |
1640 // CHECK_ATOM_M32: #define __SSSE3__ 1 | |
1641 // CHECK_ATOM_M32: #define __atom 1 | |
1642 // CHECK_ATOM_M32: #define __atom__ 1 | |
1643 // CHECK_ATOM_M32: #define __i386 1 | |
1644 // CHECK_ATOM_M32: #define __i386__ 1 | |
1645 // CHECK_ATOM_M32: #define __tune_atom__ 1 | |
1646 // CHECK_ATOM_M32: #define i386 1 | |
1647 | |
1648 // RUN: %clang -march=atom -m64 -E -dM %s -o - 2>&1 \ | |
1649 // RUN: -target i386-unknown-linux \ | |
1650 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATOM_M64 | |
1651 // CHECK_ATOM_M64: #define __MMX__ 1 | |
1652 // CHECK_ATOM_M64: #define __MOVBE__ 1 | |
1653 // CHECK_ATOM_M64: #define __SSE2_MATH__ 1 | |
1654 // CHECK_ATOM_M64: #define __SSE2__ 1 | |
1655 // CHECK_ATOM_M64: #define __SSE3__ 1 | |
1656 // CHECK_ATOM_M64: #define __SSE_MATH__ 1 | |
1657 // CHECK_ATOM_M64: #define __SSE__ 1 | |
1658 // CHECK_ATOM_M64: #define __SSSE3__ 1 | |
1659 // CHECK_ATOM_M64: #define __amd64 1 | |
1660 // CHECK_ATOM_M64: #define __amd64__ 1 | |
1661 // CHECK_ATOM_M64: #define __atom 1 | |
1662 // CHECK_ATOM_M64: #define __atom__ 1 | |
1663 // CHECK_ATOM_M64: #define __tune_atom__ 1 | |
1664 // CHECK_ATOM_M64: #define __x86_64 1 | |
1665 // CHECK_ATOM_M64: #define __x86_64__ 1 | |
1666 | |
1667 // RUN: %clang -march=goldmont -m32 -E -dM %s -o - 2>&1 \ | |
1668 // RUN: -target i386-unknown-linux \ | |
1669 // RUN: | FileCheck %s -check-prefix=CHECK_GLM_M32 | |
1670 // CHECK_GLM_M32: #define __AES__ 1 | |
1671 // CHECK_GLM_M32: #define __CLFLUSHOPT__ 1 | |
1672 // CHECK_GLM_M32: #define __FSGSBASE__ 1 | |
1673 // CHECK_GLM_M32: #define __FXSR__ 1 | |
1674 // CHECK_GLM_M32: #define __MMX__ 1 | |
1675 // CHECK_GLM_M32: #define __MOVBE__ 1 | |
1676 // CHECK_GLM_M32: #define __PCLMUL__ 1 | |
1677 // CHECK_GLM_M32: #define __POPCNT__ 1 | |
1678 // CHECK_GLM_M32: #define __PRFCHW__ 1 | |
1679 // CHECK_GLM_M32: #define __RDRND__ 1 | |
1680 // CHECK_GLM_M32: #define __RDSEED__ 1 | |
1681 // CHECK_GLM_M32: #define __SHA__ 1 | |
1682 // CHECK_GLM_M32: #define __SSE2__ 1 | |
1683 // CHECK_GLM_M32: #define __SSE3__ 1 | |
1684 // CHECK_GLM_M32: #define __SSE4_1__ 1 | |
1685 // CHECK_GLM_M32: #define __SSE4_2__ 1 | |
1686 // CHECK_GLM_M32: #define __SSE_MATH__ 1 | |
1687 // CHECK_GLM_M32: #define __SSE__ 1 | |
1688 // CHECK_GLM_M32: #define __SSSE3__ 1 | |
1689 // CHECK_GLM_M32: #define __XSAVEC__ 1 | |
1690 // CHECK_GLM_M32: #define __XSAVEOPT__ 1 | |
1691 // CHECK_GLM_M32: #define __XSAVES__ 1 | |
1692 // CHECK_GLM_M32: #define __XSAVE__ 1 | |
1693 // CHECK_GLM_M32: #define __goldmont 1 | |
1694 // CHECK_GLM_M32: #define __goldmont__ 1 | |
1695 // CHECK_GLM_M32: #define __i386 1 | |
1696 // CHECK_GLM_M32: #define __i386__ 1 | |
1697 // CHECK_GLM_M32: #define __tune_goldmont__ 1 | |
1698 // CHECK_GLM_M32: #define i386 1 | |
1699 | |
1700 // RUN: %clang -march=goldmont -m64 -E -dM %s -o - 2>&1 \ | |
1701 // RUN: -target i386-unknown-linux \ | |
1702 // RUN: | FileCheck %s -check-prefix=CHECK_GLM_M64 | |
1703 // CHECK_GLM_M64: #define __AES__ 1 | |
1704 // CHECK_GLM_M64: #define __CLFLUSHOPT__ 1 | |
1705 // CHECK_GLM_M64: #define __FSGSBASE__ 1 | |
1706 // CHECK_GLM_M64: #define __FXSR__ 1 | |
1707 // CHECK_GLM_M64: #define __MMX__ 1 | |
1708 // CHECK_GLM_M64: #define __MOVBE__ 1 | |
1709 // CHECK_GLM_M64: #define __PCLMUL__ 1 | |
1710 // CHECK_GLM_M64: #define __POPCNT__ 1 | |
1711 // CHECK_GLM_M64: #define __PRFCHW__ 1 | |
1712 // CHECK_GLM_M64: #define __RDRND__ 1 | |
1713 // CHECK_GLM_M64: #define __RDSEED__ 1 | |
1714 // CHECK_GLM_M64: #define __SHA__ 1 | |
1715 // CHECK_GLM_M64: #define __SSE2__ 1 | |
1716 // CHECK_GLM_M64: #define __SSE3__ 1 | |
1717 // CHECK_GLM_M64: #define __SSE4_1__ 1 | |
1718 // CHECK_GLM_M64: #define __SSE4_2__ 1 | |
1719 // CHECK_GLM_M64: #define __SSE__ 1 | |
1720 // CHECK_GLM_M64: #define __SSSE3__ 1 | |
1721 // CHECK_GLM_M64: #define __XSAVEC__ 1 | |
1722 // CHECK_GLM_M64: #define __XSAVEOPT__ 1 | |
1723 // CHECK_GLM_M64: #define __XSAVES__ 1 | |
1724 // CHECK_GLM_M64: #define __XSAVE__ 1 | |
1725 // CHECK_GLM_M64: #define __goldmont 1 | |
1726 // CHECK_GLM_M64: #define __goldmont__ 1 | |
1727 // CHECK_GLM_M64: #define __tune_goldmont__ 1 | |
1728 // CHECK_GLM_M64: #define __x86_64 1 | |
1729 // CHECK_GLM_M64: #define __x86_64__ 1 | |
1730 | |
1731 // RUN: %clang -march=goldmont-plus -m32 -E -dM %s -o - 2>&1 \ | |
1732 // RUN: -target i386-unknown-linux \ | |
1733 // RUN: | FileCheck %s -check-prefix=CHECK_GLMP_M32 | |
1734 // CHECK_GLMP_M32: #define __AES__ 1 | |
1735 // CHECK_GLMP_M32: #define __CLFLUSHOPT__ 1 | |
1736 // CHECK_GLMP_M32: #define __FSGSBASE__ 1 | |
1737 // CHECK_GLMP_M32: #define __FXSR__ 1 | |
1738 // CHECK_GLMP_M32: #define __MMX__ 1 | |
1739 // CHECK_GLMP_M32: #define __MOVBE__ 1 | |
1740 // CHECK_GLMP_M32: #define __PCLMUL__ 1 | |
1741 // CHECK_GLMP_M32: #define __POPCNT__ 1 | |
1742 // CHECK_GLMP_M32: #define __PRFCHW__ 1 | |
1743 // CHECK_GLMP_M32: #define __PTWRITE__ 1 | |
1744 // CHECK_GLMP_M32: #define __RDPID__ 1 | |
1745 // CHECK_GLMP_M32: #define __RDRND__ 1 | |
1746 // CHECK_GLMP_M32: #define __RDSEED__ 1 | |
1747 // CHECK_GLMP_M32: #define __SGX__ 1 | |
1748 // CHECK_GLMP_M32: #define __SHA__ 1 | |
1749 // CHECK_GLMP_M32: #define __SSE2__ 1 | |
1750 // CHECK_GLMP_M32: #define __SSE3__ 1 | |
1751 // CHECK_GLMP_M32: #define __SSE4_1__ 1 | |
1752 // CHECK_GLMP_M32: #define __SSE4_2__ 1 | |
1753 // CHECK_GLMP_M32: #define __SSE_MATH__ 1 | |
1754 // CHECK_GLMP_M32: #define __SSE__ 1 | |
1755 // CHECK_GLMP_M32: #define __SSSE3__ 1 | |
1756 // CHECK_GLMP_M32: #define __XSAVEC__ 1 | |
1757 // CHECK_GLMP_M32: #define __XSAVEOPT__ 1 | |
1758 // CHECK_GLMP_M32: #define __XSAVES__ 1 | |
1759 // CHECK_GLMP_M32: #define __XSAVE__ 1 | |
1760 // CHECK_GLMP_M32: #define __goldmont_plus 1 | |
1761 // CHECK_GLMP_M32: #define __goldmont_plus__ 1 | |
1762 // CHECK_GLMP_M32: #define __i386 1 | |
1763 // CHECK_GLMP_M32: #define __i386__ 1 | |
1764 // CHECK_GLMP_M32: #define __tune_goldmont_plus__ 1 | |
1765 // CHECK_GLMP_M32: #define i386 1 | |
1766 | |
1767 // RUN: %clang -march=goldmont-plus -m64 -E -dM %s -o - 2>&1 \ | |
1768 // RUN: -target i386-unknown-linux \ | |
1769 // RUN: | FileCheck %s -check-prefix=CHECK_GLMP_M64 | |
1770 // CHECK_GLMP_M64: #define __AES__ 1 | |
1771 // CHECK_GLMP_M64: #define __CLFLUSHOPT__ 1 | |
1772 // CHECK_GLMP_M64: #define __FSGSBASE__ 1 | |
1773 // CHECK_GLMP_M64: #define __FXSR__ 1 | |
1774 // CHECK_GLMP_M64: #define __MMX__ 1 | |
1775 // CHECK_GLMP_M64: #define __MOVBE__ 1 | |
1776 // CHECK_GLMP_M64: #define __PCLMUL__ 1 | |
1777 // CHECK_GLMP_M64: #define __POPCNT__ 1 | |
1778 // CHECK_GLMP_M64: #define __PRFCHW__ 1 | |
1779 // CHECK_GLMP_M64: #define __PTWRITE__ 1 | |
1780 // CHECK_GLMP_M64: #define __RDPID__ 1 | |
1781 // CHECK_GLMP_M64: #define __RDRND__ 1 | |
1782 // CHECK_GLMP_M64: #define __RDSEED__ 1 | |
1783 // CHECK_GLMP_M64: #define __SGX__ 1 | |
1784 // CHECK_GLMP_M64: #define __SHA__ 1 | |
1785 // CHECK_GLMP_M64: #define __SSE2__ 1 | |
1786 // CHECK_GLMP_M64: #define __SSE3__ 1 | |
1787 // CHECK_GLMP_M64: #define __SSE4_1__ 1 | |
1788 // CHECK_GLMP_M64: #define __SSE4_2__ 1 | |
1789 // CHECK_GLMP_M64: #define __SSE__ 1 | |
1790 // CHECK_GLMP_M64: #define __SSSE3__ 1 | |
1791 // CHECK_GLMP_M64: #define __XSAVEC__ 1 | |
1792 // CHECK_GLMP_M64: #define __XSAVEOPT__ 1 | |
1793 // CHECK_GLMP_M64: #define __XSAVES__ 1 | |
1794 // CHECK_GLMP_M64: #define __XSAVE__ 1 | |
1795 // CHECK_GLMP_M64: #define __goldmont_plus 1 | |
1796 // CHECK_GLMP_M64: #define __goldmont_plus__ 1 | |
1797 // CHECK_GLMP_M64: #define __tune_goldmont_plus__ 1 | |
1798 // CHECK_GLMP_M64: #define __x86_64 1 | |
1799 // CHECK_GLMP_M64: #define __x86_64__ 1 | |
1800 | |
1801 // RUN: %clang -march=tremont -m32 -E -dM %s -o - 2>&1 \ | |
1802 // RUN: -target i386-unknown-linux \ | |
1803 // RUN: | FileCheck %s -check-prefix=CHECK_TRM_M32 | |
1804 // CHECK_TRM_M32: #define __AES__ 1 | |
1805 // CHECK_TRM_M32: #define __CLDEMOTE__ 1 | |
1806 // CHECK_TRM_M32: #define __CLFLUSHOPT__ 1 | |
1807 // CHECK_TRM_M32: #define __FSGSBASE__ 1 | |
1808 // CHECK_TRM_M32: #define __FXSR__ 1 | |
1809 // CHECK_TRM_M32: #define __GFNI__ 1 | |
1810 // CHECK_TRM_M32: #define __MMX__ 1 | |
1811 // CHECK_TRM_M32: #define __MOVBE__ 1 | |
1812 // CHECK_TRM_M32: #define __MOVDIR64B__ 1 | |
1813 // CHECK_TRM_M32: #define __MOVDIRI__ 1 | |
1814 // CHECK_TRM_M32: #define __PCLMUL__ 1 | |
1815 // CHECK_TRM_M32: #define __POPCNT__ 1 | |
1816 // CHECK_TRM_M32: #define __PRFCHW__ 1 | |
1817 // CHECK_TRM_M32: #define __PTWRITE__ 1 | |
1818 // CHECK_TRM_M32: #define __RDPID__ 1 | |
1819 // CHECK_TRM_M32: #define __RDRND__ 1 | |
1820 // CHECK_TRM_M32: #define __RDSEED__ 1 | |
1821 // CHECK_TRM_M32: #define __SGX__ 1 | |
1822 // CHECK_TRM_M32: #define __SHA__ 1 | |
1823 // CHECK_TRM_M32: #define __SSE2__ 1 | |
1824 // CHECK_TRM_M32: #define __SSE3__ 1 | |
1825 // CHECK_TRM_M32: #define __SSE4_1__ 1 | |
1826 // CHECK_TRM_M32: #define __SSE4_2__ 1 | |
1827 // CHECK_TRM_M32: #define __SSE_MATH__ 1 | |
1828 // CHECK_TRM_M32: #define __SSE__ 1 | |
1829 // CHECK_TRM_M32: #define __SSSE3__ 1 | |
1830 // CHECK_TRM_M32: #define __WAITPKG__ 1 | |
1831 // CHECK_TRM_M32: #define __XSAVEC__ 1 | |
1832 // CHECK_TRM_M32: #define __XSAVEOPT__ 1 | |
1833 // CHECK_TRM_M32: #define __XSAVES__ 1 | |
1834 // CHECK_TRM_M32: #define __XSAVE__ 1 | |
1835 // CHECK_TRM_M32: #define __i386 1 | |
1836 // CHECK_TRM_M32: #define __i386__ 1 | |
1837 // CHECK_TRM_M32: #define __tremont 1 | |
1838 // CHECK_TRM_M32: #define __tremont__ 1 | |
1839 // CHECK_TRM_M32: #define __tune_tremont__ 1 | |
1840 // CHECK_TRM_M32: #define i386 1 | |
1841 | |
1842 // RUN: %clang -march=tremont -m64 -E -dM %s -o - 2>&1 \ | |
1843 // RUN: -target i386-unknown-linux \ | |
1844 // RUN: | FileCheck %s -check-prefix=CHECK_TRM_M64 | |
1845 // CHECK_TRM_M64: #define __AES__ 1 | |
1846 // CHECK_TRM_M64: #define __CLDEMOTE__ 1 | |
1847 // CHECK_TRM_M64: #define __CLFLUSHOPT__ 1 | |
1848 // CHECK_TRM_M64: #define __FSGSBASE__ 1 | |
1849 // CHECK_TRM_M64: #define __FXSR__ 1 | |
1850 // CHECK_TRM_M64: #define __GFNI__ 1 | |
1851 // CHECK_TRM_M64: #define __MMX__ 1 | |
1852 // CHECK_TRM_M64: #define __MOVBE__ 1 | |
1853 // CHECK_TRM_M64: #define __MOVDIR64B__ 1 | |
1854 // CHECK_TRM_M64: #define __MOVDIRI__ 1 | |
1855 // CHECK_TRM_M64: #define __PCLMUL__ 1 | |
1856 // CHECK_TRM_M64: #define __POPCNT__ 1 | |
1857 // CHECK_TRM_M64: #define __PRFCHW__ 1 | |
1858 // CHECK_TRM_M64: #define __PTWRITE__ 1 | |
1859 // CHECK_TRM_M64: #define __RDPID__ 1 | |
1860 // CHECK_TRM_M64: #define __RDRND__ 1 | |
1861 // CHECK_TRM_M64: #define __RDSEED__ 1 | |
1862 // CHECK_TRM_M64: #define __SGX__ 1 | |
1863 // CHECK_TRM_M64: #define __SHA__ 1 | |
1864 // CHECK_TRM_M64: #define __SSE2__ 1 | |
1865 // CHECK_TRM_M64: #define __SSE3__ 1 | |
1866 // CHECK_TRM_M64: #define __SSE4_1__ 1 | |
1867 // CHECK_TRM_M64: #define __SSE4_2__ 1 | |
1868 // CHECK_TRM_M64: #define __SSE__ 1 | |
1869 // CHECK_TRM_M64: #define __SSSE3__ 1 | |
1870 // CHECK_TRM_M64: #define __WAITPKG__ 1 | |
1871 // CHECK_TRM_M64: #define __XSAVEC__ 1 | |
1872 // CHECK_TRM_M64: #define __XSAVEOPT__ 1 | |
1873 // CHECK_TRM_M64: #define __XSAVES__ 1 | |
1874 // CHECK_TRM_M64: #define __XSAVE__ 1 | |
1875 // CHECK_TRM_M64: #define __tremont 1 | |
1876 // CHECK_TRM_M64: #define __tremont__ 1 | |
1877 // CHECK_TRM_M64: #define __tune_tremont__ 1 | |
1878 // CHECK_TRM_M64: #define __x86_64 1 | |
1879 // CHECK_TRM_M64: #define __x86_64__ 1 | |
1880 | |
1881 // RUN: %clang -march=slm -m32 -E -dM %s -o - 2>&1 \ | |
1882 // RUN: -target i386-unknown-linux \ | |
1883 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SLM_M32 | |
1884 // CHECK_SLM_M32: #define __FXSR__ 1 | |
1885 // CHECK_SLM_M32: #define __MMX__ 1 | |
1886 // CHECK_SLM_M32: #define __MOVBE__ 1 | |
1887 // CHECK_SLM_M32: #define __PCLMUL__ 1 | |
1888 // CHECK_SLM_M32: #define __POPCNT__ 1 | |
1889 // CHECK_SLM_M32: #define __PRFCHW__ 1 | |
1890 // CHECK_SLM_M32: #define __RDRND__ 1 | |
1891 // CHECK_SLM_M32: #define __SSE2__ 1 | |
1892 // CHECK_SLM_M32: #define __SSE3__ 1 | |
1893 // CHECK_SLM_M32: #define __SSE4_1__ 1 | |
1894 // CHECK_SLM_M32: #define __SSE4_2__ 1 | |
1895 // CHECK_SLM_M32: #define __SSE__ 1 | |
1896 // CHECK_SLM_M32: #define __SSSE3__ 1 | |
1897 // CHECK_SLM_M32: #define __i386 1 | |
1898 // CHECK_SLM_M32: #define __i386__ 1 | |
1899 // CHECK_SLM_M32: #define __slm 1 | |
1900 // CHECK_SLM_M32: #define __slm__ 1 | |
1901 // CHECK_SLM_M32: #define __tune_slm__ 1 | |
1902 // CHECK_SLM_M32: #define i386 1 | |
1903 | |
1904 // RUN: %clang -march=slm -m64 -E -dM %s -o - 2>&1 \ | |
1905 // RUN: -target i386-unknown-linux \ | |
1906 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SLM_M64 | |
1907 // CHECK_SLM_M64: #define __FXSR__ 1 | |
1908 // CHECK_SLM_M64: #define __MMX__ 1 | |
1909 // CHECK_SLM_M64: #define __MOVBE__ 1 | |
1910 // CHECK_SLM_M64: #define __PCLMUL__ 1 | |
1911 // CHECK_SLM_M64: #define __POPCNT__ 1 | |
1912 // CHECK_SLM_M64: #define __PRFCHW__ 1 | |
1913 // CHECK_SLM_M64: #define __RDRND__ 1 | |
1914 // CHECK_SLM_M64: #define __SSE2_MATH__ 1 | |
1915 // CHECK_SLM_M64: #define __SSE2__ 1 | |
1916 // CHECK_SLM_M64: #define __SSE3__ 1 | |
1917 // CHECK_SLM_M64: #define __SSE4_1__ 1 | |
1918 // CHECK_SLM_M64: #define __SSE4_2__ 1 | |
1919 // CHECK_SLM_M64: #define __SSE_MATH__ 1 | |
1920 // CHECK_SLM_M64: #define __SSE__ 1 | |
1921 // CHECK_SLM_M64: #define __SSSE3__ 1 | |
1922 // CHECK_SLM_M64: #define __amd64 1 | |
1923 // CHECK_SLM_M64: #define __amd64__ 1 | |
1924 // CHECK_SLM_M64: #define __slm 1 | |
1925 // CHECK_SLM_M64: #define __slm__ 1 | |
1926 // CHECK_SLM_M64: #define __tune_slm__ 1 | |
1927 // CHECK_SLM_M64: #define __x86_64 1 | |
1928 // CHECK_SLM_M64: #define __x86_64__ 1 | |
1929 | |
1930 // RUN: %clang -march=lakemont -m32 -E -dM %s -o - 2>&1 \ | |
1931 // RUN: -target i386-unknown-linux \ | |
1932 // RUN: | FileCheck %s -check-prefix=CHECK_LAKEMONT_M32 | |
1933 // CHECK_LAKEMONT_M32: #define __i386 1 | |
1934 // CHECK_LAKEMONT_M32: #define __i386__ 1 | |
1935 // CHECK_LAKEMONT_M32: #define __i586 1 | |
1936 // CHECK_LAKEMONT_M32: #define __i586__ 1 | |
1937 // CHECK_LAKEMONT_M32: #define __pentium 1 | |
1938 // CHECK_LAKEMONT_M32: #define __pentium__ 1 | |
1939 // CHECK_LAKEMONT_M32: #define __tune_lakemont__ 1 | |
1940 // CHECK_LAKEMONT_M32: #define i386 1 | |
1941 // RUN: not %clang -march=lakemont -m64 -E -dM %s -o - 2>&1 \ | |
1942 // RUN: -target i386-unknown-linux \ | |
1943 // RUN: | FileCheck %s -check-prefix=CHECK_LAKEMONT_M64 | |
1944 // CHECK_LAKEMONT_M64: error: | |
1945 | |
1946 // RUN: %clang -march=geode -m32 -E -dM %s -o - 2>&1 \ | |
1947 // RUN: -target i386-unknown-linux \ | |
1948 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_GEODE_M32 | |
1949 // CHECK_GEODE_M32: #define __3dNOW_A__ 1 | |
1950 // CHECK_GEODE_M32: #define __3dNOW__ 1 | |
1951 // CHECK_GEODE_M32: #define __MMX__ 1 | |
1952 // CHECK_GEODE_M32: #define __geode 1 | |
1953 // CHECK_GEODE_M32: #define __geode__ 1 | |
1954 // CHECK_GEODE_M32: #define __i386 1 | |
1955 // CHECK_GEODE_M32: #define __i386__ 1 | |
1956 // CHECK_GEODE_M32: #define __tune_geode__ 1 | |
1957 // CHECK_GEODE_M32: #define i386 1 | |
1958 // RUN: not %clang -march=geode -m64 -E -dM %s -o - 2>&1 \ | |
1959 // RUN: -target i386-unknown-linux \ | |
1960 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_GEODE_M64 | |
1961 // CHECK_GEODE_M64: error: {{.*}} | |
1962 | |
1963 // RUN: %clang -march=k6 -m32 -E -dM %s -o - 2>&1 \ | |
1964 // RUN: -target i386-unknown-linux \ | |
1965 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_M32 | |
1966 // CHECK_K6_M32: #define __MMX__ 1 | |
1967 // CHECK_K6_M32: #define __i386 1 | |
1968 // CHECK_K6_M32: #define __i386__ 1 | |
1969 // CHECK_K6_M32: #define __k6 1 | |
1970 // CHECK_K6_M32: #define __k6__ 1 | |
1971 // CHECK_K6_M32: #define __tune_k6__ 1 | |
1972 // CHECK_K6_M32: #define i386 1 | |
1973 // RUN: not %clang -march=k6 -m64 -E -dM %s -o - 2>&1 \ | |
1974 // RUN: -target i386-unknown-linux \ | |
1975 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_M64 | |
1976 // CHECK_K6_M64: error: {{.*}} | |
1977 | |
1978 // RUN: %clang -march=k6-2 -m32 -E -dM %s -o - 2>&1 \ | |
1979 // RUN: -target i386-unknown-linux \ | |
1980 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_2_M32 | |
1981 // CHECK_K6_2_M32: #define __3dNOW__ 1 | |
1982 // CHECK_K6_2_M32: #define __MMX__ 1 | |
1983 // CHECK_K6_2_M32: #define __i386 1 | |
1984 // CHECK_K6_2_M32: #define __i386__ 1 | |
1985 // CHECK_K6_2_M32: #define __k6 1 | |
1986 // CHECK_K6_2_M32: #define __k6_2__ 1 | |
1987 // CHECK_K6_2_M32: #define __k6__ 1 | |
1988 // CHECK_K6_2_M32: #define __tune_k6_2__ 1 | |
1989 // CHECK_K6_2_M32: #define __tune_k6__ 1 | |
1990 // CHECK_K6_2_M32: #define i386 1 | |
1991 // RUN: not %clang -march=k6-2 -m64 -E -dM %s -o - 2>&1 \ | |
1992 // RUN: -target i386-unknown-linux \ | |
1993 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_2_M64 | |
1994 // CHECK_K6_2_M64: error: {{.*}} | |
1995 | |
1996 // RUN: %clang -march=k6-3 -m32 -E -dM %s -o - 2>&1 \ | |
1997 // RUN: -target i386-unknown-linux \ | |
1998 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_3_M32 | |
1999 // CHECK_K6_3_M32: #define __3dNOW__ 1 | |
2000 // CHECK_K6_3_M32: #define __MMX__ 1 | |
2001 // CHECK_K6_3_M32: #define __i386 1 | |
2002 // CHECK_K6_3_M32: #define __i386__ 1 | |
2003 // CHECK_K6_3_M32: #define __k6 1 | |
2004 // CHECK_K6_3_M32: #define __k6_3__ 1 | |
2005 // CHECK_K6_3_M32: #define __k6__ 1 | |
2006 // CHECK_K6_3_M32: #define __tune_k6_3__ 1 | |
2007 // CHECK_K6_3_M32: #define __tune_k6__ 1 | |
2008 // CHECK_K6_3_M32: #define i386 1 | |
2009 // RUN: not %clang -march=k6-3 -m64 -E -dM %s -o - 2>&1 \ | |
2010 // RUN: -target i386-unknown-linux \ | |
2011 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_3_M64 | |
2012 // CHECK_K6_3_M64: error: {{.*}} | |
2013 | |
2014 // RUN: %clang -march=athlon -m32 -E -dM %s -o - 2>&1 \ | |
2015 // RUN: -target i386-unknown-linux \ | |
2016 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_M32 | |
2017 // CHECK_ATHLON_M32: #define __3dNOW_A__ 1 | |
2018 // CHECK_ATHLON_M32: #define __3dNOW__ 1 | |
2019 // CHECK_ATHLON_M32: #define __MMX__ 1 | |
2020 // CHECK_ATHLON_M32: #define __athlon 1 | |
2021 // CHECK_ATHLON_M32: #define __athlon__ 1 | |
2022 // CHECK_ATHLON_M32: #define __i386 1 | |
2023 // CHECK_ATHLON_M32: #define __i386__ 1 | |
2024 // CHECK_ATHLON_M32: #define __tune_athlon__ 1 | |
2025 // CHECK_ATHLON_M32: #define i386 1 | |
2026 // RUN: not %clang -march=athlon -m64 -E -dM %s -o - 2>&1 \ | |
2027 // RUN: -target i386-unknown-linux \ | |
2028 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_M64 | |
2029 // CHECK_ATHLON_M64: error: {{.*}} | |
2030 | |
2031 // RUN: %clang -march=athlon-tbird -m32 -E -dM %s -o - 2>&1 \ | |
2032 // RUN: -target i386-unknown-linux \ | |
2033 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_TBIRD_M32 | |
2034 // CHECK_ATHLON_TBIRD_M32: #define __3dNOW_A__ 1 | |
2035 // CHECK_ATHLON_TBIRD_M32: #define __3dNOW__ 1 | |
2036 // CHECK_ATHLON_TBIRD_M32: #define __MMX__ 1 | |
2037 // CHECK_ATHLON_TBIRD_M32: #define __athlon 1 | |
2038 // CHECK_ATHLON_TBIRD_M32: #define __athlon__ 1 | |
2039 // CHECK_ATHLON_TBIRD_M32: #define __i386 1 | |
2040 // CHECK_ATHLON_TBIRD_M32: #define __i386__ 1 | |
2041 // CHECK_ATHLON_TBIRD_M32: #define __tune_athlon__ 1 | |
2042 // CHECK_ATHLON_TBIRD_M32: #define i386 1 | |
2043 // RUN: not %clang -march=athlon-tbird -m64 -E -dM %s -o - 2>&1 \ | |
2044 // RUN: -target i386-unknown-linux \ | |
2045 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_TBIRD_M64 | |
2046 // CHECK_ATHLON_TBIRD_M64: error: {{.*}} | |
2047 | |
2048 // RUN: %clang -march=athlon-4 -m32 -E -dM %s -o - 2>&1 \ | |
2049 // RUN: -target i386-unknown-linux \ | |
2050 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_4_M32 | |
2051 // CHECK_ATHLON_4_M32: #define __3dNOW_A__ 1 | |
2052 // CHECK_ATHLON_4_M32: #define __3dNOW__ 1 | |
2053 // CHECK_ATHLON_4_M32: #define __MMX__ 1 | |
2054 // CHECK_ATHLON_4_M32: #define __SSE__ 1 | |
2055 // CHECK_ATHLON_4_M32: #define __athlon 1 | |
2056 // CHECK_ATHLON_4_M32: #define __athlon__ 1 | |
2057 // CHECK_ATHLON_4_M32: #define __athlon_sse__ 1 | |
2058 // CHECK_ATHLON_4_M32: #define __i386 1 | |
2059 // CHECK_ATHLON_4_M32: #define __i386__ 1 | |
2060 // CHECK_ATHLON_4_M32: #define __tune_athlon__ 1 | |
2061 // CHECK_ATHLON_4_M32: #define __tune_athlon_sse__ 1 | |
2062 // CHECK_ATHLON_4_M32: #define i386 1 | |
2063 // RUN: not %clang -march=athlon-4 -m64 -E -dM %s -o - 2>&1 \ | |
2064 // RUN: -target i386-unknown-linux \ | |
2065 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_4_M64 | |
2066 // CHECK_ATHLON_4_M64: error: {{.*}} | |
2067 | |
2068 // RUN: %clang -march=athlon-xp -m32 -E -dM %s -o - 2>&1 \ | |
2069 // RUN: -target i386-unknown-linux \ | |
2070 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_XP_M32 | |
2071 // CHECK_ATHLON_XP_M32: #define __3dNOW_A__ 1 | |
2072 // CHECK_ATHLON_XP_M32: #define __3dNOW__ 1 | |
2073 // CHECK_ATHLON_XP_M32: #define __MMX__ 1 | |
2074 // CHECK_ATHLON_XP_M32: #define __SSE__ 1 | |
2075 // CHECK_ATHLON_XP_M32: #define __athlon 1 | |
2076 // CHECK_ATHLON_XP_M32: #define __athlon__ 1 | |
2077 // CHECK_ATHLON_XP_M32: #define __athlon_sse__ 1 | |
2078 // CHECK_ATHLON_XP_M32: #define __i386 1 | |
2079 // CHECK_ATHLON_XP_M32: #define __i386__ 1 | |
2080 // CHECK_ATHLON_XP_M32: #define __tune_athlon__ 1 | |
2081 // CHECK_ATHLON_XP_M32: #define __tune_athlon_sse__ 1 | |
2082 // CHECK_ATHLON_XP_M32: #define i386 1 | |
2083 // RUN: not %clang -march=athlon-xp -m64 -E -dM %s -o - 2>&1 \ | |
2084 // RUN: -target i386-unknown-linux \ | |
2085 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_XP_M64 | |
2086 // CHECK_ATHLON_XP_M64: error: {{.*}} | |
2087 | |
2088 // RUN: %clang -march=athlon-mp -m32 -E -dM %s -o - 2>&1 \ | |
2089 // RUN: -target i386-unknown-linux \ | |
2090 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_MP_M32 | |
2091 // CHECK_ATHLON_MP_M32: #define __3dNOW_A__ 1 | |
2092 // CHECK_ATHLON_MP_M32: #define __3dNOW__ 1 | |
2093 // CHECK_ATHLON_MP_M32: #define __MMX__ 1 | |
2094 // CHECK_ATHLON_MP_M32: #define __SSE__ 1 | |
2095 // CHECK_ATHLON_MP_M32: #define __athlon 1 | |
2096 // CHECK_ATHLON_MP_M32: #define __athlon__ 1 | |
2097 // CHECK_ATHLON_MP_M32: #define __athlon_sse__ 1 | |
2098 // CHECK_ATHLON_MP_M32: #define __i386 1 | |
2099 // CHECK_ATHLON_MP_M32: #define __i386__ 1 | |
2100 // CHECK_ATHLON_MP_M32: #define __tune_athlon__ 1 | |
2101 // CHECK_ATHLON_MP_M32: #define __tune_athlon_sse__ 1 | |
2102 // CHECK_ATHLON_MP_M32: #define i386 1 | |
2103 // RUN: not %clang -march=athlon-mp -m64 -E -dM %s -o - 2>&1 \ | |
2104 // RUN: -target i386-unknown-linux \ | |
2105 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_MP_M64 | |
2106 // CHECK_ATHLON_MP_M64: error: {{.*}} | |
2107 | |
2108 // RUN: %clang -march=x86-64 -m32 -E -dM %s -o - 2>&1 \ | |
2109 // RUN: -target i386-unknown-linux \ | |
2110 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_X86_64_M32 | |
2111 // CHECK_X86_64_M32: #define __MMX__ 1 | |
2112 // CHECK_X86_64_M32: #define __SSE2__ 1 | |
2113 // CHECK_X86_64_M32: #define __SSE__ 1 | |
2114 // CHECK_X86_64_M32: #define __i386 1 | |
2115 // CHECK_X86_64_M32: #define __i386__ 1 | |
2116 // CHECK_X86_64_M32: #define __k8 1 | |
2117 // CHECK_X86_64_M32: #define __k8__ 1 | |
2118 // CHECK_X86_64_M32: #define i386 1 | |
2119 | |
2120 // RUN: %clang -march=x86-64 -m64 -E -dM %s -o - 2>&1 \ | |
2121 // RUN: -target i386-unknown-linux \ | |
2122 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_X86_64_M64 | |
2123 // CHECK_X86_64_M64: #define __MMX__ 1 | |
2124 // CHECK_X86_64_M64: #define __SSE2_MATH__ 1 | |
2125 // CHECK_X86_64_M64: #define __SSE2__ 1 | |
2126 // CHECK_X86_64_M64: #define __SSE_MATH__ 1 | |
2127 // CHECK_X86_64_M64: #define __SSE__ 1 | |
2128 // CHECK_X86_64_M64: #define __amd64 1 | |
2129 // CHECK_X86_64_M64: #define __amd64__ 1 | |
2130 // CHECK_X86_64_M64: #define __k8 1 | |
2131 // CHECK_X86_64_M64: #define __k8__ 1 | |
2132 // CHECK_X86_64_M64: #define __x86_64 1 | |
2133 // CHECK_X86_64_M64: #define __x86_64__ 1 | |
2134 | |
2135 // RUN: %clang -march=k8 -m32 -E -dM %s -o - 2>&1 \ | |
2136 // RUN: -target i386-unknown-linux \ | |
2137 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K8_M32 | |
2138 // CHECK_K8_M32: #define __3dNOW_A__ 1 | |
2139 // CHECK_K8_M32: #define __3dNOW__ 1 | |
2140 // CHECK_K8_M32: #define __MMX__ 1 | |
2141 // CHECK_K8_M32: #define __SSE2__ 1 | |
2142 // CHECK_K8_M32: #define __SSE__ 1 | |
2143 // CHECK_K8_M32: #define __i386 1 | |
2144 // CHECK_K8_M32: #define __i386__ 1 | |
2145 // CHECK_K8_M32: #define __k8 1 | |
2146 // CHECK_K8_M32: #define __k8__ 1 | |
2147 // CHECK_K8_M32: #define __tune_k8__ 1 | |
2148 // CHECK_K8_M32: #define i386 1 | |
2149 | |
2150 // RUN: %clang -march=k8 -m64 -E -dM %s -o - 2>&1 \ | |
2151 // RUN: -target i386-unknown-linux \ | |
2152 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K8_M64 | |
2153 // CHECK_K8_M64: #define __3dNOW_A__ 1 | |
2154 // CHECK_K8_M64: #define __3dNOW__ 1 | |
2155 // CHECK_K8_M64: #define __MMX__ 1 | |
2156 // CHECK_K8_M64: #define __SSE2_MATH__ 1 | |
2157 // CHECK_K8_M64: #define __SSE2__ 1 | |
2158 // CHECK_K8_M64: #define __SSE_MATH__ 1 | |
2159 // CHECK_K8_M64: #define __SSE__ 1 | |
2160 // CHECK_K8_M64: #define __amd64 1 | |
2161 // CHECK_K8_M64: #define __amd64__ 1 | |
2162 // CHECK_K8_M64: #define __k8 1 | |
2163 // CHECK_K8_M64: #define __k8__ 1 | |
2164 // CHECK_K8_M64: #define __tune_k8__ 1 | |
2165 // CHECK_K8_M64: #define __x86_64 1 | |
2166 // CHECK_K8_M64: #define __x86_64__ 1 | |
2167 | |
2168 // RUN: %clang -march=k8-sse3 -m32 -E -dM %s -o - 2>&1 \ | |
2169 // RUN: -target i386-unknown-linux \ | |
2170 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K8_SSE3_M32 | |
2171 // CHECK_K8_SSE3_M32: #define __3dNOW_A__ 1 | |
2172 // CHECK_K8_SSE3_M32: #define __3dNOW__ 1 | |
2173 // CHECK_K8_SSE3_M32: #define __MMX__ 1 | |
2174 // CHECK_K8_SSE3_M32: #define __SSE2__ 1 | |
2175 // CHECK_K8_SSE3_M32: #define __SSE3__ 1 | |
2176 // CHECK_K8_SSE3_M32: #define __SSE__ 1 | |
2177 // CHECK_K8_SSE3_M32: #define __i386 1 | |
2178 // CHECK_K8_SSE3_M32: #define __i386__ 1 | |
2179 // CHECK_K8_SSE3_M32: #define __k8 1 | |
2180 // CHECK_K8_SSE3_M32: #define __k8__ 1 | |
2181 // CHECK_K8_SSE3_M32: #define __tune_k8__ 1 | |
2182 // CHECK_K8_SSE3_M32: #define i386 1 | |
2183 | |
2184 // RUN: %clang -march=k8-sse3 -m64 -E -dM %s -o - 2>&1 \ | |
2185 // RUN: -target i386-unknown-linux \ | |
2186 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K8_SSE3_M64 | |
2187 // CHECK_K8_SSE3_M64: #define __3dNOW_A__ 1 | |
2188 // CHECK_K8_SSE3_M64: #define __3dNOW__ 1 | |
2189 // CHECK_K8_SSE3_M64: #define __MMX__ 1 | |
2190 // CHECK_K8_SSE3_M64: #define __SSE2_MATH__ 1 | |
2191 // CHECK_K8_SSE3_M64: #define __SSE2__ 1 | |
2192 // CHECK_K8_SSE3_M64: #define __SSE3__ 1 | |
2193 // CHECK_K8_SSE3_M64: #define __SSE_MATH__ 1 | |
2194 // CHECK_K8_SSE3_M64: #define __SSE__ 1 | |
2195 // CHECK_K8_SSE3_M64: #define __amd64 1 | |
2196 // CHECK_K8_SSE3_M64: #define __amd64__ 1 | |
2197 // CHECK_K8_SSE3_M64: #define __k8 1 | |
2198 // CHECK_K8_SSE3_M64: #define __k8__ 1 | |
2199 // CHECK_K8_SSE3_M64: #define __tune_k8__ 1 | |
2200 // CHECK_K8_SSE3_M64: #define __x86_64 1 | |
2201 // CHECK_K8_SSE3_M64: #define __x86_64__ 1 | |
2202 | |
2203 // RUN: %clang -march=opteron -m32 -E -dM %s -o - 2>&1 \ | |
2204 // RUN: -target i386-unknown-linux \ | |
2205 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_OPTERON_M32 | |
2206 // CHECK_OPTERON_M32: #define __3dNOW_A__ 1 | |
2207 // CHECK_OPTERON_M32: #define __3dNOW__ 1 | |
2208 // CHECK_OPTERON_M32: #define __MMX__ 1 | |
2209 // CHECK_OPTERON_M32: #define __SSE2__ 1 | |
2210 // CHECK_OPTERON_M32: #define __SSE__ 1 | |
2211 // CHECK_OPTERON_M32: #define __i386 1 | |
2212 // CHECK_OPTERON_M32: #define __i386__ 1 | |
2213 // CHECK_OPTERON_M32: #define __k8 1 | |
2214 // CHECK_OPTERON_M32: #define __k8__ 1 | |
2215 // CHECK_OPTERON_M32: #define __tune_k8__ 1 | |
2216 // CHECK_OPTERON_M32: #define i386 1 | |
2217 | |
2218 // RUN: %clang -march=opteron -m64 -E -dM %s -o - 2>&1 \ | |
2219 // RUN: -target i386-unknown-linux \ | |
2220 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_OPTERON_M64 | |
2221 // CHECK_OPTERON_M64: #define __3dNOW_A__ 1 | |
2222 // CHECK_OPTERON_M64: #define __3dNOW__ 1 | |
2223 // CHECK_OPTERON_M64: #define __MMX__ 1 | |
2224 // CHECK_OPTERON_M64: #define __SSE2_MATH__ 1 | |
2225 // CHECK_OPTERON_M64: #define __SSE2__ 1 | |
2226 // CHECK_OPTERON_M64: #define __SSE_MATH__ 1 | |
2227 // CHECK_OPTERON_M64: #define __SSE__ 1 | |
2228 // CHECK_OPTERON_M64: #define __amd64 1 | |
2229 // CHECK_OPTERON_M64: #define __amd64__ 1 | |
2230 // CHECK_OPTERON_M64: #define __k8 1 | |
2231 // CHECK_OPTERON_M64: #define __k8__ 1 | |
2232 // CHECK_OPTERON_M64: #define __tune_k8__ 1 | |
2233 // CHECK_OPTERON_M64: #define __x86_64 1 | |
2234 // CHECK_OPTERON_M64: #define __x86_64__ 1 | |
2235 | |
2236 // RUN: %clang -march=opteron-sse3 -m32 -E -dM %s -o - 2>&1 \ | |
2237 // RUN: -target i386-unknown-linux \ | |
2238 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_OPTERON_SSE3_M32 | |
2239 // CHECK_OPTERON_SSE3_M32: #define __3dNOW_A__ 1 | |
2240 // CHECK_OPTERON_SSE3_M32: #define __3dNOW__ 1 | |
2241 // CHECK_OPTERON_SSE3_M32: #define __MMX__ 1 | |
2242 // CHECK_OPTERON_SSE3_M32: #define __SSE2__ 1 | |
2243 // CHECK_OPTERON_SSE3_M32: #define __SSE3__ 1 | |
2244 // CHECK_OPTERON_SSE3_M32: #define __SSE__ 1 | |
2245 // CHECK_OPTERON_SSE3_M32: #define __i386 1 | |
2246 // CHECK_OPTERON_SSE3_M32: #define __i386__ 1 | |
2247 // CHECK_OPTERON_SSE3_M32: #define __k8 1 | |
2248 // CHECK_OPTERON_SSE3_M32: #define __k8__ 1 | |
2249 // CHECK_OPTERON_SSE3_M32: #define __tune_k8__ 1 | |
2250 // CHECK_OPTERON_SSE3_M32: #define i386 1 | |
2251 | |
2252 // RUN: %clang -march=opteron-sse3 -m64 -E -dM %s -o - 2>&1 \ | |
2253 // RUN: -target i386-unknown-linux \ | |
2254 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_OPTERON_SSE3_M64 | |
2255 // CHECK_OPTERON_SSE3_M64: #define __3dNOW_A__ 1 | |
2256 // CHECK_OPTERON_SSE3_M64: #define __3dNOW__ 1 | |
2257 // CHECK_OPTERON_SSE3_M64: #define __MMX__ 1 | |
2258 // CHECK_OPTERON_SSE3_M64: #define __SSE2_MATH__ 1 | |
2259 // CHECK_OPTERON_SSE3_M64: #define __SSE2__ 1 | |
2260 // CHECK_OPTERON_SSE3_M64: #define __SSE3__ 1 | |
2261 // CHECK_OPTERON_SSE3_M64: #define __SSE_MATH__ 1 | |
2262 // CHECK_OPTERON_SSE3_M64: #define __SSE__ 1 | |
2263 // CHECK_OPTERON_SSE3_M64: #define __amd64 1 | |
2264 // CHECK_OPTERON_SSE3_M64: #define __amd64__ 1 | |
2265 // CHECK_OPTERON_SSE3_M64: #define __k8 1 | |
2266 // CHECK_OPTERON_SSE3_M64: #define __k8__ 1 | |
2267 // CHECK_OPTERON_SSE3_M64: #define __tune_k8__ 1 | |
2268 // CHECK_OPTERON_SSE3_M64: #define __x86_64 1 | |
2269 // CHECK_OPTERON_SSE3_M64: #define __x86_64__ 1 | |
2270 | |
2271 // RUN: %clang -march=athlon64 -m32 -E -dM %s -o - 2>&1 \ | |
2272 // RUN: -target i386-unknown-linux \ | |
2273 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON64_M32 | |
2274 // CHECK_ATHLON64_M32: #define __3dNOW_A__ 1 | |
2275 // CHECK_ATHLON64_M32: #define __3dNOW__ 1 | |
2276 // CHECK_ATHLON64_M32: #define __MMX__ 1 | |
2277 // CHECK_ATHLON64_M32: #define __SSE2__ 1 | |
2278 // CHECK_ATHLON64_M32: #define __SSE__ 1 | |
2279 // CHECK_ATHLON64_M32: #define __i386 1 | |
2280 // CHECK_ATHLON64_M32: #define __i386__ 1 | |
2281 // CHECK_ATHLON64_M32: #define __k8 1 | |
2282 // CHECK_ATHLON64_M32: #define __k8__ 1 | |
2283 // CHECK_ATHLON64_M32: #define __tune_k8__ 1 | |
2284 // CHECK_ATHLON64_M32: #define i386 1 | |
2285 | |
2286 // RUN: %clang -march=athlon64 -m64 -E -dM %s -o - 2>&1 \ | |
2287 // RUN: -target i386-unknown-linux \ | |
2288 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON64_M64 | |
2289 // CHECK_ATHLON64_M64: #define __3dNOW_A__ 1 | |
2290 // CHECK_ATHLON64_M64: #define __3dNOW__ 1 | |
2291 // CHECK_ATHLON64_M64: #define __MMX__ 1 | |
2292 // CHECK_ATHLON64_M64: #define __SSE2_MATH__ 1 | |
2293 // CHECK_ATHLON64_M64: #define __SSE2__ 1 | |
2294 // CHECK_ATHLON64_M64: #define __SSE_MATH__ 1 | |
2295 // CHECK_ATHLON64_M64: #define __SSE__ 1 | |
2296 // CHECK_ATHLON64_M64: #define __amd64 1 | |
2297 // CHECK_ATHLON64_M64: #define __amd64__ 1 | |
2298 // CHECK_ATHLON64_M64: #define __k8 1 | |
2299 // CHECK_ATHLON64_M64: #define __k8__ 1 | |
2300 // CHECK_ATHLON64_M64: #define __tune_k8__ 1 | |
2301 // CHECK_ATHLON64_M64: #define __x86_64 1 | |
2302 // CHECK_ATHLON64_M64: #define __x86_64__ 1 | |
2303 | |
2304 // RUN: %clang -march=athlon64-sse3 -m32 -E -dM %s -o - 2>&1 \ | |
2305 // RUN: -target i386-unknown-linux \ | |
2306 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON64_SSE3_M32 | |
2307 // CHECK_ATHLON64_SSE3_M32: #define __3dNOW_A__ 1 | |
2308 // CHECK_ATHLON64_SSE3_M32: #define __3dNOW__ 1 | |
2309 // CHECK_ATHLON64_SSE3_M32: #define __MMX__ 1 | |
2310 // CHECK_ATHLON64_SSE3_M32: #define __SSE2__ 1 | |
2311 // CHECK_ATHLON64_SSE3_M32: #define __SSE3__ 1 | |
2312 // CHECK_ATHLON64_SSE3_M32: #define __SSE__ 1 | |
2313 // CHECK_ATHLON64_SSE3_M32: #define __i386 1 | |
2314 // CHECK_ATHLON64_SSE3_M32: #define __i386__ 1 | |
2315 // CHECK_ATHLON64_SSE3_M32: #define __k8 1 | |
2316 // CHECK_ATHLON64_SSE3_M32: #define __k8__ 1 | |
2317 // CHECK_ATHLON64_SSE3_M32: #define __tune_k8__ 1 | |
2318 // CHECK_ATHLON64_SSE3_M32: #define i386 1 | |
2319 | |
2320 // RUN: %clang -march=athlon64-sse3 -m64 -E -dM %s -o - 2>&1 \ | |
2321 // RUN: -target i386-unknown-linux \ | |
2322 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON64_SSE3_M64 | |
2323 // CHECK_ATHLON64_SSE3_M64: #define __3dNOW_A__ 1 | |
2324 // CHECK_ATHLON64_SSE3_M64: #define __3dNOW__ 1 | |
2325 // CHECK_ATHLON64_SSE3_M64: #define __MMX__ 1 | |
2326 // CHECK_ATHLON64_SSE3_M64: #define __SSE2_MATH__ 1 | |
2327 // CHECK_ATHLON64_SSE3_M64: #define __SSE2__ 1 | |
2328 // CHECK_ATHLON64_SSE3_M64: #define __SSE3__ 1 | |
2329 // CHECK_ATHLON64_SSE3_M64: #define __SSE_MATH__ 1 | |
2330 // CHECK_ATHLON64_SSE3_M64: #define __SSE__ 1 | |
2331 // CHECK_ATHLON64_SSE3_M64: #define __amd64 1 | |
2332 // CHECK_ATHLON64_SSE3_M64: #define __amd64__ 1 | |
2333 // CHECK_ATHLON64_SSE3_M64: #define __k8 1 | |
2334 // CHECK_ATHLON64_SSE3_M64: #define __k8__ 1 | |
2335 // CHECK_ATHLON64_SSE3_M64: #define __tune_k8__ 1 | |
2336 // CHECK_ATHLON64_SSE3_M64: #define __x86_64 1 | |
2337 // CHECK_ATHLON64_SSE3_M64: #define __x86_64__ 1 | |
2338 | |
2339 // RUN: %clang -march=athlon-fx -m32 -E -dM %s -o - 2>&1 \ | |
2340 // RUN: -target i386-unknown-linux \ | |
2341 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_FX_M32 | |
2342 // CHECK_ATHLON_FX_M32: #define __3dNOW_A__ 1 | |
2343 // CHECK_ATHLON_FX_M32: #define __3dNOW__ 1 | |
2344 // CHECK_ATHLON_FX_M32: #define __MMX__ 1 | |
2345 // CHECK_ATHLON_FX_M32: #define __SSE2__ 1 | |
2346 // CHECK_ATHLON_FX_M32: #define __SSE__ 1 | |
2347 // CHECK_ATHLON_FX_M32: #define __i386 1 | |
2348 // CHECK_ATHLON_FX_M32: #define __i386__ 1 | |
2349 // CHECK_ATHLON_FX_M32: #define __k8 1 | |
2350 // CHECK_ATHLON_FX_M32: #define __k8__ 1 | |
2351 // CHECK_ATHLON_FX_M32: #define __tune_k8__ 1 | |
2352 // CHECK_ATHLON_FX_M32: #define i386 1 | |
2353 | |
2354 // RUN: %clang -march=athlon-fx -m64 -E -dM %s -o - 2>&1 \ | |
2355 // RUN: -target i386-unknown-linux \ | |
2356 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_FX_M64 | |
2357 // CHECK_ATHLON_FX_M64: #define __3dNOW_A__ 1 | |
2358 // CHECK_ATHLON_FX_M64: #define __3dNOW__ 1 | |
2359 // CHECK_ATHLON_FX_M64: #define __MMX__ 1 | |
2360 // CHECK_ATHLON_FX_M64: #define __SSE2_MATH__ 1 | |
2361 // CHECK_ATHLON_FX_M64: #define __SSE2__ 1 | |
2362 // CHECK_ATHLON_FX_M64: #define __SSE_MATH__ 1 | |
2363 // CHECK_ATHLON_FX_M64: #define __SSE__ 1 | |
2364 // CHECK_ATHLON_FX_M64: #define __amd64 1 | |
2365 // CHECK_ATHLON_FX_M64: #define __amd64__ 1 | |
2366 // CHECK_ATHLON_FX_M64: #define __k8 1 | |
2367 // CHECK_ATHLON_FX_M64: #define __k8__ 1 | |
2368 // CHECK_ATHLON_FX_M64: #define __tune_k8__ 1 | |
2369 // CHECK_ATHLON_FX_M64: #define __x86_64 1 | |
2370 // CHECK_ATHLON_FX_M64: #define __x86_64__ 1 | |
2371 | |
2372 // RUN: %clang -march=amdfam10 -m32 -E -dM %s -o - 2>&1 \ | |
2373 // RUN: -target i386-unknown-linux \ | |
2374 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_AMDFAM10_M32 | |
2375 // CHECK_AMDFAM10_M32: #define __3dNOW_A__ 1 | |
2376 // CHECK_AMDFAM10_M32: #define __3dNOW__ 1 | |
2377 // CHECK_AMDFAM10_M32: #define __LZCNT__ 1 | |
2378 // CHECK_AMDFAM10_M32: #define __MMX__ 1 | |
2379 // CHECK_AMDFAM10_M32: #define __POPCNT__ 1 | |
2380 // CHECK_AMDFAM10_M32: #define __SSE2_MATH__ 1 | |
2381 // CHECK_AMDFAM10_M32: #define __SSE2__ 1 | |
2382 // CHECK_AMDFAM10_M32: #define __SSE3__ 1 | |
2383 // CHECK_AMDFAM10_M32: #define __SSE4A__ 1 | |
2384 // CHECK_AMDFAM10_M32: #define __SSE_MATH__ 1 | |
2385 // CHECK_AMDFAM10_M32: #define __SSE__ 1 | |
2386 // CHECK_AMDFAM10_M32: #define __amdfam10 1 | |
2387 // CHECK_AMDFAM10_M32: #define __amdfam10__ 1 | |
2388 // CHECK_AMDFAM10_M32: #define __i386 1 | |
2389 // CHECK_AMDFAM10_M32: #define __i386__ 1 | |
2390 // CHECK_AMDFAM10_M32: #define __tune_amdfam10__ 1 | |
2391 | |
2392 // RUN: %clang -march=amdfam10 -m64 -E -dM %s -o - 2>&1 \ | |
2393 // RUN: -target i386-unknown-linux \ | |
2394 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_AMDFAM10_M64 | |
2395 // CHECK_AMDFAM10_M64: #define __3dNOW_A__ 1 | |
2396 // CHECK_AMDFAM10_M64: #define __3dNOW__ 1 | |
2397 // CHECK_AMDFAM10_M64: #define __LZCNT__ 1 | |
2398 // CHECK_AMDFAM10_M64: #define __MMX__ 1 | |
2399 // CHECK_AMDFAM10_M64: #define __POPCNT__ 1 | |
2400 // CHECK_AMDFAM10_M64: #define __SSE2_MATH__ 1 | |
2401 // CHECK_AMDFAM10_M64: #define __SSE2__ 1 | |
2402 // CHECK_AMDFAM10_M64: #define __SSE3__ 1 | |
2403 // CHECK_AMDFAM10_M64: #define __SSE4A__ 1 | |
2404 // CHECK_AMDFAM10_M64: #define __SSE_MATH__ 1 | |
2405 // CHECK_AMDFAM10_M64: #define __SSE__ 1 | |
2406 // CHECK_AMDFAM10_M64: #define __amd64 1 | |
2407 // CHECK_AMDFAM10_M64: #define __amd64__ 1 | |
2408 // CHECK_AMDFAM10_M64: #define __amdfam10 1 | |
2409 // CHECK_AMDFAM10_M64: #define __amdfam10__ 1 | |
2410 // CHECK_AMDFAM10_M64: #define __tune_amdfam10__ 1 | |
2411 // CHECK_AMDFAM10_M64: #define __x86_64 1 | |
2412 // CHECK_AMDFAM10_M64: #define __x86_64__ 1 | |
2413 | |
2414 // RUN: %clang -march=btver1 -m32 -E -dM %s -o - 2>&1 \ | |
2415 // RUN: -target i386-unknown-linux \ | |
2416 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BTVER1_M32 | |
2417 // CHECK_BTVER1_M32-NOT: #define __3dNOW_A__ 1 | |
2418 // CHECK_BTVER1_M32-NOT: #define __3dNOW__ 1 | |
2419 // CHECK_BTVER1_M32: #define __LZCNT__ 1 | |
2420 // CHECK_BTVER1_M32: #define __MMX__ 1 | |
2421 // CHECK_BTVER1_M32: #define __POPCNT__ 1 | |
2422 // CHECK_BTVER1_M32: #define __PRFCHW__ 1 | |
2423 // CHECK_BTVER1_M32: #define __SSE2_MATH__ 1 | |
2424 // CHECK_BTVER1_M32: #define __SSE2__ 1 | |
2425 // CHECK_BTVER1_M32: #define __SSE3__ 1 | |
2426 // CHECK_BTVER1_M32: #define __SSE4A__ 1 | |
2427 // CHECK_BTVER1_M32: #define __SSE_MATH__ 1 | |
2428 // CHECK_BTVER1_M32: #define __SSE__ 1 | |
2429 // CHECK_BTVER1_M32: #define __SSSE3__ 1 | |
2430 // CHECK_BTVER1_M32: #define __btver1 1 | |
2431 // CHECK_BTVER1_M32: #define __btver1__ 1 | |
2432 // CHECK_BTVER1_M32: #define __i386 1 | |
2433 // CHECK_BTVER1_M32: #define __i386__ 1 | |
2434 // CHECK_BTVER1_M32: #define __tune_btver1__ 1 | |
2435 | |
2436 // RUN: %clang -march=btver1 -m64 -E -dM %s -o - 2>&1 \ | |
2437 // RUN: -target i386-unknown-linux \ | |
2438 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BTVER1_M64 | |
2439 // CHECK_BTVER1_M64-NOT: #define __3dNOW_A__ 1 | |
2440 // CHECK_BTVER1_M64-NOT: #define __3dNOW__ 1 | |
2441 // CHECK_BTVER1_M64: #define __LZCNT__ 1 | |
2442 // CHECK_BTVER1_M64: #define __MMX__ 1 | |
2443 // CHECK_BTVER1_M64: #define __POPCNT__ 1 | |
2444 // CHECK_BTVER1_M64: #define __PRFCHW__ 1 | |
2445 // CHECK_BTVER1_M64: #define __SSE2_MATH__ 1 | |
2446 // CHECK_BTVER1_M64: #define __SSE2__ 1 | |
2447 // CHECK_BTVER1_M64: #define __SSE3__ 1 | |
2448 // CHECK_BTVER1_M64: #define __SSE4A__ 1 | |
2449 // CHECK_BTVER1_M64: #define __SSE_MATH__ 1 | |
2450 // CHECK_BTVER1_M64: #define __SSE__ 1 | |
2451 // CHECK_BTVER1_M64: #define __SSSE3__ 1 | |
2452 // CHECK_BTVER1_M64: #define __amd64 1 | |
2453 // CHECK_BTVER1_M64: #define __amd64__ 1 | |
2454 // CHECK_BTVER1_M64: #define __btver1 1 | |
2455 // CHECK_BTVER1_M64: #define __btver1__ 1 | |
2456 // CHECK_BTVER1_M64: #define __tune_btver1__ 1 | |
2457 // CHECK_BTVER1_M64: #define __x86_64 1 | |
2458 // CHECK_BTVER1_M64: #define __x86_64__ 1 | |
2459 | |
2460 // RUN: %clang -march=btver2 -m32 -E -dM %s -o - 2>&1 \ | |
2461 // RUN: -target i386-unknown-linux \ | |
2462 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BTVER2_M32 | |
2463 // CHECK_BTVER2_M32-NOT: #define __3dNOW_A__ 1 | |
2464 // CHECK_BTVER2_M32-NOT: #define __3dNOW__ 1 | |
2465 // CHECK_BTVER2_M32: #define __AES__ 1 | |
2466 // CHECK_BTVER2_M32: #define __AVX__ 1 | |
2467 // CHECK_BTVER2_M32: #define __BMI__ 1 | |
2468 // CHECK_BTVER2_M32: #define __F16C__ 1 | |
2469 // CHECK_BTVER2_M32: #define __LZCNT__ 1 | |
2470 // CHECK_BTVER2_M32: #define __MMX__ 1 | |
2471 // CHECK_BTVER2_M32: #define __MOVBE__ 1 | |
2472 // CHECK_BTVER2_M32: #define __PCLMUL__ 1 | |
2473 // CHECK_BTVER2_M32: #define __POPCNT__ 1 | |
2474 // CHECK_BTVER2_M32: #define __PRFCHW__ 1 | |
2475 // CHECK_BTVER2_M32: #define __SSE2_MATH__ 1 | |
2476 // CHECK_BTVER2_M32: #define __SSE2__ 1 | |
2477 // CHECK_BTVER2_M32: #define __SSE3__ 1 | |
2478 // CHECK_BTVER2_M32: #define __SSE4A__ 1 | |
2479 // CHECK_BTVER2_M32: #define __SSE_MATH__ 1 | |
2480 // CHECK_BTVER2_M32: #define __SSE__ 1 | |
2481 // CHECK_BTVER2_M32: #define __SSSE3__ 1 | |
2482 // CHECK_BTVER2_M32: #define __XSAVEOPT__ 1 | |
2483 // CHECK_BTVER2_M32: #define __XSAVE__ 1 | |
2484 // CHECK_BTVER2_M32: #define __btver2 1 | |
2485 // CHECK_BTVER2_M32: #define __btver2__ 1 | |
2486 // CHECK_BTVER2_M32: #define __i386 1 | |
2487 // CHECK_BTVER2_M32: #define __i386__ 1 | |
2488 // CHECK_BTVER2_M32: #define __tune_btver2__ 1 | |
2489 | |
2490 // RUN: %clang -march=btver2 -m64 -E -dM %s -o - 2>&1 \ | |
2491 // RUN: -target i386-unknown-linux \ | |
2492 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BTVER2_M64 | |
2493 // CHECK_BTVER2_M64-NOT: #define __3dNOW_A__ 1 | |
2494 // CHECK_BTVER2_M64-NOT: #define __3dNOW__ 1 | |
2495 // CHECK_BTVER2_M64: #define __AES__ 1 | |
2496 // CHECK_BTVER2_M64: #define __AVX__ 1 | |
2497 // CHECK_BTVER2_M64: #define __BMI__ 1 | |
2498 // CHECK_BTVER2_M64: #define __F16C__ 1 | |
2499 // CHECK_BTVER2_M64: #define __LZCNT__ 1 | |
2500 // CHECK_BTVER2_M64: #define __MMX__ 1 | |
2501 // CHECK_BTVER2_M64: #define __MOVBE__ 1 | |
2502 // CHECK_BTVER2_M64: #define __PCLMUL__ 1 | |
2503 // CHECK_BTVER2_M64: #define __POPCNT__ 1 | |
2504 // CHECK_BTVER2_M64: #define __PRFCHW__ 1 | |
2505 // CHECK_BTVER2_M64: #define __SSE2_MATH__ 1 | |
2506 // CHECK_BTVER2_M64: #define __SSE2__ 1 | |
2507 // CHECK_BTVER2_M64: #define __SSE3__ 1 | |
2508 // CHECK_BTVER2_M64: #define __SSE4A__ 1 | |
2509 // CHECK_BTVER2_M64: #define __SSE_MATH__ 1 | |
2510 // CHECK_BTVER2_M64: #define __SSE__ 1 | |
2511 // CHECK_BTVER2_M64: #define __SSSE3__ 1 | |
2512 // CHECK_BTVER2_M64: #define __XSAVEOPT__ 1 | |
2513 // CHECK_BTVER2_M64: #define __XSAVE__ 1 | |
2514 // CHECK_BTVER2_M64: #define __amd64 1 | |
2515 // CHECK_BTVER2_M64: #define __amd64__ 1 | |
2516 // CHECK_BTVER2_M64: #define __btver2 1 | |
2517 // CHECK_BTVER2_M64: #define __btver2__ 1 | |
2518 // CHECK_BTVER2_M64: #define __tune_btver2__ 1 | |
2519 // CHECK_BTVER2_M64: #define __x86_64 1 | |
2520 // CHECK_BTVER2_M64: #define __x86_64__ 1 | |
2521 | |
2522 // RUN: %clang -march=bdver1 -m32 -E -dM %s -o - 2>&1 \ | |
2523 // RUN: -target i386-unknown-linux \ | |
2524 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER1_M32 | |
2525 // CHECK_BDVER1_M32-NOT: #define __3dNOW_A__ 1 | |
2526 // CHECK_BDVER1_M32-NOT: #define __3dNOW__ 1 | |
2527 // CHECK_BDVER1_M32: #define __AES__ 1 | |
2528 // CHECK_BDVER1_M32: #define __AVX__ 1 | |
2529 // CHECK_BDVER1_M32: #define __FMA4__ 1 | |
2530 // CHECK_BDVER1_M32: #define __LWP__ 1 | |
2531 // CHECK_BDVER1_M32: #define __LZCNT__ 1 | |
2532 // CHECK_BDVER1_M32: #define __MMX__ 1 | |
2533 // CHECK_BDVER1_M32: #define __PCLMUL__ 1 | |
2534 // CHECK_BDVER1_M32: #define __POPCNT__ 1 | |
2535 // CHECK_BDVER1_M32: #define __PRFCHW__ 1 | |
2536 // CHECK_BDVER1_M32: #define __SSE2_MATH__ 1 | |
2537 // CHECK_BDVER1_M32: #define __SSE2__ 1 | |
2538 // CHECK_BDVER1_M32: #define __SSE3__ 1 | |
2539 // CHECK_BDVER1_M32: #define __SSE4A__ 1 | |
2540 // CHECK_BDVER1_M32: #define __SSE4_1__ 1 | |
2541 // CHECK_BDVER1_M32: #define __SSE4_2__ 1 | |
2542 // CHECK_BDVER1_M32: #define __SSE_MATH__ 1 | |
2543 // CHECK_BDVER1_M32: #define __SSE__ 1 | |
2544 // CHECK_BDVER1_M32: #define __SSSE3__ 1 | |
2545 // CHECK_BDVER1_M32: #define __XOP__ 1 | |
2546 // CHECK_BDVER1_M32: #define __XSAVE__ 1 | |
2547 // CHECK_BDVER1_M32: #define __bdver1 1 | |
2548 // CHECK_BDVER1_M32: #define __bdver1__ 1 | |
2549 // CHECK_BDVER1_M32: #define __i386 1 | |
2550 // CHECK_BDVER1_M32: #define __i386__ 1 | |
2551 // CHECK_BDVER1_M32: #define __tune_bdver1__ 1 | |
2552 | |
2553 // RUN: %clang -march=bdver1 -m64 -E -dM %s -o - 2>&1 \ | |
2554 // RUN: -target i386-unknown-linux \ | |
2555 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER1_M64 | |
2556 // CHECK_BDVER1_M64-NOT: #define __3dNOW_A__ 1 | |
2557 // CHECK_BDVER1_M64-NOT: #define __3dNOW__ 1 | |
2558 // CHECK_BDVER1_M64: #define __AES__ 1 | |
2559 // CHECK_BDVER1_M64: #define __AVX__ 1 | |
2560 // CHECK_BDVER1_M64: #define __FMA4__ 1 | |
2561 // CHECK_BDVER1_M64: #define __LWP__ 1 | |
2562 // CHECK_BDVER1_M64: #define __LZCNT__ 1 | |
2563 // CHECK_BDVER1_M64: #define __MMX__ 1 | |
2564 // CHECK_BDVER1_M64: #define __PCLMUL__ 1 | |
2565 // CHECK_BDVER1_M64: #define __POPCNT__ 1 | |
2566 // CHECK_BDVER1_M64: #define __PRFCHW__ 1 | |
2567 // CHECK_BDVER1_M64: #define __SSE2_MATH__ 1 | |
2568 // CHECK_BDVER1_M64: #define __SSE2__ 1 | |
2569 // CHECK_BDVER1_M64: #define __SSE3__ 1 | |
2570 // CHECK_BDVER1_M64: #define __SSE4A__ 1 | |
2571 // CHECK_BDVER1_M64: #define __SSE4_1__ 1 | |
2572 // CHECK_BDVER1_M64: #define __SSE4_2__ 1 | |
2573 // CHECK_BDVER1_M64: #define __SSE_MATH__ 1 | |
2574 // CHECK_BDVER1_M64: #define __SSE__ 1 | |
2575 // CHECK_BDVER1_M64: #define __SSSE3__ 1 | |
2576 // CHECK_BDVER1_M64: #define __XOP__ 1 | |
2577 // CHECK_BDVER1_M64: #define __XSAVE__ 1 | |
2578 // CHECK_BDVER1_M64: #define __amd64 1 | |
2579 // CHECK_BDVER1_M64: #define __amd64__ 1 | |
2580 // CHECK_BDVER1_M64: #define __bdver1 1 | |
2581 // CHECK_BDVER1_M64: #define __bdver1__ 1 | |
2582 // CHECK_BDVER1_M64: #define __tune_bdver1__ 1 | |
2583 // CHECK_BDVER1_M64: #define __x86_64 1 | |
2584 // CHECK_BDVER1_M64: #define __x86_64__ 1 | |
2585 | |
2586 // RUN: %clang -march=bdver2 -m32 -E -dM %s -o - 2>&1 \ | |
2587 // RUN: -target i386-unknown-linux \ | |
2588 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER2_M32 | |
2589 // CHECK_BDVER2_M32-NOT: #define __3dNOW_A__ 1 | |
2590 // CHECK_BDVER2_M32-NOT: #define __3dNOW__ 1 | |
2591 // CHECK_BDVER2_M32: #define __AES__ 1 | |
2592 // CHECK_BDVER2_M32: #define __AVX__ 1 | |
2593 // CHECK_BDVER2_M32: #define __BMI__ 1 | |
2594 // CHECK_BDVER2_M32: #define __F16C__ 1 | |
2595 // CHECK_BDVER2_M32: #define __FMA4__ 1 | |
2596 // CHECK_BDVER2_M32: #define __FMA__ 1 | |
2597 // CHECK_BDVER2_M32: #define __LWP__ 1 | |
2598 // CHECK_BDVER2_M32: #define __LZCNT__ 1 | |
2599 // CHECK_BDVER2_M32: #define __MMX__ 1 | |
2600 // CHECK_BDVER2_M32: #define __PCLMUL__ 1 | |
2601 // CHECK_BDVER2_M32: #define __POPCNT__ 1 | |
2602 // CHECK_BDVER2_M32: #define __PRFCHW__ 1 | |
2603 // CHECK_BDVER2_M32: #define __SSE2_MATH__ 1 | |
2604 // CHECK_BDVER2_M32: #define __SSE2__ 1 | |
2605 // CHECK_BDVER2_M32: #define __SSE3__ 1 | |
2606 // CHECK_BDVER2_M32: #define __SSE4A__ 1 | |
2607 // CHECK_BDVER2_M32: #define __SSE4_1__ 1 | |
2608 // CHECK_BDVER2_M32: #define __SSE4_2__ 1 | |
2609 // CHECK_BDVER2_M32: #define __SSE_MATH__ 1 | |
2610 // CHECK_BDVER2_M32: #define __SSE__ 1 | |
2611 // CHECK_BDVER2_M32: #define __SSSE3__ 1 | |
2612 // CHECK_BDVER2_M32: #define __TBM__ 1 | |
2613 // CHECK_BDVER2_M32: #define __XOP__ 1 | |
2614 // CHECK_BDVER2_M32: #define __XSAVE__ 1 | |
2615 // CHECK_BDVER2_M32: #define __bdver2 1 | |
2616 // CHECK_BDVER2_M32: #define __bdver2__ 1 | |
2617 // CHECK_BDVER2_M32: #define __i386 1 | |
2618 // CHECK_BDVER2_M32: #define __i386__ 1 | |
2619 // CHECK_BDVER2_M32: #define __tune_bdver2__ 1 | |
2620 | |
2621 // RUN: %clang -march=bdver2 -m64 -E -dM %s -o - 2>&1 \ | |
2622 // RUN: -target i386-unknown-linux \ | |
2623 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER2_M64 | |
2624 // CHECK_BDVER2_M64-NOT: #define __3dNOW_A__ 1 | |
2625 // CHECK_BDVER2_M64-NOT: #define __3dNOW__ 1 | |
2626 // CHECK_BDVER2_M64: #define __AES__ 1 | |
2627 // CHECK_BDVER2_M64: #define __AVX__ 1 | |
2628 // CHECK_BDVER2_M64: #define __BMI__ 1 | |
2629 // CHECK_BDVER2_M64: #define __F16C__ 1 | |
2630 // CHECK_BDVER2_M64: #define __FMA4__ 1 | |
2631 // CHECK_BDVER2_M64: #define __FMA__ 1 | |
2632 // CHECK_BDVER2_M64: #define __LWP__ 1 | |
2633 // CHECK_BDVER2_M64: #define __LZCNT__ 1 | |
2634 // CHECK_BDVER2_M64: #define __MMX__ 1 | |
2635 // CHECK_BDVER2_M64: #define __PCLMUL__ 1 | |
2636 // CHECK_BDVER2_M64: #define __POPCNT__ 1 | |
2637 // CHECK_BDVER2_M64: #define __PRFCHW__ 1 | |
2638 // CHECK_BDVER2_M64: #define __SSE2_MATH__ 1 | |
2639 // CHECK_BDVER2_M64: #define __SSE2__ 1 | |
2640 // CHECK_BDVER2_M64: #define __SSE3__ 1 | |
2641 // CHECK_BDVER2_M64: #define __SSE4A__ 1 | |
2642 // CHECK_BDVER2_M64: #define __SSE4_1__ 1 | |
2643 // CHECK_BDVER2_M64: #define __SSE4_2__ 1 | |
2644 // CHECK_BDVER2_M64: #define __SSE_MATH__ 1 | |
2645 // CHECK_BDVER2_M64: #define __SSE__ 1 | |
2646 // CHECK_BDVER2_M64: #define __SSSE3__ 1 | |
2647 // CHECK_BDVER2_M64: #define __TBM__ 1 | |
2648 // CHECK_BDVER2_M64: #define __XOP__ 1 | |
2649 // CHECK_BDVER2_M64: #define __XSAVE__ 1 | |
2650 // CHECK_BDVER2_M64: #define __amd64 1 | |
2651 // CHECK_BDVER2_M64: #define __amd64__ 1 | |
2652 // CHECK_BDVER2_M64: #define __bdver2 1 | |
2653 // CHECK_BDVER2_M64: #define __bdver2__ 1 | |
2654 // CHECK_BDVER2_M64: #define __tune_bdver2__ 1 | |
2655 // CHECK_BDVER2_M64: #define __x86_64 1 | |
2656 // CHECK_BDVER2_M64: #define __x86_64__ 1 | |
2657 | |
2658 // RUN: %clang -march=bdver3 -m32 -E -dM %s -o - 2>&1 \ | |
2659 // RUN: -target i386-unknown-linux \ | |
2660 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER3_M32 | |
2661 // CHECK_BDVER3_M32-NOT: #define __3dNOW_A__ 1 | |
2662 // CHECK_BDVER3_M32-NOT: #define __3dNOW__ 1 | |
2663 // CHECK_BDVER3_M32: #define __AES__ 1 | |
2664 // CHECK_BDVER3_M32: #define __AVX__ 1 | |
2665 // CHECK_BDVER3_M32: #define __BMI__ 1 | |
2666 // CHECK_BDVER3_M32: #define __F16C__ 1 | |
2667 // CHECK_BDVER3_M32: #define __FMA4__ 1 | |
2668 // CHECK_BDVER3_M32: #define __FMA__ 1 | |
2669 // CHECK_BDVER3_M32: #define __FSGSBASE__ 1 | |
2670 // CHECK_BDVER3_M32: #define __LWP__ 1 | |
2671 // CHECK_BDVER3_M32: #define __LZCNT__ 1 | |
2672 // CHECK_BDVER3_M32: #define __MMX__ 1 | |
2673 // CHECK_BDVER3_M32: #define __PCLMUL__ 1 | |
2674 // CHECK_BDVER3_M32: #define __POPCNT__ 1 | |
2675 // CHECK_BDVER3_M32: #define __PRFCHW__ 1 | |
2676 // CHECK_BDVER3_M32: #define __SSE2_MATH__ 1 | |
2677 // CHECK_BDVER3_M32: #define __SSE2__ 1 | |
2678 // CHECK_BDVER3_M32: #define __SSE3__ 1 | |
2679 // CHECK_BDVER3_M32: #define __SSE4A__ 1 | |
2680 // CHECK_BDVER3_M32: #define __SSE4_1__ 1 | |
2681 // CHECK_BDVER3_M32: #define __SSE4_2__ 1 | |
2682 // CHECK_BDVER3_M32: #define __SSE_MATH__ 1 | |
2683 // CHECK_BDVER3_M32: #define __SSE__ 1 | |
2684 // CHECK_BDVER3_M32: #define __SSSE3__ 1 | |
2685 // CHECK_BDVER3_M32: #define __TBM__ 1 | |
2686 // CHECK_BDVER3_M32: #define __XOP__ 1 | |
2687 // CHECK_BDVER3_M32: #define __XSAVEOPT__ 1 | |
2688 // CHECK_BDVER3_M32: #define __XSAVE__ 1 | |
2689 // CHECK_BDVER3_M32: #define __bdver3 1 | |
2690 // CHECK_BDVER3_M32: #define __bdver3__ 1 | |
2691 // CHECK_BDVER3_M32: #define __i386 1 | |
2692 // CHECK_BDVER3_M32: #define __i386__ 1 | |
2693 // CHECK_BDVER3_M32: #define __tune_bdver3__ 1 | |
2694 | |
2695 // RUN: %clang -march=bdver3 -m64 -E -dM %s -o - 2>&1 \ | |
2696 // RUN: -target i386-unknown-linux \ | |
2697 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER3_M64 | |
2698 // CHECK_BDVER3_M64-NOT: #define __3dNOW_A__ 1 | |
2699 // CHECK_BDVER3_M64-NOT: #define __3dNOW__ 1 | |
2700 // CHECK_BDVER3_M64: #define __AES__ 1 | |
2701 // CHECK_BDVER3_M64: #define __AVX__ 1 | |
2702 // CHECK_BDVER3_M64: #define __BMI__ 1 | |
2703 // CHECK_BDVER3_M64: #define __F16C__ 1 | |
2704 // CHECK_BDVER3_M64: #define __FMA4__ 1 | |
2705 // CHECK_BDVER3_M64: #define __FMA__ 1 | |
2706 // CHECK_BDVER3_M64: #define __FSGSBASE__ 1 | |
2707 // CHECK_BDVER3_M64: #define __LWP__ 1 | |
2708 // CHECK_BDVER3_M64: #define __LZCNT__ 1 | |
2709 // CHECK_BDVER3_M64: #define __MMX__ 1 | |
2710 // CHECK_BDVER3_M64: #define __PCLMUL__ 1 | |
2711 // CHECK_BDVER3_M64: #define __POPCNT__ 1 | |
2712 // CHECK_BDVER3_M64: #define __PRFCHW__ 1 | |
2713 // CHECK_BDVER3_M64: #define __SSE2_MATH__ 1 | |
2714 // CHECK_BDVER3_M64: #define __SSE2__ 1 | |
2715 // CHECK_BDVER3_M64: #define __SSE3__ 1 | |
2716 // CHECK_BDVER3_M64: #define __SSE4A__ 1 | |
2717 // CHECK_BDVER3_M64: #define __SSE4_1__ 1 | |
2718 // CHECK_BDVER3_M64: #define __SSE4_2__ 1 | |
2719 // CHECK_BDVER3_M64: #define __SSE_MATH__ 1 | |
2720 // CHECK_BDVER3_M64: #define __SSE__ 1 | |
2721 // CHECK_BDVER3_M64: #define __SSSE3__ 1 | |
2722 // CHECK_BDVER3_M64: #define __TBM__ 1 | |
2723 // CHECK_BDVER3_M64: #define __XOP__ 1 | |
2724 // CHECK_BDVER3_M64: #define __XSAVEOPT__ 1 | |
2725 // CHECK_BDVER3_M64: #define __XSAVE__ 1 | |
2726 // CHECK_BDVER3_M64: #define __amd64 1 | |
2727 // CHECK_BDVER3_M64: #define __amd64__ 1 | |
2728 // CHECK_BDVER3_M64: #define __bdver3 1 | |
2729 // CHECK_BDVER3_M64: #define __bdver3__ 1 | |
2730 // CHECK_BDVER3_M64: #define __tune_bdver3__ 1 | |
2731 // CHECK_BDVER3_M64: #define __x86_64 1 | |
2732 // CHECK_BDVER3_M64: #define __x86_64__ 1 | |
2733 | |
2734 // RUN: %clang -march=bdver4 -m32 -E -dM %s -o - 2>&1 \ | |
2735 // RUN: -target i386-unknown-linux \ | |
2736 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER4_M32 | |
2737 // CHECK_BDVER4_M32-NOT: #define __3dNOW_A__ 1 | |
2738 // CHECK_BDVER4_M32-NOT: #define __3dNOW__ 1 | |
2739 // CHECK_BDVER4_M32: #define __AES__ 1 | |
2740 // CHECK_BDVER4_M32: #define __AVX2__ 1 | |
2741 // CHECK_BDVER4_M32: #define __AVX__ 1 | |
2742 // CHECK_BDVER4_M32: #define __BMI2__ 1 | |
2743 // CHECK_BDVER4_M32: #define __BMI__ 1 | |
2744 // CHECK_BDVER4_M32: #define __F16C__ 1 | |
2745 // CHECK_BDVER4_M32: #define __FMA4__ 1 | |
2746 // CHECK_BDVER4_M32: #define __FMA__ 1 | |
2747 // CHECK_BDVER4_M32: #define __FSGSBASE__ 1 | |
2748 // CHECK_BDVER4_M32: #define __LWP__ 1 | |
2749 // CHECK_BDVER4_M32: #define __LZCNT__ 1 | |
2750 // CHECK_BDVER4_M32: #define __MMX__ 1 | |
2751 // CHECK_BDVER4_M32: #define __PCLMUL__ 1 | |
2752 // CHECK_BDVER4_M32: #define __POPCNT__ 1 | |
2753 // CHECK_BDVER4_M32: #define __PRFCHW__ 1 | |
2754 // CHECK_BDVER4_M32: #define __SSE2_MATH__ 1 | |
2755 // CHECK_BDVER4_M32: #define __SSE2__ 1 | |
2756 // CHECK_BDVER4_M32: #define __SSE3__ 1 | |
2757 // CHECK_BDVER4_M32: #define __SSE4A__ 1 | |
2758 // CHECK_BDVER4_M32: #define __SSE4_1__ 1 | |
2759 // CHECK_BDVER4_M32: #define __SSE4_2__ 1 | |
2760 // CHECK_BDVER4_M32: #define __SSE_MATH__ 1 | |
2761 // CHECK_BDVER4_M32: #define __SSE__ 1 | |
2762 // CHECK_BDVER4_M32: #define __SSSE3__ 1 | |
2763 // CHECK_BDVER4_M32: #define __TBM__ 1 | |
2764 // CHECK_BDVER4_M32: #define __XOP__ 1 | |
2765 // CHECK_BDVER4_M32: #define __XSAVE__ 1 | |
2766 // CHECK_BDVER4_M32: #define __bdver4 1 | |
2767 // CHECK_BDVER4_M32: #define __bdver4__ 1 | |
2768 // CHECK_BDVER4_M32: #define __i386 1 | |
2769 // CHECK_BDVER4_M32: #define __i386__ 1 | |
2770 // CHECK_BDVER4_M32: #define __tune_bdver4__ 1 | |
2771 | |
2772 // RUN: %clang -march=bdver4 -m64 -E -dM %s -o - 2>&1 \ | |
2773 // RUN: -target i386-unknown-linux \ | |
2774 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER4_M64 | |
2775 // CHECK_BDVER4_M64-NOT: #define __3dNOW_A__ 1 | |
2776 // CHECK_BDVER4_M64-NOT: #define __3dNOW__ 1 | |
2777 // CHECK_BDVER4_M64: #define __AES__ 1 | |
2778 // CHECK_BDVER4_M64: #define __AVX2__ 1 | |
2779 // CHECK_BDVER4_M64: #define __AVX__ 1 | |
2780 // CHECK_BDVER4_M64: #define __BMI2__ 1 | |
2781 // CHECK_BDVER4_M64: #define __BMI__ 1 | |
2782 // CHECK_BDVER4_M64: #define __F16C__ 1 | |
2783 // CHECK_BDVER4_M64: #define __FMA4__ 1 | |
2784 // CHECK_BDVER4_M64: #define __FMA__ 1 | |
2785 // CHECK_BDVER4_M64: #define __FSGSBASE__ 1 | |
2786 // CHECK_BDVER4_M64: #define __LWP__ 1 | |
2787 // CHECK_BDVER4_M64: #define __LZCNT__ 1 | |
2788 // CHECK_BDVER4_M64: #define __MMX__ 1 | |
2789 // CHECK_BDVER4_M64: #define __PCLMUL__ 1 | |
2790 // CHECK_BDVER4_M64: #define __POPCNT__ 1 | |
2791 // CHECK_BDVER4_M64: #define __PRFCHW__ 1 | |
2792 // CHECK_BDVER4_M64: #define __SSE2_MATH__ 1 | |
2793 // CHECK_BDVER4_M64: #define __SSE2__ 1 | |
2794 // CHECK_BDVER4_M64: #define __SSE3__ 1 | |
2795 // CHECK_BDVER4_M64: #define __SSE4A__ 1 | |
2796 // CHECK_BDVER4_M64: #define __SSE4_1__ 1 | |
2797 // CHECK_BDVER4_M64: #define __SSE4_2__ 1 | |
2798 // CHECK_BDVER4_M64: #define __SSE_MATH__ 1 | |
2799 // CHECK_BDVER4_M64: #define __SSE__ 1 | |
2800 // CHECK_BDVER4_M64: #define __SSSE3__ 1 | |
2801 // CHECK_BDVER4_M64: #define __TBM__ 1 | |
2802 // CHECK_BDVER4_M64: #define __XOP__ 1 | |
2803 // CHECK_BDVER4_M64: #define __XSAVE__ 1 | |
2804 // CHECK_BDVER4_M64: #define __amd64 1 | |
2805 // CHECK_BDVER4_M64: #define __amd64__ 1 | |
2806 // CHECK_BDVER4_M64: #define __bdver4 1 | |
2807 // CHECK_BDVER4_M64: #define __bdver4__ 1 | |
2808 // CHECK_BDVER4_M64: #define __tune_bdver4__ 1 | |
2809 // CHECK_BDVER4_M64: #define __x86_64 1 | |
2810 // CHECK_BDVER4_M64: #define __x86_64__ 1 | |
2811 | |
2812 // RUN: %clang -march=znver1 -m32 -E -dM %s -o - 2>&1 \ | |
2813 // RUN: -target i386-unknown-linux \ | |
2814 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER1_M32 | |
2815 // CHECK_ZNVER1_M32-NOT: #define __3dNOW_A__ 1 | |
2816 // CHECK_ZNVER1_M32-NOT: #define __3dNOW__ 1 | |
2817 // CHECK_ZNVER1_M32: #define __ADX__ 1 | |
2818 // CHECK_ZNVER1_M32: #define __AES__ 1 | |
2819 // CHECK_ZNVER1_M32: #define __AVX2__ 1 | |
2820 // CHECK_ZNVER1_M32: #define __AVX__ 1 | |
2821 // CHECK_ZNVER1_M32: #define __BMI2__ 1 | |
2822 // CHECK_ZNVER1_M32: #define __BMI__ 1 | |
2823 // CHECK_ZNVER1_M32: #define __CLFLUSHOPT__ 1 | |
2824 // CHECK_ZNVER1_M32: #define __CLZERO__ 1 | |
2825 // CHECK_ZNVER1_M32: #define __F16C__ 1 | |
2826 // CHECK_ZNVER1_M32: #define __FMA__ 1 | |
2827 // CHECK_ZNVER1_M32: #define __FSGSBASE__ 1 | |
2828 // CHECK_ZNVER1_M32: #define __LZCNT__ 1 | |
2829 // CHECK_ZNVER1_M32: #define __MMX__ 1 | |
2830 // CHECK_ZNVER1_M32: #define __MOVBE__ 1 | |
2831 // CHECK_ZNVER1_M32: #define __PCLMUL__ 1 | |
2832 // CHECK_ZNVER1_M32: #define __POPCNT__ 1 | |
2833 // CHECK_ZNVER1_M32: #define __PRFCHW__ 1 | |
2834 // CHECK_ZNVER1_M32: #define __RDRND__ 1 | |
2835 // CHECK_ZNVER1_M32: #define __RDSEED__ 1 | |
2836 // CHECK_ZNVER1_M32: #define __SHA__ 1 | |
2837 // CHECK_ZNVER1_M32: #define __SSE2_MATH__ 1 | |
2838 // CHECK_ZNVER1_M32: #define __SSE2__ 1 | |
2839 // CHECK_ZNVER1_M32: #define __SSE3__ 1 | |
2840 // CHECK_ZNVER1_M32: #define __SSE4A__ 1 | |
2841 // CHECK_ZNVER1_M32: #define __SSE4_1__ 1 | |
2842 // CHECK_ZNVER1_M32: #define __SSE4_2__ 1 | |
2843 // CHECK_ZNVER1_M32: #define __SSE_MATH__ 1 | |
2844 // CHECK_ZNVER1_M32: #define __SSE__ 1 | |
2845 // CHECK_ZNVER1_M32: #define __SSSE3__ 1 | |
2846 // CHECK_ZNVER1_M32: #define __XSAVEC__ 1 | |
2847 // CHECK_ZNVER1_M32: #define __XSAVEOPT__ 1 | |
2848 // CHECK_ZNVER1_M32: #define __XSAVES__ 1 | |
2849 // CHECK_ZNVER1_M32: #define __XSAVE__ 1 | |
2850 // CHECK_ZNVER1_M32: #define __i386 1 | |
2851 // CHECK_ZNVER1_M32: #define __i386__ 1 | |
2852 // CHECK_ZNVER1_M32: #define __tune_znver1__ 1 | |
2853 // CHECK_ZNVER1_M32: #define __znver1 1 | |
2854 // CHECK_ZNVER1_M32: #define __znver1__ 1 | |
2855 | |
2856 // RUN: %clang -march=znver1 -m64 -E -dM %s -o - 2>&1 \ | |
2857 // RUN: -target i386-unknown-linux \ | |
2858 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER1_M64 | |
2859 // CHECK_ZNVER1_M64-NOT: #define __3dNOW_A__ 1 | |
2860 // CHECK_ZNVER1_M64-NOT: #define __3dNOW__ 1 | |
2861 // CHECK_ZNVER1_M64: #define __ADX__ 1 | |
2862 // CHECK_ZNVER1_M64: #define __AES__ 1 | |
2863 // CHECK_ZNVER1_M64: #define __AVX2__ 1 | |
2864 // CHECK_ZNVER1_M64: #define __AVX__ 1 | |
2865 // CHECK_ZNVER1_M64: #define __BMI2__ 1 | |
2866 // CHECK_ZNVER1_M64: #define __BMI__ 1 | |
2867 // CHECK_ZNVER1_M64: #define __CLFLUSHOPT__ 1 | |
2868 // CHECK_ZNVER1_M64: #define __CLZERO__ 1 | |
2869 // CHECK_ZNVER1_M64: #define __F16C__ 1 | |
2870 // CHECK_ZNVER1_M64: #define __FMA__ 1 | |
2871 // CHECK_ZNVER1_M64: #define __FSGSBASE__ 1 | |
2872 // CHECK_ZNVER1_M64: #define __LZCNT__ 1 | |
2873 // CHECK_ZNVER1_M64: #define __MMX__ 1 | |
2874 // CHECK_ZNVER1_M64: #define __MOVBE__ 1 | |
2875 // CHECK_ZNVER1_M64: #define __PCLMUL__ 1 | |
2876 // CHECK_ZNVER1_M64: #define __POPCNT__ 1 | |
2877 // CHECK_ZNVER1_M64: #define __PRFCHW__ 1 | |
2878 // CHECK_ZNVER1_M64: #define __RDRND__ 1 | |
2879 // CHECK_ZNVER1_M64: #define __RDSEED__ 1 | |
2880 // CHECK_ZNVER1_M64: #define __SHA__ 1 | |
2881 // CHECK_ZNVER1_M64: #define __SSE2_MATH__ 1 | |
2882 // CHECK_ZNVER1_M64: #define __SSE2__ 1 | |
2883 // CHECK_ZNVER1_M64: #define __SSE3__ 1 | |
2884 // CHECK_ZNVER1_M64: #define __SSE4A__ 1 | |
2885 // CHECK_ZNVER1_M64: #define __SSE4_1__ 1 | |
2886 // CHECK_ZNVER1_M64: #define __SSE4_2__ 1 | |
2887 // CHECK_ZNVER1_M64: #define __SSE_MATH__ 1 | |
2888 // CHECK_ZNVER1_M64: #define __SSE__ 1 | |
2889 // CHECK_ZNVER1_M64: #define __SSSE3__ 1 | |
2890 // CHECK_ZNVER1_M64: #define __XSAVEC__ 1 | |
2891 // CHECK_ZNVER1_M64: #define __XSAVEOPT__ 1 | |
2892 // CHECK_ZNVER1_M64: #define __XSAVES__ 1 | |
2893 // CHECK_ZNVER1_M64: #define __XSAVE__ 1 | |
2894 // CHECK_ZNVER1_M64: #define __amd64 1 | |
2895 // CHECK_ZNVER1_M64: #define __amd64__ 1 | |
2896 // CHECK_ZNVER1_M64: #define __tune_znver1__ 1 | |
2897 // CHECK_ZNVER1_M64: #define __x86_64 1 | |
2898 // CHECK_ZNVER1_M64: #define __x86_64__ 1 | |
2899 // CHECK_ZNVER1_M64: #define __znver1 1 | |
2900 // CHECK_ZNVER1_M64: #define __znver1__ 1 | |
2901 | |
2902 // RUN: %clang -march=znver2 -m32 -E -dM %s -o - 2>&1 \ | |
2903 // RUN: -target i386-unknown-linux \ | |
2904 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER2_M32 | |
2905 // CHECK_ZNVER2_M32-NOT: #define __3dNOW_A__ 1 | |
2906 // CHECK_ZNVER2_M32-NOT: #define __3dNOW__ 1 | |
2907 // CHECK_ZNVER2_M32: #define __ADX__ 1 | |
2908 // CHECK_ZNVER2_M32: #define __AES__ 1 | |
2909 // CHECK_ZNVER2_M32: #define __AVX2__ 1 | |
2910 // CHECK_ZNVER2_M32: #define __AVX__ 1 | |
2911 // CHECK_ZNVER2_M32: #define __BMI2__ 1 | |
2912 // CHECK_ZNVER2_M32: #define __BMI__ 1 | |
2913 // CHECK_ZNVER2_M32: #define __CLFLUSHOPT__ 1 | |
2914 // CHECK_ZNVER2_M32: #define __CLWB__ 1 | |
2915 // CHECK_ZNVER2_M32: #define __CLZERO__ 1 | |
2916 // CHECK_ZNVER2_M32: #define __F16C__ 1 | |
2917 // CHECK_ZNVER2_M32: #define __FMA__ 1 | |
2918 // CHECK_ZNVER2_M32: #define __FSGSBASE__ 1 | |
2919 // CHECK_ZNVER2_M32: #define __LZCNT__ 1 | |
2920 // CHECK_ZNVER2_M32: #define __MMX__ 1 | |
2921 // CHECK_ZNVER2_M32: #define __PCLMUL__ 1 | |
2922 // CHECK_ZNVER2_M32: #define __POPCNT__ 1 | |
2923 // CHECK_ZNVER2_M32: #define __PRFCHW__ 1 | |
2924 // CHECK_ZNVER2_M32: #define __RDPID__ 1 | |
2925 // CHECK_ZNVER2_M32: #define __RDRND__ 1 | |
2926 // CHECK_ZNVER2_M32: #define __RDSEED__ 1 | |
2927 // CHECK_ZNVER2_M32: #define __SHA__ 1 | |
2928 // CHECK_ZNVER2_M32: #define __SSE2_MATH__ 1 | |
2929 // CHECK_ZNVER2_M32: #define __SSE2__ 1 | |
2930 // CHECK_ZNVER2_M32: #define __SSE3__ 1 | |
2931 // CHECK_ZNVER2_M32: #define __SSE4A__ 1 | |
2932 // CHECK_ZNVER2_M32: #define __SSE4_1__ 1 | |
2933 // CHECK_ZNVER2_M32: #define __SSE4_2__ 1 | |
2934 // CHECK_ZNVER2_M32: #define __SSE_MATH__ 1 | |
2935 // CHECK_ZNVER2_M32: #define __SSE__ 1 | |
2936 // CHECK_ZNVER2_M32: #define __SSSE3__ 1 | |
2937 // CHECK_ZNVER2_M32: #define __WBNOINVD__ 1 | |
2938 // CHECK_ZNVER2_M32: #define __XSAVEC__ 1 | |
2939 // CHECK_ZNVER2_M32: #define __XSAVEOPT__ 1 | |
2940 // CHECK_ZNVER2_M32: #define __XSAVES__ 1 | |
2941 // CHECK_ZNVER2_M32: #define __XSAVE__ 1 | |
2942 // CHECK_ZNVER2_M32: #define __i386 1 | |
2943 // CHECK_ZNVER2_M32: #define __i386__ 1 | |
2944 // CHECK_ZNVER2_M32: #define __tune_znver2__ 1 | |
2945 // CHECK_ZNVER2_M32: #define __znver2 1 | |
2946 // CHECK_ZNVER2_M32: #define __znver2__ 1 | |
2947 | |
2948 // RUN: %clang -march=znver2 -m64 -E -dM %s -o - 2>&1 \ | |
2949 // RUN: -target i386-unknown-linux \ | |
2950 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER2_M64 | |
2951 // CHECK_ZNVER2_M64-NOT: #define __3dNOW_A__ 1 | |
2952 // CHECK_ZNVER2_M64-NOT: #define __3dNOW__ 1 | |
2953 // CHECK_ZNVER2_M64: #define __ADX__ 1 | |
2954 // CHECK_ZNVER2_M64: #define __AES__ 1 | |
2955 // CHECK_ZNVER2_M64: #define __AVX2__ 1 | |
2956 // CHECK_ZNVER2_M64: #define __AVX__ 1 | |
2957 // CHECK_ZNVER2_M64: #define __BMI2__ 1 | |
2958 // CHECK_ZNVER2_M64: #define __BMI__ 1 | |
2959 // CHECK_ZNVER2_M64: #define __CLFLUSHOPT__ 1 | |
2960 // CHECK_ZNVER2_M64: #define __CLWB__ 1 | |
2961 // CHECK_ZNVER2_M64: #define __CLZERO__ 1 | |
2962 // CHECK_ZNVER2_M64: #define __F16C__ 1 | |
2963 // CHECK_ZNVER2_M64: #define __FMA__ 1 | |
2964 // CHECK_ZNVER2_M64: #define __FSGSBASE__ 1 | |
2965 // CHECK_ZNVER2_M64: #define __LZCNT__ 1 | |
2966 // CHECK_ZNVER2_M64: #define __MMX__ 1 | |
2967 // CHECK_ZNVER2_M64: #define __PCLMUL__ 1 | |
2968 // CHECK_ZNVER2_M64: #define __POPCNT__ 1 | |
2969 // CHECK_ZNVER2_M64: #define __PRFCHW__ 1 | |
2970 // CHECK_ZNVER2_M64: #define __RDPID__ 1 | |
2971 // CHECK_ZNVER2_M64: #define __RDRND__ 1 | |
2972 // CHECK_ZNVER2_M64: #define __RDSEED__ 1 | |
2973 // CHECK_ZNVER2_M64: #define __SHA__ 1 | |
2974 // CHECK_ZNVER2_M64: #define __SSE2_MATH__ 1 | |
2975 // CHECK_ZNVER2_M64: #define __SSE2__ 1 | |
2976 // CHECK_ZNVER2_M64: #define __SSE3__ 1 | |
2977 // CHECK_ZNVER2_M64: #define __SSE4A__ 1 | |
2978 // CHECK_ZNVER2_M64: #define __SSE4_1__ 1 | |
2979 // CHECK_ZNVER2_M64: #define __SSE4_2__ 1 | |
2980 // CHECK_ZNVER2_M64: #define __SSE_MATH__ 1 | |
2981 // CHECK_ZNVER2_M64: #define __SSE__ 1 | |
2982 // CHECK_ZNVER2_M64: #define __SSSE3__ 1 | |
2983 // CHECK_ZNVER2_M64: #define __WBNOINVD__ 1 | |
2984 // CHECK_ZNVER2_M64: #define __XSAVEC__ 1 | |
2985 // CHECK_ZNVER2_M64: #define __XSAVEOPT__ 1 | |
2986 // CHECK_ZNVER2_M64: #define __XSAVES__ 1 | |
2987 // CHECK_ZNVER2_M64: #define __XSAVE__ 1 | |
2988 // CHECK_ZNVER2_M64: #define __amd64 1 | |
2989 // CHECK_ZNVER2_M64: #define __amd64__ 1 | |
2990 // CHECK_ZNVER2_M64: #define __tune_znver2__ 1 | |
2991 // CHECK_ZNVER2_M64: #define __x86_64 1 | |
2992 // CHECK_ZNVER2_M64: #define __x86_64__ 1 | |
2993 // CHECK_ZNVER2_M64: #define __znver2 1 | |
2994 // CHECK_ZNVER2_M64: #define __znver2__ 1 | |
2995 | |
2996 // End X86/GCC/Linux tests ------------------ | |
2997 | |
2998 // Begin PPC/GCC/Linux tests ---------------- | |
2999 // Check that VSX also turns on altivec. | |
3000 // RUN: %clang -mvsx -E -dM %s -o - 2>&1 \ | |
3001 // RUN: -target powerpc-unknown-linux \ | |
3002 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_VSX_M32 | |
3003 // CHECK_PPC_VSX_M32: #define __ALTIVEC__ 1 | |
3004 // CHECK_PPC_VSX_M32: #define __VSX__ 1 | |
3005 | |
3006 // RUN: %clang -mvsx -E -dM %s -o - 2>&1 \ | |
3007 // RUN: -target powerpc64-unknown-linux \ | |
3008 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_VSX_M64 | |
3009 // CHECK_PPC_VSX_M64: #define __VSX__ 1 | |
3010 | |
3011 // RUN: %clang -mpower8-vector -E -dM %s -o - 2>&1 \ | |
3012 // RUN: -target powerpc64-unknown-linux \ | |
3013 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_POWER8_VECTOR_M64 | |
3014 // CHECK_PPC_POWER8_VECTOR_M64: #define __POWER8_VECTOR__ 1 | |
3015 | |
3016 // RUN: %clang -mpower9-vector -E -dM %s -o - 2>&1 \ | |
3017 // RUN: -target powerpc64-unknown-linux \ | |
3018 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_POWER9_VECTOR_M64 | |
3019 // CHECK_PPC_POWER9_VECTOR_M64: #define __POWER9_VECTOR__ 1 | |
3020 | |
3021 // RUN: %clang -mcrypto -E -dM %s -o - 2>&1 \ | |
3022 // RUN: -target powerpc64-unknown-linux \ | |
3023 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_CRYPTO_M64 | |
3024 // CHECK_PPC_CRYPTO_M64: #define __CRYPTO__ 1 | |
3025 | |
3026 // HTM is available on power8 or later which includes all of powerpc64le as an | |
3027 // ABI choice. Test that, the cpus, and the option. | |
3028 // RUN: %clang -mhtm -E -dM %s -o - 2>&1 \ | |
3029 // RUN: -target powerpc64-unknown-linux \ | |
3030 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_HTM | |
3031 // RUN: %clang -E -dM %s -o - 2>&1 \ | |
3032 // RUN: -target powerpc64le-unknown-linux \ | |
3033 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_HTM | |
3034 // RUN: %clang -mcpu=pwr8 -E -dM %s -o - 2>&1 \ | |
3035 // RUN: -target powerpc64-unknown-linux \ | |
3036 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_HTM | |
3037 // RUN: %clang -mcpu=pwr9 -E -dM %s -o - 2>&1 \ | |
3038 // RUN: -target powerpc64-unknown-linux \ | |
3039 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_HTM | |
3040 // CHECK_PPC_HTM: #define __HTM__ 1 | |
3041 | |
3042 // RUN: %clang -mcpu=ppc64 -E -dM %s -o - 2>&1 \ | |
3043 // RUN: -target powerpc64-unknown-unknown \ | |
3044 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_GCC_ATOMICS | |
3045 // RUN: %clang -mcpu=pwr8 -E -dM %s -o - 2>&1 \ | |
3046 // RUN: -target powerpc64-unknown-unknown \ | |
3047 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_GCC_ATOMICS | |
3048 // RUN: %clang -E -dM %s -o - 2>&1 \ | |
3049 // RUN: -target powerpc64le-unknown-linux \ | |
3050 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_GCC_ATOMICS | |
3051 // CHECK_PPC_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1 | |
3052 // CHECK_PPC_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1 | |
3053 // CHECK_PPC_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1 | |
3054 // CHECK_PPC_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1 | |
3055 | |
3056 // End PPC/GCC/Linux tests ------------------ | |
3057 | |
3058 // Begin Sparc/GCC/Linux tests ---------------- | |
3059 | |
3060 // RUN: %clang -E -dM %s -o - 2>&1 \ | |
3061 // RUN: -target sparc-unknown-linux \ | |
3062 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPARC | |
3063 // CHECK_SPARC: #define __BIG_ENDIAN__ 1 | |
3064 // CHECK_SPARC: #define __sparc 1 | |
3065 // CHECK_SPARC: #define __sparc__ 1 | |
3066 // CHECK_SPARC-NOT: #define __sparcv9 1 | |
3067 // CHECK_SPARC-NOT: #define __sparcv9__ 1 | |
3068 // CHECK_SPARC: #define __sparcv8 1 | |
3069 // CHECK_SPARC-NOT: #define __sparcv9 1 | |
3070 // CHECK_SPARC-NOT: #define __sparcv9__ 1 | |
3071 | |
3072 // RUN: %clang -mcpu=v9 -E -dM %s -o - 2>&1 \ | |
3073 // RUN: -target sparc-unknown-linux \ | |
3074 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPARC-V9 | |
3075 // CHECK_SPARC-V9-NOT: #define __sparcv8 1 | |
3076 // CHECK_SPARC-V9: #define __sparc_v9__ 1 | |
3077 // CHECK_SPARC-V9: #define __sparcv9 1 | |
3078 // CHECK_SPARC-V9-NOT: #define __sparcv8 1 | |
3079 | |
3080 // RUN: %clang -E -dM %s -o - 2>&1 \ | |
3081 // RUN: -target sparcel-unknown-linux \ | |
3082 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPARCEL | |
3083 // RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=myriad2 2>&1 \ | |
3084 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-2 \ | |
3085 // RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2 | |
3086 // RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=myriad2.1 2>&1 \ | |
3087 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-1 \ | |
3088 // RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2 | |
3089 // RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=myriad2.2 2>&1 \ | |
3090 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-2 \ | |
3091 // RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2 | |
3092 // RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=myriad2.3 2>&1 \ | |
3093 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-3 \ | |
3094 // RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2 | |
3095 // RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2100 2>&1 \ | |
3096 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-1 \ | |
3097 // RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2 | |
3098 // RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2150 2>&1 \ | |
3099 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-2 \ | |
3100 // RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2 | |
3101 // RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2155 2>&1 \ | |
3102 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-2 \ | |
3103 // RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2 | |
3104 // RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2450 2>&1 \ | |
3105 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-2 \ | |
3106 // RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2 | |
3107 // RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2455 2>&1 \ | |
3108 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-2 \ | |
3109 // RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2 | |
3110 // RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2x5x 2>&1 \ | |
3111 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-2 \ | |
3112 // RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2 | |
3113 // RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2080 2>&1 \ | |
3114 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-3 \ | |
3115 // RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2 | |
3116 // RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2085 2>&1 \ | |
3117 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-3 \ | |
3118 // RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2 | |
3119 // RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2480 2>&1 \ | |
3120 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-3 \ | |
3121 // RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2 | |
3122 // RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2485 2>&1 \ | |
3123 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-3 \ | |
3124 // RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2 | |
3125 // RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2x8x 2>&1 \ | |
3126 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-3 \ | |
3127 // RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2 | |
3128 // CHECK_SPARCEL: #define __LITTLE_ENDIAN__ 1 | |
3129 // CHECK_MYRIAD2: #define __leon__ 1 | |
3130 // CHECK_MYRIAD2-1: #define __myriad2 1 | |
3131 // CHECK_MYRIAD2-1: #define __myriad2__ 1 | |
3132 // CHECK_MYRIAD2-2: #define __ma2x5x 1 | |
3133 // CHECK_MYRIAD2-2: #define __ma2x5x__ 1 | |
3134 // CHECK_MYRIAD2-2: #define __myriad2 2 | |
3135 // CHECK_MYRIAD2-2: #define __myriad2__ 2 | |
3136 // CHECK_MYRIAD2-3: #define __ma2x8x 1 | |
3137 // CHECK_MYRIAD2-3: #define __ma2x8x__ 1 | |
3138 // CHECK_MYRIAD2-3: #define __myriad2 3 | |
3139 // CHECK_MYRIAD2-3: #define __myriad2__ 3 | |
3140 // CHECK_SPARCEL: #define __sparc 1 | |
3141 // CHECK_SPARCEL: #define __sparc__ 1 | |
3142 // CHECK_MYRIAD2: #define __sparc_v8__ 1 | |
3143 // CHECK_SPARCEL: #define __sparcv8 1 | |
3144 | |
3145 // RUN: %clang -E -dM %s -o - 2>&1 \ | |
3146 // RUN: -target sparcv9-unknown-linux \ | |
3147 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPARCV9 | |
3148 // CHECK_SPARCV9: #define __BIG_ENDIAN__ 1 | |
3149 // CHECK_SPARCV9: #define __sparc 1 | |
3150 // CHECK_SPARCV9: #define __sparc64__ 1 | |
3151 // CHECK_SPARCV9: #define __sparc__ 1 | |
3152 // CHECK_SPARCV9: #define __sparc_v9__ 1 | |
3153 // CHECK_SPARCV9: #define __sparcv9 1 | |
3154 // CHECK_SPARCV9: #define __sparcv9__ 1 | |
3155 | |
3156 // Begin SystemZ/GCC/Linux tests ---------------- | |
3157 | |
3158 // RUN: %clang -march=arch8 -E -dM %s -o - 2>&1 \ | |
3159 // RUN: -target s390x-unknown-linux \ | |
3160 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH8 | |
3161 // RUN: %clang -march=z10 -E -dM %s -o - 2>&1 \ | |
3162 // RUN: -target s390x-unknown-linux \ | |
3163 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH8 | |
3164 // CHECK_SYSTEMZ_ARCH8: #define __ARCH__ 8 | |
3165 // CHECK_SYSTEMZ_ARCH8: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1 | |
3166 // CHECK_SYSTEMZ_ARCH8: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1 | |
3167 // CHECK_SYSTEMZ_ARCH8: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1 | |
3168 // CHECK_SYSTEMZ_ARCH8: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1 | |
3169 // CHECK_SYSTEMZ_ARCH8: #define __LONG_DOUBLE_128__ 1 | |
3170 // CHECK_SYSTEMZ_ARCH8: #define __s390__ 1 | |
3171 // CHECK_SYSTEMZ_ARCH8: #define __s390x__ 1 | |
3172 // CHECK_SYSTEMZ_ARCH8: #define __zarch__ 1 | |
3173 | |
3174 // RUN: %clang -march=arch9 -E -dM %s -o - 2>&1 \ | |
3175 // RUN: -target s390x-unknown-linux \ | |
3176 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH9 | |
3177 // RUN: %clang -march=z196 -E -dM %s -o - 2>&1 \ | |
3178 // RUN: -target s390x-unknown-linux \ | |
3179 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH9 | |
3180 // CHECK_SYSTEMZ_ARCH9: #define __ARCH__ 9 | |
3181 // CHECK_SYSTEMZ_ARCH9: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1 | |
3182 // CHECK_SYSTEMZ_ARCH9: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1 | |
3183 // CHECK_SYSTEMZ_ARCH9: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1 | |
3184 // CHECK_SYSTEMZ_ARCH9: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1 | |
3185 // CHECK_SYSTEMZ_ARCH9: #define __LONG_DOUBLE_128__ 1 | |
3186 // CHECK_SYSTEMZ_ARCH9: #define __s390__ 1 | |
3187 // CHECK_SYSTEMZ_ARCH9: #define __s390x__ 1 | |
3188 // CHECK_SYSTEMZ_ARCH9: #define __zarch__ 1 | |
3189 | |
3190 // RUN: %clang -march=arch10 -E -dM %s -o - 2>&1 \ | |
3191 // RUN: -target s390x-unknown-linux \ | |
3192 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH10 | |
3193 // RUN: %clang -march=zEC12 -E -dM %s -o - 2>&1 \ | |
3194 // RUN: -target s390x-unknown-linux \ | |
3195 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH10 | |
3196 // CHECK_SYSTEMZ_ARCH10: #define __ARCH__ 10 | |
3197 // CHECK_SYSTEMZ_ARCH10: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1 | |
3198 // CHECK_SYSTEMZ_ARCH10: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1 | |
3199 // CHECK_SYSTEMZ_ARCH10: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1 | |
3200 // CHECK_SYSTEMZ_ARCH10: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1 | |
3201 // CHECK_SYSTEMZ_ARCH10: #define __HTM__ 1 | |
3202 // CHECK_SYSTEMZ_ARCH10: #define __LONG_DOUBLE_128__ 1 | |
3203 // CHECK_SYSTEMZ_ARCH10: #define __s390__ 1 | |
3204 // CHECK_SYSTEMZ_ARCH10: #define __s390x__ 1 | |
3205 // CHECK_SYSTEMZ_ARCH10: #define __zarch__ 1 | |
3206 | |
3207 // RUN: %clang -march=arch11 -E -dM %s -o - 2>&1 \ | |
3208 // RUN: -target s390x-unknown-linux \ | |
3209 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH11 | |
3210 // RUN: %clang -march=z13 -E -dM %s -o - 2>&1 \ | |
3211 // RUN: -target s390x-unknown-linux \ | |
3212 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH11 | |
3213 // CHECK_SYSTEMZ_ARCH11: #define __ARCH__ 11 | |
3214 // CHECK_SYSTEMZ_ARCH11: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1 | |
3215 // CHECK_SYSTEMZ_ARCH11: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1 | |
3216 // CHECK_SYSTEMZ_ARCH11: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1 | |
3217 // CHECK_SYSTEMZ_ARCH11: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1 | |
3218 // CHECK_SYSTEMZ_ARCH11: #define __HTM__ 1 | |
3219 // CHECK_SYSTEMZ_ARCH11: #define __LONG_DOUBLE_128__ 1 | |
3220 // CHECK_SYSTEMZ_ARCH11: #define __VX__ 1 | |
3221 // CHECK_SYSTEMZ_ARCH11: #define __s390__ 1 | |
3222 // CHECK_SYSTEMZ_ARCH11: #define __s390x__ 1 | |
3223 // CHECK_SYSTEMZ_ARCH11: #define __zarch__ 1 | |
3224 | |
3225 // RUN: %clang -march=arch12 -E -dM %s -o - 2>&1 \ | |
3226 // RUN: -target s390x-unknown-linux \ | |
3227 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH12 | |
3228 // RUN: %clang -march=z14 -E -dM %s -o - 2>&1 \ | |
3229 // RUN: -target s390x-unknown-linux \ | |
3230 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH12 | |
3231 // CHECK_SYSTEMZ_ARCH12: #define __ARCH__ 12 | |
3232 // CHECK_SYSTEMZ_ARCH12: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1 | |
3233 // CHECK_SYSTEMZ_ARCH12: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1 | |
3234 // CHECK_SYSTEMZ_ARCH12: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1 | |
3235 // CHECK_SYSTEMZ_ARCH12: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1 | |
3236 // CHECK_SYSTEMZ_ARCH12: #define __HTM__ 1 | |
3237 // CHECK_SYSTEMZ_ARCH12: #define __LONG_DOUBLE_128__ 1 | |
3238 // CHECK_SYSTEMZ_ARCH12: #define __VX__ 1 | |
3239 // CHECK_SYSTEMZ_ARCH12: #define __s390__ 1 | |
3240 // CHECK_SYSTEMZ_ARCH12: #define __s390x__ 1 | |
3241 // CHECK_SYSTEMZ_ARCH12: #define __zarch__ 1 | |
3242 | |
3243 // RUN: %clang -march=arch13 -E -dM %s -o - 2>&1 \ | |
3244 // RUN: -target s390x-unknown-linux \ | |
3245 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH13 | |
3246 // RUN: %clang -march=z15 -E -dM %s -o - 2>&1 \ | |
3247 // RUN: -target s390x-unknown-linux \ | |
3248 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH13 | |
3249 // CHECK_SYSTEMZ_ARCH13: #define __ARCH__ 13 | |
3250 // CHECK_SYSTEMZ_ARCH13: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1 | |
3251 // CHECK_SYSTEMZ_ARCH13: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1 | |
3252 // CHECK_SYSTEMZ_ARCH13: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1 | |
3253 // CHECK_SYSTEMZ_ARCH13: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1 | |
3254 // CHECK_SYSTEMZ_ARCH13: #define __HTM__ 1 | |
3255 // CHECK_SYSTEMZ_ARCH13: #define __LONG_DOUBLE_128__ 1 | |
3256 // CHECK_SYSTEMZ_ARCH13: #define __VX__ 1 | |
3257 // CHECK_SYSTEMZ_ARCH13: #define __s390__ 1 | |
3258 // CHECK_SYSTEMZ_ARCH13: #define __s390x__ 1 | |
3259 // CHECK_SYSTEMZ_ARCH13: #define __zarch__ 1 | |
3260 | |
3261 // RUN: %clang -mhtm -E -dM %s -o - 2>&1 \ | |
3262 // RUN: -target s390x-unknown-linux \ | |
3263 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_HTM | |
3264 // CHECK_SYSTEMZ_HTM: #define __HTM__ 1 | |
3265 | |
3266 // RUN: %clang -mvx -E -dM %s -o - 2>&1 \ | |
3267 // RUN: -target s390x-unknown-linux \ | |
3268 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_VX | |
3269 // CHECK_SYSTEMZ_VX: #define __VX__ 1 | |
3270 | |
3271 // RUN: %clang -fzvector -E -dM %s -o - 2>&1 \ | |
3272 // RUN: -target s390x-unknown-linux \ | |
3273 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ZVECTOR | |
3274 // RUN: %clang -mzvector -E -dM %s -o - 2>&1 \ | |
3275 // RUN: -target s390x-unknown-linux \ | |
3276 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ZVECTOR | |
3277 // CHECK_SYSTEMZ_ZVECTOR: #define __VEC__ 10303 | |
3278 | |
3279 // Begin amdgcn tests ---------------- | |
3280 | |
3281 // RUN: %clang -march=amdgcn -E -dM %s -o - 2>&1 \ | |
3282 // RUN: -target amdgcn-unknown-unknown \ | |
3283 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_AMDGCN | |
3284 // CHECK_AMDGCN: #define __AMDGCN__ 1 | |
3285 // CHECK_AMDGCN: #define __HAS_FMAF__ 1 | |
3286 // CHECK_AMDGCN: #define __HAS_FP64__ 1 | |
3287 // CHECK_AMDGCN: #define __HAS_LDEXPF__ 1 | |
3288 | |
3289 // Begin r600 tests ---------------- | |
3290 | |
3291 // RUN: %clang -march=amdgcn -E -dM %s -o - 2>&1 \ | |
3292 // RUN: -target r600-unknown-unknown \ | |
3293 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_R600 | |
3294 // CHECK_R600: #define __R600__ 1 | |
3295 // CHECK_R600-NOT: #define __HAS_FMAF__ 1 | |
3296 | |
3297 // RUN: %clang -march=amdgcn -mcpu=cypress -E -dM %s -o - 2>&1 \ | |
3298 // RUN: -target r600-unknown-unknown \ | |
3299 // RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_R600_FP64 | |
3300 // CHECK_R600_FP64-DAG: #define __R600__ 1 | |
3301 // CHECK_R600_FP64-DAG: #define __HAS_FMAF__ 1 |