Clang Project

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