• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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 %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 %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 %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 %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 %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 %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 %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 %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 %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 %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 %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 %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 %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 %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 %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 %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 %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 %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 %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 i386 1
160 // RUN: not %clang -march=i686 -m64 -E -dM %s -o - 2>&1 \
161 // RUN:     -target i386-unknown-linux \
162 // RUN:   | FileCheck %s -check-prefix=CHECK_I686_M64
163 // CHECK_I686_M64: error:
164 //
165 // RUN: %clang -march=pentiumpro -m32 -E -dM %s -o - 2>&1 \
166 // RUN:     -target i386-unknown-linux \
167 // RUN:   | FileCheck %s -check-prefix=CHECK_PENTIUMPRO_M32
168 // CHECK_PENTIUMPRO_M32: #define __i386 1
169 // CHECK_PENTIUMPRO_M32: #define __i386__ 1
170 // CHECK_PENTIUMPRO_M32: #define __i686 1
171 // CHECK_PENTIUMPRO_M32: #define __i686__ 1
172 // CHECK_PENTIUMPRO_M32: #define __pentiumpro 1
173 // CHECK_PENTIUMPRO_M32: #define __pentiumpro__ 1
174 // CHECK_PENTIUMPRO_M32: #define __tune_i686__ 1
175 // CHECK_PENTIUMPRO_M32: #define __tune_pentiumpro__ 1
176 // CHECK_PENTIUMPRO_M32: #define i386 1
177 // RUN: not %clang -march=pentiumpro -m64 -E -dM %s -o - 2>&1 \
178 // RUN:     -target i386-unknown-linux \
179 // RUN:   | FileCheck %s -check-prefix=CHECK_PENTIUMPRO_M64
180 // CHECK_PENTIUMPRO_M64: error:
181 //
182 // RUN: %clang -march=pentium2 -m32 -E -dM %s -o - 2>&1 \
183 // RUN:     -target i386-unknown-linux \
184 // RUN:   | FileCheck %s -check-prefix=CHECK_PENTIUM2_M32
185 // CHECK_PENTIUM2_M32: #define __MMX__ 1
186 // CHECK_PENTIUM2_M32: #define __i386 1
187 // CHECK_PENTIUM2_M32: #define __i386__ 1
188 // CHECK_PENTIUM2_M32: #define __i686 1
189 // CHECK_PENTIUM2_M32: #define __i686__ 1
190 // CHECK_PENTIUM2_M32: #define __pentiumpro 1
191 // CHECK_PENTIUM2_M32: #define __pentiumpro__ 1
192 // CHECK_PENTIUM2_M32: #define __tune_i686__ 1
193 // CHECK_PENTIUM2_M32: #define __tune_pentium2__ 1
194 // CHECK_PENTIUM2_M32: #define __tune_pentiumpro__ 1
195 // CHECK_PENTIUM2_M32: #define i386 1
196 // RUN: not %clang -march=pentium2 -m64 -E -dM %s -o - 2>&1 \
197 // RUN:     -target i386-unknown-linux \
198 // RUN:   | FileCheck %s -check-prefix=CHECK_PENTIUM2_M64
199 // CHECK_PENTIUM2_M64: error:
200 //
201 // RUN: %clang -march=pentium3 -m32 -E -dM %s -o - 2>&1 \
202 // RUN:     -target i386-unknown-linux \
203 // RUN:   | FileCheck %s -check-prefix=CHECK_PENTIUM3_M32
204 // CHECK_PENTIUM3_M32: #define __MMX__ 1
205 // CHECK_PENTIUM3_M32: #define __SSE__ 1
206 // CHECK_PENTIUM3_M32: #define __i386 1
207 // CHECK_PENTIUM3_M32: #define __i386__ 1
208 // CHECK_PENTIUM3_M32: #define __i686 1
209 // CHECK_PENTIUM3_M32: #define __i686__ 1
210 // CHECK_PENTIUM3_M32: #define __pentiumpro 1
211 // CHECK_PENTIUM3_M32: #define __pentiumpro__ 1
212 // CHECK_PENTIUM3_M32: #define __tune_i686__ 1
213 // CHECK_PENTIUM3_M32: #define __tune_pentium2__ 1
214 // CHECK_PENTIUM3_M32: #define __tune_pentium3__ 1
215 // CHECK_PENTIUM3_M32: #define __tune_pentiumpro__ 1
216 // CHECK_PENTIUM3_M32: #define i386 1
217 // RUN: not %clang -march=pentium3 -m64 -E -dM %s -o - 2>&1 \
218 // RUN:     -target i386-unknown-linux \
219 // RUN:   | FileCheck %s -check-prefix=CHECK_PENTIUM3_M64
220 // CHECK_PENTIUM3_M64: error:
221 //
222 // RUN: %clang -march=pentium3m -m32 -E -dM %s -o - 2>&1 \
223 // RUN:     -target i386-unknown-linux \
224 // RUN:   | FileCheck %s -check-prefix=CHECK_PENTIUM3M_M32
225 // CHECK_PENTIUM3M_M32: #define __MMX__ 1
226 // CHECK_PENTIUM3M_M32: #define __SSE__ 1
227 // CHECK_PENTIUM3M_M32: #define __i386 1
228 // CHECK_PENTIUM3M_M32: #define __i386__ 1
229 // CHECK_PENTIUM3M_M32: #define __i686 1
230 // CHECK_PENTIUM3M_M32: #define __i686__ 1
231 // CHECK_PENTIUM3M_M32: #define __pentiumpro 1
232 // CHECK_PENTIUM3M_M32: #define __pentiumpro__ 1
233 // CHECK_PENTIUM3M_M32: #define __tune_i686__ 1
234 // CHECK_PENTIUM3M_M32: #define __tune_pentiumpro__ 1
235 // CHECK_PENTIUM3M_M32: #define i386 1
236 // RUN: not %clang -march=pentium3m -m64 -E -dM %s -o - 2>&1 \
237 // RUN:     -target i386-unknown-linux \
238 // RUN:   | FileCheck %s -check-prefix=CHECK_PENTIUM3M_M64
239 // CHECK_PENTIUM3M_M64: error:
240 //
241 // RUN: %clang -march=pentium-m -m32 -E -dM %s -o - 2>&1 \
242 // RUN:     -target i386-unknown-linux \
243 // RUN:   | FileCheck %s -check-prefix=CHECK_PENTIUM_M_M32
244 // CHECK_PENTIUM_M_M32: #define __MMX__ 1
245 // CHECK_PENTIUM_M_M32: #define __SSE2__ 1
246 // CHECK_PENTIUM_M_M32: #define __SSE__ 1
247 // CHECK_PENTIUM_M_M32: #define __i386 1
248 // CHECK_PENTIUM_M_M32: #define __i386__ 1
249 // CHECK_PENTIUM_M_M32: #define __i686 1
250 // CHECK_PENTIUM_M_M32: #define __i686__ 1
251 // CHECK_PENTIUM_M_M32: #define __pentiumpro 1
252 // CHECK_PENTIUM_M_M32: #define __pentiumpro__ 1
253 // CHECK_PENTIUM_M_M32: #define __tune_i686__ 1
254 // CHECK_PENTIUM_M_M32: #define __tune_pentiumpro__ 1
255 // CHECK_PENTIUM_M_M32: #define i386 1
256 // RUN: not %clang -march=pentium-m -m64 -E -dM %s -o - 2>&1 \
257 // RUN:     -target i386-unknown-linux \
258 // RUN:   | FileCheck %s -check-prefix=CHECK_PENTIUM_M_M64
259 // CHECK_PENTIUM_M_M64: error:
260 //
261 // RUN: %clang -march=pentium4 -m32 -E -dM %s -o - 2>&1 \
262 // RUN:     -target i386-unknown-linux \
263 // RUN:   | FileCheck %s -check-prefix=CHECK_PENTIUM4_M32
264 // CHECK_PENTIUM4_M32: #define __MMX__ 1
265 // CHECK_PENTIUM4_M32: #define __SSE2__ 1
266 // CHECK_PENTIUM4_M32: #define __SSE__ 1
267 // CHECK_PENTIUM4_M32: #define __i386 1
268 // CHECK_PENTIUM4_M32: #define __i386__ 1
269 // CHECK_PENTIUM4_M32: #define __pentium4 1
270 // CHECK_PENTIUM4_M32: #define __pentium4__ 1
271 // CHECK_PENTIUM4_M32: #define __tune_pentium4__ 1
272 // CHECK_PENTIUM4_M32: #define i386 1
273 // RUN: not %clang -march=pentium4 -m64 -E -dM %s -o - 2>&1 \
274 // RUN:     -target i386-unknown-linux \
275 // RUN:   | FileCheck %s -check-prefix=CHECK_PENTIUM4_M64
276 // CHECK_PENTIUM4_M64: error:
277 //
278 // RUN: %clang -march=pentium4m -m32 -E -dM %s -o - 2>&1 \
279 // RUN:     -target i386-unknown-linux \
280 // RUN:   | FileCheck %s -check-prefix=CHECK_PENTIUM4M_M32
281 // CHECK_PENTIUM4M_M32: #define __MMX__ 1
282 // CHECK_PENTIUM4M_M32: #define __SSE2__ 1
283 // CHECK_PENTIUM4M_M32: #define __SSE__ 1
284 // CHECK_PENTIUM4M_M32: #define __i386 1
285 // CHECK_PENTIUM4M_M32: #define __i386__ 1
286 // CHECK_PENTIUM4M_M32: #define __pentium4 1
287 // CHECK_PENTIUM4M_M32: #define __pentium4__ 1
288 // CHECK_PENTIUM4M_M32: #define __tune_pentium4__ 1
289 // CHECK_PENTIUM4M_M32: #define i386 1
290 // RUN: not %clang -march=pentium4m -m64 -E -dM %s -o - 2>&1 \
291 // RUN:     -target i386-unknown-linux \
292 // RUN:   | FileCheck %s -check-prefix=CHECK_PENTIUM4M_M64
293 // CHECK_PENTIUM4M_M64: error:
294 //
295 // RUN: %clang -march=prescott -m32 -E -dM %s -o - 2>&1 \
296 // RUN:     -target i386-unknown-linux \
297 // RUN:   | FileCheck %s -check-prefix=CHECK_PRESCOTT_M32
298 // CHECK_PRESCOTT_M32: #define __MMX__ 1
299 // CHECK_PRESCOTT_M32: #define __SSE2__ 1
300 // CHECK_PRESCOTT_M32: #define __SSE3__ 1
301 // CHECK_PRESCOTT_M32: #define __SSE__ 1
302 // CHECK_PRESCOTT_M32: #define __i386 1
303 // CHECK_PRESCOTT_M32: #define __i386__ 1
304 // CHECK_PRESCOTT_M32: #define __nocona 1
305 // CHECK_PRESCOTT_M32: #define __nocona__ 1
306 // CHECK_PRESCOTT_M32: #define __tune_nocona__ 1
307 // CHECK_PRESCOTT_M32: #define i386 1
308 // RUN: not %clang -march=prescott -m64 -E -dM %s -o - 2>&1 \
309 // RUN:     -target i386-unknown-linux \
310 // RUN:   | FileCheck %s -check-prefix=CHECK_PRESCOTT_M64
311 // CHECK_PRESCOTT_M64: error:
312 //
313 // RUN: %clang -march=nocona -m32 -E -dM %s -o - 2>&1 \
314 // RUN:     -target i386-unknown-linux \
315 // RUN:   | FileCheck %s -check-prefix=CHECK_NOCONA_M32
316 // CHECK_NOCONA_M32: #define __MMX__ 1
317 // CHECK_NOCONA_M32: #define __SSE2__ 1
318 // CHECK_NOCONA_M32: #define __SSE3__ 1
319 // CHECK_NOCONA_M32: #define __SSE__ 1
320 // CHECK_NOCONA_M32: #define __i386 1
321 // CHECK_NOCONA_M32: #define __i386__ 1
322 // CHECK_NOCONA_M32: #define __nocona 1
323 // CHECK_NOCONA_M32: #define __nocona__ 1
324 // CHECK_NOCONA_M32: #define __tune_nocona__ 1
325 // CHECK_NOCONA_M32: #define i386 1
326 // RUN: %clang -march=nocona -m64 -E -dM %s -o - 2>&1 \
327 // RUN:     -target i386-unknown-linux \
328 // RUN:   | FileCheck %s -check-prefix=CHECK_NOCONA_M64
329 // CHECK_NOCONA_M64: #define __MMX__ 1
330 // CHECK_NOCONA_M64: #define __SSE2_MATH__ 1
331 // CHECK_NOCONA_M64: #define __SSE2__ 1
332 // CHECK_NOCONA_M64: #define __SSE3__ 1
333 // CHECK_NOCONA_M64: #define __SSE_MATH__ 1
334 // CHECK_NOCONA_M64: #define __SSE__ 1
335 // CHECK_NOCONA_M64: #define __amd64 1
336 // CHECK_NOCONA_M64: #define __amd64__ 1
337 // CHECK_NOCONA_M64: #define __nocona 1
338 // CHECK_NOCONA_M64: #define __nocona__ 1
339 // CHECK_NOCONA_M64: #define __tune_nocona__ 1
340 // CHECK_NOCONA_M64: #define __x86_64 1
341 // CHECK_NOCONA_M64: #define __x86_64__ 1
342 //
343 // RUN: %clang -march=core2 -m32 -E -dM %s -o - 2>&1 \
344 // RUN:     -target i386-unknown-linux \
345 // RUN:   | FileCheck %s -check-prefix=CHECK_CORE2_M32
346 // CHECK_CORE2_M32: #define __MMX__ 1
347 // CHECK_CORE2_M32: #define __SSE2__ 1
348 // CHECK_CORE2_M32: #define __SSE3__ 1
349 // CHECK_CORE2_M32: #define __SSE__ 1
350 // CHECK_CORE2_M32: #define __SSSE3__ 1
351 // CHECK_CORE2_M32: #define __core2 1
352 // CHECK_CORE2_M32: #define __core2__ 1
353 // CHECK_CORE2_M32: #define __i386 1
354 // CHECK_CORE2_M32: #define __i386__ 1
355 // CHECK_CORE2_M32: #define __tune_core2__ 1
356 // CHECK_CORE2_M32: #define i386 1
357 // RUN: %clang -march=core2 -m64 -E -dM %s -o - 2>&1 \
358 // RUN:     -target i386-unknown-linux \
359 // RUN:   | FileCheck %s -check-prefix=CHECK_CORE2_M64
360 // CHECK_CORE2_M64: #define __MMX__ 1
361 // CHECK_CORE2_M64: #define __SSE2_MATH__ 1
362 // CHECK_CORE2_M64: #define __SSE2__ 1
363 // CHECK_CORE2_M64: #define __SSE3__ 1
364 // CHECK_CORE2_M64: #define __SSE_MATH__ 1
365 // CHECK_CORE2_M64: #define __SSE__ 1
366 // CHECK_CORE2_M64: #define __SSSE3__ 1
367 // CHECK_CORE2_M64: #define __amd64 1
368 // CHECK_CORE2_M64: #define __amd64__ 1
369 // CHECK_CORE2_M64: #define __core2 1
370 // CHECK_CORE2_M64: #define __core2__ 1
371 // CHECK_CORE2_M64: #define __tune_core2__ 1
372 // CHECK_CORE2_M64: #define __x86_64 1
373 // CHECK_CORE2_M64: #define __x86_64__ 1
374 //
375 // RUN: %clang -march=corei7 -m32 -E -dM %s -o - 2>&1 \
376 // RUN:     -target i386-unknown-linux \
377 // RUN:   | FileCheck %s -check-prefix=CHECK_COREI7_M32
378 // CHECK_COREI7_M32: #define __MMX__ 1
379 // CHECK_COREI7_M32: #define __POPCNT__ 1
380 // CHECK_COREI7_M32: #define __SSE2__ 1
381 // CHECK_COREI7_M32: #define __SSE3__ 1
382 // CHECK_COREI7_M32: #define __SSE4_1__ 1
383 // CHECK_COREI7_M32: #define __SSE4_2__ 1
384 // CHECK_COREI7_M32: #define __SSE__ 1
385 // CHECK_COREI7_M32: #define __SSSE3__ 1
386 // CHECK_COREI7_M32: #define __corei7 1
387 // CHECK_COREI7_M32: #define __corei7__ 1
388 // CHECK_COREI7_M32: #define __i386 1
389 // CHECK_COREI7_M32: #define __i386__ 1
390 // CHECK_COREI7_M32: #define __tune_corei7__ 1
391 // CHECK_COREI7_M32: #define i386 1
392 // RUN: %clang -march=corei7 -m64 -E -dM %s -o - 2>&1 \
393 // RUN:     -target i386-unknown-linux \
394 // RUN:   | FileCheck %s -check-prefix=CHECK_COREI7_M64
395 // CHECK_COREI7_M64: #define __MMX__ 1
396 // CHECK_COREI7_M64: #define __POPCNT__ 1
397 // CHECK_COREI7_M64: #define __SSE2_MATH__ 1
398 // CHECK_COREI7_M64: #define __SSE2__ 1
399 // CHECK_COREI7_M64: #define __SSE3__ 1
400 // CHECK_COREI7_M64: #define __SSE4_1__ 1
401 // CHECK_COREI7_M64: #define __SSE4_2__ 1
402 // CHECK_COREI7_M64: #define __SSE_MATH__ 1
403 // CHECK_COREI7_M64: #define __SSE__ 1
404 // CHECK_COREI7_M64: #define __SSSE3__ 1
405 // CHECK_COREI7_M64: #define __amd64 1
406 // CHECK_COREI7_M64: #define __amd64__ 1
407 // CHECK_COREI7_M64: #define __corei7 1
408 // CHECK_COREI7_M64: #define __corei7__ 1
409 // CHECK_COREI7_M64: #define __tune_corei7__ 1
410 // CHECK_COREI7_M64: #define __x86_64 1
411 // CHECK_COREI7_M64: #define __x86_64__ 1
412 //
413 // RUN: %clang -march=corei7-avx -m32 -E -dM %s -o - 2>&1 \
414 // RUN:     -target i386-unknown-linux \
415 // RUN:   | FileCheck %s -check-prefix=CHECK_COREI7_AVX_M32
416 // CHECK_COREI7_AVX_M32: #define __AES__ 1
417 // CHECK_COREI7_AVX_M32: #define __AVX__ 1
418 // CHECK_COREI7_AVX_M32: #define __MMX__ 1
419 // CHECK_COREI7_AVX_M32: #define __PCLMUL__ 1
420 // CHECK_COREI7_AVX_M32-NOT: __RDRND__
421 // CHECK_COREI7_AVX_M32: #define __POPCNT__ 1
422 // CHECK_COREI7_AVX_M32: #define __SSE2__ 1
423 // CHECK_COREI7_AVX_M32: #define __SSE3__ 1
424 // CHECK_COREI7_AVX_M32: #define __SSE4_1__ 1
425 // CHECK_COREI7_AVX_M32: #define __SSE4_2__ 1
426 // CHECK_COREI7_AVX_M32: #define __SSE__ 1
427 // CHECK_COREI7_AVX_M32: #define __SSSE3__ 1
428 // CHECK_COREI7_AVX_M32: #define __XSAVEOPT__ 1
429 // CHECK_COREI7_AVX_M32: #define __XSAVE__ 1
430 // CHECK_COREI7_AVX_M32: #define __corei7 1
431 // CHECK_COREI7_AVX_M32: #define __corei7__ 1
432 // CHECK_COREI7_AVX_M32: #define __i386 1
433 // CHECK_COREI7_AVX_M32: #define __i386__ 1
434 // CHECK_COREI7_AVX_M32: #define __tune_corei7__ 1
435 // CHECK_COREI7_AVX_M32: #define i386 1
436 // RUN: %clang -march=corei7-avx -m64 -E -dM %s -o - 2>&1 \
437 // RUN:     -target i386-unknown-linux \
438 // RUN:   | FileCheck %s -check-prefix=CHECK_COREI7_AVX_M64
439 // CHECK_COREI7_AVX_M64: #define __AES__ 1
440 // CHECK_COREI7_AVX_M64: #define __AVX__ 1
441 // CHECK_COREI7_AVX_M64: #define __MMX__ 1
442 // CHECK_COREI7_AVX_M64: #define __PCLMUL__ 1
443 // CHECK_COREI7_AVX_M64-NOT: __RDRND__
444 // CHECK_COREI7_AVX_M64: #define __POPCNT__ 1
445 // CHECK_COREI7_AVX_M64: #define __SSE2_MATH__ 1
446 // CHECK_COREI7_AVX_M64: #define __SSE2__ 1
447 // CHECK_COREI7_AVX_M64: #define __SSE3__ 1
448 // CHECK_COREI7_AVX_M64: #define __SSE4_1__ 1
449 // CHECK_COREI7_AVX_M64: #define __SSE4_2__ 1
450 // CHECK_COREI7_AVX_M64: #define __SSE_MATH__ 1
451 // CHECK_COREI7_AVX_M64: #define __SSE__ 1
452 // CHECK_COREI7_AVX_M64: #define __SSSE3__ 1
453 // CHECK_COREI7_AVX_M64: #define __XSAVEOPT__ 1
454 // CHECK_COREI7_AVX_M64: #define __XSAVE__ 1
455 // CHECK_COREI7_AVX_M64: #define __amd64 1
456 // CHECK_COREI7_AVX_M64: #define __amd64__ 1
457 // CHECK_COREI7_AVX_M64: #define __corei7 1
458 // CHECK_COREI7_AVX_M64: #define __corei7__ 1
459 // CHECK_COREI7_AVX_M64: #define __tune_corei7__ 1
460 // CHECK_COREI7_AVX_M64: #define __x86_64 1
461 // CHECK_COREI7_AVX_M64: #define __x86_64__ 1
462 //
463 // RUN: %clang -march=core-avx-i -m32 -E -dM %s -o - 2>&1 \
464 // RUN:     -target i386-unknown-linux \
465 // RUN:   | FileCheck %s -check-prefix=CHECK_CORE_AVX_I_M32
466 // CHECK_CORE_AVX_I_M32: #define __AES__ 1
467 // CHECK_CORE_AVX_I_M32: #define __AVX__ 1
468 // CHECK_CORE_AVX_I_M32: #define __F16C__ 1
469 // CHECK_CORE_AVX_I_M32: #define __MMX__ 1
470 // CHECK_CORE_AVX_I_M32: #define __PCLMUL__ 1
471 // CHECK_CORE_AVX_I_M32: #define __RDRND__ 1
472 // CHECK_CORE_AVX_I_M32: #define __SSE2__ 1
473 // CHECK_CORE_AVX_I_M32: #define __SSE3__ 1
474 // CHECK_CORE_AVX_I_M32: #define __SSE4_1__ 1
475 // CHECK_CORE_AVX_I_M32: #define __SSE4_2__ 1
476 // CHECK_CORE_AVX_I_M32: #define __SSE__ 1
477 // CHECK_CORE_AVX_I_M32: #define __SSSE3__ 1
478 // CHECK_CORE_AVX_I_M32: #define __XSAVEOPT__ 1
479 // CHECK_CORE_AVX_I_M32: #define __XSAVE__ 1
480 // CHECK_CORE_AVX_I_M32: #define __corei7 1
481 // CHECK_CORE_AVX_I_M32: #define __corei7__ 1
482 // CHECK_CORE_AVX_I_M32: #define __i386 1
483 // CHECK_CORE_AVX_I_M32: #define __i386__ 1
484 // CHECK_CORE_AVX_I_M32: #define __tune_corei7__ 1
485 // CHECK_CORE_AVX_I_M32: #define i386 1
486 // RUN: %clang -march=core-avx-i -m64 -E -dM %s -o - 2>&1 \
487 // RUN:     -target i386-unknown-linux \
488 // RUN:   | FileCheck %s -check-prefix=CHECK_CORE_AVX_I_M64
489 // CHECK_CORE_AVX_I_M64: #define __AES__ 1
490 // CHECK_CORE_AVX_I_M64: #define __AVX__ 1
491 // CHECK_CORE_AVX_I_M64: #define __F16C__ 1
492 // CHECK_CORE_AVX_I_M64: #define __MMX__ 1
493 // CHECK_CORE_AVX_I_M64: #define __PCLMUL__ 1
494 // CHECK_CORE_AVX_I_M64: #define __RDRND__ 1
495 // CHECK_CORE_AVX_I_M64: #define __SSE2_MATH__ 1
496 // CHECK_CORE_AVX_I_M64: #define __SSE2__ 1
497 // CHECK_CORE_AVX_I_M64: #define __SSE3__ 1
498 // CHECK_CORE_AVX_I_M64: #define __SSE4_1__ 1
499 // CHECK_CORE_AVX_I_M64: #define __SSE4_2__ 1
500 // CHECK_CORE_AVX_I_M64: #define __SSE_MATH__ 1
501 // CHECK_CORE_AVX_I_M64: #define __SSE__ 1
502 // CHECK_CORE_AVX_I_M64: #define __SSSE3__ 1
503 // CHECK_CORE_AVX_I_M64: #define __XSAVEOPT__ 1
504 // CHECK_CORE_AVX_I_M64: #define __XSAVE__ 1
505 // CHECK_CORE_AVX_I_M64: #define __amd64 1
506 // CHECK_CORE_AVX_I_M64: #define __amd64__ 1
507 // CHECK_CORE_AVX_I_M64: #define __corei7 1
508 // CHECK_CORE_AVX_I_M64: #define __corei7__ 1
509 // CHECK_CORE_AVX_I_M64: #define __tune_corei7__ 1
510 // CHECK_CORE_AVX_I_M64: #define __x86_64 1
511 // CHECK_CORE_AVX_I_M64: #define __x86_64__ 1
512 //
513 // RUN: %clang -march=core-avx2 -m32 -E -dM %s -o - 2>&1 \
514 // RUN:     -target i386-unknown-linux \
515 // RUN:   | FileCheck %s -check-prefix=CHECK_CORE_AVX2_M32
516 // CHECK_CORE_AVX2_M32: #define __AES__ 1
517 // CHECK_CORE_AVX2_M32: #define __AVX2__ 1
518 // CHECK_CORE_AVX2_M32: #define __AVX__ 1
519 // CHECK_CORE_AVX2_M32: #define __BMI2__ 1
520 // CHECK_CORE_AVX2_M32: #define __BMI__ 1
521 // CHECK_CORE_AVX2_M32: #define __F16C__ 1
522 // CHECK_CORE_AVX2_M32: #define __FMA__ 1
523 // CHECK_CORE_AVX2_M32: #define __LZCNT__ 1
524 // CHECK_CORE_AVX2_M32: #define __MMX__ 1
525 // CHECK_CORE_AVX2_M32: #define __PCLMUL__ 1
526 // CHECK_CORE_AVX2_M32: #define __POPCNT__ 1
527 // CHECK_CORE_AVX2_M32: #define __RDRND__ 1
528 // CHECK_CORE_AVX2_M32: #define __RTM__ 1
529 // CHECK_CORE_AVX2_M32: #define __SSE2__ 1
530 // CHECK_CORE_AVX2_M32: #define __SSE3__ 1
531 // CHECK_CORE_AVX2_M32: #define __SSE4_1__ 1
532 // CHECK_CORE_AVX2_M32: #define __SSE4_2__ 1
533 // CHECK_CORE_AVX2_M32: #define __SSE__ 1
534 // CHECK_CORE_AVX2_M32: #define __SSSE3__ 1
535 // CHECK_CORE_AVX2_M32: #define __XSAVEOPT__ 1
536 // CHECK_CORE_AVX2_M32: #define __XSAVE__ 1
537 // CHECK_CORE_AVX2_M32: #define __corei7 1
538 // CHECK_CORE_AVX2_M32: #define __corei7__ 1
539 // CHECK_CORE_AVX2_M32: #define __i386 1
540 // CHECK_CORE_AVX2_M32: #define __i386__ 1
541 // CHECK_CORE_AVX2_M32: #define __tune_corei7__ 1
542 // CHECK_CORE_AVX2_M32: #define i386 1
543 // RUN: %clang -march=core-avx2 -m64 -E -dM %s -o - 2>&1 \
544 // RUN:     -target i386-unknown-linux \
545 // RUN:   | FileCheck %s -check-prefix=CHECK_CORE_AVX2_M64
546 // CHECK_CORE_AVX2_M64: #define __AES__ 1
547 // CHECK_CORE_AVX2_M64: #define __AVX2__ 1
548 // CHECK_CORE_AVX2_M64: #define __AVX__ 1
549 // CHECK_CORE_AVX2_M64: #define __BMI2__ 1
550 // CHECK_CORE_AVX2_M64: #define __BMI__ 1
551 // CHECK_CORE_AVX2_M64: #define __F16C__ 1
552 // CHECK_CORE_AVX2_M64: #define __FMA__ 1
553 // CHECK_CORE_AVX2_M64: #define __LZCNT__ 1
554 // CHECK_CORE_AVX2_M64: #define __MMX__ 1
555 // CHECK_CORE_AVX2_M64: #define __PCLMUL__ 1
556 // CHECK_CORE_AVX2_M64: #define __POPCNT__ 1
557 // CHECK_CORE_AVX2_M64: #define __RDRND__ 1
558 // CHECK_CORE_AVX2_M64: #define __RTM__ 1
559 // CHECK_CORE_AVX2_M64: #define __SSE2_MATH__ 1
560 // CHECK_CORE_AVX2_M64: #define __SSE2__ 1
561 // CHECK_CORE_AVX2_M64: #define __SSE3__ 1
562 // CHECK_CORE_AVX2_M64: #define __SSE4_1__ 1
563 // CHECK_CORE_AVX2_M64: #define __SSE4_2__ 1
564 // CHECK_CORE_AVX2_M64: #define __SSE_MATH__ 1
565 // CHECK_CORE_AVX2_M64: #define __SSE__ 1
566 // CHECK_CORE_AVX2_M64: #define __SSSE3__ 1
567 // CHECK_CORE_AVX2_M64: #define __XSAVEOPT__ 1
568 // CHECK_CORE_AVX2_M64: #define __XSAVE__ 1
569 // CHECK_CORE_AVX2_M64: #define __amd64 1
570 // CHECK_CORE_AVX2_M64: #define __amd64__ 1
571 // CHECK_CORE_AVX2_M64: #define __corei7 1
572 // CHECK_CORE_AVX2_M64: #define __corei7__ 1
573 // CHECK_CORE_AVX2_M64: #define __tune_corei7__ 1
574 // CHECK_CORE_AVX2_M64: #define __x86_64 1
575 // CHECK_CORE_AVX2_M64: #define __x86_64__ 1
576 //
577 // RUN: %clang -march=broadwell -m32 -E -dM %s -o - 2>&1 \
578 // RUN:     -target i386-unknown-linux \
579 // RUN:   | FileCheck %s -check-prefix=CHECK_BROADWELL_M32
580 // CHECK_BROADWELL_M32: #define __ADX__ 1
581 // CHECK_BROADWELL_M32: #define __AES__ 1
582 // CHECK_BROADWELL_M32: #define __AVX2__ 1
583 // CHECK_BROADWELL_M32: #define __AVX__ 1
584 // CHECK_BROADWELL_M32: #define __BMI2__ 1
585 // CHECK_BROADWELL_M32: #define __BMI__ 1
586 // CHECK_BROADWELL_M32: #define __F16C__ 1
587 // CHECK_BROADWELL_M32: #define __FMA__ 1
588 // CHECK_BROADWELL_M32: #define __LZCNT__ 1
589 // CHECK_BROADWELL_M32: #define __MMX__ 1
590 // CHECK_BROADWELL_M32: #define __PCLMUL__ 1
591 // CHECK_BROADWELL_M32: #define __POPCNT__ 1
592 // CHECK_BROADWELL_M32: #define __RDRND__ 1
593 // CHECK_BROADWELL_M32: #define __RDSEED__ 1
594 // CHECK_BROADWELL_M32: #define __RTM__ 1
595 // CHECK_BROADWELL_M32: #define __SSE2__ 1
596 // CHECK_BROADWELL_M32: #define __SSE3__ 1
597 // CHECK_BROADWELL_M32: #define __SSE4_1__ 1
598 // CHECK_BROADWELL_M32: #define __SSE4_2__ 1
599 // CHECK_BROADWELL_M32: #define __SSE__ 1
600 // CHECK_BROADWELL_M32: #define __SSSE3__ 1
601 // CHECK_BROADWELL_M32: #define __XSAVEOPT__ 1
602 // CHECK_BROADWELL_M32: #define __XSAVE__ 1
603 // CHECK_BROADWELL_M32: #define __corei7 1
604 // CHECK_BROADWELL_M32: #define __corei7__ 1
605 // CHECK_BROADWELL_M32: #define __i386 1
606 // CHECK_BROADWELL_M32: #define __i386__ 1
607 // CHECK_BROADWELL_M32: #define __tune_corei7__ 1
608 // CHECK_BROADWELL_M32: #define i386 1
609 // RUN: %clang -march=broadwell -m64 -E -dM %s -o - 2>&1 \
610 // RUN:     -target i386-unknown-linux \
611 // RUN:   | FileCheck %s -check-prefix=CHECK_BROADWELL_M64
612 // CHECK_BROADWELL_M64: #define __ADX__ 1
613 // CHECK_BROADWELL_M64: #define __AES__ 1
614 // CHECK_BROADWELL_M64: #define __AVX2__ 1
615 // CHECK_BROADWELL_M64: #define __AVX__ 1
616 // CHECK_BROADWELL_M64: #define __BMI2__ 1
617 // CHECK_BROADWELL_M64: #define __BMI__ 1
618 // CHECK_BROADWELL_M64: #define __F16C__ 1
619 // CHECK_BROADWELL_M64: #define __FMA__ 1
620 // CHECK_BROADWELL_M64: #define __LZCNT__ 1
621 // CHECK_BROADWELL_M64: #define __MMX__ 1
622 // CHECK_BROADWELL_M64: #define __PCLMUL__ 1
623 // CHECK_BROADWELL_M64: #define __POPCNT__ 1
624 // CHECK_BROADWELL_M64: #define __RDRND__ 1
625 // CHECK_BROADWELL_M64: #define __RDSEED__ 1
626 // CHECK_BROADWELL_M64: #define __RTM__ 1
627 // CHECK_BROADWELL_M64: #define __SSE2_MATH__ 1
628 // CHECK_BROADWELL_M64: #define __SSE2__ 1
629 // CHECK_BROADWELL_M64: #define __SSE3__ 1
630 // CHECK_BROADWELL_M64: #define __SSE4_1__ 1
631 // CHECK_BROADWELL_M64: #define __SSE4_2__ 1
632 // CHECK_BROADWELL_M64: #define __SSE_MATH__ 1
633 // CHECK_BROADWELL_M64: #define __SSE__ 1
634 // CHECK_BROADWELL_M64: #define __SSSE3__ 1
635 // CHECK_BROADWELL_M64: #define __XSAVEOPT__ 1
636 // CHECK_BROADWELL_M64: #define __XSAVE__ 1
637 // CHECK_BROADWELL_M64: #define __amd64 1
638 // CHECK_BROADWELL_M64: #define __amd64__ 1
639 // CHECK_BROADWELL_M64: #define __corei7 1
640 // CHECK_BROADWELL_M64: #define __corei7__ 1
641 // CHECK_BROADWELL_M64: #define __tune_corei7__ 1
642 // CHECK_BROADWELL_M64: #define __x86_64 1
643 // CHECK_BROADWELL_M64: #define __x86_64__ 1
644 //
645 // RUN: %clang -march=knl -m32 -E -dM %s -o - 2>&1 \
646 // RUN:     -target i386-unknown-linux \
647 // RUN:   | FileCheck %s -check-prefix=CHECK_KNL_M32
648 // CHECK_KNL_M32: #define __AES__ 1
649 // CHECK_KNL_M32: #define __AVX2__ 1
650 // CHECK_KNL_M32: #define __AVX512CD__ 1
651 // CHECK_KNL_M32: #define __AVX512ER__ 1
652 // CHECK_KNL_M32: #define __AVX512F__ 1
653 // CHECK_KNL_M32: #define __AVX512PF__ 1
654 // CHECK_KNL_M32: #define __AVX__ 1
655 // CHECK_KNL_M32: #define __BMI2__ 1
656 // CHECK_KNL_M32: #define __BMI__ 1
657 // CHECK_KNL_M32: #define __F16C__ 1
658 // CHECK_KNL_M32: #define __FMA__ 1
659 // CHECK_KNL_M32: #define __LZCNT__ 1
660 // CHECK_KNL_M32: #define __MMX__ 1
661 // CHECK_KNL_M32: #define __PCLMUL__ 1
662 // CHECK_KNL_M32: #define __POPCNT__ 1
663 // CHECK_KNL_M32: #define __RDRND__ 1
664 // CHECK_KNL_M32: #define __RTM__ 1
665 // CHECK_KNL_M32: #define __SSE2__ 1
666 // CHECK_KNL_M32: #define __SSE3__ 1
667 // CHECK_KNL_M32: #define __SSE4_1__ 1
668 // CHECK_KNL_M32: #define __SSE4_2__ 1
669 // CHECK_KNL_M32: #define __SSE__ 1
670 // CHECK_KNL_M32: #define __SSSE3__ 1
671 // CHECK_KNL_M32: #define __XSAVEOPT__ 1
672 // CHECK_KNL_M32: #define __XSAVE__ 1
673 // CHECK_KNL_M32: #define __i386 1
674 // CHECK_KNL_M32: #define __i386__ 1
675 // CHECK_KNL_M32: #define __knl 1
676 // CHECK_KNL_M32: #define __knl__ 1
677 // CHECK_KNL_M32: #define __tune_knl__ 1
678 // CHECK_KNL_M32: #define i386 1
679 
680 // RUN: %clang -march=knl -m64 -E -dM %s -o - 2>&1 \
681 // RUN:     -target i386-unknown-linux \
682 // RUN:   | FileCheck %s -check-prefix=CHECK_KNL_M64
683 // CHECK_KNL_M64: #define __AES__ 1
684 // CHECK_KNL_M64: #define __AVX2__ 1
685 // CHECK_KNL_M64: #define __AVX512CD__ 1
686 // CHECK_KNL_M64: #define __AVX512ER__ 1
687 // CHECK_KNL_M64: #define __AVX512F__ 1
688 // CHECK_KNL_M64: #define __AVX512PF__ 1
689 // CHECK_KNL_M64: #define __AVX__ 1
690 // CHECK_KNL_M64: #define __BMI2__ 1
691 // CHECK_KNL_M64: #define __BMI__ 1
692 // CHECK_KNL_M64: #define __F16C__ 1
693 // CHECK_KNL_M64: #define __FMA__ 1
694 // CHECK_KNL_M64: #define __LZCNT__ 1
695 // CHECK_KNL_M64: #define __MMX__ 1
696 // CHECK_KNL_M64: #define __PCLMUL__ 1
697 // CHECK_KNL_M64: #define __POPCNT__ 1
698 // CHECK_KNL_M64: #define __RDRND__ 1
699 // CHECK_KNL_M64: #define __RTM__ 1
700 // CHECK_KNL_M64: #define __SSE2_MATH__ 1
701 // CHECK_KNL_M64: #define __SSE2__ 1
702 // CHECK_KNL_M64: #define __SSE3__ 1
703 // CHECK_KNL_M64: #define __SSE4_1__ 1
704 // CHECK_KNL_M64: #define __SSE4_2__ 1
705 // CHECK_KNL_M64: #define __SSE_MATH__ 1
706 // CHECK_KNL_M64: #define __SSE__ 1
707 // CHECK_KNL_M64: #define __SSSE3__ 1
708 // CHECK_KNL_M64: #define __XSAVEOPT__ 1
709 // CHECK_KNL_M64: #define __XSAVE__ 1
710 // CHECK_KNL_M64: #define __amd64 1
711 // CHECK_KNL_M64: #define __amd64__ 1
712 // CHECK_KNL_M64: #define __knl 1
713 // CHECK_KNL_M64: #define __knl__ 1
714 // CHECK_KNL_M64: #define __tune_knl__ 1
715 // CHECK_KNL_M64: #define __x86_64 1
716 // CHECK_KNL_M64: #define __x86_64__ 1
717 //
718 // RUN: %clang -march=skx -m32 -E -dM %s -o - 2>&1 \
719 // RUN:     -target i386-unknown-linux \
720 // RUN:   | FileCheck %s -check-prefix=CHECK_SKX_M32
721 // CHECK_SKX_M32: #define __AES__ 1
722 // CHECK_SKX_M32: #define __AVX2__ 1
723 // CHECK_SKX_M32: #define __AVX512BW__ 1
724 // CHECK_SKX_M32: #define __AVX512CD__ 1
725 // CHECK_SKX_M32: #define __AVX512DQ__ 1
726 // CHECK_SKX_M32: #define __AVX512F__ 1
727 // CHECK_SKX_M32: #define __AVX512VL__ 1
728 // CHECK_SKX_M32: #define __AVX__ 1
729 // CHECK_SKX_M32: #define __BMI2__ 1
730 // CHECK_SKX_M32: #define __BMI__ 1
731 // CHECK_SKX_M32: #define __F16C__ 1
732 // CHECK_SKX_M32: #define __FMA__ 1
733 // CHECK_SKX_M32: #define __LZCNT__ 1
734 // CHECK_SKX_M32: #define __MMX__ 1
735 // CHECK_SKX_M32: #define __PCLMUL__ 1
736 // CHECK_SKX_M32: #define __POPCNT__ 1
737 // CHECK_SKX_M32: #define __RDRND__ 1
738 // CHECK_SKX_M32: #define __RTM__ 1
739 // CHECK_SKX_M32: #define __SSE2__ 1
740 // CHECK_SKX_M32: #define __SSE3__ 1
741 // CHECK_SKX_M32: #define __SSE4_1__ 1
742 // CHECK_SKX_M32: #define __SSE4_2__ 1
743 // CHECK_SKX_M32: #define __SSE__ 1
744 // CHECK_SKX_M32: #define __SSSE3__ 1
745 // CHECK_SKX_M32: #define __XSAVEC__ 1
746 // CHECK_SKX_M32: #define __XSAVEOPT__ 1
747 // CHECK_SKX_M32: #define __XSAVES__ 1
748 // CHECK_SKX_M32: #define __XSAVE__ 1
749 // CHECK_SKX_M32: #define __i386 1
750 // CHECK_SKX_M32: #define __i386__ 1
751 // CHECK_SKX_M32: #define __skx 1
752 // CHECK_SKX_M32: #define __skx__ 1
753 // CHECK_SKX_M32: #define __tune_skx__ 1
754 // CHECK_SKX_M32: #define i386 1
755 
756 // RUN: %clang -march=skx -m64 -E -dM %s -o - 2>&1 \
757 // RUN:     -target i386-unknown-linux \
758 // RUN:   | FileCheck %s -check-prefix=CHECK_SKX_M64
759 // CHECK_SKX_M64: #define __AES__ 1
760 // CHECK_SKX_M64: #define __AVX2__ 1
761 // CHECK_SKX_M64: #define __AVX512BW__ 1
762 // CHECK_SKX_M64: #define __AVX512CD__ 1
763 // CHECK_SKX_M64: #define __AVX512DQ__ 1
764 // CHECK_SKX_M64: #define __AVX512F__ 1
765 // CHECK_SKX_M64: #define __AVX512VL__ 1
766 // CHECK_SKX_M64: #define __AVX__ 1
767 // CHECK_SKX_M64: #define __BMI2__ 1
768 // CHECK_SKX_M64: #define __BMI__ 1
769 // CHECK_SKX_M64: #define __F16C__ 1
770 // CHECK_SKX_M64: #define __FMA__ 1
771 // CHECK_SKX_M64: #define __LZCNT__ 1
772 // CHECK_SKX_M64: #define __MMX__ 1
773 // CHECK_SKX_M64: #define __PCLMUL__ 1
774 // CHECK_SKX_M64: #define __POPCNT__ 1
775 // CHECK_SKX_M64: #define __RDRND__ 1
776 // CHECK_SKX_M64: #define __RTM__ 1
777 // CHECK_SKX_M64: #define __SSE2_MATH__ 1
778 // CHECK_SKX_M64: #define __SSE2__ 1
779 // CHECK_SKX_M64: #define __SSE3__ 1
780 // CHECK_SKX_M64: #define __SSE4_1__ 1
781 // CHECK_SKX_M64: #define __SSE4_2__ 1
782 // CHECK_SKX_M64: #define __SSE_MATH__ 1
783 // CHECK_SKX_M64: #define __SSE__ 1
784 // CHECK_SKX_M64: #define __SSSE3__ 1
785 // CHECK_SKX_M64: #define __XSAVEC__ 1
786 // CHECK_SKX_M64: #define __XSAVEOPT__ 1
787 // CHECK_SKX_M64: #define __XSAVES__ 1
788 // CHECK_SKX_M64: #define __XSAVE__ 1
789 // CHECK_SKX_M64: #define __amd64 1
790 // CHECK_SKX_M64: #define __amd64__ 1
791 // CHECK_SKX_M64: #define __skx 1
792 // CHECK_SKX_M64: #define __skx__ 1
793 // CHECK_SKX_M64: #define __tune_skx__ 1
794 // CHECK_SKX_M64: #define __x86_64 1
795 // CHECK_SKX_M64: #define __x86_64__ 1
796 //
797 // RUN: %clang -march=atom -m32 -E -dM %s -o - 2>&1 \
798 // RUN:     -target i386-unknown-linux \
799 // RUN:   | FileCheck %s -check-prefix=CHECK_ATOM_M32
800 // CHECK_ATOM_M32: #define __MMX__ 1
801 // CHECK_ATOM_M32: #define __SSE2__ 1
802 // CHECK_ATOM_M32: #define __SSE3__ 1
803 // CHECK_ATOM_M32: #define __SSE__ 1
804 // CHECK_ATOM_M32: #define __SSSE3__ 1
805 // CHECK_ATOM_M32: #define __atom 1
806 // CHECK_ATOM_M32: #define __atom__ 1
807 // CHECK_ATOM_M32: #define __i386 1
808 // CHECK_ATOM_M32: #define __i386__ 1
809 // CHECK_ATOM_M32: #define __tune_atom__ 1
810 // CHECK_ATOM_M32: #define i386 1
811 // RUN: %clang -march=atom -m64 -E -dM %s -o - 2>&1 \
812 // RUN:     -target i386-unknown-linux \
813 // RUN:   | FileCheck %s -check-prefix=CHECK_ATOM_M64
814 // CHECK_ATOM_M64: #define __MMX__ 1
815 // CHECK_ATOM_M64: #define __SSE2_MATH__ 1
816 // CHECK_ATOM_M64: #define __SSE2__ 1
817 // CHECK_ATOM_M64: #define __SSE3__ 1
818 // CHECK_ATOM_M64: #define __SSE_MATH__ 1
819 // CHECK_ATOM_M64: #define __SSE__ 1
820 // CHECK_ATOM_M64: #define __SSSE3__ 1
821 // CHECK_ATOM_M64: #define __amd64 1
822 // CHECK_ATOM_M64: #define __amd64__ 1
823 // CHECK_ATOM_M64: #define __atom 1
824 // CHECK_ATOM_M64: #define __atom__ 1
825 // CHECK_ATOM_M64: #define __tune_atom__ 1
826 // CHECK_ATOM_M64: #define __x86_64 1
827 // CHECK_ATOM_M64: #define __x86_64__ 1
828 //
829 // RUN: %clang -march=slm -m32 -E -dM %s -o - 2>&1 \
830 // RUN:     -target i386-unknown-linux \
831 // RUN:   | FileCheck %s -check-prefix=CHECK_SLM_M32
832 // CHECK_SLM_M32: #define __MMX__ 1
833 // CHECK_SLM_M32: #define __SSE2__ 1
834 // CHECK_SLM_M32: #define __SSE3__ 1
835 // CHECK_SLM_M32: #define __SSE4_1__ 1
836 // CHECK_SLM_M32: #define __SSE4_2__ 1
837 // CHECK_SLM_M32: #define __SSE__ 1
838 // CHECK_SLM_M32: #define __SSSE3__ 1
839 // CHECK_SLM_M32: #define __i386 1
840 // CHECK_SLM_M32: #define __i386__ 1
841 // CHECK_SLM_M32: #define __slm 1
842 // CHECK_SLM_M32: #define __slm__ 1
843 // CHECK_SLM_M32: #define __tune_slm__ 1
844 // CHECK_SLM_M32: #define i386 1
845 // RUN: %clang -march=slm -m64 -E -dM %s -o - 2>&1 \
846 // RUN:     -target i386-unknown-linux \
847 // RUN:   | FileCheck %s -check-prefix=CHECK_SLM_M64
848 // CHECK_SLM_M64: #define __MMX__ 1
849 // CHECK_SLM_M64: #define __SSE2_MATH__ 1
850 // CHECK_SLM_M64: #define __SSE2__ 1
851 // CHECK_SLM_M64: #define __SSE3__ 1
852 // CHECK_SLM_M64: #define __SSE4_1__ 1
853 // CHECK_SLM_M64: #define __SSE4_2__ 1
854 // CHECK_SLM_M64: #define __SSE_MATH__ 1
855 // CHECK_SLM_M64: #define __SSE__ 1
856 // CHECK_SLM_M64: #define __SSSE3__ 1
857 // CHECK_SLM_M64: #define __amd64 1
858 // CHECK_SLM_M64: #define __amd64__ 1
859 // CHECK_SLM_M64: #define __slm 1
860 // CHECK_SLM_M64: #define __slm__ 1
861 // CHECK_SLM_M64: #define __tune_slm__ 1
862 // CHECK_SLM_M64: #define __x86_64 1
863 // CHECK_SLM_M64: #define __x86_64__ 1
864 //
865 // RUN: %clang -march=geode -m32 -E -dM %s -o - 2>&1 \
866 // RUN:     -target i386-unknown-linux \
867 // RUN:   | FileCheck %s -check-prefix=CHECK_GEODE_M32
868 // CHECK_GEODE_M32: #define __3dNOW_A__ 1
869 // CHECK_GEODE_M32: #define __3dNOW__ 1
870 // CHECK_GEODE_M32: #define __MMX__ 1
871 // CHECK_GEODE_M32: #define __geode 1
872 // CHECK_GEODE_M32: #define __geode__ 1
873 // CHECK_GEODE_M32: #define __i386 1
874 // CHECK_GEODE_M32: #define __i386__ 1
875 // CHECK_GEODE_M32: #define __tune_geode__ 1
876 // CHECK_GEODE_M32: #define i386 1
877 // RUN: not %clang -march=geode -m64 -E -dM %s -o - 2>&1 \
878 // RUN:     -target i386-unknown-linux \
879 // RUN:   | FileCheck %s -check-prefix=CHECK_GEODE_M64
880 // CHECK_GEODE_M64: error:
881 //
882 // RUN: %clang -march=k6 -m32 -E -dM %s -o - 2>&1 \
883 // RUN:     -target i386-unknown-linux \
884 // RUN:   | FileCheck %s -check-prefix=CHECK_K6_M32
885 // CHECK_K6_M32: #define __MMX__ 1
886 // CHECK_K6_M32: #define __i386 1
887 // CHECK_K6_M32: #define __i386__ 1
888 // CHECK_K6_M32: #define __k6 1
889 // CHECK_K6_M32: #define __k6__ 1
890 // CHECK_K6_M32: #define __tune_k6__ 1
891 // CHECK_K6_M32: #define i386 1
892 // RUN: not %clang -march=k6 -m64 -E -dM %s -o - 2>&1 \
893 // RUN:     -target i386-unknown-linux \
894 // RUN:   | FileCheck %s -check-prefix=CHECK_K6_M64
895 // CHECK_K6_M64: error:
896 //
897 // RUN: %clang -march=k6-2 -m32 -E -dM %s -o - 2>&1 \
898 // RUN:     -target i386-unknown-linux \
899 // RUN:   | FileCheck %s -check-prefix=CHECK_K6_2_M32
900 // CHECK_K6_2_M32: #define __3dNOW__ 1
901 // CHECK_K6_2_M32: #define __MMX__ 1
902 // CHECK_K6_2_M32: #define __i386 1
903 // CHECK_K6_2_M32: #define __i386__ 1
904 // CHECK_K6_2_M32: #define __k6 1
905 // CHECK_K6_2_M32: #define __k6_2__ 1
906 // CHECK_K6_2_M32: #define __k6__ 1
907 // CHECK_K6_2_M32: #define __tune_k6_2__ 1
908 // CHECK_K6_2_M32: #define __tune_k6__ 1
909 // CHECK_K6_2_M32: #define i386 1
910 // RUN: not %clang -march=k6-2 -m64 -E -dM %s -o - 2>&1 \
911 // RUN:     -target i386-unknown-linux \
912 // RUN:   | FileCheck %s -check-prefix=CHECK_K6_2_M64
913 // CHECK_K6_2_M64: error:
914 //
915 // RUN: %clang -march=k6-3 -m32 -E -dM %s -o - 2>&1 \
916 // RUN:     -target i386-unknown-linux \
917 // RUN:   | FileCheck %s -check-prefix=CHECK_K6_3_M32
918 // CHECK_K6_3_M32: #define __3dNOW__ 1
919 // CHECK_K6_3_M32: #define __MMX__ 1
920 // CHECK_K6_3_M32: #define __i386 1
921 // CHECK_K6_3_M32: #define __i386__ 1
922 // CHECK_K6_3_M32: #define __k6 1
923 // CHECK_K6_3_M32: #define __k6_3__ 1
924 // CHECK_K6_3_M32: #define __k6__ 1
925 // CHECK_K6_3_M32: #define __tune_k6_3__ 1
926 // CHECK_K6_3_M32: #define __tune_k6__ 1
927 // CHECK_K6_3_M32: #define i386 1
928 // RUN: not %clang -march=k6-3 -m64 -E -dM %s -o - 2>&1 \
929 // RUN:     -target i386-unknown-linux \
930 // RUN:   | FileCheck %s -check-prefix=CHECK_K6_3_M64
931 // CHECK_K6_3_M64: error:
932 //
933 // RUN: %clang -march=athlon -m32 -E -dM %s -o - 2>&1 \
934 // RUN:     -target i386-unknown-linux \
935 // RUN:   | FileCheck %s -check-prefix=CHECK_ATHLON_M32
936 // CHECK_ATHLON_M32: #define __3dNOW_A__ 1
937 // CHECK_ATHLON_M32: #define __3dNOW__ 1
938 // CHECK_ATHLON_M32: #define __MMX__ 1
939 // CHECK_ATHLON_M32: #define __athlon 1
940 // CHECK_ATHLON_M32: #define __athlon__ 1
941 // CHECK_ATHLON_M32: #define __i386 1
942 // CHECK_ATHLON_M32: #define __i386__ 1
943 // CHECK_ATHLON_M32: #define __tune_athlon__ 1
944 // CHECK_ATHLON_M32: #define i386 1
945 // RUN: not %clang -march=athlon -m64 -E -dM %s -o - 2>&1 \
946 // RUN:     -target i386-unknown-linux \
947 // RUN:   | FileCheck %s -check-prefix=CHECK_ATHLON_M64
948 // CHECK_ATHLON_M64: error:
949 //
950 // RUN: %clang -march=athlon-tbird -m32 -E -dM %s -o - 2>&1 \
951 // RUN:     -target i386-unknown-linux \
952 // RUN:   | FileCheck %s -check-prefix=CHECK_ATHLON_TBIRD_M32
953 // CHECK_ATHLON_TBIRD_M32: #define __3dNOW_A__ 1
954 // CHECK_ATHLON_TBIRD_M32: #define __3dNOW__ 1
955 // CHECK_ATHLON_TBIRD_M32: #define __MMX__ 1
956 // CHECK_ATHLON_TBIRD_M32: #define __athlon 1
957 // CHECK_ATHLON_TBIRD_M32: #define __athlon__ 1
958 // CHECK_ATHLON_TBIRD_M32: #define __i386 1
959 // CHECK_ATHLON_TBIRD_M32: #define __i386__ 1
960 // CHECK_ATHLON_TBIRD_M32: #define __tune_athlon__ 1
961 // CHECK_ATHLON_TBIRD_M32: #define i386 1
962 // RUN: not %clang -march=athlon-tbird -m64 -E -dM %s -o - 2>&1 \
963 // RUN:     -target i386-unknown-linux \
964 // RUN:   | FileCheck %s -check-prefix=CHECK_ATHLON_TBIRD_M64
965 // CHECK_ATHLON_TBIRD_M64: error:
966 //
967 // RUN: %clang -march=athlon-4 -m32 -E -dM %s -o - 2>&1 \
968 // RUN:     -target i386-unknown-linux \
969 // RUN:   | FileCheck %s -check-prefix=CHECK_ATHLON_4_M32
970 // CHECK_ATHLON_4_M32: #define __3dNOW_A__ 1
971 // CHECK_ATHLON_4_M32: #define __3dNOW__ 1
972 // CHECK_ATHLON_4_M32: #define __MMX__ 1
973 // CHECK_ATHLON_4_M32: #define __SSE__ 1
974 // CHECK_ATHLON_4_M32: #define __athlon 1
975 // CHECK_ATHLON_4_M32: #define __athlon__ 1
976 // CHECK_ATHLON_4_M32: #define __athlon_sse__ 1
977 // CHECK_ATHLON_4_M32: #define __i386 1
978 // CHECK_ATHLON_4_M32: #define __i386__ 1
979 // CHECK_ATHLON_4_M32: #define __tune_athlon__ 1
980 // CHECK_ATHLON_4_M32: #define __tune_athlon_sse__ 1
981 // CHECK_ATHLON_4_M32: #define i386 1
982 // RUN: not %clang -march=athlon-4 -m64 -E -dM %s -o - 2>&1 \
983 // RUN:     -target i386-unknown-linux \
984 // RUN:   | FileCheck %s -check-prefix=CHECK_ATHLON_4_M64
985 // CHECK_ATHLON_4_M64: error:
986 //
987 // RUN: %clang -march=athlon-xp -m32 -E -dM %s -o - 2>&1 \
988 // RUN:     -target i386-unknown-linux \
989 // RUN:   | FileCheck %s -check-prefix=CHECK_ATHLON_XP_M32
990 // CHECK_ATHLON_XP_M32: #define __3dNOW_A__ 1
991 // CHECK_ATHLON_XP_M32: #define __3dNOW__ 1
992 // CHECK_ATHLON_XP_M32: #define __MMX__ 1
993 // CHECK_ATHLON_XP_M32: #define __SSE__ 1
994 // CHECK_ATHLON_XP_M32: #define __athlon 1
995 // CHECK_ATHLON_XP_M32: #define __athlon__ 1
996 // CHECK_ATHLON_XP_M32: #define __athlon_sse__ 1
997 // CHECK_ATHLON_XP_M32: #define __i386 1
998 // CHECK_ATHLON_XP_M32: #define __i386__ 1
999 // CHECK_ATHLON_XP_M32: #define __tune_athlon__ 1
1000 // CHECK_ATHLON_XP_M32: #define __tune_athlon_sse__ 1
1001 // CHECK_ATHLON_XP_M32: #define i386 1
1002 // RUN: not %clang -march=athlon-xp -m64 -E -dM %s -o - 2>&1 \
1003 // RUN:     -target i386-unknown-linux \
1004 // RUN:   | FileCheck %s -check-prefix=CHECK_ATHLON_XP_M64
1005 // CHECK_ATHLON_XP_M64: error:
1006 //
1007 // RUN: %clang -march=athlon-mp -m32 -E -dM %s -o - 2>&1 \
1008 // RUN:     -target i386-unknown-linux \
1009 // RUN:   | FileCheck %s -check-prefix=CHECK_ATHLON_MP_M32
1010 // CHECK_ATHLON_MP_M32: #define __3dNOW_A__ 1
1011 // CHECK_ATHLON_MP_M32: #define __3dNOW__ 1
1012 // CHECK_ATHLON_MP_M32: #define __MMX__ 1
1013 // CHECK_ATHLON_MP_M32: #define __SSE__ 1
1014 // CHECK_ATHLON_MP_M32: #define __athlon 1
1015 // CHECK_ATHLON_MP_M32: #define __athlon__ 1
1016 // CHECK_ATHLON_MP_M32: #define __athlon_sse__ 1
1017 // CHECK_ATHLON_MP_M32: #define __i386 1
1018 // CHECK_ATHLON_MP_M32: #define __i386__ 1
1019 // CHECK_ATHLON_MP_M32: #define __tune_athlon__ 1
1020 // CHECK_ATHLON_MP_M32: #define __tune_athlon_sse__ 1
1021 // CHECK_ATHLON_MP_M32: #define i386 1
1022 // RUN: not %clang -march=athlon-mp -m64 -E -dM %s -o - 2>&1 \
1023 // RUN:     -target i386-unknown-linux \
1024 // RUN:   | FileCheck %s -check-prefix=CHECK_ATHLON_MP_M64
1025 // CHECK_ATHLON_MP_M64: error:
1026 //
1027 // RUN: %clang -march=x86-64 -m32 -E -dM %s -o - 2>&1 \
1028 // RUN:     -target i386-unknown-linux \
1029 // RUN:   | FileCheck %s -check-prefix=CHECK_X86_64_M32
1030 // CHECK_X86_64_M32: #define __MMX__ 1
1031 // CHECK_X86_64_M32: #define __SSE2__ 1
1032 // CHECK_X86_64_M32: #define __SSE__ 1
1033 // CHECK_X86_64_M32: #define __i386 1
1034 // CHECK_X86_64_M32: #define __i386__ 1
1035 // CHECK_X86_64_M32: #define __k8 1
1036 // CHECK_X86_64_M32: #define __k8__ 1
1037 // CHECK_X86_64_M32: #define i386 1
1038 // RUN: %clang -march=x86-64 -m64 -E -dM %s -o - 2>&1 \
1039 // RUN:     -target i386-unknown-linux \
1040 // RUN:   | FileCheck %s -check-prefix=CHECK_X86_64_M64
1041 // CHECK_X86_64_M64: #define __MMX__ 1
1042 // CHECK_X86_64_M64: #define __SSE2_MATH__ 1
1043 // CHECK_X86_64_M64: #define __SSE2__ 1
1044 // CHECK_X86_64_M64: #define __SSE_MATH__ 1
1045 // CHECK_X86_64_M64: #define __SSE__ 1
1046 // CHECK_X86_64_M64: #define __amd64 1
1047 // CHECK_X86_64_M64: #define __amd64__ 1
1048 // CHECK_X86_64_M64: #define __k8 1
1049 // CHECK_X86_64_M64: #define __k8__ 1
1050 // CHECK_X86_64_M64: #define __x86_64 1
1051 // CHECK_X86_64_M64: #define __x86_64__ 1
1052 //
1053 // RUN: %clang -march=k8 -m32 -E -dM %s -o - 2>&1 \
1054 // RUN:     -target i386-unknown-linux \
1055 // RUN:   | FileCheck %s -check-prefix=CHECK_K8_M32
1056 // CHECK_K8_M32: #define __3dNOW_A__ 1
1057 // CHECK_K8_M32: #define __3dNOW__ 1
1058 // CHECK_K8_M32: #define __MMX__ 1
1059 // CHECK_K8_M32: #define __SSE2__ 1
1060 // CHECK_K8_M32: #define __SSE__ 1
1061 // CHECK_K8_M32: #define __i386 1
1062 // CHECK_K8_M32: #define __i386__ 1
1063 // CHECK_K8_M32: #define __k8 1
1064 // CHECK_K8_M32: #define __k8__ 1
1065 // CHECK_K8_M32: #define __tune_k8__ 1
1066 // CHECK_K8_M32: #define i386 1
1067 // RUN: %clang -march=k8 -m64 -E -dM %s -o - 2>&1 \
1068 // RUN:     -target i386-unknown-linux \
1069 // RUN:   | FileCheck %s -check-prefix=CHECK_K8_M64
1070 // CHECK_K8_M64: #define __3dNOW_A__ 1
1071 // CHECK_K8_M64: #define __3dNOW__ 1
1072 // CHECK_K8_M64: #define __MMX__ 1
1073 // CHECK_K8_M64: #define __SSE2_MATH__ 1
1074 // CHECK_K8_M64: #define __SSE2__ 1
1075 // CHECK_K8_M64: #define __SSE_MATH__ 1
1076 // CHECK_K8_M64: #define __SSE__ 1
1077 // CHECK_K8_M64: #define __amd64 1
1078 // CHECK_K8_M64: #define __amd64__ 1
1079 // CHECK_K8_M64: #define __k8 1
1080 // CHECK_K8_M64: #define __k8__ 1
1081 // CHECK_K8_M64: #define __tune_k8__ 1
1082 // CHECK_K8_M64: #define __x86_64 1
1083 // CHECK_K8_M64: #define __x86_64__ 1
1084 //
1085 // RUN: %clang -march=k8-sse3 -m32 -E -dM %s -o - 2>&1 \
1086 // RUN:     -target i386-unknown-linux \
1087 // RUN:   | FileCheck %s -check-prefix=CHECK_K8_SSE3_M32
1088 // CHECK_K8_SSE3_M32: #define __3dNOW_A__ 1
1089 // CHECK_K8_SSE3_M32: #define __3dNOW__ 1
1090 // CHECK_K8_SSE3_M32: #define __MMX__ 1
1091 // CHECK_K8_SSE3_M32: #define __SSE2__ 1
1092 // CHECK_K8_SSE3_M32: #define __SSE3__ 1
1093 // CHECK_K8_SSE3_M32: #define __SSE__ 1
1094 // CHECK_K8_SSE3_M32: #define __i386 1
1095 // CHECK_K8_SSE3_M32: #define __i386__ 1
1096 // CHECK_K8_SSE3_M32: #define __k8 1
1097 // CHECK_K8_SSE3_M32: #define __k8__ 1
1098 // CHECK_K8_SSE3_M32: #define __tune_k8__ 1
1099 // CHECK_K8_SSE3_M32: #define i386 1
1100 // RUN: %clang -march=k8-sse3 -m64 -E -dM %s -o - 2>&1 \
1101 // RUN:     -target i386-unknown-linux \
1102 // RUN:   | FileCheck %s -check-prefix=CHECK_K8_SSE3_M64
1103 // CHECK_K8_SSE3_M64: #define __3dNOW_A__ 1
1104 // CHECK_K8_SSE3_M64: #define __3dNOW__ 1
1105 // CHECK_K8_SSE3_M64: #define __MMX__ 1
1106 // CHECK_K8_SSE3_M64: #define __SSE2_MATH__ 1
1107 // CHECK_K8_SSE3_M64: #define __SSE2__ 1
1108 // CHECK_K8_SSE3_M64: #define __SSE3__ 1
1109 // CHECK_K8_SSE3_M64: #define __SSE_MATH__ 1
1110 // CHECK_K8_SSE3_M64: #define __SSE__ 1
1111 // CHECK_K8_SSE3_M64: #define __amd64 1
1112 // CHECK_K8_SSE3_M64: #define __amd64__ 1
1113 // CHECK_K8_SSE3_M64: #define __k8 1
1114 // CHECK_K8_SSE3_M64: #define __k8__ 1
1115 // CHECK_K8_SSE3_M64: #define __tune_k8__ 1
1116 // CHECK_K8_SSE3_M64: #define __x86_64 1
1117 // CHECK_K8_SSE3_M64: #define __x86_64__ 1
1118 //
1119 // RUN: %clang -march=opteron -m32 -E -dM %s -o - 2>&1 \
1120 // RUN:     -target i386-unknown-linux \
1121 // RUN:   | FileCheck %s -check-prefix=CHECK_OPTERON_M32
1122 // CHECK_OPTERON_M32: #define __3dNOW_A__ 1
1123 // CHECK_OPTERON_M32: #define __3dNOW__ 1
1124 // CHECK_OPTERON_M32: #define __MMX__ 1
1125 // CHECK_OPTERON_M32: #define __SSE2__ 1
1126 // CHECK_OPTERON_M32: #define __SSE__ 1
1127 // CHECK_OPTERON_M32: #define __i386 1
1128 // CHECK_OPTERON_M32: #define __i386__ 1
1129 // CHECK_OPTERON_M32: #define __k8 1
1130 // CHECK_OPTERON_M32: #define __k8__ 1
1131 // CHECK_OPTERON_M32: #define __tune_k8__ 1
1132 // CHECK_OPTERON_M32: #define i386 1
1133 // RUN: %clang -march=opteron -m64 -E -dM %s -o - 2>&1 \
1134 // RUN:     -target i386-unknown-linux \
1135 // RUN:   | FileCheck %s -check-prefix=CHECK_OPTERON_M64
1136 // CHECK_OPTERON_M64: #define __3dNOW_A__ 1
1137 // CHECK_OPTERON_M64: #define __3dNOW__ 1
1138 // CHECK_OPTERON_M64: #define __MMX__ 1
1139 // CHECK_OPTERON_M64: #define __SSE2_MATH__ 1
1140 // CHECK_OPTERON_M64: #define __SSE2__ 1
1141 // CHECK_OPTERON_M64: #define __SSE_MATH__ 1
1142 // CHECK_OPTERON_M64: #define __SSE__ 1
1143 // CHECK_OPTERON_M64: #define __amd64 1
1144 // CHECK_OPTERON_M64: #define __amd64__ 1
1145 // CHECK_OPTERON_M64: #define __k8 1
1146 // CHECK_OPTERON_M64: #define __k8__ 1
1147 // CHECK_OPTERON_M64: #define __tune_k8__ 1
1148 // CHECK_OPTERON_M64: #define __x86_64 1
1149 // CHECK_OPTERON_M64: #define __x86_64__ 1
1150 //
1151 // RUN: %clang -march=opteron-sse3 -m32 -E -dM %s -o - 2>&1 \
1152 // RUN:     -target i386-unknown-linux \
1153 // RUN:   | FileCheck %s -check-prefix=CHECK_OPTERON_SSE3_M32
1154 // CHECK_OPTERON_SSE3_M32: #define __3dNOW_A__ 1
1155 // CHECK_OPTERON_SSE3_M32: #define __3dNOW__ 1
1156 // CHECK_OPTERON_SSE3_M32: #define __MMX__ 1
1157 // CHECK_OPTERON_SSE3_M32: #define __SSE2__ 1
1158 // CHECK_OPTERON_SSE3_M32: #define __SSE3__ 1
1159 // CHECK_OPTERON_SSE3_M32: #define __SSE__ 1
1160 // CHECK_OPTERON_SSE3_M32: #define __i386 1
1161 // CHECK_OPTERON_SSE3_M32: #define __i386__ 1
1162 // CHECK_OPTERON_SSE3_M32: #define __k8 1
1163 // CHECK_OPTERON_SSE3_M32: #define __k8__ 1
1164 // CHECK_OPTERON_SSE3_M32: #define __tune_k8__ 1
1165 // CHECK_OPTERON_SSE3_M32: #define i386 1
1166 // RUN: %clang -march=opteron-sse3 -m64 -E -dM %s -o - 2>&1 \
1167 // RUN:     -target i386-unknown-linux \
1168 // RUN:   | FileCheck %s -check-prefix=CHECK_OPTERON_SSE3_M64
1169 // CHECK_OPTERON_SSE3_M64: #define __3dNOW_A__ 1
1170 // CHECK_OPTERON_SSE3_M64: #define __3dNOW__ 1
1171 // CHECK_OPTERON_SSE3_M64: #define __MMX__ 1
1172 // CHECK_OPTERON_SSE3_M64: #define __SSE2_MATH__ 1
1173 // CHECK_OPTERON_SSE3_M64: #define __SSE2__ 1
1174 // CHECK_OPTERON_SSE3_M64: #define __SSE3__ 1
1175 // CHECK_OPTERON_SSE3_M64: #define __SSE_MATH__ 1
1176 // CHECK_OPTERON_SSE3_M64: #define __SSE__ 1
1177 // CHECK_OPTERON_SSE3_M64: #define __amd64 1
1178 // CHECK_OPTERON_SSE3_M64: #define __amd64__ 1
1179 // CHECK_OPTERON_SSE3_M64: #define __k8 1
1180 // CHECK_OPTERON_SSE3_M64: #define __k8__ 1
1181 // CHECK_OPTERON_SSE3_M64: #define __tune_k8__ 1
1182 // CHECK_OPTERON_SSE3_M64: #define __x86_64 1
1183 // CHECK_OPTERON_SSE3_M64: #define __x86_64__ 1
1184 //
1185 // RUN: %clang -march=athlon64 -m32 -E -dM %s -o - 2>&1 \
1186 // RUN:     -target i386-unknown-linux \
1187 // RUN:   | FileCheck %s -check-prefix=CHECK_ATHLON64_M32
1188 // CHECK_ATHLON64_M32: #define __3dNOW_A__ 1
1189 // CHECK_ATHLON64_M32: #define __3dNOW__ 1
1190 // CHECK_ATHLON64_M32: #define __MMX__ 1
1191 // CHECK_ATHLON64_M32: #define __SSE2__ 1
1192 // CHECK_ATHLON64_M32: #define __SSE__ 1
1193 // CHECK_ATHLON64_M32: #define __i386 1
1194 // CHECK_ATHLON64_M32: #define __i386__ 1
1195 // CHECK_ATHLON64_M32: #define __k8 1
1196 // CHECK_ATHLON64_M32: #define __k8__ 1
1197 // CHECK_ATHLON64_M32: #define __tune_k8__ 1
1198 // CHECK_ATHLON64_M32: #define i386 1
1199 // RUN: %clang -march=athlon64 -m64 -E -dM %s -o - 2>&1 \
1200 // RUN:     -target i386-unknown-linux \
1201 // RUN:   | FileCheck %s -check-prefix=CHECK_ATHLON64_M64
1202 // CHECK_ATHLON64_M64: #define __3dNOW_A__ 1
1203 // CHECK_ATHLON64_M64: #define __3dNOW__ 1
1204 // CHECK_ATHLON64_M64: #define __MMX__ 1
1205 // CHECK_ATHLON64_M64: #define __SSE2_MATH__ 1
1206 // CHECK_ATHLON64_M64: #define __SSE2__ 1
1207 // CHECK_ATHLON64_M64: #define __SSE_MATH__ 1
1208 // CHECK_ATHLON64_M64: #define __SSE__ 1
1209 // CHECK_ATHLON64_M64: #define __amd64 1
1210 // CHECK_ATHLON64_M64: #define __amd64__ 1
1211 // CHECK_ATHLON64_M64: #define __k8 1
1212 // CHECK_ATHLON64_M64: #define __k8__ 1
1213 // CHECK_ATHLON64_M64: #define __tune_k8__ 1
1214 // CHECK_ATHLON64_M64: #define __x86_64 1
1215 // CHECK_ATHLON64_M64: #define __x86_64__ 1
1216 //
1217 // RUN: %clang -march=athlon64-sse3 -m32 -E -dM %s -o - 2>&1 \
1218 // RUN:     -target i386-unknown-linux \
1219 // RUN:   | FileCheck %s -check-prefix=CHECK_ATHLON64_SSE3_M32
1220 // CHECK_ATHLON64_SSE3_M32: #define __3dNOW_A__ 1
1221 // CHECK_ATHLON64_SSE3_M32: #define __3dNOW__ 1
1222 // CHECK_ATHLON64_SSE3_M32: #define __MMX__ 1
1223 // CHECK_ATHLON64_SSE3_M32: #define __SSE2__ 1
1224 // CHECK_ATHLON64_SSE3_M32: #define __SSE3__ 1
1225 // CHECK_ATHLON64_SSE3_M32: #define __SSE__ 1
1226 // CHECK_ATHLON64_SSE3_M32: #define __i386 1
1227 // CHECK_ATHLON64_SSE3_M32: #define __i386__ 1
1228 // CHECK_ATHLON64_SSE3_M32: #define __k8 1
1229 // CHECK_ATHLON64_SSE3_M32: #define __k8__ 1
1230 // CHECK_ATHLON64_SSE3_M32: #define __tune_k8__ 1
1231 // CHECK_ATHLON64_SSE3_M32: #define i386 1
1232 // RUN: %clang -march=athlon64-sse3 -m64 -E -dM %s -o - 2>&1 \
1233 // RUN:     -target i386-unknown-linux \
1234 // RUN:   | FileCheck %s -check-prefix=CHECK_ATHLON64_SSE3_M64
1235 // CHECK_ATHLON64_SSE3_M64: #define __3dNOW_A__ 1
1236 // CHECK_ATHLON64_SSE3_M64: #define __3dNOW__ 1
1237 // CHECK_ATHLON64_SSE3_M64: #define __MMX__ 1
1238 // CHECK_ATHLON64_SSE3_M64: #define __SSE2_MATH__ 1
1239 // CHECK_ATHLON64_SSE3_M64: #define __SSE2__ 1
1240 // CHECK_ATHLON64_SSE3_M64: #define __SSE3__ 1
1241 // CHECK_ATHLON64_SSE3_M64: #define __SSE_MATH__ 1
1242 // CHECK_ATHLON64_SSE3_M64: #define __SSE__ 1
1243 // CHECK_ATHLON64_SSE3_M64: #define __amd64 1
1244 // CHECK_ATHLON64_SSE3_M64: #define __amd64__ 1
1245 // CHECK_ATHLON64_SSE3_M64: #define __k8 1
1246 // CHECK_ATHLON64_SSE3_M64: #define __k8__ 1
1247 // CHECK_ATHLON64_SSE3_M64: #define __tune_k8__ 1
1248 // CHECK_ATHLON64_SSE3_M64: #define __x86_64 1
1249 // CHECK_ATHLON64_SSE3_M64: #define __x86_64__ 1
1250 //
1251 // RUN: %clang -march=athlon-fx -m32 -E -dM %s -o - 2>&1 \
1252 // RUN:     -target i386-unknown-linux \
1253 // RUN:   | FileCheck %s -check-prefix=CHECK_ATHLON_FX_M32
1254 // CHECK_ATHLON_FX_M32: #define __3dNOW_A__ 1
1255 // CHECK_ATHLON_FX_M32: #define __3dNOW__ 1
1256 // CHECK_ATHLON_FX_M32: #define __MMX__ 1
1257 // CHECK_ATHLON_FX_M32: #define __SSE2__ 1
1258 // CHECK_ATHLON_FX_M32: #define __SSE__ 1
1259 // CHECK_ATHLON_FX_M32: #define __i386 1
1260 // CHECK_ATHLON_FX_M32: #define __i386__ 1
1261 // CHECK_ATHLON_FX_M32: #define __k8 1
1262 // CHECK_ATHLON_FX_M32: #define __k8__ 1
1263 // CHECK_ATHLON_FX_M32: #define __tune_k8__ 1
1264 // CHECK_ATHLON_FX_M32: #define i386 1
1265 // RUN: %clang -march=athlon-fx -m64 -E -dM %s -o - 2>&1 \
1266 // RUN:     -target i386-unknown-linux \
1267 // RUN:   | FileCheck %s -check-prefix=CHECK_ATHLON_FX_M64
1268 // CHECK_ATHLON_FX_M64: #define __3dNOW_A__ 1
1269 // CHECK_ATHLON_FX_M64: #define __3dNOW__ 1
1270 // CHECK_ATHLON_FX_M64: #define __MMX__ 1
1271 // CHECK_ATHLON_FX_M64: #define __SSE2_MATH__ 1
1272 // CHECK_ATHLON_FX_M64: #define __SSE2__ 1
1273 // CHECK_ATHLON_FX_M64: #define __SSE_MATH__ 1
1274 // CHECK_ATHLON_FX_M64: #define __SSE__ 1
1275 // CHECK_ATHLON_FX_M64: #define __amd64 1
1276 // CHECK_ATHLON_FX_M64: #define __amd64__ 1
1277 // CHECK_ATHLON_FX_M64: #define __k8 1
1278 // CHECK_ATHLON_FX_M64: #define __k8__ 1
1279 // CHECK_ATHLON_FX_M64: #define __tune_k8__ 1
1280 // CHECK_ATHLON_FX_M64: #define __x86_64 1
1281 // CHECK_ATHLON_FX_M64: #define __x86_64__ 1
1282 // RUN: %clang -march=amdfam10 -m32 -E -dM %s -o - 2>&1 \
1283 // RUN:     -target i386-unknown-linux \
1284 // RUN:   | FileCheck %s -check-prefix=CHECK_AMDFAM10_M32
1285 // CHECK_AMDFAM10_M32: #define __3dNOW_A__ 1
1286 // CHECK_AMDFAM10_M32: #define __3dNOW__ 1
1287 // CHECK_AMDFAM10_M32: #define __LZCNT__ 1
1288 // CHECK_AMDFAM10_M32: #define __MMX__ 1
1289 // CHECK_AMDFAM10_M32: #define __POPCNT__ 1
1290 // CHECK_AMDFAM10_M32: #define __SSE2_MATH__ 1
1291 // CHECK_AMDFAM10_M32: #define __SSE2__ 1
1292 // CHECK_AMDFAM10_M32: #define __SSE3__ 1
1293 // CHECK_AMDFAM10_M32: #define __SSE4A__ 1
1294 // CHECK_AMDFAM10_M32: #define __SSE_MATH__ 1
1295 // CHECK_AMDFAM10_M32: #define __SSE__ 1
1296 // CHECK_AMDFAM10_M32: #define __amdfam10 1
1297 // CHECK_AMDFAM10_M32: #define __amdfam10__ 1
1298 // CHECK_AMDFAM10_M32: #define __i386 1
1299 // CHECK_AMDFAM10_M32: #define __i386__ 1
1300 // CHECK_AMDFAM10_M32: #define __tune_amdfam10__ 1
1301 // RUN: %clang -march=amdfam10 -m64 -E -dM %s -o - 2>&1 \
1302 // RUN:     -target i386-unknown-linux \
1303 // RUN:   | FileCheck %s -check-prefix=CHECK_AMDFAM10_M64
1304 // CHECK_AMDFAM10_M64: #define __3dNOW_A__ 1
1305 // CHECK_AMDFAM10_M64: #define __3dNOW__ 1
1306 // CHECK_AMDFAM10_M64: #define __LZCNT__ 1
1307 // CHECK_AMDFAM10_M64: #define __MMX__ 1
1308 // CHECK_AMDFAM10_M64: #define __POPCNT__ 1
1309 // CHECK_AMDFAM10_M64: #define __SSE2_MATH__ 1
1310 // CHECK_AMDFAM10_M64: #define __SSE2__ 1
1311 // CHECK_AMDFAM10_M64: #define __SSE3__ 1
1312 // CHECK_AMDFAM10_M64: #define __SSE4A__ 1
1313 // CHECK_AMDFAM10_M64: #define __SSE_MATH__ 1
1314 // CHECK_AMDFAM10_M64: #define __SSE__ 1
1315 // CHECK_AMDFAM10_M64: #define __amd64 1
1316 // CHECK_AMDFAM10_M64: #define __amd64__ 1
1317 // CHECK_AMDFAM10_M64: #define __amdfam10 1
1318 // CHECK_AMDFAM10_M64: #define __amdfam10__ 1
1319 // CHECK_AMDFAM10_M64: #define __tune_amdfam10__ 1
1320 // CHECK_AMDFAM10_M64: #define __x86_64 1
1321 // CHECK_AMDFAM10_M64: #define __x86_64__ 1
1322 // RUN: %clang -march=btver1 -m32 -E -dM %s -o - 2>&1 \
1323 // RUN:     -target i386-unknown-linux \
1324 // RUN:   | FileCheck %s -check-prefix=CHECK_BTVER1_M32
1325 // CHECK_BTVER1_M32-NOT: #define __3dNOW_A__ 1
1326 // CHECK_BTVER1_M32-NOT: #define __3dNOW__ 1
1327 // CHECK_BTVER1_M32: #define __LZCNT__ 1
1328 // CHECK_BTVER1_M32: #define __MMX__ 1
1329 // CHECK_BTVER1_M32: #define __POPCNT__ 1
1330 // CHECK_BTVER1_M32: #define __PRFCHW__ 1
1331 // CHECK_BTVER1_M32: #define __SSE2_MATH__ 1
1332 // CHECK_BTVER1_M32: #define __SSE2__ 1
1333 // CHECK_BTVER1_M32: #define __SSE3__ 1
1334 // CHECK_BTVER1_M32: #define __SSE4A__ 1
1335 // CHECK_BTVER1_M32: #define __SSE_MATH__ 1
1336 // CHECK_BTVER1_M32: #define __SSE__ 1
1337 // CHECK_BTVER1_M32: #define __SSSE3__ 1
1338 // CHECK_BTVER1_M32: #define __XSAVE__ 1
1339 // CHECK_BTVER1_M32: #define __btver1 1
1340 // CHECK_BTVER1_M32: #define __btver1__ 1
1341 // CHECK_BTVER1_M32: #define __i386 1
1342 // CHECK_BTVER1_M32: #define __i386__ 1
1343 // CHECK_BTVER1_M32: #define __tune_btver1__ 1
1344 // RUN: %clang -march=btver1 -m64 -E -dM %s -o - 2>&1 \
1345 // RUN:     -target i386-unknown-linux \
1346 // RUN:   | FileCheck %s -check-prefix=CHECK_BTVER1_M64
1347 // CHECK_BTVER1_M64-NOT: #define __3dNOW_A__ 1
1348 // CHECK_BTVER1_M64-NOT: #define __3dNOW__ 1
1349 // CHECK_BTVER1_M64: #define __LZCNT__ 1
1350 // CHECK_BTVER1_M64: #define __MMX__ 1
1351 // CHECK_BTVER1_M64: #define __POPCNT__ 1
1352 // CHECK_BTVER1_M64: #define __PRFCHW__ 1
1353 // CHECK_BTVER1_M64: #define __SSE2_MATH__ 1
1354 // CHECK_BTVER1_M64: #define __SSE2__ 1
1355 // CHECK_BTVER1_M64: #define __SSE3__ 1
1356 // CHECK_BTVER1_M64: #define __SSE4A__ 1
1357 // CHECK_BTVER1_M64: #define __SSE_MATH__ 1
1358 // CHECK_BTVER1_M64: #define __SSE__ 1
1359 // CHECK_BTVER1_M64: #define __SSSE3__ 1
1360 // CHECK_BTVER1_M64: #define __XSAVE__ 1
1361 // CHECK_BTVER1_M64: #define __amd64 1
1362 // CHECK_BTVER1_M64: #define __amd64__ 1
1363 // CHECK_BTVER1_M64: #define __btver1 1
1364 // CHECK_BTVER1_M64: #define __btver1__ 1
1365 // CHECK_BTVER1_M64: #define __tune_btver1__ 1
1366 // CHECK_BTVER1_M64: #define __x86_64 1
1367 // CHECK_BTVER1_M64: #define __x86_64__ 1
1368 // RUN: %clang -march=btver2 -m32 -E -dM %s -o - 2>&1 \
1369 // RUN:     -target i386-unknown-linux \
1370 // RUN:   | FileCheck %s -check-prefix=CHECK_BTVER2_M32
1371 // CHECK_BTVER2_M32-NOT: #define __3dNOW_A__ 1
1372 // CHECK_BTVER2_M32-NOT: #define __3dNOW__ 1
1373 // CHECK_BTVER2_M32: #define __AES__ 1
1374 // CHECK_BTVER2_M32: #define __AVX__ 1
1375 // CHECK_BTVER2_M32: #define __BMI__ 1
1376 // CHECK_BTVER2_M32: #define __F16C__ 1
1377 // CHECK_BTVER2_M32: #define __LZCNT__ 1
1378 // CHECK_BTVER2_M32: #define __MMX__ 1
1379 // CHECK_BTVER2_M32: #define __PCLMUL__ 1
1380 // CHECK_BTVER2_M32: #define __POPCNT__ 1
1381 // CHECK_BTVER2_M32: #define __PRFCHW__ 1
1382 // CHECK_BTVER2_M32: #define __SSE2_MATH__ 1
1383 // CHECK_BTVER2_M32: #define __SSE2__ 1
1384 // CHECK_BTVER2_M32: #define __SSE3__ 1
1385 // CHECK_BTVER2_M32: #define __SSE4A__ 1
1386 // CHECK_BTVER2_M32: #define __SSE_MATH__ 1
1387 // CHECK_BTVER2_M32: #define __SSE__ 1
1388 // CHECK_BTVER2_M32: #define __SSSE3__ 1
1389 // CHECK_BTVER2_M32: #define __XSAVEOPT__ 1
1390 // CHECK_BTVER2_M32: #define __XSAVE__ 1
1391 // CHECK_BTVER2_M32: #define __btver2 1
1392 // CHECK_BTVER2_M32: #define __btver2__ 1
1393 // CHECK_BTVER2_M32: #define __i386 1
1394 // CHECK_BTVER2_M32: #define __i386__ 1
1395 // CHECK_BTVER2_M32: #define __tune_btver2__ 1
1396 // RUN: %clang -march=btver2 -m64 -E -dM %s -o - 2>&1 \
1397 // RUN:     -target i386-unknown-linux \
1398 // RUN:   | FileCheck %s -check-prefix=CHECK_BTVER2_M64
1399 // CHECK_BTVER2_M64-NOT: #define __3dNOW_A__ 1
1400 // CHECK_BTVER2_M64-NOT: #define __3dNOW__ 1
1401 // CHECK_BTVER2_M64: #define __AES__ 1
1402 // CHECK_BTVER2_M64: #define __AVX__ 1
1403 // CHECK_BTVER2_M64: #define __BMI__ 1
1404 // CHECK_BTVER2_M64: #define __F16C__ 1
1405 // CHECK_BTVER2_M64: #define __LZCNT__ 1
1406 // CHECK_BTVER2_M64: #define __MMX__ 1
1407 // CHECK_BTVER2_M64: #define __PCLMUL__ 1
1408 // CHECK_BTVER2_M64: #define __POPCNT__ 1
1409 // CHECK_BTVER2_M64: #define __PRFCHW__ 1
1410 // CHECK_BTVER2_M64: #define __SSE2_MATH__ 1
1411 // CHECK_BTVER2_M64: #define __SSE2__ 1
1412 // CHECK_BTVER2_M64: #define __SSE3__ 1
1413 // CHECK_BTVER2_M64: #define __SSE4A__ 1
1414 // CHECK_BTVER2_M64: #define __SSE_MATH__ 1
1415 // CHECK_BTVER2_M64: #define __SSE__ 1
1416 // CHECK_BTVER2_M64: #define __SSSE3__ 1
1417 // CHECK_BTVER2_M64: #define __XSAVEOPT__ 1
1418 // CHECK_BTVER2_M64: #define __XSAVE__ 1
1419 // CHECK_BTVER2_M64: #define __amd64 1
1420 // CHECK_BTVER2_M64: #define __amd64__ 1
1421 // CHECK_BTVER2_M64: #define __btver2 1
1422 // CHECK_BTVER2_M64: #define __btver2__ 1
1423 // CHECK_BTVER2_M64: #define __tune_btver2__ 1
1424 // CHECK_BTVER2_M64: #define __x86_64 1
1425 // CHECK_BTVER2_M64: #define __x86_64__ 1
1426 // RUN: %clang -march=bdver1 -m32 -E -dM %s -o - 2>&1 \
1427 // RUN:     -target i386-unknown-linux \
1428 // RUN:   | FileCheck %s -check-prefix=CHECK_BDVER1_M32
1429 // CHECK_BDVER1_M32-NOT: #define __3dNOW_A__ 1
1430 // CHECK_BDVER1_M32-NOT: #define __3dNOW__ 1
1431 // CHECK_BDVER1_M32: #define __AES__ 1
1432 // CHECK_BDVER1_M32: #define __AVX__ 1
1433 // CHECK_BDVER1_M32: #define __FMA4__ 1
1434 // CHECK_BDVER1_M32: #define __LZCNT__ 1
1435 // CHECK_BDVER1_M32: #define __MMX__ 1
1436 // CHECK_BDVER1_M32: #define __PCLMUL__ 1
1437 // CHECK_BDVER1_M32: #define __POPCNT__ 1
1438 // CHECK_BDVER1_M32: #define __PRFCHW__ 1
1439 // CHECK_BDVER1_M32: #define __SSE2_MATH__ 1
1440 // CHECK_BDVER1_M32: #define __SSE2__ 1
1441 // CHECK_BDVER1_M32: #define __SSE3__ 1
1442 // CHECK_BDVER1_M32: #define __SSE4A__ 1
1443 // CHECK_BDVER1_M32: #define __SSE4_1__ 1
1444 // CHECK_BDVER1_M32: #define __SSE4_2__ 1
1445 // CHECK_BDVER1_M32: #define __SSE_MATH__ 1
1446 // CHECK_BDVER1_M32: #define __SSE__ 1
1447 // CHECK_BDVER1_M32: #define __SSSE3__ 1
1448 // CHECK_BDVER1_M32: #define __XOP__ 1
1449 // CHECK_BDVER1_M32: #define __XSAVE__ 1
1450 // CHECK_BDVER1_M32: #define __bdver1 1
1451 // CHECK_BDVER1_M32: #define __bdver1__ 1
1452 // CHECK_BDVER1_M32: #define __i386 1
1453 // CHECK_BDVER1_M32: #define __i386__ 1
1454 // CHECK_BDVER1_M32: #define __tune_bdver1__ 1
1455 // RUN: %clang -march=bdver1 -m64 -E -dM %s -o - 2>&1 \
1456 // RUN:     -target i386-unknown-linux \
1457 // RUN:   | FileCheck %s -check-prefix=CHECK_BDVER1_M64
1458 // CHECK_BDVER1_M64-NOT: #define __3dNOW_A__ 1
1459 // CHECK_BDVER1_M64-NOT: #define __3dNOW__ 1
1460 // CHECK_BDVER1_M64: #define __AES__ 1
1461 // CHECK_BDVER1_M64: #define __AVX__ 1
1462 // CHECK_BDVER1_M64: #define __FMA4__ 1
1463 // CHECK_BDVER1_M64: #define __LZCNT__ 1
1464 // CHECK_BDVER1_M64: #define __MMX__ 1
1465 // CHECK_BDVER1_M64: #define __PCLMUL__ 1
1466 // CHECK_BDVER1_M64: #define __POPCNT__ 1
1467 // CHECK_BDVER1_M64: #define __PRFCHW__ 1
1468 // CHECK_BDVER1_M64: #define __SSE2_MATH__ 1
1469 // CHECK_BDVER1_M64: #define __SSE2__ 1
1470 // CHECK_BDVER1_M64: #define __SSE3__ 1
1471 // CHECK_BDVER1_M64: #define __SSE4A__ 1
1472 // CHECK_BDVER1_M64: #define __SSE4_1__ 1
1473 // CHECK_BDVER1_M64: #define __SSE4_2__ 1
1474 // CHECK_BDVER1_M64: #define __SSE_MATH__ 1
1475 // CHECK_BDVER1_M64: #define __SSE__ 1
1476 // CHECK_BDVER1_M64: #define __SSSE3__ 1
1477 // CHECK_BDVER1_M64: #define __XOP__ 1
1478 // CHECK_BDVER1_M64: #define __XSAVE__ 1
1479 // CHECK_BDVER1_M64: #define __amd64 1
1480 // CHECK_BDVER1_M64: #define __amd64__ 1
1481 // CHECK_BDVER1_M64: #define __bdver1 1
1482 // CHECK_BDVER1_M64: #define __bdver1__ 1
1483 // CHECK_BDVER1_M64: #define __tune_bdver1__ 1
1484 // CHECK_BDVER1_M64: #define __x86_64 1
1485 // CHECK_BDVER1_M64: #define __x86_64__ 1
1486 // RUN: %clang -march=bdver2 -m32 -E -dM %s -o - 2>&1 \
1487 // RUN:     -target i386-unknown-linux \
1488 // RUN:   | FileCheck %s -check-prefix=CHECK_BDVER2_M32
1489 // CHECK_BDVER2_M32-NOT: #define __3dNOW_A__ 1
1490 // CHECK_BDVER2_M32-NOT: #define __3dNOW__ 1
1491 // CHECK_BDVER2_M32: #define __AES__ 1
1492 // CHECK_BDVER2_M32: #define __AVX__ 1
1493 // CHECK_BDVER2_M32: #define __BMI__ 1
1494 // CHECK_BDVER2_M32: #define __F16C__ 1
1495 // CHECK_BDVER2_M32: #define __FMA4__ 1
1496 // CHECK_BDVER2_M32: #define __FMA__ 1
1497 // CHECK_BDVER2_M32: #define __LZCNT__ 1
1498 // CHECK_BDVER2_M32: #define __MMX__ 1
1499 // CHECK_BDVER2_M32: #define __PCLMUL__ 1
1500 // CHECK_BDVER2_M32: #define __POPCNT__ 1
1501 // CHECK_BDVER2_M32: #define __PRFCHW__ 1
1502 // CHECK_BDVER2_M32: #define __SSE2_MATH__ 1
1503 // CHECK_BDVER2_M32: #define __SSE2__ 1
1504 // CHECK_BDVER2_M32: #define __SSE3__ 1
1505 // CHECK_BDVER2_M32: #define __SSE4A__ 1
1506 // CHECK_BDVER2_M32: #define __SSE4_1__ 1
1507 // CHECK_BDVER2_M32: #define __SSE4_2__ 1
1508 // CHECK_BDVER2_M32: #define __SSE_MATH__ 1
1509 // CHECK_BDVER2_M32: #define __SSE__ 1
1510 // CHECK_BDVER2_M32: #define __SSSE3__ 1
1511 // CHECK_BDVER2_M32: #define __TBM__ 1
1512 // CHECK_BDVER2_M32: #define __XOP__ 1
1513 // CHECK_BDVER2_M32: #define __XSAVE__ 1
1514 // CHECK_BDVER2_M32: #define __bdver2 1
1515 // CHECK_BDVER2_M32: #define __bdver2__ 1
1516 // CHECK_BDVER2_M32: #define __i386 1
1517 // CHECK_BDVER2_M32: #define __i386__ 1
1518 // CHECK_BDVER2_M32: #define __tune_bdver2__ 1
1519 // RUN: %clang -march=bdver2 -m64 -E -dM %s -o - 2>&1 \
1520 // RUN:     -target i386-unknown-linux \
1521 // RUN:   | FileCheck %s -check-prefix=CHECK_BDVER2_M64
1522 // CHECK_BDVER2_M64-NOT: #define __3dNOW_A__ 1
1523 // CHECK_BDVER2_M64-NOT: #define __3dNOW__ 1
1524 // CHECK_BDVER2_M64: #define __AES__ 1
1525 // CHECK_BDVER2_M64: #define __AVX__ 1
1526 // CHECK_BDVER2_M64: #define __BMI__ 1
1527 // CHECK_BDVER2_M64: #define __F16C__ 1
1528 // CHECK_BDVER2_M64: #define __FMA4__ 1
1529 // CHECK_BDVER2_M64: #define __FMA__ 1
1530 // CHECK_BDVER2_M64: #define __LZCNT__ 1
1531 // CHECK_BDVER2_M64: #define __MMX__ 1
1532 // CHECK_BDVER2_M64: #define __PCLMUL__ 1
1533 // CHECK_BDVER2_M64: #define __POPCNT__ 1
1534 // CHECK_BDVER2_M64: #define __PRFCHW__ 1
1535 // CHECK_BDVER2_M64: #define __SSE2_MATH__ 1
1536 // CHECK_BDVER2_M64: #define __SSE2__ 1
1537 // CHECK_BDVER2_M64: #define __SSE3__ 1
1538 // CHECK_BDVER2_M64: #define __SSE4A__ 1
1539 // CHECK_BDVER2_M64: #define __SSE4_1__ 1
1540 // CHECK_BDVER2_M64: #define __SSE4_2__ 1
1541 // CHECK_BDVER2_M64: #define __SSE_MATH__ 1
1542 // CHECK_BDVER2_M64: #define __SSE__ 1
1543 // CHECK_BDVER2_M64: #define __SSSE3__ 1
1544 // CHECK_BDVER2_M64: #define __TBM__ 1
1545 // CHECK_BDVER2_M64: #define __XOP__ 1
1546 // CHECK_BDVER2_M64: #define __XSAVE__ 1
1547 // CHECK_BDVER2_M64: #define __amd64 1
1548 // CHECK_BDVER2_M64: #define __amd64__ 1
1549 // CHECK_BDVER2_M64: #define __bdver2 1
1550 // CHECK_BDVER2_M64: #define __bdver2__ 1
1551 // CHECK_BDVER2_M64: #define __tune_bdver2__ 1
1552 // CHECK_BDVER2_M64: #define __x86_64 1
1553 // CHECK_BDVER2_M64: #define __x86_64__ 1
1554 // RUN: %clang -march=bdver3 -m32 -E -dM %s -o - 2>&1 \
1555 // RUN:     -target i386-unknown-linux \
1556 // RUN:   | FileCheck %s -check-prefix=CHECK_BDVER3_M32
1557 // CHECK_BDVER3_M32-NOT: #define __3dNOW_A__ 1
1558 // CHECK_BDVER3_M32-NOT: #define __3dNOW__ 1
1559 // CHECK_BDVER3_M32: #define __AES__ 1
1560 // CHECK_BDVER3_M32: #define __AVX__ 1
1561 // CHECK_BDVER3_M32: #define __BMI__ 1
1562 // CHECK_BDVER3_M32: #define __F16C__ 1
1563 // CHECK_BDVER3_M32: #define __FMA4__ 1
1564 // CHECK_BDVER3_M32: #define __FMA__ 1
1565 // CHECK_BDVER3_M32: #define __FSGSBASE__ 1
1566 // CHECK_BDVER3_M32: #define __LZCNT__ 1
1567 // CHECK_BDVER3_M32: #define __MMX__ 1
1568 // CHECK_BDVER3_M32: #define __PCLMUL__ 1
1569 // CHECK_BDVER3_M32: #define __POPCNT__ 1
1570 // CHECK_BDVER3_M32: #define __PRFCHW__ 1
1571 // CHECK_BDVER3_M32: #define __SSE2_MATH__ 1
1572 // CHECK_BDVER3_M32: #define __SSE2__ 1
1573 // CHECK_BDVER3_M32: #define __SSE3__ 1
1574 // CHECK_BDVER3_M32: #define __SSE4A__ 1
1575 // CHECK_BDVER3_M32: #define __SSE4_1__ 1
1576 // CHECK_BDVER3_M32: #define __SSE4_2__ 1
1577 // CHECK_BDVER3_M32: #define __SSE_MATH__ 1
1578 // CHECK_BDVER3_M32: #define __SSE__ 1
1579 // CHECK_BDVER3_M32: #define __SSSE3__ 1
1580 // CHECK_BDVER3_M32: #define __TBM__ 1
1581 // CHECK_BDVER3_M32: #define __XOP__ 1
1582 // CHECK_BDVER3_M32: #define __XSAVEOPT__ 1
1583 // CHECK_BDVER3_M32: #define __XSAVE__ 1
1584 // CHECK_BDVER3_M32: #define __bdver3 1
1585 // CHECK_BDVER3_M32: #define __bdver3__ 1
1586 // CHECK_BDVER3_M32: #define __i386 1
1587 // CHECK_BDVER3_M32: #define __i386__ 1
1588 // CHECK_BDVER3_M32: #define __tune_bdver3__ 1
1589 // RUN: %clang -march=bdver3 -m64 -E -dM %s -o - 2>&1 \
1590 // RUN:     -target i386-unknown-linux \
1591 // RUN:   | FileCheck %s -check-prefix=CHECK_BDVER3_M64
1592 // CHECK_BDVER3_M64-NOT: #define __3dNOW_A__ 1
1593 // CHECK_BDVER3_M64-NOT: #define __3dNOW__ 1
1594 // CHECK_BDVER3_M64: #define __AES__ 1
1595 // CHECK_BDVER3_M64: #define __AVX__ 1
1596 // CHECK_BDVER3_M64: #define __BMI__ 1
1597 // CHECK_BDVER3_M64: #define __F16C__ 1
1598 // CHECK_BDVER3_M64: #define __FMA4__ 1
1599 // CHECK_BDVER3_M64: #define __FMA__ 1
1600 // CHECK_BDVER3_M64: #define __FSGSBASE__ 1
1601 // CHECK_BDVER3_M64: #define __LZCNT__ 1
1602 // CHECK_BDVER3_M64: #define __MMX__ 1
1603 // CHECK_BDVER3_M64: #define __PCLMUL__ 1
1604 // CHECK_BDVER3_M64: #define __POPCNT__ 1
1605 // CHECK_BDVER3_M64: #define __PRFCHW__ 1
1606 // CHECK_BDVER3_M64: #define __SSE2_MATH__ 1
1607 // CHECK_BDVER3_M64: #define __SSE2__ 1
1608 // CHECK_BDVER3_M64: #define __SSE3__ 1
1609 // CHECK_BDVER3_M64: #define __SSE4A__ 1
1610 // CHECK_BDVER3_M64: #define __SSE4_1__ 1
1611 // CHECK_BDVER3_M64: #define __SSE4_2__ 1
1612 // CHECK_BDVER3_M64: #define __SSE_MATH__ 1
1613 // CHECK_BDVER3_M64: #define __SSE__ 1
1614 // CHECK_BDVER3_M64: #define __SSSE3__ 1
1615 // CHECK_BDVER3_M64: #define __TBM__ 1
1616 // CHECK_BDVER3_M64: #define __XOP__ 1
1617 // CHECK_BDVER3_M64: #define __XSAVEOPT__ 1
1618 // CHECK_BDVER3_M64: #define __XSAVE__ 1
1619 // CHECK_BDVER3_M64: #define __amd64 1
1620 // CHECK_BDVER3_M64: #define __amd64__ 1
1621 // CHECK_BDVER3_M64: #define __bdver3 1
1622 // CHECK_BDVER3_M64: #define __bdver3__ 1
1623 // CHECK_BDVER3_M64: #define __tune_bdver3__ 1
1624 // CHECK_BDVER3_M64: #define __x86_64 1
1625 // CHECK_BDVER3_M64: #define __x86_64__ 1
1626 // RUN: %clang -march=bdver4 -m32 -E -dM %s -o - 2>&1 \
1627 // RUN:     -target i386-unknown-linux \
1628 // RUN:   | FileCheck %s -check-prefix=CHECK_BDVER4_M32
1629 // CHECK_BDVER4_M32-NOT: #define __3dNOW_A__ 1
1630 // CHECK_BDVER4_M32-NOT: #define __3dNOW__ 1
1631 // CHECK_BDVER4_M32: #define __AES__ 1
1632 // CHECK_BDVER4_M32: #define __AVX2__ 1
1633 // CHECK_BDVER4_M32: #define __AVX__ 1
1634 // CHECK_BDVER4_M32: #define __BMI2__ 1
1635 // CHECK_BDVER4_M32: #define __BMI__ 1
1636 // CHECK_BDVER4_M32: #define __F16C__ 1
1637 // CHECK_BDVER4_M32: #define __FMA4__ 1
1638 // CHECK_BDVER4_M32: #define __FMA__ 1
1639 // CHECK_BDVER4_M32: #define __FSGSBASE__ 1
1640 // CHECK_BDVER4_M32: #define __LZCNT__ 1
1641 // CHECK_BDVER4_M32: #define __MMX__ 1
1642 // CHECK_BDVER4_M32: #define __PCLMUL__ 1
1643 // CHECK_BDVER4_M32: #define __POPCNT__ 1
1644 // CHECK_BDVER4_M32: #define __PRFCHW__ 1
1645 // CHECK_BDVER4_M32: #define __SSE2_MATH__ 1
1646 // CHECK_BDVER4_M32: #define __SSE2__ 1
1647 // CHECK_BDVER4_M32: #define __SSE3__ 1
1648 // CHECK_BDVER4_M32: #define __SSE4A__ 1
1649 // CHECK_BDVER4_M32: #define __SSE4_1__ 1
1650 // CHECK_BDVER4_M32: #define __SSE4_2__ 1
1651 // CHECK_BDVER4_M32: #define __SSE_MATH__ 1
1652 // CHECK_BDVER4_M32: #define __SSE__ 1
1653 // CHECK_BDVER4_M32: #define __SSSE3__ 1
1654 // CHECK_BDVER4_M32: #define __TBM__ 1
1655 // CHECK_BDVER4_M32: #define __XOP__ 1
1656 // CHECK_BDVER4_M32: #define __XSAVE__ 1
1657 // CHECK_BDVER4_M32: #define __bdver4 1
1658 // CHECK_BDVER4_M32: #define __bdver4__ 1
1659 // CHECK_BDVER4_M32: #define __i386 1
1660 // CHECK_BDVER4_M32: #define __i386__ 1
1661 // CHECK_BDVER4_M32: #define __tune_bdver4__ 1
1662 // RUN: %clang -march=bdver4 -m64 -E -dM %s -o - 2>&1 \
1663 // RUN:     -target i386-unknown-linux \
1664 // RUN:   | FileCheck %s -check-prefix=CHECK_BDVER4_M64
1665 // CHECK_BDVER4_M64-NOT: #define __3dNOW_A__ 1
1666 // CHECK_BDVER4_M64-NOT: #define __3dNOW__ 1
1667 // CHECK_BDVER4_M64: #define __AES__ 1
1668 // CHECK_BDVER4_M64: #define __AVX2__ 1
1669 // CHECK_BDVER4_M64: #define __AVX__ 1
1670 // CHECK_BDVER4_M64: #define __BMI2__ 1
1671 // CHECK_BDVER4_M64: #define __BMI__ 1
1672 // CHECK_BDVER4_M64: #define __F16C__ 1
1673 // CHECK_BDVER4_M64: #define __FMA4__ 1
1674 // CHECK_BDVER4_M64: #define __FMA__ 1
1675 // CHECK_BDVER4_M64: #define __FSGSBASE__ 1
1676 // CHECK_BDVER4_M64: #define __LZCNT__ 1
1677 // CHECK_BDVER4_M64: #define __MMX__ 1
1678 // CHECK_BDVER4_M64: #define __PCLMUL__ 1
1679 // CHECK_BDVER4_M64: #define __POPCNT__ 1
1680 // CHECK_BDVER4_M64: #define __PRFCHW__ 1
1681 // CHECK_BDVER4_M64: #define __SSE2_MATH__ 1
1682 // CHECK_BDVER4_M64: #define __SSE2__ 1
1683 // CHECK_BDVER4_M64: #define __SSE3__ 1
1684 // CHECK_BDVER4_M64: #define __SSE4A__ 1
1685 // CHECK_BDVER4_M64: #define __SSE4_1__ 1
1686 // CHECK_BDVER4_M64: #define __SSE4_2__ 1
1687 // CHECK_BDVER4_M64: #define __SSE_MATH__ 1
1688 // CHECK_BDVER4_M64: #define __SSE__ 1
1689 // CHECK_BDVER4_M64: #define __SSSE3__ 1
1690 // CHECK_BDVER4_M64: #define __TBM__ 1
1691 // CHECK_BDVER4_M64: #define __XOP__ 1
1692 // CHECK_BDVER4_M64: #define __XSAVE__ 1
1693 // CHECK_BDVER4_M64: #define __amd64 1
1694 // CHECK_BDVER4_M64: #define __amd64__ 1
1695 // CHECK_BDVER4_M64: #define __bdver4 1
1696 // CHECK_BDVER4_M64: #define __bdver4__ 1
1697 // CHECK_BDVER4_M64: #define __tune_bdver4__ 1
1698 // CHECK_BDVER4_M64: #define __x86_64 1
1699 // CHECK_BDVER4_M64: #define __x86_64__ 1
1700 //
1701 // End X86/GCC/Linux tests ------------------
1702 
1703 // Begin PPC/GCC/Linux tests ----------------
1704 // RUN: %clang -mvsx -E -dM %s -o - 2>&1 \
1705 // RUN:     -target powerpc64-unknown-linux \
1706 // RUN:   | FileCheck %s -check-prefix=CHECK_PPC_VSX_M64
1707 //
1708 // CHECK_PPC_VSX_M64: #define __VSX__
1709 //
1710 // RUN: %clang -mpower8-vector -E -dM %s -o - 2>&1 \
1711 // RUN:     -target powerpc64-unknown-linux \
1712 // RUN:   | FileCheck %s -check-prefix=CHECK_PPC_POWER8_VECTOR_M64
1713 //
1714 // CHECK_PPC_POWER8_VECTOR_M64: #define __POWER8_VECTOR__
1715 //
1716 // RUN: %clang -mcrypto -E -dM %s -o - 2>&1 \
1717 // RUN:     -target powerpc64-unknown-linux \
1718 // RUN:   | FileCheck %s -check-prefix=CHECK_PPC_CRYPTO_M64
1719 //
1720 // CHECK_PPC_CRYPTO_M64: #define __CRYPTO__
1721 //
1722 // RUN: %clang -mcpu=ppc64 -E -dM %s -o - 2>&1 \
1723 // RUN:     -target powerpc64-unknown-unknown \
1724 // RUN:   | FileCheck %s -check-prefix=CHECK_PPC_GCC_ATOMICS
1725 // RUN: %clang -mcpu=pwr8 -E -dM %s -o - 2>&1 \
1726 // RUN:     -target powerpc64-unknown-unknown \
1727 // RUN:   | FileCheck %s -check-prefix=CHECK_PPC_GCC_ATOMICS
1728 // RUN: %clang -E -dM %s -o - 2>&1 \
1729 // RUN:     -target powerpc64le-unknown-linux \
1730 // RUN:   | FileCheck %s -check-prefix=CHECK_PPC_GCC_ATOMICS
1731 //
1732 // CHECK_PPC_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1
1733 // CHECK_PPC_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2
1734 // CHECK_PPC_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4
1735 // CHECK_PPC_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8
1736 //
1737 // End PPC/GCC/Linux tests ------------------
1738 
1739 // Begin Sparc/GCC/Linux tests ----------------
1740 //
1741 // RUN: %clang -E -dM %s -o - 2>&1 \
1742 // RUN:     -target sparc-unknown-linux \
1743 // RUN:   | FileCheck %s -check-prefix=CHECK_SPARC
1744 // RUN: %clang -mcpu=v9 -E -dM %s -o - 2>&1 \
1745 // RUN:     -target sparc-unknown-linux \
1746 // RUN:   | FileCheck %s -check-prefix=CHECK_SPARC-V9
1747 //
1748 // CHECK_SPARC: #define __BIG_ENDIAN__ 1
1749 // CHECK_SPARC: #define __sparc 1
1750 // CHECK_SPARC: #define __sparc__ 1
1751 // CHECK_SPARC-NOT: #define __sparcv9 1
1752 // CHECK_SPARC-NOT: #define __sparcv9__ 1
1753 // CHECK_SPARC: #define __sparcv8 1
1754 // CHECK_SPARC-NOT: #define __sparcv9 1
1755 // CHECK_SPARC-NOT: #define __sparcv9__ 1
1756 
1757 // CHECK_SPARC-V9-NOT: #define __sparcv8 1
1758 // CHECK_SPARC-V9: #define __sparc_v9__ 1
1759 // CHECK_SPARC-V9: #define __sparcv9 1
1760 // CHECK_SPARC-V9-NOT: #define __sparcv8 1
1761 
1762 //
1763 // RUN: %clang -E -dM %s -o - 2>&1 \
1764 // RUN:     -target sparcel-unknown-linux \
1765 // RUN:   | FileCheck %s -check-prefix=CHECK_SPARCEL
1766 //
1767 // CHECK_SPARCEL: #define __LITTLE_ENDIAN__ 1
1768 // CHECK_SPARCEL: #define __sparc 1
1769 // CHECK_SPARCEL: #define __sparc__ 1
1770 // CHECK_SPARCEL: #define __sparcv8 1
1771 //
1772 // RUN: %clang -E -dM %s -o - 2>&1 \
1773 // RUN:     -target sparcv9-unknown-linux \
1774 // RUN:   | FileCheck %s -check-prefix=CHECK_SPARCV9
1775 //
1776 // CHECK_SPARCV9: #define __BIG_ENDIAN__ 1
1777 // CHECK_SPARCV9: #define __sparc 1
1778 // CHECK_SPARCV9: #define __sparc64__ 1
1779 // CHECK_SPARCV9: #define __sparc__ 1
1780 // CHECK_SPARCV9: #define __sparc_v9__ 1
1781 // CHECK_SPARCV9: #define __sparcv9 1
1782 // CHECK_SPARCV9: #define __sparcv9__ 1
1783 
1784 // Begin SystemZ/GCC/Linux tests ----------------
1785 //
1786 // RUN: %clang -march=z10 -E -dM %s -o - 2>&1 \
1787 // RUN:     -target s390x-unknown-linux \
1788 // RUN:   | FileCheck %s -check-prefix=CHECK_SYSTEMZ_Z10
1789 //
1790 // CHECK_SYSTEMZ_Z10: #define __LONG_DOUBLE_128__ 1
1791 // CHECK_SYSTEMZ_Z10: #define __s390__ 1
1792 // CHECK_SYSTEMZ_Z10: #define __s390x__ 1
1793 // CHECK_SYSTEMZ_Z10: #define __zarch__ 1
1794 //
1795 // RUN: %clang -march=zEC12 -E -dM %s -o - 2>&1 \
1796 // RUN:     -target s390x-unknown-linux \
1797 // RUN:   | FileCheck %s -check-prefix=CHECK_SYSTEMZ_ZEC12
1798 //
1799 // CHECK_SYSTEMZ_ZEC12: #define __HTM__ 1
1800 // CHECK_SYSTEMZ_ZEC12: #define __LONG_DOUBLE_128__ 1
1801 // CHECK_SYSTEMZ_ZEC12: #define __s390__ 1
1802 // CHECK_SYSTEMZ_ZEC12: #define __s390x__ 1
1803 // CHECK_SYSTEMZ_ZEC12: #define __zarch__ 1
1804 //
1805 // RUN: %clang -mhtm -E -dM %s -o - 2>&1 \
1806 // RUN:     -target s390x-unknown-linux \
1807 // RUN:   | FileCheck %s -check-prefix=CHECK_SYSTEMZ_HTM
1808 //
1809 // CHECK_SYSTEMZ_HTM: #define __HTM__ 1
1810 //
1811 // RUN: %clang -fzvector -E -dM %s -o - 2>&1 \
1812 // RUN:     -target s390x-unknown-linux \
1813 // RUN:   | FileCheck %s -check-prefix=CHECK_SYSTEMZ_ZVECTOR
1814 // RUN: %clang -mzvector -E -dM %s -o - 2>&1 \
1815 // RUN:     -target s390x-unknown-linux \
1816 // RUN:   | FileCheck %s -check-prefix=CHECK_SYSTEMZ_ZVECTOR
1817 //
1818 // CHECK_SYSTEMZ_ZVECTOR: #define __VEC__ 10301
1819