blob: c70ebf37085eb83993b41b508a3575cd7f349f34 [file] [log] [blame]
Chandler Carruthe83c3d92011-09-28 10:17:41 +00001// Begin X86/GCC/Linux tests ----------------
Gabor Buellac9e976c2018-04-12 18:15:39 +00002
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00003// RUN: %clang -march=i386 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00004// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00005// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I386_M32
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00006// 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
Rafael Espindola925213b2013-07-04 16:16:58 +000010// RUN: not %clang -march=i386 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000011// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000012// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I386_M64
13// CHECK_I386_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +000014
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000015// RUN: %clang -march=i486 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000016// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000017// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I486_M32
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000018// 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
Rafael Espindola925213b2013-07-04 16:16:58 +000024// RUN: not %clang -march=i486 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000025// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000026// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I486_M64
27// CHECK_I486_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +000028
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000029// RUN: %clang -march=i586 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000030// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000031// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I586_M32
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000032// 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
Rafael Espindola925213b2013-07-04 16:16:58 +000041// RUN: not %clang -march=i586 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000042// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000043// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I586_M64
44// CHECK_I586_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +000045
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000046// RUN: %clang -march=pentium -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000047// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000048// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM_M32
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000049// 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
Rafael Espindola925213b2013-07-04 16:16:58 +000058// RUN: not %clang -march=pentium -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000059// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000060// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM_M64
61// CHECK_PENTIUM_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +000062
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000063// RUN: %clang -march=pentium-mmx -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000064// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000065// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM_MMX_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +000066// CHECK_PENTIUM_MMX_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000067// 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
Rafael Espindola925213b2013-07-04 16:16:58 +000078// RUN: not %clang -march=pentium-mmx -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000079// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000080// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM_MMX_M64
81// CHECK_PENTIUM_MMX_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +000082
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000083// RUN: %clang -march=winchip-c6 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000084// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000085// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_WINCHIP_C6_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +000086// CHECK_WINCHIP_C6_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000087// 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
Rafael Espindola925213b2013-07-04 16:16:58 +000093// RUN: not %clang -march=winchip-c6 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000094// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000095// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_WINCHIP_C6_M64
96// CHECK_WINCHIP_C6_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +000097
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000098// RUN: %clang -march=winchip2 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000099// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000100// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_WINCHIP2_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000101// CHECK_WINCHIP2_M32: #define __3dNOW__ 1
102// CHECK_WINCHIP2_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000103// 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
Rafael Espindola925213b2013-07-04 16:16:58 +0000109// RUN: not %clang -march=winchip2 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000110// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000111// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_WINCHIP2_M64
112// CHECK_WINCHIP2_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +0000113
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000114// RUN: %clang -march=c3 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000115// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000116// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_C3_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000117// CHECK_C3_M32: #define __3dNOW__ 1
118// CHECK_C3_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000119// 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
Rafael Espindola925213b2013-07-04 16:16:58 +0000125// RUN: not %clang -march=c3 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000126// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000127// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_C3_M64
128// CHECK_C3_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +0000129
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000130// RUN: %clang -march=c3-2 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000131// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000132// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_C3_2_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000133// CHECK_C3_2_M32: #define __MMX__ 1
134// CHECK_C3_2_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000135// 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
Rafael Espindola925213b2013-07-04 16:16:58 +0000145// RUN: not %clang -march=c3-2 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000146// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000147// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_C3_2_M64
148// CHECK_C3_2_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +0000149
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000150// RUN: %clang -march=i686 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000151// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000152// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I686_M32
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000153// 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
Craig Toppera6021e32017-10-26 23:06:19 +0000159// CHECK_I686_M32: #define __tune_i686__ 1
160// CHECK_I686_M32: #define __tune_pentiumpro__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000161// CHECK_I686_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +0000162// RUN: not %clang -march=i686 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000163// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000164// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I686_M64
165// CHECK_I686_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +0000166
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000167// RUN: %clang -march=pentiumpro -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000168// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000169// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUMPRO_M32
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000170// 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
Rafael Espindola925213b2013-07-04 16:16:58 +0000179// RUN: not %clang -march=pentiumpro -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000180// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000181// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUMPRO_M64
182// CHECK_PENTIUMPRO_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +0000183
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000184// RUN: %clang -march=pentium2 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000185// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000186// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM2_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000187// CHECK_PENTIUM2_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000188// 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
Rafael Espindola925213b2013-07-04 16:16:58 +0000198// RUN: not %clang -march=pentium2 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000199// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000200// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM2_M64
201// CHECK_PENTIUM2_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +0000202
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000203// RUN: %clang -march=pentium3 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000204// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000205// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM3_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000206// CHECK_PENTIUM3_M32: #define __MMX__ 1
207// CHECK_PENTIUM3_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000208// 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
Rafael Espindola925213b2013-07-04 16:16:58 +0000219// RUN: not %clang -march=pentium3 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000220// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000221// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM3_M64
222// CHECK_PENTIUM3_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +0000223
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000224// RUN: %clang -march=pentium3m -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000225// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000226// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM3M_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000227// CHECK_PENTIUM3M_M32: #define __MMX__ 1
228// CHECK_PENTIUM3M_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000229// 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
Rafael Espindola925213b2013-07-04 16:16:58 +0000238// RUN: not %clang -march=pentium3m -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000239// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000240// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM3M_M64
241// CHECK_PENTIUM3M_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +0000242
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000243// RUN: %clang -march=pentium-m -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000244// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000245// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM_M_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000246// CHECK_PENTIUM_M_M32: #define __MMX__ 1
247// CHECK_PENTIUM_M_M32: #define __SSE2__ 1
248// CHECK_PENTIUM_M_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000249// 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
Rafael Espindola925213b2013-07-04 16:16:58 +0000258// RUN: not %clang -march=pentium-m -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000259// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000260// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM_M_M64
261// CHECK_PENTIUM_M_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +0000262
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000263// RUN: %clang -march=pentium4 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000264// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000265// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM4_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000266// CHECK_PENTIUM4_M32: #define __MMX__ 1
267// CHECK_PENTIUM4_M32: #define __SSE2__ 1
268// CHECK_PENTIUM4_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000269// 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
Rafael Espindola925213b2013-07-04 16:16:58 +0000275// RUN: not %clang -march=pentium4 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000276// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000277// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM4_M64
278// CHECK_PENTIUM4_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +0000279
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000280// RUN: %clang -march=pentium4m -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000281// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000282// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM4M_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000283// CHECK_PENTIUM4M_M32: #define __MMX__ 1
284// CHECK_PENTIUM4M_M32: #define __SSE2__ 1
285// CHECK_PENTIUM4M_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000286// 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
Rafael Espindola925213b2013-07-04 16:16:58 +0000292// RUN: not %clang -march=pentium4m -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000293// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000294// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM4M_M64
295// CHECK_PENTIUM4M_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +0000296
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000297// RUN: %clang -march=prescott -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000298// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000299// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PRESCOTT_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000300// CHECK_PRESCOTT_M32: #define __MMX__ 1
301// CHECK_PRESCOTT_M32: #define __SSE2__ 1
302// CHECK_PRESCOTT_M32: #define __SSE3__ 1
303// CHECK_PRESCOTT_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000304// CHECK_PRESCOTT_M32: #define __i386 1
305// CHECK_PRESCOTT_M32: #define __i386__ 1
306// CHECK_PRESCOTT_M32: #define __nocona 1
307// CHECK_PRESCOTT_M32: #define __nocona__ 1
308// CHECK_PRESCOTT_M32: #define __tune_nocona__ 1
309// CHECK_PRESCOTT_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +0000310// RUN: not %clang -march=prescott -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000311// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000312// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PRESCOTT_M64
313// CHECK_PRESCOTT_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +0000314
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000315// RUN: %clang -march=nocona -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000316// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000317// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_NOCONA_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000318// CHECK_NOCONA_M32: #define __MMX__ 1
319// CHECK_NOCONA_M32: #define __SSE2__ 1
320// CHECK_NOCONA_M32: #define __SSE3__ 1
321// CHECK_NOCONA_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000322// CHECK_NOCONA_M32: #define __i386 1
323// CHECK_NOCONA_M32: #define __i386__ 1
324// CHECK_NOCONA_M32: #define __nocona 1
325// CHECK_NOCONA_M32: #define __nocona__ 1
326// CHECK_NOCONA_M32: #define __tune_nocona__ 1
327// CHECK_NOCONA_M32: #define i386 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000328// RUN: %clang -march=nocona -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000329// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000330// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_NOCONA_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000331// CHECK_NOCONA_M64: #define __MMX__ 1
332// CHECK_NOCONA_M64: #define __SSE2_MATH__ 1
333// CHECK_NOCONA_M64: #define __SSE2__ 1
334// CHECK_NOCONA_M64: #define __SSE3__ 1
335// CHECK_NOCONA_M64: #define __SSE_MATH__ 1
336// CHECK_NOCONA_M64: #define __SSE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000337// CHECK_NOCONA_M64: #define __amd64 1
338// CHECK_NOCONA_M64: #define __amd64__ 1
339// CHECK_NOCONA_M64: #define __nocona 1
340// CHECK_NOCONA_M64: #define __nocona__ 1
341// CHECK_NOCONA_M64: #define __tune_nocona__ 1
342// CHECK_NOCONA_M64: #define __x86_64 1
343// CHECK_NOCONA_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000344
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000345// RUN: %clang -march=core2 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000346// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000347// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE2_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000348// CHECK_CORE2_M32: #define __MMX__ 1
349// CHECK_CORE2_M32: #define __SSE2__ 1
350// CHECK_CORE2_M32: #define __SSE3__ 1
351// CHECK_CORE2_M32: #define __SSE__ 1
352// CHECK_CORE2_M32: #define __SSSE3__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000353// CHECK_CORE2_M32: #define __core2 1
354// CHECK_CORE2_M32: #define __core2__ 1
355// CHECK_CORE2_M32: #define __i386 1
356// CHECK_CORE2_M32: #define __i386__ 1
357// CHECK_CORE2_M32: #define __tune_core2__ 1
358// CHECK_CORE2_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000359
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000360// RUN: %clang -march=core2 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000361// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000362// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE2_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000363// CHECK_CORE2_M64: #define __MMX__ 1
364// CHECK_CORE2_M64: #define __SSE2_MATH__ 1
365// CHECK_CORE2_M64: #define __SSE2__ 1
366// CHECK_CORE2_M64: #define __SSE3__ 1
367// CHECK_CORE2_M64: #define __SSE_MATH__ 1
368// CHECK_CORE2_M64: #define __SSE__ 1
369// CHECK_CORE2_M64: #define __SSSE3__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000370// CHECK_CORE2_M64: #define __amd64 1
371// CHECK_CORE2_M64: #define __amd64__ 1
372// CHECK_CORE2_M64: #define __core2 1
373// CHECK_CORE2_M64: #define __core2__ 1
374// CHECK_CORE2_M64: #define __tune_core2__ 1
375// CHECK_CORE2_M64: #define __x86_64 1
376// CHECK_CORE2_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000377
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000378// RUN: %clang -march=corei7 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000379// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000380// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_COREI7_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000381// CHECK_COREI7_M32: #define __MMX__ 1
Craig Topperb644c972012-06-03 21:49:41 +0000382// CHECK_COREI7_M32: #define __POPCNT__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000383// CHECK_COREI7_M32: #define __SSE2__ 1
384// CHECK_COREI7_M32: #define __SSE3__ 1
385// CHECK_COREI7_M32: #define __SSE4_1__ 1
386// CHECK_COREI7_M32: #define __SSE4_2__ 1
387// CHECK_COREI7_M32: #define __SSE__ 1
388// CHECK_COREI7_M32: #define __SSSE3__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000389// CHECK_COREI7_M32: #define __corei7 1
390// CHECK_COREI7_M32: #define __corei7__ 1
391// CHECK_COREI7_M32: #define __i386 1
392// CHECK_COREI7_M32: #define __i386__ 1
393// CHECK_COREI7_M32: #define __tune_corei7__ 1
394// CHECK_COREI7_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000395
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000396// RUN: %clang -march=corei7 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000397// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000398// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_COREI7_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000399// CHECK_COREI7_M64: #define __MMX__ 1
Craig Topperb644c972012-06-03 21:49:41 +0000400// CHECK_COREI7_M64: #define __POPCNT__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000401// CHECK_COREI7_M64: #define __SSE2_MATH__ 1
402// CHECK_COREI7_M64: #define __SSE2__ 1
403// CHECK_COREI7_M64: #define __SSE3__ 1
404// CHECK_COREI7_M64: #define __SSE4_1__ 1
405// CHECK_COREI7_M64: #define __SSE4_2__ 1
406// CHECK_COREI7_M64: #define __SSE_MATH__ 1
407// CHECK_COREI7_M64: #define __SSE__ 1
408// CHECK_COREI7_M64: #define __SSSE3__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000409// CHECK_COREI7_M64: #define __amd64 1
410// CHECK_COREI7_M64: #define __amd64__ 1
411// CHECK_COREI7_M64: #define __corei7 1
412// CHECK_COREI7_M64: #define __corei7__ 1
413// CHECK_COREI7_M64: #define __tune_corei7__ 1
414// CHECK_COREI7_M64: #define __x86_64 1
415// CHECK_COREI7_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000416
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000417// RUN: %clang -march=corei7-avx -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000418// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000419// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_COREI7_AVX_M32
Craig Topper5f365e92012-04-26 07:31:30 +0000420// CHECK_COREI7_AVX_M32: #define __AVX__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000421// CHECK_COREI7_AVX_M32: #define __MMX__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000422// CHECK_COREI7_AVX_M32: #define __PCLMUL__ 1
Benjamin Kramer1e250392012-07-07 09:39:18 +0000423// CHECK_COREI7_AVX_M32-NOT: __RDRND__
Craig Topperb644c972012-06-03 21:49:41 +0000424// CHECK_COREI7_AVX_M32: #define __POPCNT__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000425// CHECK_COREI7_AVX_M32: #define __SSE2__ 1
426// CHECK_COREI7_AVX_M32: #define __SSE3__ 1
427// CHECK_COREI7_AVX_M32: #define __SSE4_1__ 1
428// CHECK_COREI7_AVX_M32: #define __SSE4_2__ 1
429// CHECK_COREI7_AVX_M32: #define __SSE__ 1
430// CHECK_COREI7_AVX_M32: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000431// CHECK_COREI7_AVX_M32: #define __XSAVEOPT__ 1
432// CHECK_COREI7_AVX_M32: #define __XSAVE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000433// CHECK_COREI7_AVX_M32: #define __corei7 1
434// CHECK_COREI7_AVX_M32: #define __corei7__ 1
435// CHECK_COREI7_AVX_M32: #define __i386 1
436// CHECK_COREI7_AVX_M32: #define __i386__ 1
437// CHECK_COREI7_AVX_M32: #define __tune_corei7__ 1
438// CHECK_COREI7_AVX_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000439
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000440// RUN: %clang -march=corei7-avx -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000441// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000442// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_COREI7_AVX_M64
Craig Topper5f365e92012-04-26 07:31:30 +0000443// CHECK_COREI7_AVX_M64: #define __AVX__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000444// CHECK_COREI7_AVX_M64: #define __MMX__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000445// CHECK_COREI7_AVX_M64: #define __PCLMUL__ 1
Benjamin Kramer1e250392012-07-07 09:39:18 +0000446// CHECK_COREI7_AVX_M64-NOT: __RDRND__
Craig Topperb644c972012-06-03 21:49:41 +0000447// CHECK_COREI7_AVX_M64: #define __POPCNT__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000448// CHECK_COREI7_AVX_M64: #define __SSE2_MATH__ 1
449// CHECK_COREI7_AVX_M64: #define __SSE2__ 1
450// CHECK_COREI7_AVX_M64: #define __SSE3__ 1
451// CHECK_COREI7_AVX_M64: #define __SSE4_1__ 1
452// CHECK_COREI7_AVX_M64: #define __SSE4_2__ 1
453// CHECK_COREI7_AVX_M64: #define __SSE_MATH__ 1
454// CHECK_COREI7_AVX_M64: #define __SSE__ 1
455// CHECK_COREI7_AVX_M64: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000456// CHECK_COREI7_AVX_M64: #define __XSAVEOPT__ 1
457// CHECK_COREI7_AVX_M64: #define __XSAVE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000458// CHECK_COREI7_AVX_M64: #define __amd64 1
459// CHECK_COREI7_AVX_M64: #define __amd64__ 1
460// CHECK_COREI7_AVX_M64: #define __corei7 1
461// CHECK_COREI7_AVX_M64: #define __corei7__ 1
462// CHECK_COREI7_AVX_M64: #define __tune_corei7__ 1
463// CHECK_COREI7_AVX_M64: #define __x86_64 1
464// CHECK_COREI7_AVX_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000465
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000466// RUN: %clang -march=core-avx-i -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000467// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000468// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE_AVX_I_M32
Craig Topper5f365e92012-04-26 07:31:30 +0000469// CHECK_CORE_AVX_I_M32: #define __AVX__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +0000470// CHECK_CORE_AVX_I_M32: #define __F16C__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000471// CHECK_CORE_AVX_I_M32: #define __MMX__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000472// CHECK_CORE_AVX_I_M32: #define __PCLMUL__ 1
Benjamin Kramer1e250392012-07-07 09:39:18 +0000473// CHECK_CORE_AVX_I_M32: #define __RDRND__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000474// CHECK_CORE_AVX_I_M32: #define __SSE2__ 1
475// CHECK_CORE_AVX_I_M32: #define __SSE3__ 1
476// CHECK_CORE_AVX_I_M32: #define __SSE4_1__ 1
477// CHECK_CORE_AVX_I_M32: #define __SSE4_2__ 1
478// CHECK_CORE_AVX_I_M32: #define __SSE__ 1
479// CHECK_CORE_AVX_I_M32: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000480// CHECK_CORE_AVX_I_M32: #define __XSAVEOPT__ 1
481// CHECK_CORE_AVX_I_M32: #define __XSAVE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000482// CHECK_CORE_AVX_I_M32: #define __corei7 1
483// CHECK_CORE_AVX_I_M32: #define __corei7__ 1
484// CHECK_CORE_AVX_I_M32: #define __i386 1
485// CHECK_CORE_AVX_I_M32: #define __i386__ 1
486// CHECK_CORE_AVX_I_M32: #define __tune_corei7__ 1
487// CHECK_CORE_AVX_I_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000488
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000489// RUN: %clang -march=core-avx-i -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000490// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000491// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE_AVX_I_M64
Craig Topper5f365e92012-04-26 07:31:30 +0000492// CHECK_CORE_AVX_I_M64: #define __AVX__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +0000493// CHECK_CORE_AVX_I_M64: #define __F16C__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000494// CHECK_CORE_AVX_I_M64: #define __MMX__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000495// CHECK_CORE_AVX_I_M64: #define __PCLMUL__ 1
Benjamin Kramer1e250392012-07-07 09:39:18 +0000496// CHECK_CORE_AVX_I_M64: #define __RDRND__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000497// CHECK_CORE_AVX_I_M64: #define __SSE2_MATH__ 1
498// CHECK_CORE_AVX_I_M64: #define __SSE2__ 1
499// CHECK_CORE_AVX_I_M64: #define __SSE3__ 1
500// CHECK_CORE_AVX_I_M64: #define __SSE4_1__ 1
501// CHECK_CORE_AVX_I_M64: #define __SSE4_2__ 1
502// CHECK_CORE_AVX_I_M64: #define __SSE_MATH__ 1
503// CHECK_CORE_AVX_I_M64: #define __SSE__ 1
504// CHECK_CORE_AVX_I_M64: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000505// CHECK_CORE_AVX_I_M64: #define __XSAVEOPT__ 1
506// CHECK_CORE_AVX_I_M64: #define __XSAVE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000507// CHECK_CORE_AVX_I_M64: #define __amd64 1
508// CHECK_CORE_AVX_I_M64: #define __amd64__ 1
509// CHECK_CORE_AVX_I_M64: #define __corei7 1
510// CHECK_CORE_AVX_I_M64: #define __corei7__ 1
511// CHECK_CORE_AVX_I_M64: #define __tune_corei7__ 1
512// CHECK_CORE_AVX_I_M64: #define __x86_64 1
513// CHECK_CORE_AVX_I_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000514
Craig Topperbba778b2012-06-03 21:46:30 +0000515// RUN: %clang -march=core-avx2 -m32 -E -dM %s -o - 2>&1 \
516// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000517// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE_AVX2_M32
Craig Topper449314e2013-08-20 07:09:39 +0000518// CHECK_CORE_AVX2_M32: #define __AVX2__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000519// CHECK_CORE_AVX2_M32: #define __AVX__ 1
520// CHECK_CORE_AVX2_M32: #define __BMI2__ 1
521// CHECK_CORE_AVX2_M32: #define __BMI__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +0000522// CHECK_CORE_AVX2_M32: #define __F16C__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000523// CHECK_CORE_AVX2_M32: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +0000524// CHECK_CORE_AVX2_M32: #define __INVPCID__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000525// CHECK_CORE_AVX2_M32: #define __LZCNT__ 1
526// CHECK_CORE_AVX2_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000527// CHECK_CORE_AVX2_M32: #define __MOVBE__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000528// CHECK_CORE_AVX2_M32: #define __PCLMUL__ 1
529// CHECK_CORE_AVX2_M32: #define __POPCNT__ 1
Benjamin Kramer1e250392012-07-07 09:39:18 +0000530// CHECK_CORE_AVX2_M32: #define __RDRND__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000531// CHECK_CORE_AVX2_M32: #define __SSE2__ 1
532// CHECK_CORE_AVX2_M32: #define __SSE3__ 1
533// CHECK_CORE_AVX2_M32: #define __SSE4_1__ 1
534// CHECK_CORE_AVX2_M32: #define __SSE4_2__ 1
535// CHECK_CORE_AVX2_M32: #define __SSE__ 1
536// CHECK_CORE_AVX2_M32: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000537// CHECK_CORE_AVX2_M32: #define __XSAVEOPT__ 1
538// CHECK_CORE_AVX2_M32: #define __XSAVE__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000539// CHECK_CORE_AVX2_M32: #define __corei7 1
540// CHECK_CORE_AVX2_M32: #define __corei7__ 1
541// CHECK_CORE_AVX2_M32: #define __i386 1
542// CHECK_CORE_AVX2_M32: #define __i386__ 1
543// CHECK_CORE_AVX2_M32: #define __tune_corei7__ 1
544// CHECK_CORE_AVX2_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000545
Craig Topperbba778b2012-06-03 21:46:30 +0000546// RUN: %clang -march=core-avx2 -m64 -E -dM %s -o - 2>&1 \
547// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000548// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE_AVX2_M64
Craig Topper449314e2013-08-20 07:09:39 +0000549// CHECK_CORE_AVX2_M64: #define __AVX2__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000550// CHECK_CORE_AVX2_M64: #define __AVX__ 1
551// CHECK_CORE_AVX2_M64: #define __BMI2__ 1
552// CHECK_CORE_AVX2_M64: #define __BMI__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +0000553// CHECK_CORE_AVX2_M64: #define __F16C__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000554// CHECK_CORE_AVX2_M64: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +0000555// CHECK_CORE_AVX2_M64: #define __INVPCID__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000556// CHECK_CORE_AVX2_M64: #define __LZCNT__ 1
557// CHECK_CORE_AVX2_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000558// CHECK_CORE_AVX2_M64: #define __MOVBE__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000559// CHECK_CORE_AVX2_M64: #define __PCLMUL__ 1
560// CHECK_CORE_AVX2_M64: #define __POPCNT__ 1
Benjamin Kramer1e250392012-07-07 09:39:18 +0000561// CHECK_CORE_AVX2_M64: #define __RDRND__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000562// CHECK_CORE_AVX2_M64: #define __SSE2_MATH__ 1
563// CHECK_CORE_AVX2_M64: #define __SSE2__ 1
564// CHECK_CORE_AVX2_M64: #define __SSE3__ 1
565// CHECK_CORE_AVX2_M64: #define __SSE4_1__ 1
566// CHECK_CORE_AVX2_M64: #define __SSE4_2__ 1
567// CHECK_CORE_AVX2_M64: #define __SSE_MATH__ 1
568// CHECK_CORE_AVX2_M64: #define __SSE__ 1
569// CHECK_CORE_AVX2_M64: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000570// CHECK_CORE_AVX2_M64: #define __XSAVEOPT__ 1
571// CHECK_CORE_AVX2_M64: #define __XSAVE__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000572// CHECK_CORE_AVX2_M64: #define __amd64 1
573// CHECK_CORE_AVX2_M64: #define __amd64__ 1
574// CHECK_CORE_AVX2_M64: #define __corei7 1
575// CHECK_CORE_AVX2_M64: #define __corei7__ 1
576// CHECK_CORE_AVX2_M64: #define __tune_corei7__ 1
577// CHECK_CORE_AVX2_M64: #define __x86_64 1
578// CHECK_CORE_AVX2_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000579
Robert Khasanov50e6f582014-09-19 09:53:48 +0000580// RUN: %clang -march=broadwell -m32 -E -dM %s -o - 2>&1 \
581// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000582// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BROADWELL_M32
Robert Khasanov50e6f582014-09-19 09:53:48 +0000583// CHECK_BROADWELL_M32: #define __ADX__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000584// CHECK_BROADWELL_M32: #define __AVX2__ 1
585// CHECK_BROADWELL_M32: #define __AVX__ 1
586// CHECK_BROADWELL_M32: #define __BMI2__ 1
587// CHECK_BROADWELL_M32: #define __BMI__ 1
588// CHECK_BROADWELL_M32: #define __F16C__ 1
589// CHECK_BROADWELL_M32: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +0000590// CHECK_BROADWELL_M32: #define __INVPCID__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000591// CHECK_BROADWELL_M32: #define __LZCNT__ 1
592// CHECK_BROADWELL_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000593// CHECK_BROADWELL_M32: #define __MOVBE__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000594// CHECK_BROADWELL_M32: #define __PCLMUL__ 1
595// CHECK_BROADWELL_M32: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000596// CHECK_BROADWELL_M32: #define __PRFCHW__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000597// CHECK_BROADWELL_M32: #define __RDRND__ 1
598// CHECK_BROADWELL_M32: #define __RDSEED__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000599// CHECK_BROADWELL_M32: #define __SSE2__ 1
600// CHECK_BROADWELL_M32: #define __SSE3__ 1
601// CHECK_BROADWELL_M32: #define __SSE4_1__ 1
602// CHECK_BROADWELL_M32: #define __SSE4_2__ 1
603// CHECK_BROADWELL_M32: #define __SSE__ 1
604// CHECK_BROADWELL_M32: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000605// CHECK_BROADWELL_M32: #define __XSAVEOPT__ 1
606// CHECK_BROADWELL_M32: #define __XSAVE__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000607// CHECK_BROADWELL_M32: #define __corei7 1
608// CHECK_BROADWELL_M32: #define __corei7__ 1
609// CHECK_BROADWELL_M32: #define __i386 1
610// CHECK_BROADWELL_M32: #define __i386__ 1
611// CHECK_BROADWELL_M32: #define __tune_corei7__ 1
612// CHECK_BROADWELL_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000613
Robert Khasanov50e6f582014-09-19 09:53:48 +0000614// RUN: %clang -march=broadwell -m64 -E -dM %s -o - 2>&1 \
615// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000616// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BROADWELL_M64
Robert Khasanov50e6f582014-09-19 09:53:48 +0000617// CHECK_BROADWELL_M64: #define __ADX__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000618// CHECK_BROADWELL_M64: #define __AVX2__ 1
619// CHECK_BROADWELL_M64: #define __AVX__ 1
620// CHECK_BROADWELL_M64: #define __BMI2__ 1
621// CHECK_BROADWELL_M64: #define __BMI__ 1
622// CHECK_BROADWELL_M64: #define __F16C__ 1
623// CHECK_BROADWELL_M64: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +0000624// CHECK_BROADWELL_M64: #define __INVPCID__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000625// CHECK_BROADWELL_M64: #define __LZCNT__ 1
626// CHECK_BROADWELL_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000627// CHECK_BROADWELL_M64: #define __MOVBE__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000628// CHECK_BROADWELL_M64: #define __PCLMUL__ 1
629// CHECK_BROADWELL_M64: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000630// CHECK_BROADWELL_M64: #define __PRFCHW__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000631// CHECK_BROADWELL_M64: #define __RDRND__ 1
632// CHECK_BROADWELL_M64: #define __RDSEED__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000633// CHECK_BROADWELL_M64: #define __SSE2_MATH__ 1
634// CHECK_BROADWELL_M64: #define __SSE2__ 1
635// CHECK_BROADWELL_M64: #define __SSE3__ 1
636// CHECK_BROADWELL_M64: #define __SSE4_1__ 1
637// CHECK_BROADWELL_M64: #define __SSE4_2__ 1
638// CHECK_BROADWELL_M64: #define __SSE_MATH__ 1
639// CHECK_BROADWELL_M64: #define __SSE__ 1
640// CHECK_BROADWELL_M64: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000641// CHECK_BROADWELL_M64: #define __XSAVEOPT__ 1
642// CHECK_BROADWELL_M64: #define __XSAVE__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000643// CHECK_BROADWELL_M64: #define __amd64 1
644// CHECK_BROADWELL_M64: #define __amd64__ 1
645// CHECK_BROADWELL_M64: #define __corei7 1
646// CHECK_BROADWELL_M64: #define __corei7__ 1
647// CHECK_BROADWELL_M64: #define __tune_corei7__ 1
648// CHECK_BROADWELL_M64: #define __x86_64 1
649// CHECK_BROADWELL_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000650
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000651// RUN: %clang -march=skylake -m32 -E -dM %s -o - 2>&1 \
652// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000653// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SKL_M32
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000654// CHECK_SKL_M32: #define __ADX__ 1
655// CHECK_SKL_M32: #define __AES__ 1
656// CHECK_SKL_M32: #define __AVX2__ 1
657// CHECK_SKL_M32: #define __AVX__ 1
658// CHECK_SKL_M32: #define __BMI2__ 1
659// CHECK_SKL_M32: #define __BMI__ 1
Craig Topper78b47872017-02-08 06:48:58 +0000660// CHECK_SKL_M32: #define __CLFLUSHOPT__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000661// CHECK_SKL_M32: #define __F16C__ 1
662// CHECK_SKL_M32: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +0000663// CHECK_SKL_M32: #define __INVPCID__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000664// CHECK_SKL_M32: #define __LZCNT__ 1
665// CHECK_SKL_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000666// CHECK_SKL_M32: #define __MOVBE__ 1
Craig Topperb16cb822017-02-08 07:56:42 +0000667// CHECK_SKL_M32: #define __MPX__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000668// CHECK_SKL_M32: #define __PCLMUL__ 1
669// CHECK_SKL_M32: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000670// CHECK_SKL_M32: #define __PRFCHW__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000671// CHECK_SKL_M32: #define __RDRND__ 1
672// CHECK_SKL_M32: #define __RDSEED__ 1
Craig Topper204ecff2017-02-08 08:23:17 +0000673// CHECK_SKL_M32: #define __SGX__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000674// CHECK_SKL_M32: #define __SSE2__ 1
675// CHECK_SKL_M32: #define __SSE3__ 1
676// CHECK_SKL_M32: #define __SSE4_1__ 1
677// CHECK_SKL_M32: #define __SSE4_2__ 1
678// CHECK_SKL_M32: #define __SSE__ 1
679// CHECK_SKL_M32: #define __SSSE3__ 1
680// CHECK_SKL_M32: #define __XSAVEC__ 1
681// CHECK_SKL_M32: #define __XSAVEOPT__ 1
682// CHECK_SKL_M32: #define __XSAVES__ 1
683// CHECK_SKL_M32: #define __XSAVE__ 1
684// CHECK_SKL_M32: #define i386 1
685
686// RUN: %clang -march=skylake -m64 -E -dM %s -o - 2>&1 \
687// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000688// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SKL_M64
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000689// CHECK_SKL_M64: #define __ADX__ 1
690// CHECK_SKL_M64: #define __AES__ 1
691// CHECK_SKL_M64: #define __AVX2__ 1
692// CHECK_SKL_M64: #define __AVX__ 1
693// CHECK_SKL_M64: #define __BMI2__ 1
694// CHECK_SKL_M64: #define __BMI__ 1
Craig Topper78b47872017-02-08 06:48:58 +0000695// CHECK_SKL_M64: #define __CLFLUSHOPT__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000696// CHECK_SKL_M64: #define __F16C__ 1
697// CHECK_SKL_M64: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +0000698// CHECK_SKL_M64: #define __INVPCID__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000699// CHECK_SKL_M64: #define __LZCNT__ 1
700// CHECK_SKL_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000701// CHECK_SKL_M64: #define __MOVBE__ 1
Craig Topperb16cb822017-02-08 07:56:42 +0000702// CHECK_SKL_M64: #define __MPX__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000703// CHECK_SKL_M64: #define __PCLMUL__ 1
704// CHECK_SKL_M64: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000705// CHECK_SKL_M64: #define __PRFCHW__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000706// CHECK_SKL_M64: #define __RDRND__ 1
707// CHECK_SKL_M64: #define __RDSEED__ 1
Craig Topper204ecff2017-02-08 08:23:17 +0000708// CHECK_SKL_M64: #define __SGX__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000709// CHECK_SKL_M64: #define __SSE2_MATH__ 1
710// CHECK_SKL_M64: #define __SSE2__ 1
711// CHECK_SKL_M64: #define __SSE3__ 1
712// CHECK_SKL_M64: #define __SSE4_1__ 1
713// CHECK_SKL_M64: #define __SSE4_2__ 1
714// CHECK_SKL_M64: #define __SSE_MATH__ 1
715// CHECK_SKL_M64: #define __SSE__ 1
716// CHECK_SKL_M64: #define __SSSE3__ 1
717// CHECK_SKL_M64: #define __XSAVEC__ 1
718// CHECK_SKL_M64: #define __XSAVEOPT__ 1
719// CHECK_SKL_M64: #define __XSAVES__ 1
720// CHECK_SKL_M64: #define __XSAVE__ 1
721// CHECK_SKL_M64: #define __amd64 1
722// CHECK_SKL_M64: #define __amd64__ 1
723// CHECK_SKL_M64: #define __x86_64 1
724// CHECK_SKL_M64: #define __x86_64__ 1
725
Craig Topper449314e2013-08-20 07:09:39 +0000726// RUN: %clang -march=knl -m32 -E -dM %s -o - 2>&1 \
727// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000728// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_KNL_M32
Craig Topper449314e2013-08-20 07:09:39 +0000729// CHECK_KNL_M32: #define __AES__ 1
730// CHECK_KNL_M32: #define __AVX2__ 1
Craig Topper679b53a2013-08-21 05:29:10 +0000731// CHECK_KNL_M32: #define __AVX512CD__ 1
732// CHECK_KNL_M32: #define __AVX512ER__ 1
Craig Topperaf0ca632013-08-20 07:52:37 +0000733// CHECK_KNL_M32: #define __AVX512F__ 1
Craig Topper679b53a2013-08-21 05:29:10 +0000734// CHECK_KNL_M32: #define __AVX512PF__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000735// CHECK_KNL_M32: #define __AVX__ 1
736// CHECK_KNL_M32: #define __BMI2__ 1
737// CHECK_KNL_M32: #define __BMI__ 1
738// CHECK_KNL_M32: #define __F16C__ 1
739// CHECK_KNL_M32: #define __FMA__ 1
740// CHECK_KNL_M32: #define __LZCNT__ 1
741// CHECK_KNL_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000742// CHECK_KNL_M32: #define __MOVBE__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000743// CHECK_KNL_M32: #define __PCLMUL__ 1
744// CHECK_KNL_M32: #define __POPCNT__ 1
Craig Topperd2bf7b02017-02-08 08:23:40 +0000745// CHECK_KNL_M32: #define __PREFETCHWT1__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000746// CHECK_KNL_M32: #define __PRFCHW__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000747// CHECK_KNL_M32: #define __RDRND__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000748// CHECK_KNL_M32: #define __SSE2__ 1
749// CHECK_KNL_M32: #define __SSE3__ 1
750// CHECK_KNL_M32: #define __SSE4_1__ 1
751// CHECK_KNL_M32: #define __SSE4_2__ 1
752// CHECK_KNL_M32: #define __SSE__ 1
753// CHECK_KNL_M32: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000754// CHECK_KNL_M32: #define __XSAVEOPT__ 1
755// CHECK_KNL_M32: #define __XSAVE__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000756// CHECK_KNL_M32: #define __i386 1
757// CHECK_KNL_M32: #define __i386__ 1
758// CHECK_KNL_M32: #define __knl 1
759// CHECK_KNL_M32: #define __knl__ 1
760// CHECK_KNL_M32: #define __tune_knl__ 1
761// CHECK_KNL_M32: #define i386 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000762
Craig Topper449314e2013-08-20 07:09:39 +0000763// RUN: %clang -march=knl -m64 -E -dM %s -o - 2>&1 \
764// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000765// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_KNL_M64
Craig Topper449314e2013-08-20 07:09:39 +0000766// CHECK_KNL_M64: #define __AES__ 1
767// CHECK_KNL_M64: #define __AVX2__ 1
Craig Topper679b53a2013-08-21 05:29:10 +0000768// CHECK_KNL_M64: #define __AVX512CD__ 1
769// CHECK_KNL_M64: #define __AVX512ER__ 1
Craig Topperaf0ca632013-08-20 07:52:37 +0000770// CHECK_KNL_M64: #define __AVX512F__ 1
Craig Topper679b53a2013-08-21 05:29:10 +0000771// CHECK_KNL_M64: #define __AVX512PF__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000772// CHECK_KNL_M64: #define __AVX__ 1
773// CHECK_KNL_M64: #define __BMI2__ 1
774// CHECK_KNL_M64: #define __BMI__ 1
775// CHECK_KNL_M64: #define __F16C__ 1
776// CHECK_KNL_M64: #define __FMA__ 1
777// CHECK_KNL_M64: #define __LZCNT__ 1
778// CHECK_KNL_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000779// CHECK_KNL_M64: #define __MOVBE__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000780// CHECK_KNL_M64: #define __PCLMUL__ 1
781// CHECK_KNL_M64: #define __POPCNT__ 1
Craig Topperd2bf7b02017-02-08 08:23:40 +0000782// CHECK_KNL_M64: #define __PREFETCHWT1__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000783// CHECK_KNL_M64: #define __PRFCHW__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000784// CHECK_KNL_M64: #define __RDRND__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000785// CHECK_KNL_M64: #define __SSE2_MATH__ 1
786// CHECK_KNL_M64: #define __SSE2__ 1
787// CHECK_KNL_M64: #define __SSE3__ 1
788// CHECK_KNL_M64: #define __SSE4_1__ 1
789// CHECK_KNL_M64: #define __SSE4_2__ 1
790// CHECK_KNL_M64: #define __SSE_MATH__ 1
791// CHECK_KNL_M64: #define __SSE__ 1
792// CHECK_KNL_M64: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000793// CHECK_KNL_M64: #define __XSAVEOPT__ 1
794// CHECK_KNL_M64: #define __XSAVE__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000795// CHECK_KNL_M64: #define __amd64 1
796// CHECK_KNL_M64: #define __amd64__ 1
797// CHECK_KNL_M64: #define __knl 1
798// CHECK_KNL_M64: #define __knl__ 1
799// CHECK_KNL_M64: #define __tune_knl__ 1
800// CHECK_KNL_M64: #define __x86_64 1
801// CHECK_KNL_M64: #define __x86_64__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000802
803// RUN: %clang -march=knm -m32 -E -dM %s -o - 2>&1 \
804// RUN: -target i386-unknown-linux \
805// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_KNM_M32
806// CHECK_KNM_M32: #define __AES__ 1
807// CHECK_KNM_M32: #define __AVX2__ 1
808// CHECK_KNM_M32: #define __AVX512CD__ 1
809// CHECK_KNM_M32: #define __AVX512ER__ 1
810// CHECK_KNM_M32: #define __AVX512F__ 1
811// CHECK_KNM_M32: #define __AVX512PF__ 1
Craig Topper009cebf2017-10-25 17:10:58 +0000812// CHECK_KNM_M32: #define __AVX512VPOPCNTDQ__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000813// CHECK_KNM_M32: #define __AVX__ 1
814// CHECK_KNM_M32: #define __BMI2__ 1
815// CHECK_KNM_M32: #define __BMI__ 1
816// CHECK_KNM_M32: #define __F16C__ 1
817// CHECK_KNM_M32: #define __FMA__ 1
818// CHECK_KNM_M32: #define __LZCNT__ 1
819// CHECK_KNM_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000820// CHECK_KNM_M32: #define __MOVBE__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000821// CHECK_KNM_M32: #define __PCLMUL__ 1
822// CHECK_KNM_M32: #define __POPCNT__ 1
823// CHECK_KNM_M32: #define __PREFETCHWT1__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000824// CHECK_KNM_M32: #define __PRFCHW__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000825// CHECK_KNM_M32: #define __RDRND__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000826// CHECK_KNM_M32: #define __SSE2__ 1
827// CHECK_KNM_M32: #define __SSE3__ 1
828// CHECK_KNM_M32: #define __SSE4_1__ 1
829// CHECK_KNM_M32: #define __SSE4_2__ 1
830// CHECK_KNM_M32: #define __SSE__ 1
831// CHECK_KNM_M32: #define __SSSE3__ 1
832// CHECK_KNM_M32: #define __XSAVEOPT__ 1
833// CHECK_KNM_M32: #define __XSAVE__ 1
834// CHECK_KNM_M32: #define __i386 1
835// CHECK_KNM_M32: #define __i386__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000836// CHECK_KNM_M32: #define i386 1
837
838// RUN: %clang -march=knm -m64 -E -dM %s -o - 2>&1 \
839// RUN: -target i386-unknown-linux \
840// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_KNM_M64
841// CHECK_KNM_M64: #define __AES__ 1
842// CHECK_KNM_M64: #define __AVX2__ 1
843// CHECK_KNM_M64: #define __AVX512CD__ 1
844// CHECK_KNM_M64: #define __AVX512ER__ 1
845// CHECK_KNM_M64: #define __AVX512F__ 1
846// CHECK_KNM_M64: #define __AVX512PF__ 1
Craig Topper009cebf2017-10-25 17:10:58 +0000847// CHECK_KNM_M64: #define __AVX512VPOPCNTDQ__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000848// CHECK_KNM_M64: #define __AVX__ 1
849// CHECK_KNM_M64: #define __BMI2__ 1
850// CHECK_KNM_M64: #define __BMI__ 1
851// CHECK_KNM_M64: #define __F16C__ 1
852// CHECK_KNM_M64: #define __FMA__ 1
853// CHECK_KNM_M64: #define __LZCNT__ 1
854// CHECK_KNM_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000855// CHECK_KNM_M64: #define __MOVBE__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000856// CHECK_KNM_M64: #define __PCLMUL__ 1
857// CHECK_KNM_M64: #define __POPCNT__ 1
858// CHECK_KNM_M64: #define __PREFETCHWT1__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000859// CHECK_KNM_M64: #define __PRFCHW__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000860// CHECK_KNM_M64: #define __RDRND__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000861// CHECK_KNM_M64: #define __SSE2_MATH__ 1
862// CHECK_KNM_M64: #define __SSE2__ 1
863// CHECK_KNM_M64: #define __SSE3__ 1
864// CHECK_KNM_M64: #define __SSE4_1__ 1
865// CHECK_KNM_M64: #define __SSE4_2__ 1
866// CHECK_KNM_M64: #define __SSE_MATH__ 1
867// CHECK_KNM_M64: #define __SSE__ 1
868// CHECK_KNM_M64: #define __SSSE3__ 1
869// CHECK_KNM_M64: #define __XSAVEOPT__ 1
870// CHECK_KNM_M64: #define __XSAVE__ 1
871// CHECK_KNM_M64: #define __amd64 1
872// CHECK_KNM_M64: #define __amd64__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000873// CHECK_KNM_M64: #define __x86_64 1
874// CHECK_KNM_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000875
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000876// RUN: %clang -march=skylake-avx512 -m32 -E -dM %s -o - 2>&1 \
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000877// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000878// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SKX_M32
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000879// CHECK_SKX_M32: #define __AES__ 1
880// CHECK_SKX_M32: #define __AVX2__ 1
881// CHECK_SKX_M32: #define __AVX512BW__ 1
882// CHECK_SKX_M32: #define __AVX512CD__ 1
883// CHECK_SKX_M32: #define __AVX512DQ__ 1
884// CHECK_SKX_M32: #define __AVX512F__ 1
885// CHECK_SKX_M32: #define __AVX512VL__ 1
886// CHECK_SKX_M32: #define __AVX__ 1
887// CHECK_SKX_M32: #define __BMI2__ 1
888// CHECK_SKX_M32: #define __BMI__ 1
Craig Topper78b47872017-02-08 06:48:58 +0000889// CHECK_SKX_M32: #define __CLFLUSHOPT__ 1
Craig Topper8c708cf2017-02-08 07:36:58 +0000890// CHECK_SKX_M32: #define __CLWB__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000891// CHECK_SKX_M32: #define __F16C__ 1
892// CHECK_SKX_M32: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +0000893// CHECK_SKX_M32: #define __INVPCID__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000894// CHECK_SKX_M32: #define __LZCNT__ 1
895// CHECK_SKX_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000896// CHECK_SKX_M32: #define __MOVBE__ 1
Craig Topperb16cb822017-02-08 07:56:42 +0000897// CHECK_SKX_M32: #define __MPX__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000898// CHECK_SKX_M32: #define __PCLMUL__ 1
Craig Topper5bd93e92017-12-27 22:26:00 +0000899// CHECK_SKX_M32: #define __PKU__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000900// CHECK_SKX_M32: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000901// CHECK_SKX_M32: #define __PRFCHW__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000902// CHECK_SKX_M32: #define __RDRND__ 1
Craig Topperc0b4aba2018-01-19 00:28:42 +0000903// CHECK_SKX_M32: #define __RDSEED__ 1
Gabor Buella59665072018-04-10 15:03:03 +0000904// CHECK_SKX_M32-NOT: #define __SGX__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000905// CHECK_SKX_M32: #define __SSE2__ 1
906// CHECK_SKX_M32: #define __SSE3__ 1
907// CHECK_SKX_M32: #define __SSE4_1__ 1
908// CHECK_SKX_M32: #define __SSE4_2__ 1
909// CHECK_SKX_M32: #define __SSE__ 1
910// CHECK_SKX_M32: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000911// CHECK_SKX_M32: #define __XSAVEC__ 1
912// CHECK_SKX_M32: #define __XSAVEOPT__ 1
913// CHECK_SKX_M32: #define __XSAVES__ 1
914// CHECK_SKX_M32: #define __XSAVE__ 1
Craig Topper222c1722017-11-19 02:55:14 +0000915// CHECK_SKX_M32: #define __corei7 1
916// CHECK_SKX_M32: #define __corei7__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000917// CHECK_SKX_M32: #define __i386 1
918// CHECK_SKX_M32: #define __i386__ 1
Craig Topper222c1722017-11-19 02:55:14 +0000919// CHECK_SKX_M32: #define __tune_corei7__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000920// CHECK_SKX_M32: #define i386 1
921
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000922// RUN: %clang -march=skylake-avx512 -m64 -E -dM %s -o - 2>&1 \
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000923// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000924// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SKX_M64
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000925// CHECK_SKX_M64: #define __AES__ 1
926// CHECK_SKX_M64: #define __AVX2__ 1
927// CHECK_SKX_M64: #define __AVX512BW__ 1
928// CHECK_SKX_M64: #define __AVX512CD__ 1
929// CHECK_SKX_M64: #define __AVX512DQ__ 1
930// CHECK_SKX_M64: #define __AVX512F__ 1
931// CHECK_SKX_M64: #define __AVX512VL__ 1
932// CHECK_SKX_M64: #define __AVX__ 1
933// CHECK_SKX_M64: #define __BMI2__ 1
934// CHECK_SKX_M64: #define __BMI__ 1
Craig Topper78b47872017-02-08 06:48:58 +0000935// CHECK_SKX_M64: #define __CLFLUSHOPT__ 1
Craig Topper8c708cf2017-02-08 07:36:58 +0000936// CHECK_SKX_M64: #define __CLWB__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000937// CHECK_SKX_M64: #define __F16C__ 1
938// CHECK_SKX_M64: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +0000939// CHECK_SKX_M64: #define __INVPCID__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000940// CHECK_SKX_M64: #define __LZCNT__ 1
941// CHECK_SKX_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000942// CHECK_SKX_M64: #define __MOVBE__ 1
Craig Topperb16cb822017-02-08 07:56:42 +0000943// CHECK_SKX_M64: #define __MPX__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000944// CHECK_SKX_M64: #define __PCLMUL__ 1
Craig Topper5bd93e92017-12-27 22:26:00 +0000945// CHECK_SKX_M64: #define __PKU__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000946// CHECK_SKX_M64: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000947// CHECK_SKX_M64: #define __PRFCHW__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000948// CHECK_SKX_M64: #define __RDRND__ 1
Craig Topperc0b4aba2018-01-19 00:28:42 +0000949// CHECK_SKX_M64: #define __RDSEED__ 1
Gabor Buella59665072018-04-10 15:03:03 +0000950// CHECK_SKX_M64-NOT: #define __SGX__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000951// CHECK_SKX_M64: #define __SSE2_MATH__ 1
952// CHECK_SKX_M64: #define __SSE2__ 1
953// CHECK_SKX_M64: #define __SSE3__ 1
954// CHECK_SKX_M64: #define __SSE4_1__ 1
955// CHECK_SKX_M64: #define __SSE4_2__ 1
956// CHECK_SKX_M64: #define __SSE_MATH__ 1
957// CHECK_SKX_M64: #define __SSE__ 1
958// CHECK_SKX_M64: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000959// CHECK_SKX_M64: #define __XSAVEC__ 1
960// CHECK_SKX_M64: #define __XSAVEOPT__ 1
961// CHECK_SKX_M64: #define __XSAVES__ 1
962// CHECK_SKX_M64: #define __XSAVE__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000963// CHECK_SKX_M64: #define __amd64 1
964// CHECK_SKX_M64: #define __amd64__ 1
Craig Topper222c1722017-11-19 02:55:14 +0000965// CHECK_SKX_M64: #define __corei7 1
966// CHECK_SKX_M64: #define __corei7__ 1
967// CHECK_SKX_M64: #define __tune_corei7__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000968// CHECK_SKX_M64: #define __x86_64 1
969// CHECK_SKX_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000970
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000971// RUN: %clang -march=cannonlake -m32 -E -dM %s -o - 2>&1 \
972// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000973// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CNL_M32
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000974// CHECK_CNL_M32: #define __AES__ 1
975// CHECK_CNL_M32: #define __AVX2__ 1
976// CHECK_CNL_M32: #define __AVX512BW__ 1
977// CHECK_CNL_M32: #define __AVX512CD__ 1
978// CHECK_CNL_M32: #define __AVX512DQ__ 1
979// CHECK_CNL_M32: #define __AVX512F__ 1
Craig Topperb4f83a02016-02-29 06:51:38 +0000980// CHECK_CNL_M32: #define __AVX512IFMA__ 1
981// CHECK_CNL_M32: #define __AVX512VBMI__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000982// CHECK_CNL_M32: #define __AVX512VL__ 1
983// CHECK_CNL_M32: #define __AVX__ 1
984// CHECK_CNL_M32: #define __BMI2__ 1
985// CHECK_CNL_M32: #define __BMI__ 1
Craig Topper78b47872017-02-08 06:48:58 +0000986// CHECK_CNL_M32: #define __CLFLUSHOPT__ 1
Craig Topper94a940d2018-02-21 00:16:50 +0000987// CHECK_CNL_M32-NOT: #define __CLWB__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000988// CHECK_CNL_M32: #define __F16C__ 1
989// CHECK_CNL_M32: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +0000990// CHECK_CNL_M32: #define __INVPCID__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000991// CHECK_CNL_M32: #define __LZCNT__ 1
992// CHECK_CNL_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000993// CHECK_CNL_M32: #define __MOVBE__ 1
Craig Topperb16cb822017-02-08 07:56:42 +0000994// CHECK_CNL_M32: #define __MPX__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000995// CHECK_CNL_M32: #define __PCLMUL__ 1
Craig Topperd2fe2442017-12-29 06:39:16 +0000996// CHECK_CNL_M32: #define __PKU__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000997// CHECK_CNL_M32: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000998// CHECK_CNL_M32: #define __PRFCHW__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000999// CHECK_CNL_M32: #define __RDRND__ 1
Craig Topperc0b4aba2018-01-19 00:28:42 +00001000// CHECK_CNL_M32: #define __RDSEED__ 1
Craig Topper204ecff2017-02-08 08:23:17 +00001001// CHECK_CNL_M32: #define __SGX__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001002// CHECK_CNL_M32: #define __SHA__ 1
1003// CHECK_CNL_M32: #define __SSE2__ 1
1004// CHECK_CNL_M32: #define __SSE3__ 1
1005// CHECK_CNL_M32: #define __SSE4_1__ 1
1006// CHECK_CNL_M32: #define __SSE4_2__ 1
1007// CHECK_CNL_M32: #define __SSE__ 1
1008// CHECK_CNL_M32: #define __SSSE3__ 1
1009// CHECK_CNL_M32: #define __XSAVEC__ 1
1010// CHECK_CNL_M32: #define __XSAVEOPT__ 1
1011// CHECK_CNL_M32: #define __XSAVES__ 1
1012// CHECK_CNL_M32: #define __XSAVE__ 1
Craig Topper222c1722017-11-19 02:55:14 +00001013// CHECK_CNL_M32: #define __corei7 1
1014// CHECK_CNL_M32: #define __corei7__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001015// CHECK_CNL_M32: #define __i386 1
1016// CHECK_CNL_M32: #define __i386__ 1
Craig Topper222c1722017-11-19 02:55:14 +00001017// CHECK_CNL_M32: #define __tune_corei7__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001018// CHECK_CNL_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001019
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001020// RUN: %clang -march=cannonlake -m64 -E -dM %s -o - 2>&1 \
1021// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001022// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CNL_M64
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001023// CHECK_CNL_M64: #define __AES__ 1
1024// CHECK_CNL_M64: #define __AVX2__ 1
1025// CHECK_CNL_M64: #define __AVX512BW__ 1
1026// CHECK_CNL_M64: #define __AVX512CD__ 1
1027// CHECK_CNL_M64: #define __AVX512DQ__ 1
1028// CHECK_CNL_M64: #define __AVX512F__ 1
Craig Topperb4f83a02016-02-29 06:51:38 +00001029// CHECK_CNL_M64: #define __AVX512IFMA__ 1
1030// CHECK_CNL_M64: #define __AVX512VBMI__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001031// CHECK_CNL_M64: #define __AVX512VL__ 1
1032// CHECK_CNL_M64: #define __AVX__ 1
1033// CHECK_CNL_M64: #define __BMI2__ 1
1034// CHECK_CNL_M64: #define __BMI__ 1
Craig Topper78b47872017-02-08 06:48:58 +00001035// CHECK_CNL_M64: #define __CLFLUSHOPT__ 1
Craig Topper94a940d2018-02-21 00:16:50 +00001036// CHECK_CNL_M64-NOT: #define __CLWB__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001037// CHECK_CNL_M64: #define __F16C__ 1
1038// CHECK_CNL_M64: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +00001039// CHECK_CNL_M64: #define __INVPCID__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001040// CHECK_CNL_M64: #define __LZCNT__ 1
1041// CHECK_CNL_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001042// CHECK_CNL_M64: #define __MOVBE__ 1
Craig Topperb16cb822017-02-08 07:56:42 +00001043// CHECK_CNL_M64: #define __MPX__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001044// CHECK_CNL_M64: #define __PCLMUL__ 1
Craig Topperd2fe2442017-12-29 06:39:16 +00001045// CHECK_CNL_M64: #define __PKU__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001046// CHECK_CNL_M64: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +00001047// CHECK_CNL_M64: #define __PRFCHW__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001048// CHECK_CNL_M64: #define __RDRND__ 1
Craig Topperc0b4aba2018-01-19 00:28:42 +00001049// CHECK_CNL_M64: #define __RDSEED__ 1
Craig Topper204ecff2017-02-08 08:23:17 +00001050// CHECK_CNL_M64: #define __SGX__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001051// CHECK_CNL_M64: #define __SHA__ 1
1052// CHECK_CNL_M64: #define __SSE2__ 1
1053// CHECK_CNL_M64: #define __SSE3__ 1
1054// CHECK_CNL_M64: #define __SSE4_1__ 1
1055// CHECK_CNL_M64: #define __SSE4_2__ 1
1056// CHECK_CNL_M64: #define __SSE__ 1
1057// CHECK_CNL_M64: #define __SSSE3__ 1
1058// CHECK_CNL_M64: #define __XSAVEC__ 1
1059// CHECK_CNL_M64: #define __XSAVEOPT__ 1
1060// CHECK_CNL_M64: #define __XSAVES__ 1
1061// CHECK_CNL_M64: #define __XSAVE__ 1
James Y Knight3508b222016-04-01 21:33:20 +00001062// CHECK_CNL_M64: #define __amd64 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001063// CHECK_CNL_M64: #define __amd64__ 1
Craig Topper222c1722017-11-19 02:55:14 +00001064// CHECK_CNL_M64: #define __corei7 1
1065// CHECK_CNL_M64: #define __corei7__ 1
1066// CHECK_CNL_M64: #define __tune_corei7__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001067// CHECK_CNL_M64: #define __x86_64 1
1068// CHECK_CNL_M64: #define __x86_64__ 1
1069
Gabor Buella8701b182018-04-10 18:58:26 +00001070// RUN: %clang -march=icelake-client -m32 -E -dM %s -o - 2>&1 \
Craig Topper546cee42017-11-19 02:55:15 +00001071// RUN: -target i386-unknown-linux \
1072// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ICL_M32
1073// CHECK_ICL_M32: #define __AES__ 1
1074// CHECK_ICL_M32: #define __AVX2__ 1
Coby Tayree22685762017-12-27 10:01:00 +00001075// CHECK_ICL_M32: #define __AVX512BITALG__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001076// CHECK_ICL_M32: #define __AVX512BW__ 1
1077// CHECK_ICL_M32: #define __AVX512CD__ 1
1078// CHECK_ICL_M32: #define __AVX512DQ__ 1
1079// CHECK_ICL_M32: #define __AVX512F__ 1
1080// CHECK_ICL_M32: #define __AVX512IFMA__ 1
Coby Tayreea09663a2017-12-27 11:25:07 +00001081// CHECK_ICL_M32: #define __AVX512VBMI2__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001082// CHECK_ICL_M32: #define __AVX512VBMI__ 1
1083// CHECK_ICL_M32: #define __AVX512VL__ 1
Coby Tayree3d9c88c2017-12-27 10:37:51 +00001084// CHECK_ICL_M32: #define __AVX512VNNI__ 1
Craig Topperb36447d2017-12-27 22:25:59 +00001085// CHECK_ICL_M32: #define __AVX512VPOPCNTDQ__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001086// CHECK_ICL_M32: #define __AVX__ 1
1087// CHECK_ICL_M32: #define __BMI2__ 1
1088// CHECK_ICL_M32: #define __BMI__ 1
1089// CHECK_ICL_M32: #define __CLFLUSHOPT__ 1
Craig Topperb36447d2017-12-27 22:25:59 +00001090// CHECK_ICL_M32: #define __CLWB__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001091// CHECK_ICL_M32: #define __F16C__ 1
1092// CHECK_ICL_M32: #define __FMA__ 1
Coby Tayreef4811eb2017-12-27 08:37:47 +00001093// CHECK_ICL_M32: #define __GFNI__ 1
Gabor Buella078bb992018-05-25 06:34:42 +00001094// CHECK_ICL_M32: #define __INVPCID__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001095// CHECK_ICL_M32: #define __LZCNT__ 1
1096// CHECK_ICL_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001097// CHECK_ICL_M32: #define __MOVBE__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001098// CHECK_ICL_M32: #define __MPX__ 1
1099// CHECK_ICL_M32: #define __PCLMUL__ 1
Craig Topperd2fe2442017-12-29 06:39:16 +00001100// CHECK_ICL_M32: #define __PKU__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001101// CHECK_ICL_M32: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +00001102// CHECK_ICL_M32: #define __PRFCHW__ 1
Craig Topper8cdb9492018-01-20 18:36:52 +00001103// CHECK_ICL_M32: #define __RDPID__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001104// CHECK_ICL_M32: #define __RDRND__ 1
Craig Topperc0b4aba2018-01-19 00:28:42 +00001105// CHECK_ICL_M32: #define __RDSEED__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001106// CHECK_ICL_M32: #define __SGX__ 1
1107// CHECK_ICL_M32: #define __SHA__ 1
1108// CHECK_ICL_M32: #define __SSE2__ 1
1109// CHECK_ICL_M32: #define __SSE3__ 1
1110// CHECK_ICL_M32: #define __SSE4_1__ 1
1111// CHECK_ICL_M32: #define __SSE4_2__ 1
1112// CHECK_ICL_M32: #define __SSE__ 1
1113// CHECK_ICL_M32: #define __SSSE3__ 1
Coby Tayreea1e5f0c2017-12-27 08:16:54 +00001114// CHECK_ICL_M32: #define __VAES__ 1
Coby Tayreecf96c872017-12-27 09:00:31 +00001115// CHECK_ICL_M32: #define __VPCLMULQDQ__ 1
Gabor Buellaa0520162018-04-11 20:09:09 +00001116// CHECK_ICL_M32-NOT: #define __WBNOINVD__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001117// CHECK_ICL_M32: #define __XSAVEC__ 1
1118// CHECK_ICL_M32: #define __XSAVEOPT__ 1
1119// CHECK_ICL_M32: #define __XSAVES__ 1
1120// CHECK_ICL_M32: #define __XSAVE__ 1
1121// CHECK_ICL_M32: #define __corei7 1
1122// CHECK_ICL_M32: #define __corei7__ 1
1123// CHECK_ICL_M32: #define __i386 1
1124// CHECK_ICL_M32: #define __i386__ 1
1125// CHECK_ICL_M32: #define __tune_corei7__ 1
1126// CHECK_ICL_M32: #define i386 1
Gabor Buella8701b182018-04-10 18:58:26 +00001127
1128// RUN: %clang -march=icelake-client -m64 -E -dM %s -o - 2>&1 \
Craig Topper546cee42017-11-19 02:55:15 +00001129// RUN: -target i386-unknown-linux \
1130// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ICL_M64
1131// CHECK_ICL_M64: #define __AES__ 1
1132// CHECK_ICL_M64: #define __AVX2__ 1
Coby Tayree22685762017-12-27 10:01:00 +00001133// CHECK_ICL_M64: #define __AVX512BITALG__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001134// CHECK_ICL_M64: #define __AVX512BW__ 1
1135// CHECK_ICL_M64: #define __AVX512CD__ 1
1136// CHECK_ICL_M64: #define __AVX512DQ__ 1
1137// CHECK_ICL_M64: #define __AVX512F__ 1
1138// CHECK_ICL_M64: #define __AVX512IFMA__ 1
Coby Tayreea09663a2017-12-27 11:25:07 +00001139// CHECK_ICL_M64: #define __AVX512VBMI2__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001140// CHECK_ICL_M64: #define __AVX512VBMI__ 1
1141// CHECK_ICL_M64: #define __AVX512VL__ 1
Coby Tayree3d9c88c2017-12-27 10:37:51 +00001142// CHECK_ICL_M64: #define __AVX512VNNI__ 1
Craig Topperb36447d2017-12-27 22:25:59 +00001143// CHECK_ICL_M64: #define __AVX512VPOPCNTDQ__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001144// CHECK_ICL_M64: #define __AVX__ 1
1145// CHECK_ICL_M64: #define __BMI2__ 1
1146// CHECK_ICL_M64: #define __BMI__ 1
1147// CHECK_ICL_M64: #define __CLFLUSHOPT__ 1
Craig Topperb36447d2017-12-27 22:25:59 +00001148// CHECK_ICL_M64: #define __CLWB__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001149// CHECK_ICL_M64: #define __F16C__ 1
1150// CHECK_ICL_M64: #define __FMA__ 1
Coby Tayreef4811eb2017-12-27 08:37:47 +00001151// CHECK_ICL_M64: #define __GFNI__ 1
Gabor Buella078bb992018-05-25 06:34:42 +00001152// CHECK_ICL_M64: #define __INVPCID__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001153// CHECK_ICL_M64: #define __LZCNT__ 1
1154// CHECK_ICL_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001155// CHECK_ICL_M64: #define __MOVBE__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001156// CHECK_ICL_M64: #define __MPX__ 1
1157// CHECK_ICL_M64: #define __PCLMUL__ 1
Craig Topperd2fe2442017-12-29 06:39:16 +00001158// CHECK_ICL_M64: #define __PKU__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001159// CHECK_ICL_M64: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +00001160// CHECK_ICL_M64: #define __PRFCHW__ 1
Craig Topper8cdb9492018-01-20 18:36:52 +00001161// CHECK_ICL_M64: #define __RDPID__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001162// CHECK_ICL_M64: #define __RDRND__ 1
Craig Topperc0b4aba2018-01-19 00:28:42 +00001163// CHECK_ICL_M64: #define __RDSEED__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001164// CHECK_ICL_M64: #define __SGX__ 1
1165// CHECK_ICL_M64: #define __SHA__ 1
1166// CHECK_ICL_M64: #define __SSE2__ 1
1167// CHECK_ICL_M64: #define __SSE3__ 1
1168// CHECK_ICL_M64: #define __SSE4_1__ 1
1169// CHECK_ICL_M64: #define __SSE4_2__ 1
1170// CHECK_ICL_M64: #define __SSE__ 1
1171// CHECK_ICL_M64: #define __SSSE3__ 1
Coby Tayreea1e5f0c2017-12-27 08:16:54 +00001172// CHECK_ICL_M64: #define __VAES__ 1
Coby Tayreecf96c872017-12-27 09:00:31 +00001173// CHECK_ICL_M64: #define __VPCLMULQDQ__ 1
Gabor Buellaa0520162018-04-11 20:09:09 +00001174// CHECK_ICL_M64-NOT: #define __WBNOINVD__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001175// CHECK_ICL_M64: #define __XSAVEC__ 1
1176// CHECK_ICL_M64: #define __XSAVEOPT__ 1
1177// CHECK_ICL_M64: #define __XSAVES__ 1
1178// CHECK_ICL_M64: #define __XSAVE__ 1
1179// CHECK_ICL_M64: #define __amd64 1
1180// CHECK_ICL_M64: #define __amd64__ 1
1181// CHECK_ICL_M64: #define __corei7 1
1182// CHECK_ICL_M64: #define __corei7__ 1
1183// CHECK_ICL_M64: #define __tune_corei7__ 1
1184// CHECK_ICL_M64: #define __x86_64 1
1185// CHECK_ICL_M64: #define __x86_64__ 1
1186
Gabor Buella8701b182018-04-10 18:58:26 +00001187// RUN: %clang -march=icelake-server -m32 -E -dM %s -o - 2>&1 \
1188// RUN: -target i386-unknown-linux \
1189// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ICX_M32
1190// CHECK_ICX_M32: #define __AES__ 1
1191// CHECK_ICX_M32: #define __AVX2__ 1
1192// CHECK_ICX_M32: #define __AVX512BITALG__ 1
1193// CHECK_ICX_M32: #define __AVX512BW__ 1
1194// CHECK_ICX_M32: #define __AVX512CD__ 1
1195// CHECK_ICX_M32: #define __AVX512DQ__ 1
1196// CHECK_ICX_M32: #define __AVX512F__ 1
1197// CHECK_ICX_M32: #define __AVX512IFMA__ 1
1198// CHECK_ICX_M32: #define __AVX512VBMI2__ 1
1199// CHECK_ICX_M32: #define __AVX512VBMI__ 1
1200// CHECK_ICX_M32: #define __AVX512VL__ 1
1201// CHECK_ICX_M32: #define __AVX512VNNI__ 1
1202// CHECK_ICX_M32: #define __AVX512VPOPCNTDQ__ 1
1203// CHECK_ICX_M32: #define __AVX__ 1
1204// CHECK_ICX_M32: #define __BMI2__ 1
1205// CHECK_ICX_M32: #define __BMI__ 1
1206// CHECK_ICX_M32: #define __CLFLUSHOPT__ 1
1207// CHECK_ICX_M32: #define __CLWB__ 1
1208// CHECK_ICX_M32: #define __F16C__ 1
1209// CHECK_ICX_M32: #define __FMA__ 1
1210// CHECK_ICX_M32: #define __GFNI__ 1
Gabor Buella078bb992018-05-25 06:34:42 +00001211// CHECK_ICX_M32: #define __INVPCID__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001212// CHECK_ICX_M32: #define __LZCNT__ 1
1213// CHECK_ICX_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001214// CHECK_ICX_M32: #define __MOVBE__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001215// CHECK_ICX_M32: #define __MPX__ 1
1216// CHECK_ICX_M32: #define __PCLMUL__ 1
Gabor Buellab0f310d2018-05-08 06:49:41 +00001217// CHECK_ICX_M32: #define __PCONFIG__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001218// CHECK_ICX_M32: #define __PKU__ 1
1219// CHECK_ICX_M32: #define __POPCNT__ 1
1220// CHECK_ICX_M32: #define __PRFCHW__ 1
1221// CHECK_ICX_M32: #define __RDPID__ 1
1222// CHECK_ICX_M32: #define __RDRND__ 1
1223// CHECK_ICX_M32: #define __RDSEED__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001224// CHECK_ICX_M32: #define __SGX__ 1
1225// CHECK_ICX_M32: #define __SHA__ 1
1226// CHECK_ICX_M32: #define __SSE2__ 1
1227// CHECK_ICX_M32: #define __SSE3__ 1
1228// CHECK_ICX_M32: #define __SSE4_1__ 1
1229// CHECK_ICX_M32: #define __SSE4_2__ 1
1230// CHECK_ICX_M32: #define __SSE__ 1
1231// CHECK_ICX_M32: #define __SSSE3__ 1
1232// CHECK_ICX_M32: #define __VAES__ 1
1233// CHECK_ICX_M32: #define __VPCLMULQDQ__ 1
Gabor Buellaa0520162018-04-11 20:09:09 +00001234// CHECK_ICX_M32: #define __WBNOINVD__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001235// CHECK_ICX_M32: #define __XSAVEC__ 1
1236// CHECK_ICX_M32: #define __XSAVEOPT__ 1
1237// CHECK_ICX_M32: #define __XSAVES__ 1
1238// CHECK_ICX_M32: #define __XSAVE__ 1
1239// CHECK_ICX_M32: #define __corei7 1
1240// CHECK_ICX_M32: #define __corei7__ 1
1241// CHECK_ICX_M32: #define __i386 1
1242// CHECK_ICX_M32: #define __i386__ 1
1243// CHECK_ICX_M32: #define __tune_corei7__ 1
1244// CHECK_ICX_M32: #define i386 1
1245
1246// RUN: %clang -march=icelake-server -m64 -E -dM %s -o - 2>&1 \
1247// RUN: -target i386-unknown-linux \
1248// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ICX_M64
1249// CHECK_ICX_M64: #define __AES__ 1
1250// CHECK_ICX_M64: #define __AVX2__ 1
1251// CHECK_ICX_M64: #define __AVX512BITALG__ 1
1252// CHECK_ICX_M64: #define __AVX512BW__ 1
1253// CHECK_ICX_M64: #define __AVX512CD__ 1
1254// CHECK_ICX_M64: #define __AVX512DQ__ 1
1255// CHECK_ICX_M64: #define __AVX512F__ 1
1256// CHECK_ICX_M64: #define __AVX512IFMA__ 1
1257// CHECK_ICX_M64: #define __AVX512VBMI2__ 1
1258// CHECK_ICX_M64: #define __AVX512VBMI__ 1
1259// CHECK_ICX_M64: #define __AVX512VL__ 1
1260// CHECK_ICX_M64: #define __AVX512VNNI__ 1
1261// CHECK_ICX_M64: #define __AVX512VPOPCNTDQ__ 1
1262// CHECK_ICX_M64: #define __AVX__ 1
1263// CHECK_ICX_M64: #define __BMI2__ 1
1264// CHECK_ICX_M64: #define __BMI__ 1
1265// CHECK_ICX_M64: #define __CLFLUSHOPT__ 1
1266// CHECK_ICX_M64: #define __CLWB__ 1
1267// CHECK_ICX_M64: #define __F16C__ 1
1268// CHECK_ICX_M64: #define __FMA__ 1
1269// CHECK_ICX_M64: #define __GFNI__ 1
Gabor Buella078bb992018-05-25 06:34:42 +00001270// CHECK_ICX_M64: #define __INVPCID__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001271// CHECK_ICX_M64: #define __LZCNT__ 1
1272// CHECK_ICX_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001273// CHECK_ICX_M64: #define __MOVBE__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001274// CHECK_ICX_M64: #define __MPX__ 1
1275// CHECK_ICX_M64: #define __PCLMUL__ 1
Gabor Buellab0f310d2018-05-08 06:49:41 +00001276// CHECK_ICX_M64: #define __PCONFIG__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001277// CHECK_ICX_M64: #define __PKU__ 1
1278// CHECK_ICX_M64: #define __POPCNT__ 1
1279// CHECK_ICX_M64: #define __PRFCHW__ 1
1280// CHECK_ICX_M64: #define __RDPID__ 1
1281// CHECK_ICX_M64: #define __RDRND__ 1
1282// CHECK_ICX_M64: #define __RDSEED__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001283// CHECK_ICX_M64: #define __SGX__ 1
1284// CHECK_ICX_M64: #define __SHA__ 1
1285// CHECK_ICX_M64: #define __SSE2__ 1
1286// CHECK_ICX_M64: #define __SSE3__ 1
1287// CHECK_ICX_M64: #define __SSE4_1__ 1
1288// CHECK_ICX_M64: #define __SSE4_2__ 1
1289// CHECK_ICX_M64: #define __SSE__ 1
1290// CHECK_ICX_M64: #define __SSSE3__ 1
1291// CHECK_ICX_M64: #define __VAES__ 1
1292// CHECK_ICX_M64: #define __VPCLMULQDQ__ 1
Gabor Buellaa0520162018-04-11 20:09:09 +00001293// CHECK_ICX_M64: #define __WBNOINVD__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001294// CHECK_ICX_M64: #define __XSAVEC__ 1
1295// CHECK_ICX_M64: #define __XSAVEOPT__ 1
1296// CHECK_ICX_M64: #define __XSAVES__ 1
1297// CHECK_ICX_M64: #define __XSAVE__ 1
1298// CHECK_ICX_M64: #define __amd64 1
1299// CHECK_ICX_M64: #define __amd64__ 1
1300// CHECK_ICX_M64: #define __corei7 1
1301// CHECK_ICX_M64: #define __corei7__ 1
1302// CHECK_ICX_M64: #define __tune_corei7__ 1
1303// CHECK_ICX_M64: #define __x86_64 1
1304// CHECK_ICX_M64: #define __x86_64__ 1
1305
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001306// RUN: %clang -march=atom -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001307// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001308// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATOM_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001309// CHECK_ATOM_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001310// CHECK_ATOM_M32: #define __MOVBE__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001311// CHECK_ATOM_M32: #define __SSE2__ 1
1312// CHECK_ATOM_M32: #define __SSE3__ 1
1313// CHECK_ATOM_M32: #define __SSE__ 1
1314// CHECK_ATOM_M32: #define __SSSE3__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001315// CHECK_ATOM_M32: #define __atom 1
1316// CHECK_ATOM_M32: #define __atom__ 1
1317// CHECK_ATOM_M32: #define __i386 1
1318// CHECK_ATOM_M32: #define __i386__ 1
1319// CHECK_ATOM_M32: #define __tune_atom__ 1
1320// CHECK_ATOM_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001321
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00001322// RUN: %clang -march=atom -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001323// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001324// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATOM_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001325// CHECK_ATOM_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001326// CHECK_ATOM_M64: #define __MOVBE__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001327// CHECK_ATOM_M64: #define __SSE2_MATH__ 1
1328// CHECK_ATOM_M64: #define __SSE2__ 1
1329// CHECK_ATOM_M64: #define __SSE3__ 1
1330// CHECK_ATOM_M64: #define __SSE_MATH__ 1
1331// CHECK_ATOM_M64: #define __SSE__ 1
1332// CHECK_ATOM_M64: #define __SSSE3__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00001333// CHECK_ATOM_M64: #define __amd64 1
1334// CHECK_ATOM_M64: #define __amd64__ 1
1335// CHECK_ATOM_M64: #define __atom 1
1336// CHECK_ATOM_M64: #define __atom__ 1
1337// CHECK_ATOM_M64: #define __tune_atom__ 1
1338// CHECK_ATOM_M64: #define __x86_64 1
1339// CHECK_ATOM_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001340
Michael Zuckermana046ef42017-06-29 13:41:04 +00001341// RUN: %clang -march=goldmont -m32 -E -dM %s -o - 2>&1 \
1342// RUN: -target i386-unknown-linux \
1343// RUN: | FileCheck %s -check-prefix=CHECK_GLM_M32
1344// CHECK_GLM_M32: #define __AES__ 1
1345// CHECK_GLM_M32: #define __CLFLUSHOPT__ 1
Michael Zuckerman35731a02017-09-25 13:49:32 +00001346// CHECK_GLM_M32: #define __FSGSBASE__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00001347// CHECK_GLM_M32: #define __FXSR__ 1
1348// CHECK_GLM_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001349// CHECK_GLM_M32: #define __MOVBE__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00001350// CHECK_GLM_M32: #define __MPX__ 1
1351// CHECK_GLM_M32: #define __PCLMUL__ 1
1352// CHECK_GLM_M32: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +00001353// CHECK_GLM_M32: #define __PRFCHW__ 1
Craig Topper9dd7e802017-06-30 18:14:04 +00001354// CHECK_GLM_M32: #define __RDRND__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00001355// CHECK_GLM_M32: #define __RDSEED__ 1
1356// CHECK_GLM_M32: #define __SHA__ 1
1357// CHECK_GLM_M32: #define __SSE2__ 1
1358// CHECK_GLM_M32: #define __SSE3__ 1
1359// CHECK_GLM_M32: #define __SSE4_1__ 1
1360// CHECK_GLM_M32: #define __SSE4_2__ 1
1361// CHECK_GLM_M32: #define __SSE_MATH__ 1
1362// CHECK_GLM_M32: #define __SSE__ 1
1363// CHECK_GLM_M32: #define __SSSE3__ 1
1364// CHECK_GLM_M32: #define __XSAVEC__ 1
1365// CHECK_GLM_M32: #define __XSAVEOPT__ 1
1366// CHECK_GLM_M32: #define __XSAVES__ 1
1367// CHECK_GLM_M32: #define __XSAVE__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00001368// CHECK_GLM_M32: #define __goldmont 1
1369// CHECK_GLM_M32: #define __goldmont__ 1
1370// CHECK_GLM_M32: #define __i386 1
1371// CHECK_GLM_M32: #define __i386__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00001372// CHECK_GLM_M32: #define __tune_goldmont__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00001373// CHECK_GLM_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001374
Michael Zuckermana046ef42017-06-29 13:41:04 +00001375// RUN: %clang -march=goldmont -m64 -E -dM %s -o - 2>&1 \
1376// RUN: -target i386-unknown-linux \
1377// RUN: | FileCheck %s -check-prefix=CHECK_GLM_M64
1378// CHECK_GLM_M64: #define __AES__ 1
1379// CHECK_GLM_M64: #define __CLFLUSHOPT__ 1
Michael Zuckerman35731a02017-09-25 13:49:32 +00001380// CHECK_GLM_M64: #define __FSGSBASE__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00001381// CHECK_GLM_M64: #define __FXSR__ 1
1382// CHECK_GLM_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001383// CHECK_GLM_M64: #define __MOVBE__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00001384// CHECK_GLM_M64: #define __MPX__ 1
1385// CHECK_GLM_M64: #define __PCLMUL__ 1
1386// CHECK_GLM_M64: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +00001387// CHECK_GLM_M64: #define __PRFCHW__ 1
Craig Topper9dd7e802017-06-30 18:14:04 +00001388// CHECK_GLM_M64: #define __RDRND__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00001389// CHECK_GLM_M64: #define __RDSEED__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00001390// CHECK_GLM_M64: #define __SHA__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00001391// CHECK_GLM_M64: #define __SSE2__ 1
1392// CHECK_GLM_M64: #define __SSE3__ 1
1393// CHECK_GLM_M64: #define __SSE4_1__ 1
1394// CHECK_GLM_M64: #define __SSE4_2__ 1
1395// CHECK_GLM_M64: #define __SSE__ 1
1396// CHECK_GLM_M64: #define __SSSE3__ 1
1397// CHECK_GLM_M64: #define __XSAVEC__ 1
1398// CHECK_GLM_M64: #define __XSAVEOPT__ 1
1399// CHECK_GLM_M64: #define __XSAVES__ 1
1400// CHECK_GLM_M64: #define __XSAVE__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00001401// CHECK_GLM_M64: #define __goldmont 1
1402// CHECK_GLM_M64: #define __goldmont__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00001403// CHECK_GLM_M64: #define __tune_goldmont__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00001404// CHECK_GLM_M64: #define __x86_64 1
1405// CHECK_GLM_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001406
Gabor Buellaf594ce72018-04-16 08:10:10 +00001407// RUN: %clang -march=goldmont-plus -m32 -E -dM %s -o - 2>&1 \
1408// RUN: -target i386-unknown-linux \
1409// RUN: | FileCheck %s -check-prefix=CHECK_GLMP_M32
1410// CHECK_GLMP_M32: #define __AES__ 1
1411// CHECK_GLMP_M32: #define __CLFLUSHOPT__ 1
1412// CHECK_GLMP_M32: #define __FSGSBASE__ 1
1413// CHECK_GLMP_M32: #define __FXSR__ 1
1414// CHECK_GLMP_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001415// CHECK_GLMP_M32: #define __MOVBE__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00001416// CHECK_GLMP_M32: #define __MPX__ 1
1417// CHECK_GLMP_M32: #define __PCLMUL__ 1
1418// CHECK_GLMP_M32: #define __POPCNT__ 1
1419// CHECK_GLMP_M32: #define __PRFCHW__ 1
Gabor Buella3a757122018-05-10 07:28:54 +00001420// CHECK_GLMP_M32: #define __PTWRITE__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00001421// CHECK_GLMP_M32: #define __RDPID__ 1
1422// CHECK_GLMP_M32: #define __RDRND__ 1
1423// CHECK_GLMP_M32: #define __RDSEED__ 1
1424// CHECK_GLMP_M32: #define __SGX__ 1
1425// CHECK_GLMP_M32: #define __SHA__ 1
1426// CHECK_GLMP_M32: #define __SSE2__ 1
1427// CHECK_GLMP_M32: #define __SSE3__ 1
1428// CHECK_GLMP_M32: #define __SSE4_1__ 1
1429// CHECK_GLMP_M32: #define __SSE4_2__ 1
1430// CHECK_GLMP_M32: #define __SSE_MATH__ 1
1431// CHECK_GLMP_M32: #define __SSE__ 1
1432// CHECK_GLMP_M32: #define __SSSE3__ 1
1433// CHECK_GLMP_M32: #define __XSAVEC__ 1
1434// CHECK_GLMP_M32: #define __XSAVEOPT__ 1
1435// CHECK_GLMP_M32: #define __XSAVES__ 1
1436// CHECK_GLMP_M32: #define __XSAVE__ 1
1437// CHECK_GLMP_M32: #define __goldmont_plus 1
1438// CHECK_GLMP_M32: #define __goldmont_plus__ 1
1439// CHECK_GLMP_M32: #define __i386 1
1440// CHECK_GLMP_M32: #define __i386__ 1
1441// CHECK_GLMP_M32: #define __tune_goldmont_plus__ 1
1442// CHECK_GLMP_M32: #define i386 1
1443
1444// RUN: %clang -march=goldmont-plus -m64 -E -dM %s -o - 2>&1 \
1445// RUN: -target i386-unknown-linux \
1446// RUN: | FileCheck %s -check-prefix=CHECK_GLMP_M64
1447// CHECK_GLMP_M64: #define __AES__ 1
1448// CHECK_GLMP_M64: #define __CLFLUSHOPT__ 1
1449// CHECK_GLMP_M64: #define __FSGSBASE__ 1
1450// CHECK_GLMP_M64: #define __FXSR__ 1
1451// CHECK_GLMP_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001452// CHECK_GLMP_M64: #define __MOVBE__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00001453// CHECK_GLMP_M64: #define __MPX__ 1
1454// CHECK_GLMP_M64: #define __PCLMUL__ 1
1455// CHECK_GLMP_M64: #define __POPCNT__ 1
1456// CHECK_GLMP_M64: #define __PRFCHW__ 1
Gabor Buella3a757122018-05-10 07:28:54 +00001457// CHECK_GLMP_M64: #define __PTWRITE__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00001458// CHECK_GLMP_M64: #define __RDPID__ 1
1459// CHECK_GLMP_M64: #define __RDRND__ 1
1460// CHECK_GLMP_M64: #define __RDSEED__ 1
1461// CHECK_GLMP_M64: #define __SGX__ 1
1462// CHECK_GLMP_M64: #define __SHA__ 1
1463// CHECK_GLMP_M64: #define __SSE2__ 1
1464// CHECK_GLMP_M64: #define __SSE3__ 1
1465// CHECK_GLMP_M64: #define __SSE4_1__ 1
1466// CHECK_GLMP_M64: #define __SSE4_2__ 1
1467// CHECK_GLMP_M64: #define __SSE__ 1
1468// CHECK_GLMP_M64: #define __SSSE3__ 1
1469// CHECK_GLMP_M64: #define __XSAVEC__ 1
1470// CHECK_GLMP_M64: #define __XSAVEOPT__ 1
1471// CHECK_GLMP_M64: #define __XSAVES__ 1
1472// CHECK_GLMP_M64: #define __XSAVE__ 1
1473// CHECK_GLMP_M64: #define __goldmont_plus 1
1474// CHECK_GLMP_M64: #define __goldmont_plus__ 1
1475// CHECK_GLMP_M64: #define __tune_goldmont_plus__ 1
1476// CHECK_GLMP_M64: #define __x86_64 1
1477// CHECK_GLMP_M64: #define __x86_64__ 1
1478
1479// RUN: %clang -march=tremont -m32 -E -dM %s -o - 2>&1 \
1480// RUN: -target i386-unknown-linux \
1481// RUN: | FileCheck %s -check-prefix=CHECK_TRM_M32
1482// CHECK_TRM_M32: #define __AES__ 1
1483// CHECK_TRM_M32: #define __CLDEMOTE__ 1
1484// CHECK_TRM_M32: #define __CLFLUSHOPT__ 1
1485// CHECK_TRM_M32: #define __FSGSBASE__ 1
1486// CHECK_TRM_M32: #define __FXSR__ 1
1487// CHECK_TRM_M32: #define __GFNI__ 1
1488// CHECK_TRM_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001489// CHECK_TRM_M32: #define __MOVBE__ 1
Gabor Buellaa51e0c22018-05-01 10:05:42 +00001490// CHECK_TRM_M32: #define __MOVDIR64B__ 1
1491// CHECK_TRM_M32: #define __MOVDIRI__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00001492// CHECK_TRM_M32: #define __MPX__ 1
1493// CHECK_TRM_M32: #define __PCLMUL__ 1
1494// CHECK_TRM_M32: #define __POPCNT__ 1
1495// CHECK_TRM_M32: #define __PRFCHW__ 1
Gabor Buella3a757122018-05-10 07:28:54 +00001496// CHECK_TRM_M32: #define __PTWRITE__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00001497// CHECK_TRM_M32: #define __RDPID__ 1
1498// CHECK_TRM_M32: #define __RDRND__ 1
1499// CHECK_TRM_M32: #define __RDSEED__ 1
1500// CHECK_TRM_M32: #define __SGX__ 1
1501// CHECK_TRM_M32: #define __SHA__ 1
1502// CHECK_TRM_M32: #define __SSE2__ 1
1503// CHECK_TRM_M32: #define __SSE3__ 1
1504// CHECK_TRM_M32: #define __SSE4_1__ 1
1505// CHECK_TRM_M32: #define __SSE4_2__ 1
1506// CHECK_TRM_M32: #define __SSE_MATH__ 1
1507// CHECK_TRM_M32: #define __SSE__ 1
1508// CHECK_TRM_M32: #define __SSSE3__ 1
Gabor Buellaeba6c422018-04-20 18:44:33 +00001509// CHECK_TRM_M32: #define __WAITPKG__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00001510// CHECK_TRM_M32: #define __XSAVEC__ 1
1511// CHECK_TRM_M32: #define __XSAVEOPT__ 1
1512// CHECK_TRM_M32: #define __XSAVES__ 1
1513// CHECK_TRM_M32: #define __XSAVE__ 1
1514// CHECK_TRM_M32: #define __i386 1
1515// CHECK_TRM_M32: #define __i386__ 1
1516// CHECK_TRM_M32: #define __tremont 1
1517// CHECK_TRM_M32: #define __tremont__ 1
1518// CHECK_TRM_M32: #define __tune_tremont__ 1
1519// CHECK_TRM_M32: #define i386 1
1520
1521// RUN: %clang -march=tremont -m64 -E -dM %s -o - 2>&1 \
1522// RUN: -target i386-unknown-linux \
1523// RUN: | FileCheck %s -check-prefix=CHECK_TRM_M64
1524// CHECK_TRM_M64: #define __AES__ 1
1525// CHECK_TRM_M64: #define __CLDEMOTE__ 1
1526// CHECK_TRM_M64: #define __CLFLUSHOPT__ 1
1527// CHECK_TRM_M64: #define __FSGSBASE__ 1
1528// CHECK_TRM_M64: #define __FXSR__ 1
1529// CHECK_TRM_M64: #define __GFNI__ 1
1530// CHECK_TRM_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001531// CHECK_TRM_M64: #define __MOVBE__ 1
Gabor Buellaa51e0c22018-05-01 10:05:42 +00001532// CHECK_TRM_M64: #define __MOVDIR64B__ 1
1533// CHECK_TRM_M64: #define __MOVDIRI__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00001534// CHECK_TRM_M64: #define __MPX__ 1
1535// CHECK_TRM_M64: #define __PCLMUL__ 1
1536// CHECK_TRM_M64: #define __POPCNT__ 1
1537// CHECK_TRM_M64: #define __PRFCHW__ 1
Gabor Buella3a757122018-05-10 07:28:54 +00001538// CHECK_TRM_M64: #define __PTWRITE__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00001539// CHECK_TRM_M64: #define __RDPID__ 1
1540// CHECK_TRM_M64: #define __RDRND__ 1
1541// CHECK_TRM_M64: #define __RDSEED__ 1
1542// CHECK_TRM_M64: #define __SGX__ 1
1543// CHECK_TRM_M64: #define __SHA__ 1
1544// CHECK_TRM_M64: #define __SSE2__ 1
1545// CHECK_TRM_M64: #define __SSE3__ 1
1546// CHECK_TRM_M64: #define __SSE4_1__ 1
1547// CHECK_TRM_M64: #define __SSE4_2__ 1
1548// CHECK_TRM_M64: #define __SSE__ 1
1549// CHECK_TRM_M64: #define __SSSE3__ 1
Gabor Buellaeba6c422018-04-20 18:44:33 +00001550// CHECK_TRM_M64: #define __WAITPKG__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00001551// CHECK_TRM_M64: #define __XSAVEC__ 1
1552// CHECK_TRM_M64: #define __XSAVEOPT__ 1
1553// CHECK_TRM_M64: #define __XSAVES__ 1
1554// CHECK_TRM_M64: #define __XSAVE__ 1
1555// CHECK_TRM_M64: #define __tremont 1
1556// CHECK_TRM_M64: #define __tremont__ 1
1557// CHECK_TRM_M64: #define __tune_tremont__ 1
1558// CHECK_TRM_M64: #define __x86_64 1
1559// CHECK_TRM_M64: #define __x86_64__ 1
1560
Benjamin Kramerffecc842013-08-30 14:05:34 +00001561// RUN: %clang -march=slm -m32 -E -dM %s -o - 2>&1 \
1562// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001563// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SLM_M32
Craig Topper921aff62017-12-22 05:09:38 +00001564// CHECK_SLM_M32: #define __FXSR__ 1
Benjamin Kramerffecc842013-08-30 14:05:34 +00001565// CHECK_SLM_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001566// CHECK_SLM_M32: #define __MOVBE__ 1
Craig Topper921aff62017-12-22 05:09:38 +00001567// CHECK_SLM_M32: #define __PCLMUL__ 1
1568// CHECK_SLM_M32: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +00001569// CHECK_SLM_M32: #define __PRFCHW__ 1
Craig Topperace5c372018-01-26 19:34:45 +00001570// CHECK_SLM_M32: #define __RDRND__ 1
Benjamin Kramerffecc842013-08-30 14:05:34 +00001571// CHECK_SLM_M32: #define __SSE2__ 1
1572// CHECK_SLM_M32: #define __SSE3__ 1
1573// CHECK_SLM_M32: #define __SSE4_1__ 1
1574// CHECK_SLM_M32: #define __SSE4_2__ 1
1575// CHECK_SLM_M32: #define __SSE__ 1
1576// CHECK_SLM_M32: #define __SSSE3__ 1
1577// CHECK_SLM_M32: #define __i386 1
1578// CHECK_SLM_M32: #define __i386__ 1
1579// CHECK_SLM_M32: #define __slm 1
1580// CHECK_SLM_M32: #define __slm__ 1
1581// CHECK_SLM_M32: #define __tune_slm__ 1
1582// CHECK_SLM_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001583
Benjamin Kramerffecc842013-08-30 14:05:34 +00001584// RUN: %clang -march=slm -m64 -E -dM %s -o - 2>&1 \
1585// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001586// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SLM_M64
Craig Topper921aff62017-12-22 05:09:38 +00001587// CHECK_SLM_M64: #define __FXSR__ 1
Benjamin Kramerffecc842013-08-30 14:05:34 +00001588// CHECK_SLM_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001589// CHECK_SLM_M64: #define __MOVBE__ 1
Craig Topper921aff62017-12-22 05:09:38 +00001590// CHECK_SLM_M64: #define __PCLMUL__ 1
1591// CHECK_SLM_M64: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +00001592// CHECK_SLM_M64: #define __PRFCHW__ 1
Craig Topperace5c372018-01-26 19:34:45 +00001593// CHECK_SLM_M64: #define __RDRND__ 1
Benjamin Kramerffecc842013-08-30 14:05:34 +00001594// CHECK_SLM_M64: #define __SSE2_MATH__ 1
1595// CHECK_SLM_M64: #define __SSE2__ 1
1596// CHECK_SLM_M64: #define __SSE3__ 1
1597// CHECK_SLM_M64: #define __SSE4_1__ 1
1598// CHECK_SLM_M64: #define __SSE4_2__ 1
1599// CHECK_SLM_M64: #define __SSE_MATH__ 1
1600// CHECK_SLM_M64: #define __SSE__ 1
1601// CHECK_SLM_M64: #define __SSSE3__ 1
1602// CHECK_SLM_M64: #define __amd64 1
1603// CHECK_SLM_M64: #define __amd64__ 1
1604// CHECK_SLM_M64: #define __slm 1
1605// CHECK_SLM_M64: #define __slm__ 1
1606// CHECK_SLM_M64: #define __tune_slm__ 1
1607// CHECK_SLM_M64: #define __x86_64 1
1608// CHECK_SLM_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001609
Andrey Turetskiyfd259ff2016-04-05 15:04:26 +00001610// RUN: %clang -march=lakemont -m32 -E -dM %s -o - 2>&1 \
1611// RUN: -target i386-unknown-linux \
Craig Toppera2b907a2017-11-01 02:18:49 +00001612// RUN: | FileCheck %s -check-prefix=CHECK_LAKEMONT_M32
1613// CHECK_LAKEMONT_M32: #define __i386 1
1614// CHECK_LAKEMONT_M32: #define __i386__ 1
1615// CHECK_LAKEMONT_M32: #define __i586 1
1616// CHECK_LAKEMONT_M32: #define __i586__ 1
1617// CHECK_LAKEMONT_M32: #define __pentium 1
1618// CHECK_LAKEMONT_M32: #define __pentium__ 1
1619// CHECK_LAKEMONT_M32: #define __tune_lakemont__ 1
1620// CHECK_LAKEMONT_M32: #define i386 1
Andrey Turetskiyfd259ff2016-04-05 15:04:26 +00001621// RUN: not %clang -march=lakemont -m64 -E -dM %s -o - 2>&1 \
1622// RUN: -target i386-unknown-linux \
Craig Toppera2b907a2017-11-01 02:18:49 +00001623// RUN: | FileCheck %s -check-prefix=CHECK_LAKEMONT_M64
1624// CHECK_LAKEMONT_M64: error:
Gabor Buellac9e976c2018-04-12 18:15:39 +00001625
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001626// RUN: %clang -march=geode -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001627// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001628// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_GEODE_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001629// CHECK_GEODE_M32: #define __3dNOW_A__ 1
1630// CHECK_GEODE_M32: #define __3dNOW__ 1
1631// CHECK_GEODE_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001632// CHECK_GEODE_M32: #define __geode 1
1633// CHECK_GEODE_M32: #define __geode__ 1
1634// CHECK_GEODE_M32: #define __i386 1
1635// CHECK_GEODE_M32: #define __i386__ 1
1636// CHECK_GEODE_M32: #define __tune_geode__ 1
1637// CHECK_GEODE_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00001638// RUN: not %clang -march=geode -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001639// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001640// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_GEODE_M64
1641// CHECK_GEODE_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00001642
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001643// RUN: %clang -march=k6 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001644// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001645// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001646// CHECK_K6_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001647// CHECK_K6_M32: #define __i386 1
1648// CHECK_K6_M32: #define __i386__ 1
1649// CHECK_K6_M32: #define __k6 1
1650// CHECK_K6_M32: #define __k6__ 1
1651// CHECK_K6_M32: #define __tune_k6__ 1
1652// CHECK_K6_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00001653// RUN: not %clang -march=k6 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001654// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001655// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_M64
1656// CHECK_K6_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00001657
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001658// RUN: %clang -march=k6-2 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001659// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001660// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_2_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001661// CHECK_K6_2_M32: #define __3dNOW__ 1
1662// CHECK_K6_2_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001663// CHECK_K6_2_M32: #define __i386 1
1664// CHECK_K6_2_M32: #define __i386__ 1
1665// CHECK_K6_2_M32: #define __k6 1
1666// CHECK_K6_2_M32: #define __k6_2__ 1
1667// CHECK_K6_2_M32: #define __k6__ 1
1668// CHECK_K6_2_M32: #define __tune_k6_2__ 1
1669// CHECK_K6_2_M32: #define __tune_k6__ 1
1670// CHECK_K6_2_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00001671// RUN: not %clang -march=k6-2 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001672// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001673// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_2_M64
1674// CHECK_K6_2_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00001675
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001676// RUN: %clang -march=k6-3 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001677// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001678// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_3_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001679// CHECK_K6_3_M32: #define __3dNOW__ 1
1680// CHECK_K6_3_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001681// CHECK_K6_3_M32: #define __i386 1
1682// CHECK_K6_3_M32: #define __i386__ 1
1683// CHECK_K6_3_M32: #define __k6 1
1684// CHECK_K6_3_M32: #define __k6_3__ 1
1685// CHECK_K6_3_M32: #define __k6__ 1
1686// CHECK_K6_3_M32: #define __tune_k6_3__ 1
1687// CHECK_K6_3_M32: #define __tune_k6__ 1
1688// CHECK_K6_3_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00001689// RUN: not %clang -march=k6-3 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001690// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001691// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_3_M64
1692// CHECK_K6_3_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00001693
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001694// RUN: %clang -march=athlon -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001695// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001696// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001697// CHECK_ATHLON_M32: #define __3dNOW_A__ 1
1698// CHECK_ATHLON_M32: #define __3dNOW__ 1
1699// CHECK_ATHLON_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001700// CHECK_ATHLON_M32: #define __athlon 1
1701// CHECK_ATHLON_M32: #define __athlon__ 1
1702// CHECK_ATHLON_M32: #define __i386 1
1703// CHECK_ATHLON_M32: #define __i386__ 1
1704// CHECK_ATHLON_M32: #define __tune_athlon__ 1
1705// CHECK_ATHLON_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00001706// RUN: not %clang -march=athlon -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001707// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001708// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_M64
1709// CHECK_ATHLON_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00001710
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001711// RUN: %clang -march=athlon-tbird -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001712// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001713// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_TBIRD_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001714// CHECK_ATHLON_TBIRD_M32: #define __3dNOW_A__ 1
1715// CHECK_ATHLON_TBIRD_M32: #define __3dNOW__ 1
1716// CHECK_ATHLON_TBIRD_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001717// CHECK_ATHLON_TBIRD_M32: #define __athlon 1
1718// CHECK_ATHLON_TBIRD_M32: #define __athlon__ 1
1719// CHECK_ATHLON_TBIRD_M32: #define __i386 1
1720// CHECK_ATHLON_TBIRD_M32: #define __i386__ 1
1721// CHECK_ATHLON_TBIRD_M32: #define __tune_athlon__ 1
1722// CHECK_ATHLON_TBIRD_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00001723// RUN: not %clang -march=athlon-tbird -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001724// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001725// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_TBIRD_M64
1726// CHECK_ATHLON_TBIRD_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00001727
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001728// RUN: %clang -march=athlon-4 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001729// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001730// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_4_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001731// CHECK_ATHLON_4_M32: #define __3dNOW_A__ 1
1732// CHECK_ATHLON_4_M32: #define __3dNOW__ 1
1733// CHECK_ATHLON_4_M32: #define __MMX__ 1
1734// CHECK_ATHLON_4_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001735// CHECK_ATHLON_4_M32: #define __athlon 1
1736// CHECK_ATHLON_4_M32: #define __athlon__ 1
1737// CHECK_ATHLON_4_M32: #define __athlon_sse__ 1
1738// CHECK_ATHLON_4_M32: #define __i386 1
1739// CHECK_ATHLON_4_M32: #define __i386__ 1
1740// CHECK_ATHLON_4_M32: #define __tune_athlon__ 1
Chandler Carruth5d0feef2011-09-28 09:54:11 +00001741// CHECK_ATHLON_4_M32: #define __tune_athlon_sse__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001742// CHECK_ATHLON_4_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00001743// RUN: not %clang -march=athlon-4 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001744// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001745// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_4_M64
1746// CHECK_ATHLON_4_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00001747
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001748// RUN: %clang -march=athlon-xp -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001749// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001750// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_XP_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001751// CHECK_ATHLON_XP_M32: #define __3dNOW_A__ 1
1752// CHECK_ATHLON_XP_M32: #define __3dNOW__ 1
1753// CHECK_ATHLON_XP_M32: #define __MMX__ 1
1754// CHECK_ATHLON_XP_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001755// CHECK_ATHLON_XP_M32: #define __athlon 1
1756// CHECK_ATHLON_XP_M32: #define __athlon__ 1
1757// CHECK_ATHLON_XP_M32: #define __athlon_sse__ 1
1758// CHECK_ATHLON_XP_M32: #define __i386 1
1759// CHECK_ATHLON_XP_M32: #define __i386__ 1
1760// CHECK_ATHLON_XP_M32: #define __tune_athlon__ 1
Chandler Carruth5d0feef2011-09-28 09:54:11 +00001761// CHECK_ATHLON_XP_M32: #define __tune_athlon_sse__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001762// CHECK_ATHLON_XP_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00001763// RUN: not %clang -march=athlon-xp -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001764// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001765// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_XP_M64
1766// CHECK_ATHLON_XP_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00001767
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001768// RUN: %clang -march=athlon-mp -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001769// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001770// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_MP_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001771// CHECK_ATHLON_MP_M32: #define __3dNOW_A__ 1
1772// CHECK_ATHLON_MP_M32: #define __3dNOW__ 1
1773// CHECK_ATHLON_MP_M32: #define __MMX__ 1
1774// CHECK_ATHLON_MP_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001775// CHECK_ATHLON_MP_M32: #define __athlon 1
1776// CHECK_ATHLON_MP_M32: #define __athlon__ 1
1777// CHECK_ATHLON_MP_M32: #define __athlon_sse__ 1
1778// CHECK_ATHLON_MP_M32: #define __i386 1
1779// CHECK_ATHLON_MP_M32: #define __i386__ 1
1780// CHECK_ATHLON_MP_M32: #define __tune_athlon__ 1
Chandler Carruth5d0feef2011-09-28 09:54:11 +00001781// CHECK_ATHLON_MP_M32: #define __tune_athlon_sse__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001782// CHECK_ATHLON_MP_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00001783// RUN: not %clang -march=athlon-mp -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001784// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001785// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_MP_M64
1786// CHECK_ATHLON_MP_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00001787
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001788// RUN: %clang -march=x86-64 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001789// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001790// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_X86_64_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001791// CHECK_X86_64_M32: #define __MMX__ 1
1792// CHECK_X86_64_M32: #define __SSE2__ 1
1793// CHECK_X86_64_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001794// CHECK_X86_64_M32: #define __i386 1
1795// CHECK_X86_64_M32: #define __i386__ 1
1796// CHECK_X86_64_M32: #define __k8 1
1797// CHECK_X86_64_M32: #define __k8__ 1
1798// CHECK_X86_64_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001799
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00001800// RUN: %clang -march=x86-64 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001801// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001802// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_X86_64_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001803// CHECK_X86_64_M64: #define __MMX__ 1
1804// CHECK_X86_64_M64: #define __SSE2_MATH__ 1
1805// CHECK_X86_64_M64: #define __SSE2__ 1
1806// CHECK_X86_64_M64: #define __SSE_MATH__ 1
1807// CHECK_X86_64_M64: #define __SSE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00001808// CHECK_X86_64_M64: #define __amd64 1
1809// CHECK_X86_64_M64: #define __amd64__ 1
1810// CHECK_X86_64_M64: #define __k8 1
1811// CHECK_X86_64_M64: #define __k8__ 1
1812// CHECK_X86_64_M64: #define __x86_64 1
1813// CHECK_X86_64_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001814
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001815// RUN: %clang -march=k8 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001816// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001817// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K8_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001818// CHECK_K8_M32: #define __3dNOW_A__ 1
1819// CHECK_K8_M32: #define __3dNOW__ 1
1820// CHECK_K8_M32: #define __MMX__ 1
1821// CHECK_K8_M32: #define __SSE2__ 1
1822// CHECK_K8_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001823// CHECK_K8_M32: #define __i386 1
1824// CHECK_K8_M32: #define __i386__ 1
1825// CHECK_K8_M32: #define __k8 1
1826// CHECK_K8_M32: #define __k8__ 1
1827// CHECK_K8_M32: #define __tune_k8__ 1
1828// CHECK_K8_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001829
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00001830// RUN: %clang -march=k8 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001831// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001832// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K8_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001833// CHECK_K8_M64: #define __3dNOW_A__ 1
1834// CHECK_K8_M64: #define __3dNOW__ 1
1835// CHECK_K8_M64: #define __MMX__ 1
1836// CHECK_K8_M64: #define __SSE2_MATH__ 1
1837// CHECK_K8_M64: #define __SSE2__ 1
1838// CHECK_K8_M64: #define __SSE_MATH__ 1
1839// CHECK_K8_M64: #define __SSE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00001840// CHECK_K8_M64: #define __amd64 1
1841// CHECK_K8_M64: #define __amd64__ 1
1842// CHECK_K8_M64: #define __k8 1
1843// CHECK_K8_M64: #define __k8__ 1
1844// CHECK_K8_M64: #define __tune_k8__ 1
1845// CHECK_K8_M64: #define __x86_64 1
1846// CHECK_K8_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001847
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001848// RUN: %clang -march=k8-sse3 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001849// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001850// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K8_SSE3_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001851// CHECK_K8_SSE3_M32: #define __3dNOW_A__ 1
1852// CHECK_K8_SSE3_M32: #define __3dNOW__ 1
1853// CHECK_K8_SSE3_M32: #define __MMX__ 1
1854// CHECK_K8_SSE3_M32: #define __SSE2__ 1
1855// CHECK_K8_SSE3_M32: #define __SSE3__ 1
1856// CHECK_K8_SSE3_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001857// CHECK_K8_SSE3_M32: #define __i386 1
1858// CHECK_K8_SSE3_M32: #define __i386__ 1
1859// CHECK_K8_SSE3_M32: #define __k8 1
1860// CHECK_K8_SSE3_M32: #define __k8__ 1
1861// CHECK_K8_SSE3_M32: #define __tune_k8__ 1
1862// CHECK_K8_SSE3_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001863
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00001864// RUN: %clang -march=k8-sse3 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001865// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001866// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K8_SSE3_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001867// CHECK_K8_SSE3_M64: #define __3dNOW_A__ 1
1868// CHECK_K8_SSE3_M64: #define __3dNOW__ 1
1869// CHECK_K8_SSE3_M64: #define __MMX__ 1
1870// CHECK_K8_SSE3_M64: #define __SSE2_MATH__ 1
1871// CHECK_K8_SSE3_M64: #define __SSE2__ 1
1872// CHECK_K8_SSE3_M64: #define __SSE3__ 1
1873// CHECK_K8_SSE3_M64: #define __SSE_MATH__ 1
1874// CHECK_K8_SSE3_M64: #define __SSE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00001875// CHECK_K8_SSE3_M64: #define __amd64 1
1876// CHECK_K8_SSE3_M64: #define __amd64__ 1
1877// CHECK_K8_SSE3_M64: #define __k8 1
1878// CHECK_K8_SSE3_M64: #define __k8__ 1
1879// CHECK_K8_SSE3_M64: #define __tune_k8__ 1
1880// CHECK_K8_SSE3_M64: #define __x86_64 1
1881// CHECK_K8_SSE3_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001882
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001883// RUN: %clang -march=opteron -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001884// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001885// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_OPTERON_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001886// CHECK_OPTERON_M32: #define __3dNOW_A__ 1
1887// CHECK_OPTERON_M32: #define __3dNOW__ 1
1888// CHECK_OPTERON_M32: #define __MMX__ 1
1889// CHECK_OPTERON_M32: #define __SSE2__ 1
1890// CHECK_OPTERON_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001891// CHECK_OPTERON_M32: #define __i386 1
1892// CHECK_OPTERON_M32: #define __i386__ 1
1893// CHECK_OPTERON_M32: #define __k8 1
1894// CHECK_OPTERON_M32: #define __k8__ 1
1895// CHECK_OPTERON_M32: #define __tune_k8__ 1
1896// CHECK_OPTERON_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001897
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00001898// RUN: %clang -march=opteron -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001899// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001900// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_OPTERON_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001901// CHECK_OPTERON_M64: #define __3dNOW_A__ 1
1902// CHECK_OPTERON_M64: #define __3dNOW__ 1
1903// CHECK_OPTERON_M64: #define __MMX__ 1
1904// CHECK_OPTERON_M64: #define __SSE2_MATH__ 1
1905// CHECK_OPTERON_M64: #define __SSE2__ 1
1906// CHECK_OPTERON_M64: #define __SSE_MATH__ 1
1907// CHECK_OPTERON_M64: #define __SSE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00001908// CHECK_OPTERON_M64: #define __amd64 1
1909// CHECK_OPTERON_M64: #define __amd64__ 1
1910// CHECK_OPTERON_M64: #define __k8 1
1911// CHECK_OPTERON_M64: #define __k8__ 1
1912// CHECK_OPTERON_M64: #define __tune_k8__ 1
1913// CHECK_OPTERON_M64: #define __x86_64 1
1914// CHECK_OPTERON_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001915
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001916// RUN: %clang -march=opteron-sse3 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001917// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001918// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_OPTERON_SSE3_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001919// CHECK_OPTERON_SSE3_M32: #define __3dNOW_A__ 1
1920// CHECK_OPTERON_SSE3_M32: #define __3dNOW__ 1
1921// CHECK_OPTERON_SSE3_M32: #define __MMX__ 1
1922// CHECK_OPTERON_SSE3_M32: #define __SSE2__ 1
1923// CHECK_OPTERON_SSE3_M32: #define __SSE3__ 1
1924// CHECK_OPTERON_SSE3_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001925// CHECK_OPTERON_SSE3_M32: #define __i386 1
1926// CHECK_OPTERON_SSE3_M32: #define __i386__ 1
1927// CHECK_OPTERON_SSE3_M32: #define __k8 1
1928// CHECK_OPTERON_SSE3_M32: #define __k8__ 1
1929// CHECK_OPTERON_SSE3_M32: #define __tune_k8__ 1
1930// CHECK_OPTERON_SSE3_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001931
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00001932// RUN: %clang -march=opteron-sse3 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001933// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001934// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_OPTERON_SSE3_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001935// CHECK_OPTERON_SSE3_M64: #define __3dNOW_A__ 1
1936// CHECK_OPTERON_SSE3_M64: #define __3dNOW__ 1
1937// CHECK_OPTERON_SSE3_M64: #define __MMX__ 1
1938// CHECK_OPTERON_SSE3_M64: #define __SSE2_MATH__ 1
1939// CHECK_OPTERON_SSE3_M64: #define __SSE2__ 1
1940// CHECK_OPTERON_SSE3_M64: #define __SSE3__ 1
1941// CHECK_OPTERON_SSE3_M64: #define __SSE_MATH__ 1
1942// CHECK_OPTERON_SSE3_M64: #define __SSE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00001943// CHECK_OPTERON_SSE3_M64: #define __amd64 1
1944// CHECK_OPTERON_SSE3_M64: #define __amd64__ 1
1945// CHECK_OPTERON_SSE3_M64: #define __k8 1
1946// CHECK_OPTERON_SSE3_M64: #define __k8__ 1
1947// CHECK_OPTERON_SSE3_M64: #define __tune_k8__ 1
1948// CHECK_OPTERON_SSE3_M64: #define __x86_64 1
1949// CHECK_OPTERON_SSE3_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001950
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001951// RUN: %clang -march=athlon64 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001952// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001953// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON64_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001954// CHECK_ATHLON64_M32: #define __3dNOW_A__ 1
1955// CHECK_ATHLON64_M32: #define __3dNOW__ 1
1956// CHECK_ATHLON64_M32: #define __MMX__ 1
1957// CHECK_ATHLON64_M32: #define __SSE2__ 1
1958// CHECK_ATHLON64_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001959// CHECK_ATHLON64_M32: #define __i386 1
1960// CHECK_ATHLON64_M32: #define __i386__ 1
1961// CHECK_ATHLON64_M32: #define __k8 1
1962// CHECK_ATHLON64_M32: #define __k8__ 1
1963// CHECK_ATHLON64_M32: #define __tune_k8__ 1
1964// CHECK_ATHLON64_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001965
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00001966// RUN: %clang -march=athlon64 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001967// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001968// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON64_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001969// CHECK_ATHLON64_M64: #define __3dNOW_A__ 1
1970// CHECK_ATHLON64_M64: #define __3dNOW__ 1
1971// CHECK_ATHLON64_M64: #define __MMX__ 1
1972// CHECK_ATHLON64_M64: #define __SSE2_MATH__ 1
1973// CHECK_ATHLON64_M64: #define __SSE2__ 1
1974// CHECK_ATHLON64_M64: #define __SSE_MATH__ 1
1975// CHECK_ATHLON64_M64: #define __SSE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00001976// CHECK_ATHLON64_M64: #define __amd64 1
1977// CHECK_ATHLON64_M64: #define __amd64__ 1
1978// CHECK_ATHLON64_M64: #define __k8 1
1979// CHECK_ATHLON64_M64: #define __k8__ 1
1980// CHECK_ATHLON64_M64: #define __tune_k8__ 1
1981// CHECK_ATHLON64_M64: #define __x86_64 1
1982// CHECK_ATHLON64_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001983
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001984// RUN: %clang -march=athlon64-sse3 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00001985// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001986// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON64_SSE3_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00001987// CHECK_ATHLON64_SSE3_M32: #define __3dNOW_A__ 1
1988// CHECK_ATHLON64_SSE3_M32: #define __3dNOW__ 1
1989// CHECK_ATHLON64_SSE3_M32: #define __MMX__ 1
1990// CHECK_ATHLON64_SSE3_M32: #define __SSE2__ 1
1991// CHECK_ATHLON64_SSE3_M32: #define __SSE3__ 1
1992// CHECK_ATHLON64_SSE3_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00001993// CHECK_ATHLON64_SSE3_M32: #define __i386 1
1994// CHECK_ATHLON64_SSE3_M32: #define __i386__ 1
1995// CHECK_ATHLON64_SSE3_M32: #define __k8 1
1996// CHECK_ATHLON64_SSE3_M32: #define __k8__ 1
1997// CHECK_ATHLON64_SSE3_M32: #define __tune_k8__ 1
1998// CHECK_ATHLON64_SSE3_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001999
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00002000// RUN: %clang -march=athlon64-sse3 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002001// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002002// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON64_SSE3_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002003// CHECK_ATHLON64_SSE3_M64: #define __3dNOW_A__ 1
2004// CHECK_ATHLON64_SSE3_M64: #define __3dNOW__ 1
2005// CHECK_ATHLON64_SSE3_M64: #define __MMX__ 1
2006// CHECK_ATHLON64_SSE3_M64: #define __SSE2_MATH__ 1
2007// CHECK_ATHLON64_SSE3_M64: #define __SSE2__ 1
2008// CHECK_ATHLON64_SSE3_M64: #define __SSE3__ 1
2009// CHECK_ATHLON64_SSE3_M64: #define __SSE_MATH__ 1
2010// CHECK_ATHLON64_SSE3_M64: #define __SSE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00002011// CHECK_ATHLON64_SSE3_M64: #define __amd64 1
2012// CHECK_ATHLON64_SSE3_M64: #define __amd64__ 1
2013// CHECK_ATHLON64_SSE3_M64: #define __k8 1
2014// CHECK_ATHLON64_SSE3_M64: #define __k8__ 1
2015// CHECK_ATHLON64_SSE3_M64: #define __tune_k8__ 1
2016// CHECK_ATHLON64_SSE3_M64: #define __x86_64 1
2017// CHECK_ATHLON64_SSE3_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002018
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002019// RUN: %clang -march=athlon-fx -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002020// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002021// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_FX_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002022// CHECK_ATHLON_FX_M32: #define __3dNOW_A__ 1
2023// CHECK_ATHLON_FX_M32: #define __3dNOW__ 1
2024// CHECK_ATHLON_FX_M32: #define __MMX__ 1
2025// CHECK_ATHLON_FX_M32: #define __SSE2__ 1
2026// CHECK_ATHLON_FX_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002027// CHECK_ATHLON_FX_M32: #define __i386 1
2028// CHECK_ATHLON_FX_M32: #define __i386__ 1
2029// CHECK_ATHLON_FX_M32: #define __k8 1
2030// CHECK_ATHLON_FX_M32: #define __k8__ 1
2031// CHECK_ATHLON_FX_M32: #define __tune_k8__ 1
2032// CHECK_ATHLON_FX_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002033
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00002034// RUN: %clang -march=athlon-fx -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002035// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002036// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_FX_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002037// CHECK_ATHLON_FX_M64: #define __3dNOW_A__ 1
2038// CHECK_ATHLON_FX_M64: #define __3dNOW__ 1
2039// CHECK_ATHLON_FX_M64: #define __MMX__ 1
2040// CHECK_ATHLON_FX_M64: #define __SSE2_MATH__ 1
2041// CHECK_ATHLON_FX_M64: #define __SSE2__ 1
2042// CHECK_ATHLON_FX_M64: #define __SSE_MATH__ 1
2043// CHECK_ATHLON_FX_M64: #define __SSE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00002044// CHECK_ATHLON_FX_M64: #define __amd64 1
2045// CHECK_ATHLON_FX_M64: #define __amd64__ 1
2046// CHECK_ATHLON_FX_M64: #define __k8 1
2047// CHECK_ATHLON_FX_M64: #define __k8__ 1
2048// CHECK_ATHLON_FX_M64: #define __tune_k8__ 1
2049// CHECK_ATHLON_FX_M64: #define __x86_64 1
2050// CHECK_ATHLON_FX_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002051
Eli Friedman3e94f572012-11-17 01:43:10 +00002052// RUN: %clang -march=amdfam10 -m32 -E -dM %s -o - 2>&1 \
2053// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002054// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_AMDFAM10_M32
Eli Friedman3e94f572012-11-17 01:43:10 +00002055// CHECK_AMDFAM10_M32: #define __3dNOW_A__ 1
2056// CHECK_AMDFAM10_M32: #define __3dNOW__ 1
2057// CHECK_AMDFAM10_M32: #define __LZCNT__ 1
2058// CHECK_AMDFAM10_M32: #define __MMX__ 1
2059// CHECK_AMDFAM10_M32: #define __POPCNT__ 1
2060// CHECK_AMDFAM10_M32: #define __SSE2_MATH__ 1
2061// CHECK_AMDFAM10_M32: #define __SSE2__ 1
2062// CHECK_AMDFAM10_M32: #define __SSE3__ 1
2063// CHECK_AMDFAM10_M32: #define __SSE4A__ 1
2064// CHECK_AMDFAM10_M32: #define __SSE_MATH__ 1
2065// CHECK_AMDFAM10_M32: #define __SSE__ 1
2066// CHECK_AMDFAM10_M32: #define __amdfam10 1
2067// CHECK_AMDFAM10_M32: #define __amdfam10__ 1
2068// CHECK_AMDFAM10_M32: #define __i386 1
2069// CHECK_AMDFAM10_M32: #define __i386__ 1
2070// CHECK_AMDFAM10_M32: #define __tune_amdfam10__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002071
Benjamin Kramer8ac9c222012-05-29 17:48:39 +00002072// RUN: %clang -march=amdfam10 -m64 -E -dM %s -o - 2>&1 \
2073// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002074// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_AMDFAM10_M64
Benjamin Kramer8ac9c222012-05-29 17:48:39 +00002075// CHECK_AMDFAM10_M64: #define __3dNOW_A__ 1
2076// CHECK_AMDFAM10_M64: #define __3dNOW__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002077// CHECK_AMDFAM10_M64: #define __LZCNT__ 1
Benjamin Kramer8ac9c222012-05-29 17:48:39 +00002078// CHECK_AMDFAM10_M64: #define __MMX__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002079// CHECK_AMDFAM10_M64: #define __POPCNT__ 1
Benjamin Kramer8ac9c222012-05-29 17:48:39 +00002080// CHECK_AMDFAM10_M64: #define __SSE2_MATH__ 1
2081// CHECK_AMDFAM10_M64: #define __SSE2__ 1
2082// CHECK_AMDFAM10_M64: #define __SSE3__ 1
2083// CHECK_AMDFAM10_M64: #define __SSE4A__ 1
2084// CHECK_AMDFAM10_M64: #define __SSE_MATH__ 1
2085// CHECK_AMDFAM10_M64: #define __SSE__ 1
2086// CHECK_AMDFAM10_M64: #define __amd64 1
2087// CHECK_AMDFAM10_M64: #define __amd64__ 1
2088// CHECK_AMDFAM10_M64: #define __amdfam10 1
2089// CHECK_AMDFAM10_M64: #define __amdfam10__ 1
2090// CHECK_AMDFAM10_M64: #define __tune_amdfam10__ 1
2091// CHECK_AMDFAM10_M64: #define __x86_64 1
2092// CHECK_AMDFAM10_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002093
Eli Friedman3e94f572012-11-17 01:43:10 +00002094// RUN: %clang -march=btver1 -m32 -E -dM %s -o - 2>&1 \
2095// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002096// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BTVER1_M32
Eli Friedman3e94f572012-11-17 01:43:10 +00002097// CHECK_BTVER1_M32-NOT: #define __3dNOW_A__ 1
2098// CHECK_BTVER1_M32-NOT: #define __3dNOW__ 1
2099// CHECK_BTVER1_M32: #define __LZCNT__ 1
2100// CHECK_BTVER1_M32: #define __MMX__ 1
2101// CHECK_BTVER1_M32: #define __POPCNT__ 1
Yunzhong Gao61089362013-10-16 19:07:02 +00002102// CHECK_BTVER1_M32: #define __PRFCHW__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002103// CHECK_BTVER1_M32: #define __SSE2_MATH__ 1
2104// CHECK_BTVER1_M32: #define __SSE2__ 1
2105// CHECK_BTVER1_M32: #define __SSE3__ 1
2106// CHECK_BTVER1_M32: #define __SSE4A__ 1
2107// CHECK_BTVER1_M32: #define __SSE_MATH__ 1
2108// CHECK_BTVER1_M32: #define __SSE__ 1
2109// CHECK_BTVER1_M32: #define __SSSE3__ 1
2110// CHECK_BTVER1_M32: #define __btver1 1
2111// CHECK_BTVER1_M32: #define __btver1__ 1
2112// CHECK_BTVER1_M32: #define __i386 1
2113// CHECK_BTVER1_M32: #define __i386__ 1
2114// CHECK_BTVER1_M32: #define __tune_btver1__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002115
Eli Friedman3e94f572012-11-17 01:43:10 +00002116// RUN: %clang -march=btver1 -m64 -E -dM %s -o - 2>&1 \
2117// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002118// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BTVER1_M64
Eli Friedman3e94f572012-11-17 01:43:10 +00002119// CHECK_BTVER1_M64-NOT: #define __3dNOW_A__ 1
2120// CHECK_BTVER1_M64-NOT: #define __3dNOW__ 1
2121// CHECK_BTVER1_M64: #define __LZCNT__ 1
2122// CHECK_BTVER1_M64: #define __MMX__ 1
2123// CHECK_BTVER1_M64: #define __POPCNT__ 1
Yunzhong Gao61089362013-10-16 19:07:02 +00002124// CHECK_BTVER1_M64: #define __PRFCHW__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002125// CHECK_BTVER1_M64: #define __SSE2_MATH__ 1
2126// CHECK_BTVER1_M64: #define __SSE2__ 1
2127// CHECK_BTVER1_M64: #define __SSE3__ 1
2128// CHECK_BTVER1_M64: #define __SSE4A__ 1
2129// CHECK_BTVER1_M64: #define __SSE_MATH__ 1
2130// CHECK_BTVER1_M64: #define __SSE__ 1
2131// CHECK_BTVER1_M64: #define __SSSE3__ 1
2132// CHECK_BTVER1_M64: #define __amd64 1
2133// CHECK_BTVER1_M64: #define __amd64__ 1
2134// CHECK_BTVER1_M64: #define __btver1 1
2135// CHECK_BTVER1_M64: #define __btver1__ 1
2136// CHECK_BTVER1_M64: #define __tune_btver1__ 1
2137// CHECK_BTVER1_M64: #define __x86_64 1
2138// CHECK_BTVER1_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002139
Benjamin Kramer914d7e02013-05-03 10:47:15 +00002140// RUN: %clang -march=btver2 -m32 -E -dM %s -o - 2>&1 \
2141// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002142// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BTVER2_M32
Benjamin Kramer914d7e02013-05-03 10:47:15 +00002143// CHECK_BTVER2_M32-NOT: #define __3dNOW_A__ 1
2144// CHECK_BTVER2_M32-NOT: #define __3dNOW__ 1
2145// CHECK_BTVER2_M32: #define __AES__ 1
2146// CHECK_BTVER2_M32: #define __AVX__ 1
Andrea Di Biagio9760a442014-11-06 12:08:57 +00002147// CHECK_BTVER2_M32: #define __BMI__ 1
2148// CHECK_BTVER2_M32: #define __F16C__ 1
Benjamin Kramer914d7e02013-05-03 10:47:15 +00002149// CHECK_BTVER2_M32: #define __LZCNT__ 1
2150// CHECK_BTVER2_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00002151// CHECK_BTVER2_M32: #define __MOVBE__ 1
Andrea Di Biagio9760a442014-11-06 12:08:57 +00002152// CHECK_BTVER2_M32: #define __PCLMUL__ 1
Benjamin Kramer914d7e02013-05-03 10:47:15 +00002153// CHECK_BTVER2_M32: #define __POPCNT__ 1
Yunzhong Gao61089362013-10-16 19:07:02 +00002154// CHECK_BTVER2_M32: #define __PRFCHW__ 1
Benjamin Kramer914d7e02013-05-03 10:47:15 +00002155// CHECK_BTVER2_M32: #define __SSE2_MATH__ 1
2156// CHECK_BTVER2_M32: #define __SSE2__ 1
2157// CHECK_BTVER2_M32: #define __SSE3__ 1
2158// CHECK_BTVER2_M32: #define __SSE4A__ 1
2159// CHECK_BTVER2_M32: #define __SSE_MATH__ 1
2160// CHECK_BTVER2_M32: #define __SSE__ 1
2161// CHECK_BTVER2_M32: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00002162// CHECK_BTVER2_M32: #define __XSAVEOPT__ 1
2163// CHECK_BTVER2_M32: #define __XSAVE__ 1
Benjamin Kramer914d7e02013-05-03 10:47:15 +00002164// CHECK_BTVER2_M32: #define __btver2 1
2165// CHECK_BTVER2_M32: #define __btver2__ 1
2166// CHECK_BTVER2_M32: #define __i386 1
2167// CHECK_BTVER2_M32: #define __i386__ 1
2168// CHECK_BTVER2_M32: #define __tune_btver2__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002169
Benjamin Kramer914d7e02013-05-03 10:47:15 +00002170// RUN: %clang -march=btver2 -m64 -E -dM %s -o - 2>&1 \
2171// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002172// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BTVER2_M64
Benjamin Kramer914d7e02013-05-03 10:47:15 +00002173// CHECK_BTVER2_M64-NOT: #define __3dNOW_A__ 1
2174// CHECK_BTVER2_M64-NOT: #define __3dNOW__ 1
2175// CHECK_BTVER2_M64: #define __AES__ 1
2176// CHECK_BTVER2_M64: #define __AVX__ 1
Andrea Di Biagio9760a442014-11-06 12:08:57 +00002177// CHECK_BTVER2_M64: #define __BMI__ 1
2178// CHECK_BTVER2_M64: #define __F16C__ 1
Benjamin Kramer914d7e02013-05-03 10:47:15 +00002179// CHECK_BTVER2_M64: #define __LZCNT__ 1
2180// CHECK_BTVER2_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00002181// CHECK_BTVER2_M64: #define __MOVBE__ 1
Andrea Di Biagio9760a442014-11-06 12:08:57 +00002182// CHECK_BTVER2_M64: #define __PCLMUL__ 1
Benjamin Kramer914d7e02013-05-03 10:47:15 +00002183// CHECK_BTVER2_M64: #define __POPCNT__ 1
Yunzhong Gao61089362013-10-16 19:07:02 +00002184// CHECK_BTVER2_M64: #define __PRFCHW__ 1
Benjamin Kramer914d7e02013-05-03 10:47:15 +00002185// CHECK_BTVER2_M64: #define __SSE2_MATH__ 1
2186// CHECK_BTVER2_M64: #define __SSE2__ 1
2187// CHECK_BTVER2_M64: #define __SSE3__ 1
2188// CHECK_BTVER2_M64: #define __SSE4A__ 1
2189// CHECK_BTVER2_M64: #define __SSE_MATH__ 1
2190// CHECK_BTVER2_M64: #define __SSE__ 1
2191// CHECK_BTVER2_M64: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00002192// CHECK_BTVER2_M64: #define __XSAVEOPT__ 1
2193// CHECK_BTVER2_M64: #define __XSAVE__ 1
Benjamin Kramer914d7e02013-05-03 10:47:15 +00002194// CHECK_BTVER2_M64: #define __amd64 1
2195// CHECK_BTVER2_M64: #define __amd64__ 1
2196// CHECK_BTVER2_M64: #define __btver2 1
2197// CHECK_BTVER2_M64: #define __btver2__ 1
2198// CHECK_BTVER2_M64: #define __tune_btver2__ 1
2199// CHECK_BTVER2_M64: #define __x86_64 1
2200// CHECK_BTVER2_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002201
Eli Friedman3e94f572012-11-17 01:43:10 +00002202// RUN: %clang -march=bdver1 -m32 -E -dM %s -o - 2>&1 \
2203// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002204// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER1_M32
Eli Friedman3e94f572012-11-17 01:43:10 +00002205// CHECK_BDVER1_M32-NOT: #define __3dNOW_A__ 1
2206// CHECK_BDVER1_M32-NOT: #define __3dNOW__ 1
2207// CHECK_BDVER1_M32: #define __AES__ 1
2208// CHECK_BDVER1_M32: #define __AVX__ 1
2209// CHECK_BDVER1_M32: #define __FMA4__ 1
Simon Pilgrim0fd1b6c2017-05-08 17:25:48 +00002210// CHECK_BDVER1_M32: #define __LWP__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002211// CHECK_BDVER1_M32: #define __LZCNT__ 1
2212// CHECK_BDVER1_M32: #define __MMX__ 1
2213// CHECK_BDVER1_M32: #define __PCLMUL__ 1
2214// CHECK_BDVER1_M32: #define __POPCNT__ 1
Yunzhong Gao61089362013-10-16 19:07:02 +00002215// CHECK_BDVER1_M32: #define __PRFCHW__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002216// CHECK_BDVER1_M32: #define __SSE2_MATH__ 1
2217// CHECK_BDVER1_M32: #define __SSE2__ 1
2218// CHECK_BDVER1_M32: #define __SSE3__ 1
2219// CHECK_BDVER1_M32: #define __SSE4A__ 1
2220// CHECK_BDVER1_M32: #define __SSE4_1__ 1
2221// CHECK_BDVER1_M32: #define __SSE4_2__ 1
2222// CHECK_BDVER1_M32: #define __SSE_MATH__ 1
2223// CHECK_BDVER1_M32: #define __SSE__ 1
2224// CHECK_BDVER1_M32: #define __SSSE3__ 1
2225// CHECK_BDVER1_M32: #define __XOP__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00002226// CHECK_BDVER1_M32: #define __XSAVE__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002227// CHECK_BDVER1_M32: #define __bdver1 1
2228// CHECK_BDVER1_M32: #define __bdver1__ 1
2229// CHECK_BDVER1_M32: #define __i386 1
2230// CHECK_BDVER1_M32: #define __i386__ 1
2231// CHECK_BDVER1_M32: #define __tune_bdver1__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002232
Benjamin Kramer8ac9c222012-05-29 17:48:39 +00002233// RUN: %clang -march=bdver1 -m64 -E -dM %s -o - 2>&1 \
2234// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002235// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER1_M64
Benjamin Kramer8ac9c222012-05-29 17:48:39 +00002236// CHECK_BDVER1_M64-NOT: #define __3dNOW_A__ 1
2237// CHECK_BDVER1_M64-NOT: #define __3dNOW__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002238// CHECK_BDVER1_M64: #define __AES__ 1
2239// CHECK_BDVER1_M64: #define __AVX__ 1
Craig Topperf561a9562012-06-09 22:24:14 +00002240// CHECK_BDVER1_M64: #define __FMA4__ 1
Simon Pilgrim0fd1b6c2017-05-08 17:25:48 +00002241// CHECK_BDVER1_M64: #define __LWP__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002242// CHECK_BDVER1_M64: #define __LZCNT__ 1
Benjamin Kramer8ac9c222012-05-29 17:48:39 +00002243// CHECK_BDVER1_M64: #define __MMX__ 1
Craig Topperf561a9562012-06-09 22:24:14 +00002244// CHECK_BDVER1_M64: #define __PCLMUL__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002245// CHECK_BDVER1_M64: #define __POPCNT__ 1
Yunzhong Gao61089362013-10-16 19:07:02 +00002246// CHECK_BDVER1_M64: #define __PRFCHW__ 1
Benjamin Kramer8ac9c222012-05-29 17:48:39 +00002247// CHECK_BDVER1_M64: #define __SSE2_MATH__ 1
2248// CHECK_BDVER1_M64: #define __SSE2__ 1
2249// CHECK_BDVER1_M64: #define __SSE3__ 1
2250// CHECK_BDVER1_M64: #define __SSE4A__ 1
2251// CHECK_BDVER1_M64: #define __SSE4_1__ 1
2252// CHECK_BDVER1_M64: #define __SSE4_2__ 1
2253// CHECK_BDVER1_M64: #define __SSE_MATH__ 1
2254// CHECK_BDVER1_M64: #define __SSE__ 1
2255// CHECK_BDVER1_M64: #define __SSSE3__ 1
Craig Topperf561a9562012-06-09 22:24:14 +00002256// CHECK_BDVER1_M64: #define __XOP__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00002257// CHECK_BDVER1_M64: #define __XSAVE__ 1
Benjamin Kramer8ac9c222012-05-29 17:48:39 +00002258// CHECK_BDVER1_M64: #define __amd64 1
2259// CHECK_BDVER1_M64: #define __amd64__ 1
2260// CHECK_BDVER1_M64: #define __bdver1 1
2261// CHECK_BDVER1_M64: #define __bdver1__ 1
2262// CHECK_BDVER1_M64: #define __tune_bdver1__ 1
2263// CHECK_BDVER1_M64: #define __x86_64 1
2264// CHECK_BDVER1_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002265
Eli Friedman3e94f572012-11-17 01:43:10 +00002266// RUN: %clang -march=bdver2 -m32 -E -dM %s -o - 2>&1 \
2267// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002268// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER2_M32
Eli Friedman3e94f572012-11-17 01:43:10 +00002269// CHECK_BDVER2_M32-NOT: #define __3dNOW_A__ 1
2270// CHECK_BDVER2_M32-NOT: #define __3dNOW__ 1
2271// CHECK_BDVER2_M32: #define __AES__ 1
2272// CHECK_BDVER2_M32: #define __AVX__ 1
2273// CHECK_BDVER2_M32: #define __BMI__ 1
2274// CHECK_BDVER2_M32: #define __F16C__ 1
2275// CHECK_BDVER2_M32: #define __FMA4__ 1
2276// CHECK_BDVER2_M32: #define __FMA__ 1
Simon Pilgrim0fd1b6c2017-05-08 17:25:48 +00002277// CHECK_BDVER2_M32: #define __LWP__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002278// CHECK_BDVER2_M32: #define __LZCNT__ 1
2279// CHECK_BDVER2_M32: #define __MMX__ 1
2280// CHECK_BDVER2_M32: #define __PCLMUL__ 1
2281// CHECK_BDVER2_M32: #define __POPCNT__ 1
Yunzhong Gao61089362013-10-16 19:07:02 +00002282// CHECK_BDVER2_M32: #define __PRFCHW__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002283// CHECK_BDVER2_M32: #define __SSE2_MATH__ 1
2284// CHECK_BDVER2_M32: #define __SSE2__ 1
2285// CHECK_BDVER2_M32: #define __SSE3__ 1
2286// CHECK_BDVER2_M32: #define __SSE4A__ 1
2287// CHECK_BDVER2_M32: #define __SSE4_1__ 1
2288// CHECK_BDVER2_M32: #define __SSE4_2__ 1
2289// CHECK_BDVER2_M32: #define __SSE_MATH__ 1
2290// CHECK_BDVER2_M32: #define __SSE__ 1
2291// CHECK_BDVER2_M32: #define __SSSE3__ 1
Yunzhong Gao1f6aeeb2013-09-24 19:00:58 +00002292// CHECK_BDVER2_M32: #define __TBM__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002293// CHECK_BDVER2_M32: #define __XOP__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00002294// CHECK_BDVER2_M32: #define __XSAVE__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002295// CHECK_BDVER2_M32: #define __bdver2 1
2296// CHECK_BDVER2_M32: #define __bdver2__ 1
2297// CHECK_BDVER2_M32: #define __i386 1
2298// CHECK_BDVER2_M32: #define __i386__ 1
2299// CHECK_BDVER2_M32: #define __tune_bdver2__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002300
Eli Friedman3e94f572012-11-17 01:43:10 +00002301// RUN: %clang -march=bdver2 -m64 -E -dM %s -o - 2>&1 \
2302// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002303// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER2_M64
Eli Friedman3e94f572012-11-17 01:43:10 +00002304// CHECK_BDVER2_M64-NOT: #define __3dNOW_A__ 1
2305// CHECK_BDVER2_M64-NOT: #define __3dNOW__ 1
2306// CHECK_BDVER2_M64: #define __AES__ 1
2307// CHECK_BDVER2_M64: #define __AVX__ 1
2308// CHECK_BDVER2_M64: #define __BMI__ 1
2309// CHECK_BDVER2_M64: #define __F16C__ 1
2310// CHECK_BDVER2_M64: #define __FMA4__ 1
2311// CHECK_BDVER2_M64: #define __FMA__ 1
Simon Pilgrim0fd1b6c2017-05-08 17:25:48 +00002312// CHECK_BDVER2_M64: #define __LWP__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002313// CHECK_BDVER2_M64: #define __LZCNT__ 1
2314// CHECK_BDVER2_M64: #define __MMX__ 1
2315// CHECK_BDVER2_M64: #define __PCLMUL__ 1
2316// CHECK_BDVER2_M64: #define __POPCNT__ 1
Yunzhong Gao61089362013-10-16 19:07:02 +00002317// CHECK_BDVER2_M64: #define __PRFCHW__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002318// CHECK_BDVER2_M64: #define __SSE2_MATH__ 1
2319// CHECK_BDVER2_M64: #define __SSE2__ 1
2320// CHECK_BDVER2_M64: #define __SSE3__ 1
2321// CHECK_BDVER2_M64: #define __SSE4A__ 1
2322// CHECK_BDVER2_M64: #define __SSE4_1__ 1
2323// CHECK_BDVER2_M64: #define __SSE4_2__ 1
2324// CHECK_BDVER2_M64: #define __SSE_MATH__ 1
2325// CHECK_BDVER2_M64: #define __SSE__ 1
2326// CHECK_BDVER2_M64: #define __SSSE3__ 1
Yunzhong Gao1f6aeeb2013-09-24 19:00:58 +00002327// CHECK_BDVER2_M64: #define __TBM__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002328// CHECK_BDVER2_M64: #define __XOP__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00002329// CHECK_BDVER2_M64: #define __XSAVE__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00002330// CHECK_BDVER2_M64: #define __amd64 1
2331// CHECK_BDVER2_M64: #define __amd64__ 1
2332// CHECK_BDVER2_M64: #define __bdver2 1
2333// CHECK_BDVER2_M64: #define __bdver2__ 1
2334// CHECK_BDVER2_M64: #define __tune_bdver2__ 1
2335// CHECK_BDVER2_M64: #define __x86_64 1
2336// CHECK_BDVER2_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002337
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00002338// RUN: %clang -march=bdver3 -m32 -E -dM %s -o - 2>&1 \
2339// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002340// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER3_M32
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00002341// CHECK_BDVER3_M32-NOT: #define __3dNOW_A__ 1
2342// CHECK_BDVER3_M32-NOT: #define __3dNOW__ 1
2343// CHECK_BDVER3_M32: #define __AES__ 1
2344// CHECK_BDVER3_M32: #define __AVX__ 1
2345// CHECK_BDVER3_M32: #define __BMI__ 1
2346// CHECK_BDVER3_M32: #define __F16C__ 1
2347// CHECK_BDVER3_M32: #define __FMA4__ 1
2348// CHECK_BDVER3_M32: #define __FMA__ 1
Andrea Di Biagio9760a442014-11-06 12:08:57 +00002349// CHECK_BDVER3_M32: #define __FSGSBASE__ 1
Simon Pilgrim0fd1b6c2017-05-08 17:25:48 +00002350// CHECK_BDVER3_M32: #define __LWP__ 1
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00002351// CHECK_BDVER3_M32: #define __LZCNT__ 1
2352// CHECK_BDVER3_M32: #define __MMX__ 1
2353// CHECK_BDVER3_M32: #define __PCLMUL__ 1
2354// CHECK_BDVER3_M32: #define __POPCNT__ 1
2355// CHECK_BDVER3_M32: #define __PRFCHW__ 1
2356// CHECK_BDVER3_M32: #define __SSE2_MATH__ 1
2357// CHECK_BDVER3_M32: #define __SSE2__ 1
2358// CHECK_BDVER3_M32: #define __SSE3__ 1
2359// CHECK_BDVER3_M32: #define __SSE4A__ 1
2360// CHECK_BDVER3_M32: #define __SSE4_1__ 1
2361// CHECK_BDVER3_M32: #define __SSE4_2__ 1
2362// CHECK_BDVER3_M32: #define __SSE_MATH__ 1
2363// CHECK_BDVER3_M32: #define __SSE__ 1
2364// CHECK_BDVER3_M32: #define __SSSE3__ 1
2365// CHECK_BDVER3_M32: #define __TBM__ 1
2366// CHECK_BDVER3_M32: #define __XOP__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00002367// CHECK_BDVER3_M32: #define __XSAVEOPT__ 1
2368// CHECK_BDVER3_M32: #define __XSAVE__ 1
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00002369// CHECK_BDVER3_M32: #define __bdver3 1
2370// CHECK_BDVER3_M32: #define __bdver3__ 1
2371// CHECK_BDVER3_M32: #define __i386 1
2372// CHECK_BDVER3_M32: #define __i386__ 1
2373// CHECK_BDVER3_M32: #define __tune_bdver3__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002374
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00002375// RUN: %clang -march=bdver3 -m64 -E -dM %s -o - 2>&1 \
2376// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002377// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER3_M64
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00002378// CHECK_BDVER3_M64-NOT: #define __3dNOW_A__ 1
2379// CHECK_BDVER3_M64-NOT: #define __3dNOW__ 1
2380// CHECK_BDVER3_M64: #define __AES__ 1
2381// CHECK_BDVER3_M64: #define __AVX__ 1
2382// CHECK_BDVER3_M64: #define __BMI__ 1
2383// CHECK_BDVER3_M64: #define __F16C__ 1
2384// CHECK_BDVER3_M64: #define __FMA4__ 1
2385// CHECK_BDVER3_M64: #define __FMA__ 1
Andrea Di Biagio9760a442014-11-06 12:08:57 +00002386// CHECK_BDVER3_M64: #define __FSGSBASE__ 1
Simon Pilgrim0fd1b6c2017-05-08 17:25:48 +00002387// CHECK_BDVER3_M64: #define __LWP__ 1
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00002388// CHECK_BDVER3_M64: #define __LZCNT__ 1
2389// CHECK_BDVER3_M64: #define __MMX__ 1
2390// CHECK_BDVER3_M64: #define __PCLMUL__ 1
2391// CHECK_BDVER3_M64: #define __POPCNT__ 1
2392// CHECK_BDVER3_M64: #define __PRFCHW__ 1
2393// CHECK_BDVER3_M64: #define __SSE2_MATH__ 1
2394// CHECK_BDVER3_M64: #define __SSE2__ 1
2395// CHECK_BDVER3_M64: #define __SSE3__ 1
2396// CHECK_BDVER3_M64: #define __SSE4A__ 1
2397// CHECK_BDVER3_M64: #define __SSE4_1__ 1
2398// CHECK_BDVER3_M64: #define __SSE4_2__ 1
2399// CHECK_BDVER3_M64: #define __SSE_MATH__ 1
2400// CHECK_BDVER3_M64: #define __SSE__ 1
2401// CHECK_BDVER3_M64: #define __SSSE3__ 1
2402// CHECK_BDVER3_M64: #define __TBM__ 1
2403// CHECK_BDVER3_M64: #define __XOP__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00002404// CHECK_BDVER3_M64: #define __XSAVEOPT__ 1
2405// CHECK_BDVER3_M64: #define __XSAVE__ 1
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00002406// CHECK_BDVER3_M64: #define __amd64 1
2407// CHECK_BDVER3_M64: #define __amd64__ 1
2408// CHECK_BDVER3_M64: #define __bdver3 1
2409// CHECK_BDVER3_M64: #define __bdver3__ 1
2410// CHECK_BDVER3_M64: #define __tune_bdver3__ 1
2411// CHECK_BDVER3_M64: #define __x86_64 1
2412// CHECK_BDVER3_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002413
Benjamin Kramer56c58222014-05-02 15:47:51 +00002414// RUN: %clang -march=bdver4 -m32 -E -dM %s -o - 2>&1 \
2415// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002416// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER4_M32
Benjamin Kramer56c58222014-05-02 15:47:51 +00002417// CHECK_BDVER4_M32-NOT: #define __3dNOW_A__ 1
2418// CHECK_BDVER4_M32-NOT: #define __3dNOW__ 1
2419// CHECK_BDVER4_M32: #define __AES__ 1
2420// CHECK_BDVER4_M32: #define __AVX2__ 1
2421// CHECK_BDVER4_M32: #define __AVX__ 1
2422// CHECK_BDVER4_M32: #define __BMI2__ 1
2423// CHECK_BDVER4_M32: #define __BMI__ 1
2424// CHECK_BDVER4_M32: #define __F16C__ 1
2425// CHECK_BDVER4_M32: #define __FMA4__ 1
2426// CHECK_BDVER4_M32: #define __FMA__ 1
Andrea Di Biagio9760a442014-11-06 12:08:57 +00002427// CHECK_BDVER4_M32: #define __FSGSBASE__ 1
Simon Pilgrim0fd1b6c2017-05-08 17:25:48 +00002428// CHECK_BDVER4_M32: #define __LWP__ 1
Benjamin Kramer56c58222014-05-02 15:47:51 +00002429// CHECK_BDVER4_M32: #define __LZCNT__ 1
2430// CHECK_BDVER4_M32: #define __MMX__ 1
2431// CHECK_BDVER4_M32: #define __PCLMUL__ 1
2432// CHECK_BDVER4_M32: #define __POPCNT__ 1
2433// CHECK_BDVER4_M32: #define __PRFCHW__ 1
2434// CHECK_BDVER4_M32: #define __SSE2_MATH__ 1
2435// CHECK_BDVER4_M32: #define __SSE2__ 1
2436// CHECK_BDVER4_M32: #define __SSE3__ 1
2437// CHECK_BDVER4_M32: #define __SSE4A__ 1
2438// CHECK_BDVER4_M32: #define __SSE4_1__ 1
2439// CHECK_BDVER4_M32: #define __SSE4_2__ 1
2440// CHECK_BDVER4_M32: #define __SSE_MATH__ 1
2441// CHECK_BDVER4_M32: #define __SSE__ 1
2442// CHECK_BDVER4_M32: #define __SSSE3__ 1
2443// CHECK_BDVER4_M32: #define __TBM__ 1
2444// CHECK_BDVER4_M32: #define __XOP__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00002445// CHECK_BDVER4_M32: #define __XSAVE__ 1
Benjamin Kramer56c58222014-05-02 15:47:51 +00002446// CHECK_BDVER4_M32: #define __bdver4 1
2447// CHECK_BDVER4_M32: #define __bdver4__ 1
2448// CHECK_BDVER4_M32: #define __i386 1
2449// CHECK_BDVER4_M32: #define __i386__ 1
2450// CHECK_BDVER4_M32: #define __tune_bdver4__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002451
Benjamin Kramer56c58222014-05-02 15:47:51 +00002452// RUN: %clang -march=bdver4 -m64 -E -dM %s -o - 2>&1 \
2453// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002454// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER4_M64
Benjamin Kramer56c58222014-05-02 15:47:51 +00002455// CHECK_BDVER4_M64-NOT: #define __3dNOW_A__ 1
2456// CHECK_BDVER4_M64-NOT: #define __3dNOW__ 1
2457// CHECK_BDVER4_M64: #define __AES__ 1
2458// CHECK_BDVER4_M64: #define __AVX2__ 1
2459// CHECK_BDVER4_M64: #define __AVX__ 1
2460// CHECK_BDVER4_M64: #define __BMI2__ 1
2461// CHECK_BDVER4_M64: #define __BMI__ 1
2462// CHECK_BDVER4_M64: #define __F16C__ 1
2463// CHECK_BDVER4_M64: #define __FMA4__ 1
2464// CHECK_BDVER4_M64: #define __FMA__ 1
Andrea Di Biagio9760a442014-11-06 12:08:57 +00002465// CHECK_BDVER4_M64: #define __FSGSBASE__ 1
Simon Pilgrim0fd1b6c2017-05-08 17:25:48 +00002466// CHECK_BDVER4_M64: #define __LWP__ 1
Benjamin Kramer56c58222014-05-02 15:47:51 +00002467// CHECK_BDVER4_M64: #define __LZCNT__ 1
2468// CHECK_BDVER4_M64: #define __MMX__ 1
2469// CHECK_BDVER4_M64: #define __PCLMUL__ 1
2470// CHECK_BDVER4_M64: #define __POPCNT__ 1
2471// CHECK_BDVER4_M64: #define __PRFCHW__ 1
2472// CHECK_BDVER4_M64: #define __SSE2_MATH__ 1
2473// CHECK_BDVER4_M64: #define __SSE2__ 1
2474// CHECK_BDVER4_M64: #define __SSE3__ 1
2475// CHECK_BDVER4_M64: #define __SSE4A__ 1
2476// CHECK_BDVER4_M64: #define __SSE4_1__ 1
2477// CHECK_BDVER4_M64: #define __SSE4_2__ 1
2478// CHECK_BDVER4_M64: #define __SSE_MATH__ 1
2479// CHECK_BDVER4_M64: #define __SSE__ 1
2480// CHECK_BDVER4_M64: #define __SSSE3__ 1
2481// CHECK_BDVER4_M64: #define __TBM__ 1
2482// CHECK_BDVER4_M64: #define __XOP__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00002483// CHECK_BDVER4_M64: #define __XSAVE__ 1
Benjamin Kramer56c58222014-05-02 15:47:51 +00002484// CHECK_BDVER4_M64: #define __amd64 1
2485// CHECK_BDVER4_M64: #define __amd64__ 1
2486// CHECK_BDVER4_M64: #define __bdver4 1
2487// CHECK_BDVER4_M64: #define __bdver4__ 1
2488// CHECK_BDVER4_M64: #define __tune_bdver4__ 1
2489// CHECK_BDVER4_M64: #define __x86_64 1
2490// CHECK_BDVER4_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002491
Craig Topperc45744a2017-01-10 06:02:12 +00002492// RUN: %clang -march=znver1 -m32 -E -dM %s -o - 2>&1 \
2493// RUN: -target i386-unknown-linux \
2494// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER1_M32
2495// CHECK_ZNVER1_M32-NOT: #define __3dNOW_A__ 1
2496// CHECK_ZNVER1_M32-NOT: #define __3dNOW__ 1
2497// CHECK_ZNVER1_M32: #define __ADX__ 1
2498// CHECK_ZNVER1_M32: #define __AES__ 1
2499// CHECK_ZNVER1_M32: #define __AVX2__ 1
2500// CHECK_ZNVER1_M32: #define __AVX__ 1
2501// CHECK_ZNVER1_M32: #define __BMI2__ 1
2502// CHECK_ZNVER1_M32: #define __BMI__ 1
Craig Topper78b47872017-02-08 06:48:58 +00002503// CHECK_ZNVER1_M32: #define __CLFLUSHOPT__ 1
Craig Topper45742262017-02-09 06:10:14 +00002504// CHECK_ZNVER1_M32: #define __CLZERO__ 1
Craig Topperc45744a2017-01-10 06:02:12 +00002505// CHECK_ZNVER1_M32: #define __F16C__ 1
2506// CHECK_ZNVER1_M32: #define __FMA__ 1
2507// CHECK_ZNVER1_M32: #define __FSGSBASE__ 1
2508// CHECK_ZNVER1_M32: #define __LZCNT__ 1
2509// CHECK_ZNVER1_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00002510// CHECK_ZNVER1_M32: #define __MOVBE__ 1
Craig Topperc45744a2017-01-10 06:02:12 +00002511// CHECK_ZNVER1_M32: #define __PCLMUL__ 1
2512// CHECK_ZNVER1_M32: #define __POPCNT__ 1
2513// CHECK_ZNVER1_M32: #define __PRFCHW__ 1
2514// CHECK_ZNVER1_M32: #define __RDRND__ 1
2515// CHECK_ZNVER1_M32: #define __RDSEED__ 1
2516// CHECK_ZNVER1_M32: #define __SHA__ 1
2517// CHECK_ZNVER1_M32: #define __SSE2_MATH__ 1
2518// CHECK_ZNVER1_M32: #define __SSE2__ 1
2519// CHECK_ZNVER1_M32: #define __SSE3__ 1
2520// CHECK_ZNVER1_M32: #define __SSE4A__ 1
2521// CHECK_ZNVER1_M32: #define __SSE4_1__ 1
2522// CHECK_ZNVER1_M32: #define __SSE4_2__ 1
2523// CHECK_ZNVER1_M32: #define __SSE_MATH__ 1
2524// CHECK_ZNVER1_M32: #define __SSE__ 1
2525// CHECK_ZNVER1_M32: #define __SSSE3__ 1
2526// CHECK_ZNVER1_M32: #define __XSAVEC__ 1
2527// CHECK_ZNVER1_M32: #define __XSAVEOPT__ 1
2528// CHECK_ZNVER1_M32: #define __XSAVES__ 1
2529// CHECK_ZNVER1_M32: #define __XSAVE__ 1
2530// CHECK_ZNVER1_M32: #define __i386 1
2531// CHECK_ZNVER1_M32: #define __i386__ 1
2532// CHECK_ZNVER1_M32: #define __tune_znver1__ 1
2533// CHECK_ZNVER1_M32: #define __znver1 1
2534// CHECK_ZNVER1_M32: #define __znver1__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002535
Craig Topperc45744a2017-01-10 06:02:12 +00002536// RUN: %clang -march=znver1 -m64 -E -dM %s -o - 2>&1 \
2537// RUN: -target i386-unknown-linux \
2538// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER1_M64
2539// CHECK_ZNVER1_M64-NOT: #define __3dNOW_A__ 1
2540// CHECK_ZNVER1_M64-NOT: #define __3dNOW__ 1
2541// CHECK_ZNVER1_M64: #define __ADX__ 1
2542// CHECK_ZNVER1_M64: #define __AES__ 1
2543// CHECK_ZNVER1_M64: #define __AVX2__ 1
2544// CHECK_ZNVER1_M64: #define __AVX__ 1
2545// CHECK_ZNVER1_M64: #define __BMI2__ 1
2546// CHECK_ZNVER1_M64: #define __BMI__ 1
Craig Topper78b47872017-02-08 06:48:58 +00002547// CHECK_ZNVER1_M64: #define __CLFLUSHOPT__ 1
Craig Topper45742262017-02-09 06:10:14 +00002548// CHECK_ZNVER1_M64: #define __CLZERO__ 1
Craig Topperc45744a2017-01-10 06:02:12 +00002549// CHECK_ZNVER1_M64: #define __F16C__ 1
2550// CHECK_ZNVER1_M64: #define __FMA__ 1
2551// CHECK_ZNVER1_M64: #define __FSGSBASE__ 1
2552// CHECK_ZNVER1_M64: #define __LZCNT__ 1
2553// CHECK_ZNVER1_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00002554// CHECK_ZNVER1_M64: #define __MOVBE__ 1
Craig Topperc45744a2017-01-10 06:02:12 +00002555// CHECK_ZNVER1_M64: #define __PCLMUL__ 1
2556// CHECK_ZNVER1_M64: #define __POPCNT__ 1
2557// CHECK_ZNVER1_M64: #define __PRFCHW__ 1
2558// CHECK_ZNVER1_M64: #define __RDRND__ 1
2559// CHECK_ZNVER1_M64: #define __RDSEED__ 1
2560// CHECK_ZNVER1_M64: #define __SHA__ 1
2561// CHECK_ZNVER1_M64: #define __SSE2_MATH__ 1
2562// CHECK_ZNVER1_M64: #define __SSE2__ 1
2563// CHECK_ZNVER1_M64: #define __SSE3__ 1
2564// CHECK_ZNVER1_M64: #define __SSE4A__ 1
2565// CHECK_ZNVER1_M64: #define __SSE4_1__ 1
2566// CHECK_ZNVER1_M64: #define __SSE4_2__ 1
2567// CHECK_ZNVER1_M64: #define __SSE_MATH__ 1
2568// CHECK_ZNVER1_M64: #define __SSE__ 1
2569// CHECK_ZNVER1_M64: #define __SSSE3__ 1
2570// CHECK_ZNVER1_M64: #define __XSAVEC__ 1
2571// CHECK_ZNVER1_M64: #define __XSAVEOPT__ 1
2572// CHECK_ZNVER1_M64: #define __XSAVES__ 1
2573// CHECK_ZNVER1_M64: #define __XSAVE__ 1
2574// CHECK_ZNVER1_M64: #define __amd64 1
2575// CHECK_ZNVER1_M64: #define __amd64__ 1
2576// CHECK_ZNVER1_M64: #define __tune_znver1__ 1
2577// CHECK_ZNVER1_M64: #define __x86_64 1
2578// CHECK_ZNVER1_M64: #define __x86_64__ 1
2579// CHECK_ZNVER1_M64: #define __znver1 1
2580// CHECK_ZNVER1_M64: #define __znver1__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002581
Chandler Carruthe83c3d92011-09-28 10:17:41 +00002582// End X86/GCC/Linux tests ------------------
Eric Christopher2fe3b4a2013-10-16 21:19:26 +00002583
2584// Begin PPC/GCC/Linux tests ----------------
Eric Christopherd26d8832017-04-15 06:15:00 +00002585// Check that VSX also turns on altivec.
2586// RUN: %clang -mvsx -E -dM %s -o - 2>&1 \
2587// RUN: -target powerpc-unknown-linux \
2588// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_VSX_M32
Eric Christopherd26d8832017-04-15 06:15:00 +00002589// CHECK_PPC_VSX_M32: #define __ALTIVEC__ 1
2590// CHECK_PPC_VSX_M32: #define __VSX__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002591
Eric Christopher2fe3b4a2013-10-16 21:19:26 +00002592// RUN: %clang -mvsx -E -dM %s -o - 2>&1 \
2593// RUN: -target powerpc64-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002594// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_VSX_M64
James Y Knight3508b222016-04-01 21:33:20 +00002595// CHECK_PPC_VSX_M64: #define __VSX__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002596
Bill Schmidt59eb7672014-10-10 15:09:43 +00002597// RUN: %clang -mpower8-vector -E -dM %s -o - 2>&1 \
2598// RUN: -target powerpc64-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002599// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_POWER8_VECTOR_M64
James Y Knight3508b222016-04-01 21:33:20 +00002600// CHECK_PPC_POWER8_VECTOR_M64: #define __POWER8_VECTOR__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002601
Nemanja Ivanovic10e2b5d2016-09-27 10:45:22 +00002602// RUN: %clang -mpower9-vector -E -dM %s -o - 2>&1 \
2603// RUN: -target powerpc64-unknown-linux \
2604// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_POWER9_VECTOR_M64
Nemanja Ivanovic10e2b5d2016-09-27 10:45:22 +00002605// CHECK_PPC_POWER9_VECTOR_M64: #define __POWER9_VECTOR__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002606
Nemanja Ivanovic55e757d2015-03-04 21:48:22 +00002607// RUN: %clang -mcrypto -E -dM %s -o - 2>&1 \
2608// RUN: -target powerpc64-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002609// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_CRYPTO_M64
James Y Knight3508b222016-04-01 21:33:20 +00002610// CHECK_PPC_CRYPTO_M64: #define __CRYPTO__ 1
Eric Christopher74fa24f2017-03-20 21:12:53 +00002611
2612// HTM is available on power8 or later which includes all of powerpc64le as an
2613// ABI choice. Test that, the cpus, and the option.
2614// RUN: %clang -mhtm -E -dM %s -o - 2>&1 \
2615// RUN: -target powerpc64-unknown-linux \
2616// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_HTM
2617// RUN: %clang -E -dM %s -o - 2>&1 \
2618// RUN: -target powerpc64le-unknown-linux \
2619// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_HTM
2620// RUN: %clang -mcpu=pwr8 -E -dM %s -o - 2>&1 \
2621// RUN: -target powerpc64-unknown-linux \
2622// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_HTM
2623// RUN: %clang -mcpu=pwr9 -E -dM %s -o - 2>&1 \
2624// RUN: -target powerpc64-unknown-linux \
2625// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_HTM
Eric Christopher74fa24f2017-03-20 21:12:53 +00002626// CHECK_PPC_HTM: #define __HTM__ 1
2627
Hal Finkela57b8902015-10-01 13:39:49 +00002628// RUN: %clang -mcpu=ppc64 -E -dM %s -o - 2>&1 \
2629// RUN: -target powerpc64-unknown-unknown \
James Y Knight3508b222016-04-01 21:33:20 +00002630// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_GCC_ATOMICS
Nemanja Ivanovice97e1112015-05-14 20:02:24 +00002631// RUN: %clang -mcpu=pwr8 -E -dM %s -o - 2>&1 \
2632// RUN: -target powerpc64-unknown-unknown \
James Y Knight3508b222016-04-01 21:33:20 +00002633// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_GCC_ATOMICS
Nemanja Ivanovice97e1112015-05-14 20:02:24 +00002634// RUN: %clang -E -dM %s -o - 2>&1 \
2635// RUN: -target powerpc64le-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002636// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_GCC_ATOMICS
James Y Knight3508b222016-04-01 21:33:20 +00002637// CHECK_PPC_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
2638// CHECK_PPC_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
2639// CHECK_PPC_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
2640// CHECK_PPC_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002641
Nemanja Ivanovice97e1112015-05-14 20:02:24 +00002642// End PPC/GCC/Linux tests ------------------
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00002643
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00002644// Begin Sparc/GCC/Linux tests ----------------
Gabor Buellac9e976c2018-04-12 18:15:39 +00002645
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00002646// RUN: %clang -E -dM %s -o - 2>&1 \
2647// RUN: -target sparc-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002648// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPARC
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00002649// CHECK_SPARC: #define __BIG_ENDIAN__ 1
2650// CHECK_SPARC: #define __sparc 1
2651// CHECK_SPARC: #define __sparc__ 1
Joerg Sonnenbergerec353d32015-11-09 23:39:45 +00002652// CHECK_SPARC-NOT: #define __sparcv9 1
Joerg Sonnenberger4ecfa622015-11-10 19:28:17 +00002653// CHECK_SPARC-NOT: #define __sparcv9__ 1
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00002654// CHECK_SPARC: #define __sparcv8 1
Joerg Sonnenbergerec353d32015-11-09 23:39:45 +00002655// CHECK_SPARC-NOT: #define __sparcv9 1
Joerg Sonnenberger4ecfa622015-11-10 19:28:17 +00002656// CHECK_SPARC-NOT: #define __sparcv9__ 1
Joerg Sonnenbergerec353d32015-11-09 23:39:45 +00002657
Gabor Buellac9e976c2018-04-12 18:15:39 +00002658// RUN: %clang -mcpu=v9 -E -dM %s -o - 2>&1 \
2659// RUN: -target sparc-unknown-linux \
2660// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPARC-V9
Joerg Sonnenbergerec353d32015-11-09 23:39:45 +00002661// CHECK_SPARC-V9-NOT: #define __sparcv8 1
Joerg Sonnenberger4ecfa622015-11-10 19:28:17 +00002662// CHECK_SPARC-V9: #define __sparc_v9__ 1
Joerg Sonnenbergerec353d32015-11-09 23:39:45 +00002663// CHECK_SPARC-V9: #define __sparcv9 1
2664// CHECK_SPARC-V9-NOT: #define __sparcv8 1
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00002665
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00002666// RUN: %clang -E -dM %s -o - 2>&1 \
2667// RUN: -target sparcel-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002668// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPARCEL
Douglas Katzman6871afc2016-03-15 22:34:02 +00002669// RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=myriad2 2>&1 \
Walter Leefc7f8f22017-10-02 18:50:57 +00002670// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-2 \
2671// RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2
Douglas Katzman6871afc2016-03-15 22:34:02 +00002672// RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=myriad2.1 2>&1 \
Walter Leefc7f8f22017-10-02 18:50:57 +00002673// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-1 \
2674// RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2
Douglas Katzman6871afc2016-03-15 22:34:02 +00002675// RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=myriad2.2 2>&1 \
Walter Leefc7f8f22017-10-02 18:50:57 +00002676// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-2 \
2677// RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2
2678// RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=myriad2.3 2>&1 \
2679// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-3 \
2680// RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2
2681// RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2100 2>&1 \
2682// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-1 \
2683// RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2
2684// RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2150 2>&1 \
2685// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-2 \
2686// RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2
2687// RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2155 2>&1 \
2688// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-2 \
2689// RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2
Douglas Katzman87da5f42016-07-25 16:36:02 +00002690// RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2450 2>&1 \
Walter Leefc7f8f22017-10-02 18:50:57 +00002691// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-2 \
2692// RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2
2693// RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2455 2>&1 \
2694// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-2 \
2695// RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2
2696// RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2x5x 2>&1 \
2697// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-2 \
2698// RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2
2699// RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2080 2>&1 \
2700// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-3 \
2701// RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2
2702// RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2085 2>&1 \
2703// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-3 \
2704// RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2
2705// RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2480 2>&1 \
2706// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-3 \
2707// RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2
2708// RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2485 2>&1 \
2709// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-3 \
2710// RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2
2711// RUN: %clang -E -dM %s -o - -target sparcel-myriad -mcpu=ma2x8x 2>&1 \
2712// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_MYRIAD2-3 \
2713// RUN: -check-prefix=CHECK_SPARCEL -check-prefix=CHECK_MYRIAD2
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00002714// CHECK_SPARCEL: #define __LITTLE_ENDIAN__ 1
Walter Leefc7f8f22017-10-02 18:50:57 +00002715// CHECK_MYRIAD2: #define __leon__ 1
Douglas Katzman6871afc2016-03-15 22:34:02 +00002716// CHECK_MYRIAD2-1: #define __myriad2 1
2717// CHECK_MYRIAD2-1: #define __myriad2__ 1
Walter Lee637aafc2018-02-06 22:39:47 +00002718// CHECK_MYRIAD2-2: #define __ma2x5x 1
2719// CHECK_MYRIAD2-2: #define __ma2x5x__ 1
Douglas Katzman6871afc2016-03-15 22:34:02 +00002720// CHECK_MYRIAD2-2: #define __myriad2 2
2721// CHECK_MYRIAD2-2: #define __myriad2__ 2
Walter Lee637aafc2018-02-06 22:39:47 +00002722// CHECK_MYRIAD2-3: #define __ma2x8x 1
2723// CHECK_MYRIAD2-3: #define __ma2x8x__ 1
Walter Leefc7f8f22017-10-02 18:50:57 +00002724// CHECK_MYRIAD2-3: #define __myriad2 3
2725// CHECK_MYRIAD2-3: #define __myriad2__ 3
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00002726// CHECK_SPARCEL: #define __sparc 1
2727// CHECK_SPARCEL: #define __sparc__ 1
Walter Leefc7f8f22017-10-02 18:50:57 +00002728// CHECK_MYRIAD2: #define __sparc_v8__ 1
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00002729// CHECK_SPARCEL: #define __sparcv8 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002730
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00002731// RUN: %clang -E -dM %s -o - 2>&1 \
2732// RUN: -target sparcv9-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002733// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPARCV9
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00002734// CHECK_SPARCV9: #define __BIG_ENDIAN__ 1
2735// CHECK_SPARCV9: #define __sparc 1
2736// CHECK_SPARCV9: #define __sparc64__ 1
2737// CHECK_SPARCV9: #define __sparc__ 1
2738// CHECK_SPARCV9: #define __sparc_v9__ 1
2739// CHECK_SPARCV9: #define __sparcv9 1
2740// CHECK_SPARCV9: #define __sparcv9__ 1
2741
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00002742// Begin SystemZ/GCC/Linux tests ----------------
Gabor Buellac9e976c2018-04-12 18:15:39 +00002743
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00002744// RUN: %clang -march=arch8 -E -dM %s -o - 2>&1 \
2745// RUN: -target s390x-unknown-linux \
2746// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH8
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00002747// RUN: %clang -march=z10 -E -dM %s -o - 2>&1 \
2748// RUN: -target s390x-unknown-linux \
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00002749// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH8
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00002750// CHECK_SYSTEMZ_ARCH8: #define __ARCH__ 8
2751// CHECK_SYSTEMZ_ARCH8: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
2752// CHECK_SYSTEMZ_ARCH8: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
2753// CHECK_SYSTEMZ_ARCH8: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
2754// CHECK_SYSTEMZ_ARCH8: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
2755// CHECK_SYSTEMZ_ARCH8: #define __LONG_DOUBLE_128__ 1
2756// CHECK_SYSTEMZ_ARCH8: #define __s390__ 1
2757// CHECK_SYSTEMZ_ARCH8: #define __s390x__ 1
2758// CHECK_SYSTEMZ_ARCH8: #define __zarch__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002759
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00002760// RUN: %clang -march=arch9 -E -dM %s -o - 2>&1 \
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00002761// RUN: -target s390x-unknown-linux \
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00002762// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH9
2763// RUN: %clang -march=z196 -E -dM %s -o - 2>&1 \
2764// RUN: -target s390x-unknown-linux \
2765// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH9
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00002766// CHECK_SYSTEMZ_ARCH9: #define __ARCH__ 9
2767// CHECK_SYSTEMZ_ARCH9: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
2768// CHECK_SYSTEMZ_ARCH9: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
2769// CHECK_SYSTEMZ_ARCH9: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
2770// CHECK_SYSTEMZ_ARCH9: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
2771// CHECK_SYSTEMZ_ARCH9: #define __LONG_DOUBLE_128__ 1
2772// CHECK_SYSTEMZ_ARCH9: #define __s390__ 1
2773// CHECK_SYSTEMZ_ARCH9: #define __s390x__ 1
2774// CHECK_SYSTEMZ_ARCH9: #define __zarch__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002775
Ulrich Weigand30354eb2016-10-31 14:38:05 +00002776// RUN: %clang -march=arch10 -E -dM %s -o - 2>&1 \
2777// RUN: -target s390x-unknown-linux \
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00002778// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH10
2779// RUN: %clang -march=zEC12 -E -dM %s -o - 2>&1 \
2780// RUN: -target s390x-unknown-linux \
2781// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH10
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00002782// CHECK_SYSTEMZ_ARCH10: #define __ARCH__ 10
2783// CHECK_SYSTEMZ_ARCH10: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
2784// CHECK_SYSTEMZ_ARCH10: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
2785// CHECK_SYSTEMZ_ARCH10: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
2786// CHECK_SYSTEMZ_ARCH10: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
2787// CHECK_SYSTEMZ_ARCH10: #define __HTM__ 1
2788// CHECK_SYSTEMZ_ARCH10: #define __LONG_DOUBLE_128__ 1
2789// CHECK_SYSTEMZ_ARCH10: #define __s390__ 1
2790// CHECK_SYSTEMZ_ARCH10: #define __s390x__ 1
2791// CHECK_SYSTEMZ_ARCH10: #define __zarch__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002792
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00002793// RUN: %clang -march=arch11 -E -dM %s -o - 2>&1 \
2794// RUN: -target s390x-unknown-linux \
2795// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH11
2796// RUN: %clang -march=z13 -E -dM %s -o - 2>&1 \
2797// RUN: -target s390x-unknown-linux \
2798// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH11
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00002799// CHECK_SYSTEMZ_ARCH11: #define __ARCH__ 11
2800// CHECK_SYSTEMZ_ARCH11: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
2801// CHECK_SYSTEMZ_ARCH11: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
2802// CHECK_SYSTEMZ_ARCH11: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
2803// CHECK_SYSTEMZ_ARCH11: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
2804// CHECK_SYSTEMZ_ARCH11: #define __HTM__ 1
2805// CHECK_SYSTEMZ_ARCH11: #define __LONG_DOUBLE_128__ 1
2806// CHECK_SYSTEMZ_ARCH11: #define __VX__ 1
2807// CHECK_SYSTEMZ_ARCH11: #define __s390__ 1
2808// CHECK_SYSTEMZ_ARCH11: #define __s390x__ 1
2809// CHECK_SYSTEMZ_ARCH11: #define __zarch__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002810
Ulrich Weigandcac24ab2017-07-17 17:45:57 +00002811// RUN: %clang -march=arch12 -E -dM %s -o - 2>&1 \
2812// RUN: -target s390x-unknown-linux \
2813// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH12
2814// RUN: %clang -march=z14 -E -dM %s -o - 2>&1 \
2815// RUN: -target s390x-unknown-linux \
2816// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH12
Ulrich Weigandcac24ab2017-07-17 17:45:57 +00002817// CHECK_SYSTEMZ_ARCH12: #define __ARCH__ 12
2818// CHECK_SYSTEMZ_ARCH12: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
2819// CHECK_SYSTEMZ_ARCH12: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
2820// CHECK_SYSTEMZ_ARCH12: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
2821// CHECK_SYSTEMZ_ARCH12: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
2822// CHECK_SYSTEMZ_ARCH12: #define __HTM__ 1
2823// CHECK_SYSTEMZ_ARCH12: #define __LONG_DOUBLE_128__ 1
2824// CHECK_SYSTEMZ_ARCH12: #define __VX__ 1
2825// CHECK_SYSTEMZ_ARCH12: #define __s390__ 1
2826// CHECK_SYSTEMZ_ARCH12: #define __s390x__ 1
2827// CHECK_SYSTEMZ_ARCH12: #define __zarch__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002828
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00002829// RUN: %clang -mhtm -E -dM %s -o - 2>&1 \
2830// RUN: -target s390x-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002831// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_HTM
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00002832// CHECK_SYSTEMZ_HTM: #define __HTM__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002833
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00002834// RUN: %clang -mvx -E -dM %s -o - 2>&1 \
2835// RUN: -target s390x-unknown-linux \
2836// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_VX
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00002837// CHECK_SYSTEMZ_VX: #define __VX__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002838
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00002839// RUN: %clang -fzvector -E -dM %s -o - 2>&1 \
2840// RUN: -target s390x-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002841// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ZVECTOR
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00002842// RUN: %clang -mzvector -E -dM %s -o - 2>&1 \
2843// RUN: -target s390x-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002844// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ZVECTOR
Ulrich Weigand76976a72017-07-17 17:46:47 +00002845// CHECK_SYSTEMZ_ZVECTOR: #define __VEC__ 10302
Matt Arsenault5e020b22016-02-27 09:06:26 +00002846
2847// Begin amdgcn tests ----------------
Gabor Buellac9e976c2018-04-12 18:15:39 +00002848
Matt Arsenault5e020b22016-02-27 09:06:26 +00002849// RUN: %clang -march=amdgcn -E -dM %s -o - 2>&1 \
2850// RUN: -target amdgcn-unknown-unknown \
James Y Knight3508b222016-04-01 21:33:20 +00002851// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_AMDGCN
Matt Arsenault5e020b22016-02-27 09:06:26 +00002852// CHECK_AMDGCN: #define __AMDGCN__ 1
Jan Veselycda72c92017-10-19 20:40:13 +00002853// CHECK_AMDGCN: #define __HAS_FMAF__ 1
2854// CHECK_AMDGCN: #define __HAS_FP64__ 1
2855// CHECK_AMDGCN: #define __HAS_LDEXPF__ 1
Matt Arsenault5e020b22016-02-27 09:06:26 +00002856
2857// Begin r600 tests ----------------
Gabor Buellac9e976c2018-04-12 18:15:39 +00002858
Matt Arsenault5e020b22016-02-27 09:06:26 +00002859// RUN: %clang -march=amdgcn -E -dM %s -o - 2>&1 \
2860// RUN: -target r600-unknown-unknown \
James Y Knight3508b222016-04-01 21:33:20 +00002861// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_R600
Matt Arsenault5e020b22016-02-27 09:06:26 +00002862// CHECK_R600: #define __R600__ 1
Jan Veselycda72c92017-10-19 20:40:13 +00002863// CHECK_R600-NOT: #define __HAS_FMAF__ 1
2864
2865// RUN: %clang -march=amdgcn -mcpu=cypress -E -dM %s -o - 2>&1 \
2866// RUN: -target r600-unknown-unknown \
2867// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_R600_FP64
2868// CHECK_R600_FP64-DAG: #define __R600__ 1
2869// CHECK_R600_FP64-DAG: #define __HAS_FMAF__ 1