blob: f267f1759cdb5eed7ef34e8809d38b4ce3b0fc1e [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
Fangrui Songcbe4d972020-10-10 22:21:47 -07006// CHECK_I386_M32: #define __LAHF_SAHF__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00007// CHECK_I386_M32: #define __i386 1
8// CHECK_I386_M32: #define __i386__ 1
9// CHECK_I386_M32: #define __tune_i386__ 1
10// CHECK_I386_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +000011// RUN: not %clang -march=i386 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000012// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000013// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I386_M64
14// CHECK_I386_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +000015
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000016// RUN: %clang -march=i486 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000017// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000018// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I486_M32
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000019// CHECK_I486_M32: #define __i386 1
20// CHECK_I486_M32: #define __i386__ 1
21// CHECK_I486_M32: #define __i486 1
22// CHECK_I486_M32: #define __i486__ 1
23// CHECK_I486_M32: #define __tune_i486__ 1
24// CHECK_I486_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +000025// RUN: not %clang -march=i486 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000026// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000027// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I486_M64
28// CHECK_I486_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +000029
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000030// RUN: %clang -march=i586 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000031// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000032// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I586_M32
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000033// CHECK_I586_M32: #define __i386 1
34// CHECK_I586_M32: #define __i386__ 1
35// CHECK_I586_M32: #define __i586 1
36// CHECK_I586_M32: #define __i586__ 1
37// CHECK_I586_M32: #define __pentium 1
38// CHECK_I586_M32: #define __pentium__ 1
39// CHECK_I586_M32: #define __tune_i586__ 1
40// CHECK_I586_M32: #define __tune_pentium__ 1
41// CHECK_I586_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +000042// RUN: not %clang -march=i586 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000043// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000044// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I586_M64
45// CHECK_I586_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +000046
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000047// RUN: %clang -march=pentium -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000048// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000049// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM_M32
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000050// CHECK_PENTIUM_M32: #define __i386 1
51// CHECK_PENTIUM_M32: #define __i386__ 1
52// CHECK_PENTIUM_M32: #define __i586 1
53// CHECK_PENTIUM_M32: #define __i586__ 1
54// CHECK_PENTIUM_M32: #define __pentium 1
55// CHECK_PENTIUM_M32: #define __pentium__ 1
56// CHECK_PENTIUM_M32: #define __tune_i586__ 1
57// CHECK_PENTIUM_M32: #define __tune_pentium__ 1
58// CHECK_PENTIUM_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +000059// RUN: not %clang -march=pentium -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000060// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000061// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM_M64
62// CHECK_PENTIUM_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +000063
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000064// RUN: %clang -march=pentium-mmx -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000065// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000066// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM_MMX_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +000067// CHECK_PENTIUM_MMX_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000068// CHECK_PENTIUM_MMX_M32: #define __i386 1
69// CHECK_PENTIUM_MMX_M32: #define __i386__ 1
70// CHECK_PENTIUM_MMX_M32: #define __i586 1
71// CHECK_PENTIUM_MMX_M32: #define __i586__ 1
72// CHECK_PENTIUM_MMX_M32: #define __pentium 1
73// CHECK_PENTIUM_MMX_M32: #define __pentium__ 1
74// CHECK_PENTIUM_MMX_M32: #define __pentium_mmx__ 1
75// CHECK_PENTIUM_MMX_M32: #define __tune_i586__ 1
76// CHECK_PENTIUM_MMX_M32: #define __tune_pentium__ 1
77// CHECK_PENTIUM_MMX_M32: #define __tune_pentium_mmx__ 1
78// CHECK_PENTIUM_MMX_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +000079// RUN: not %clang -march=pentium-mmx -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000080// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000081// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM_MMX_M64
82// CHECK_PENTIUM_MMX_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +000083
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000084// RUN: %clang -march=winchip-c6 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000085// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000086// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_WINCHIP_C6_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +000087// CHECK_WINCHIP_C6_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000088// CHECK_WINCHIP_C6_M32: #define __i386 1
89// CHECK_WINCHIP_C6_M32: #define __i386__ 1
90// CHECK_WINCHIP_C6_M32: #define __i486 1
91// CHECK_WINCHIP_C6_M32: #define __i486__ 1
92// CHECK_WINCHIP_C6_M32: #define __tune_i486__ 1
93// CHECK_WINCHIP_C6_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +000094// RUN: not %clang -march=winchip-c6 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +000095// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +000096// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_WINCHIP_C6_M64
97// CHECK_WINCHIP_C6_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +000098
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +000099// RUN: %clang -march=winchip2 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000100// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000101// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_WINCHIP2_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000102// 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 __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000118// CHECK_C3_M32: #define __i386 1
119// CHECK_C3_M32: #define __i386__ 1
120// CHECK_C3_M32: #define __i486 1
121// CHECK_C3_M32: #define __i486__ 1
122// CHECK_C3_M32: #define __tune_i486__ 1
123// CHECK_C3_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +0000124// RUN: not %clang -march=c3 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000125// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000126// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_C3_M64
127// CHECK_C3_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +0000128
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000129// RUN: %clang -march=c3-2 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000130// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000131// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_C3_2_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000132// CHECK_C3_2_M32: #define __MMX__ 1
133// CHECK_C3_2_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000134// CHECK_C3_2_M32: #define __i386 1
135// CHECK_C3_2_M32: #define __i386__ 1
136// CHECK_C3_2_M32: #define __i686 1
137// CHECK_C3_2_M32: #define __i686__ 1
138// CHECK_C3_2_M32: #define __pentiumpro 1
139// CHECK_C3_2_M32: #define __pentiumpro__ 1
140// CHECK_C3_2_M32: #define __tune_i686__ 1
141// CHECK_C3_2_M32: #define __tune_pentium2__ 1
142// CHECK_C3_2_M32: #define __tune_pentiumpro__ 1
143// CHECK_C3_2_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +0000144// RUN: not %clang -march=c3-2 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000145// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000146// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_C3_2_M64
147// CHECK_C3_2_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +0000148
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000149// RUN: %clang -march=i686 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000150// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000151// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I686_M32
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000152// CHECK_I686_M32: #define __i386 1
153// CHECK_I686_M32: #define __i386__ 1
154// CHECK_I686_M32: #define __i686 1
155// CHECK_I686_M32: #define __i686__ 1
156// CHECK_I686_M32: #define __pentiumpro 1
157// CHECK_I686_M32: #define __pentiumpro__ 1
Craig Toppera6021e32017-10-26 23:06:19 +0000158// CHECK_I686_M32: #define __tune_i686__ 1
159// CHECK_I686_M32: #define __tune_pentiumpro__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000160// CHECK_I686_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +0000161// RUN: not %clang -march=i686 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000162// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000163// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_I686_M64
164// CHECK_I686_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +0000165
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000166// RUN: %clang -march=pentiumpro -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000167// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000168// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUMPRO_M32
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000169// CHECK_PENTIUMPRO_M32: #define __i386 1
170// CHECK_PENTIUMPRO_M32: #define __i386__ 1
171// CHECK_PENTIUMPRO_M32: #define __i686 1
172// CHECK_PENTIUMPRO_M32: #define __i686__ 1
173// CHECK_PENTIUMPRO_M32: #define __pentiumpro 1
174// CHECK_PENTIUMPRO_M32: #define __pentiumpro__ 1
175// CHECK_PENTIUMPRO_M32: #define __tune_i686__ 1
176// CHECK_PENTIUMPRO_M32: #define __tune_pentiumpro__ 1
177// CHECK_PENTIUMPRO_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +0000178// RUN: not %clang -march=pentiumpro -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000179// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000180// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUMPRO_M64
181// CHECK_PENTIUMPRO_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +0000182
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000183// RUN: %clang -march=pentium2 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000184// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000185// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PENTIUM2_M32
Craig Toppera8ccb482019-11-06 10:27:53 -0800186// CHECK_PENTIUM2_M32: #define __FXSR__ 1
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
Craig Topper704c6262019-03-13 05:14:50 +0000297// RUN: %clang -march=yonah -m32 -E -dM %s -o - 2>&1 \
298// RUN: -target i386-unknown-linux \
299// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_YONAH_M32
300// CHECK_YONAH_M32: #define __MMX__ 1
301// CHECK_YONAH_M32: #define __SSE2__ 1
302// CHECK_YONAH_M32: #define __SSE3__ 1
303// CHECK_YONAH_M32: #define __SSE__ 1
304// CHECK_YONAH_M32: #define __i386 1
305// CHECK_YONAH_M32: #define __i386__ 1
306// CHECK_YONAH_M32: #define __nocona 1
307// CHECK_YONAH_M32: #define __nocona__ 1
308// CHECK_YONAH_M32: #define __tune_nocona__ 1
309// CHECK_YONAH_M32: #define i386 1
310// RUN: not %clang -march=yonah -m64 -E -dM %s -o - 2>&1 \
311// RUN: -target i386-unknown-linux \
312// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_YONAH_M64
313// CHECK_YONAH_M64: error: {{.*}}
314
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000315// RUN: %clang -march=prescott -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_PRESCOTT_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000318// CHECK_PRESCOTT_M32: #define __MMX__ 1
319// CHECK_PRESCOTT_M32: #define __SSE2__ 1
320// CHECK_PRESCOTT_M32: #define __SSE3__ 1
321// CHECK_PRESCOTT_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000322// CHECK_PRESCOTT_M32: #define __i386 1
323// CHECK_PRESCOTT_M32: #define __i386__ 1
324// CHECK_PRESCOTT_M32: #define __nocona 1
325// CHECK_PRESCOTT_M32: #define __nocona__ 1
326// CHECK_PRESCOTT_M32: #define __tune_nocona__ 1
327// CHECK_PRESCOTT_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +0000328// RUN: not %clang -march=prescott -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_PRESCOTT_M64
331// CHECK_PRESCOTT_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +0000332
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000333// RUN: %clang -march=nocona -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000334// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000335// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_NOCONA_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000336// CHECK_NOCONA_M32: #define __MMX__ 1
337// CHECK_NOCONA_M32: #define __SSE2__ 1
338// CHECK_NOCONA_M32: #define __SSE3__ 1
339// CHECK_NOCONA_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000340// CHECK_NOCONA_M32: #define __i386 1
341// CHECK_NOCONA_M32: #define __i386__ 1
342// CHECK_NOCONA_M32: #define __nocona 1
343// CHECK_NOCONA_M32: #define __nocona__ 1
344// CHECK_NOCONA_M32: #define __tune_nocona__ 1
345// CHECK_NOCONA_M32: #define i386 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000346// RUN: %clang -march=nocona -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000347// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000348// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_NOCONA_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000349// CHECK_NOCONA_M64: #define __MMX__ 1
350// CHECK_NOCONA_M64: #define __SSE2_MATH__ 1
351// CHECK_NOCONA_M64: #define __SSE2__ 1
352// CHECK_NOCONA_M64: #define __SSE3__ 1
353// CHECK_NOCONA_M64: #define __SSE_MATH__ 1
354// CHECK_NOCONA_M64: #define __SSE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000355// CHECK_NOCONA_M64: #define __amd64 1
356// CHECK_NOCONA_M64: #define __amd64__ 1
357// CHECK_NOCONA_M64: #define __nocona 1
358// CHECK_NOCONA_M64: #define __nocona__ 1
359// CHECK_NOCONA_M64: #define __tune_nocona__ 1
360// CHECK_NOCONA_M64: #define __x86_64 1
361// CHECK_NOCONA_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000362
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000363// RUN: %clang -march=core2 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000364// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000365// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE2_M32
Freddy Ye548e08c2023-06-29 13:29:00 +0800366// RUN: %clang -march=penryn -m32 -E -dM %s -o - 2>&1 \
367// RUN: -target i386-unknown-linux \
368// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_CORE2_M32,CHECK_PENRYN_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000369// CHECK_CORE2_M32: #define __MMX__ 1
370// CHECK_CORE2_M32: #define __SSE2__ 1
371// CHECK_CORE2_M32: #define __SSE3__ 1
Freddy Ye548e08c2023-06-29 13:29:00 +0800372// CHECK_PENRYN_M32: #define __SSE4_1__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000373// CHECK_CORE2_M32: #define __SSE__ 1
374// CHECK_CORE2_M32: #define __SSSE3__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000375// CHECK_CORE2_M32: #define __core2 1
376// CHECK_CORE2_M32: #define __core2__ 1
377// CHECK_CORE2_M32: #define __i386 1
378// CHECK_CORE2_M32: #define __i386__ 1
379// CHECK_CORE2_M32: #define __tune_core2__ 1
380// CHECK_CORE2_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000381
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000382// RUN: %clang -march=core2 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000383// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000384// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE2_M64
Freddy Ye548e08c2023-06-29 13:29:00 +0800385// RUN: %clang -march=penryn -m64 -E -dM %s -o - 2>&1 \
386// RUN: -target i386-unknown-linux \
387// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_CORE2_M64,CHECK_PENRYN_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000388// CHECK_CORE2_M64: #define __MMX__ 1
389// CHECK_CORE2_M64: #define __SSE2_MATH__ 1
390// CHECK_CORE2_M64: #define __SSE2__ 1
391// CHECK_CORE2_M64: #define __SSE3__ 1
Freddy Ye548e08c2023-06-29 13:29:00 +0800392// CHECK_PENRYN_M64: #define __SSE4_1__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000393// CHECK_CORE2_M64: #define __SSE_MATH__ 1
394// CHECK_CORE2_M64: #define __SSE__ 1
395// CHECK_CORE2_M64: #define __SSSE3__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000396// CHECK_CORE2_M64: #define __amd64 1
397// CHECK_CORE2_M64: #define __amd64__ 1
398// CHECK_CORE2_M64: #define __core2 1
399// CHECK_CORE2_M64: #define __core2__ 1
400// CHECK_CORE2_M64: #define __tune_core2__ 1
401// CHECK_CORE2_M64: #define __x86_64 1
402// CHECK_CORE2_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000403
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000404// RUN: %clang -march=corei7 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000405// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000406// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_COREI7_M32
Freddy Ye548e08c2023-06-29 13:29:00 +0800407// RUN: %clang -march=nehalem -m32 -E -dM %s -o - 2>&1 \
408// RUN: -target i386-unknown-linux \
409// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_COREI7_M32
410// RUN: %clang -march=westmere -m32 -E -dM %s -o - 2>&1 \
411// RUN: -target i386-unknown-linux \
412// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_COREI7_M32,CHECK_WESTMERE_M32
413// CHECK_COREI7_M32: #define __CRC32__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000414// CHECK_COREI7_M32: #define __MMX__ 1
Freddy Ye548e08c2023-06-29 13:29:00 +0800415// CHECK_WESTMERE_M32: #define __PCLMUL__ 1
Craig Topperb644c972012-06-03 21:49:41 +0000416// CHECK_COREI7_M32: #define __POPCNT__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000417// CHECK_COREI7_M32: #define __SSE2__ 1
418// CHECK_COREI7_M32: #define __SSE3__ 1
419// CHECK_COREI7_M32: #define __SSE4_1__ 1
420// CHECK_COREI7_M32: #define __SSE4_2__ 1
421// CHECK_COREI7_M32: #define __SSE__ 1
422// CHECK_COREI7_M32: #define __SSSE3__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000423// CHECK_COREI7_M32: #define __corei7 1
424// CHECK_COREI7_M32: #define __corei7__ 1
425// CHECK_COREI7_M32: #define __i386 1
426// CHECK_COREI7_M32: #define __i386__ 1
427// CHECK_COREI7_M32: #define __tune_corei7__ 1
428// CHECK_COREI7_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000429
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000430// RUN: %clang -march=corei7 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000431// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000432// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_COREI7_M64
Freddy Ye548e08c2023-06-29 13:29:00 +0800433// RUN: %clang -march=nehalem -m64 -E -dM %s -o - 2>&1 \
434// RUN: -target i386-unknown-linux \
435// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_COREI7_M64
436// RUN: %clang -march=westmere -m64 -E -dM %s -o - 2>&1 \
437// RUN: -target i386-unknown-linux \
438// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_COREI7_M64,CHECK_WESTMERE_M64
439// CHECK_COREI7_M64: #define __CRC32__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000440// CHECK_COREI7_M64: #define __MMX__ 1
Freddy Ye548e08c2023-06-29 13:29:00 +0800441// CHECK_WESTMERE_M64: #define __PCLMUL__ 1
Craig Topperb644c972012-06-03 21:49:41 +0000442// CHECK_COREI7_M64: #define __POPCNT__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000443// CHECK_COREI7_M64: #define __SSE2_MATH__ 1
444// CHECK_COREI7_M64: #define __SSE2__ 1
445// CHECK_COREI7_M64: #define __SSE3__ 1
446// CHECK_COREI7_M64: #define __SSE4_1__ 1
447// CHECK_COREI7_M64: #define __SSE4_2__ 1
448// CHECK_COREI7_M64: #define __SSE_MATH__ 1
449// CHECK_COREI7_M64: #define __SSE__ 1
450// CHECK_COREI7_M64: #define __SSSE3__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000451// CHECK_COREI7_M64: #define __amd64 1
452// CHECK_COREI7_M64: #define __amd64__ 1
453// CHECK_COREI7_M64: #define __corei7 1
454// CHECK_COREI7_M64: #define __corei7__ 1
455// CHECK_COREI7_M64: #define __tune_corei7__ 1
456// CHECK_COREI7_M64: #define __x86_64 1
457// CHECK_COREI7_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000458
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000459// RUN: %clang -march=corei7-avx -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000460// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000461// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_COREI7_AVX_M32
Freddy Ye548e08c2023-06-29 13:29:00 +0800462// RUN: %clang -march=sandybridge -m32 -E -dM %s -o - 2>&1 \
463// RUN: -target i386-unknown-linux \
464// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_COREI7_AVX_M32
Craig Topper5f365e92012-04-26 07:31:30 +0000465// CHECK_COREI7_AVX_M32: #define __AVX__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000466// CHECK_COREI7_AVX_M32: #define __MMX__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000467// CHECK_COREI7_AVX_M32: #define __PCLMUL__ 1
Benjamin Kramer1e250392012-07-07 09:39:18 +0000468// CHECK_COREI7_AVX_M32-NOT: __RDRND__
Craig Topperb644c972012-06-03 21:49:41 +0000469// CHECK_COREI7_AVX_M32: #define __POPCNT__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000470// CHECK_COREI7_AVX_M32: #define __SSE2__ 1
471// CHECK_COREI7_AVX_M32: #define __SSE3__ 1
472// CHECK_COREI7_AVX_M32: #define __SSE4_1__ 1
473// CHECK_COREI7_AVX_M32: #define __SSE4_2__ 1
474// CHECK_COREI7_AVX_M32: #define __SSE__ 1
475// CHECK_COREI7_AVX_M32: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000476// CHECK_COREI7_AVX_M32: #define __XSAVEOPT__ 1
477// CHECK_COREI7_AVX_M32: #define __XSAVE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000478// CHECK_COREI7_AVX_M32: #define __corei7 1
479// CHECK_COREI7_AVX_M32: #define __corei7__ 1
480// CHECK_COREI7_AVX_M32: #define __i386 1
481// CHECK_COREI7_AVX_M32: #define __i386__ 1
482// CHECK_COREI7_AVX_M32: #define __tune_corei7__ 1
483// CHECK_COREI7_AVX_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000484
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000485// RUN: %clang -march=corei7-avx -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000486// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000487// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_COREI7_AVX_M64
Freddy Ye548e08c2023-06-29 13:29:00 +0800488// RUN: %clang -march=sandybridge -m64 -E -dM %s -o - 2>&1 \
489// RUN: -target i386-unknown-linux \
490// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_COREI7_AVX_M64
Craig Topper5f365e92012-04-26 07:31:30 +0000491// CHECK_COREI7_AVX_M64: #define __AVX__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000492// CHECK_COREI7_AVX_M64: #define __MMX__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000493// CHECK_COREI7_AVX_M64: #define __PCLMUL__ 1
Benjamin Kramer1e250392012-07-07 09:39:18 +0000494// CHECK_COREI7_AVX_M64-NOT: __RDRND__
Craig Topperb644c972012-06-03 21:49:41 +0000495// CHECK_COREI7_AVX_M64: #define __POPCNT__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000496// CHECK_COREI7_AVX_M64: #define __SSE2_MATH__ 1
497// CHECK_COREI7_AVX_M64: #define __SSE2__ 1
498// CHECK_COREI7_AVX_M64: #define __SSE3__ 1
499// CHECK_COREI7_AVX_M64: #define __SSE4_1__ 1
500// CHECK_COREI7_AVX_M64: #define __SSE4_2__ 1
501// CHECK_COREI7_AVX_M64: #define __SSE_MATH__ 1
502// CHECK_COREI7_AVX_M64: #define __SSE__ 1
503// CHECK_COREI7_AVX_M64: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000504// CHECK_COREI7_AVX_M64: #define __XSAVEOPT__ 1
505// CHECK_COREI7_AVX_M64: #define __XSAVE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000506// CHECK_COREI7_AVX_M64: #define __amd64 1
507// CHECK_COREI7_AVX_M64: #define __amd64__ 1
508// CHECK_COREI7_AVX_M64: #define __corei7 1
509// CHECK_COREI7_AVX_M64: #define __corei7__ 1
510// CHECK_COREI7_AVX_M64: #define __tune_corei7__ 1
511// CHECK_COREI7_AVX_M64: #define __x86_64 1
512// CHECK_COREI7_AVX_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000513
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000514// RUN: %clang -march=core-avx-i -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000515// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000516// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE_AVX_I_M32
Freddy Ye548e08c2023-06-29 13:29:00 +0800517// RUN: %clang -march=ivybridge -m32 -E -dM %s -o - 2>&1 \
518// RUN: -target i386-unknown-linux \
519// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE_AVX_I_M32
Craig Topper5f365e92012-04-26 07:31:30 +0000520// CHECK_CORE_AVX_I_M32: #define __AVX__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +0000521// CHECK_CORE_AVX_I_M32: #define __F16C__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000522// CHECK_CORE_AVX_I_M32: #define __MMX__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000523// CHECK_CORE_AVX_I_M32: #define __PCLMUL__ 1
Benjamin Kramer1e250392012-07-07 09:39:18 +0000524// CHECK_CORE_AVX_I_M32: #define __RDRND__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000525// CHECK_CORE_AVX_I_M32: #define __SSE2__ 1
526// CHECK_CORE_AVX_I_M32: #define __SSE3__ 1
527// CHECK_CORE_AVX_I_M32: #define __SSE4_1__ 1
528// CHECK_CORE_AVX_I_M32: #define __SSE4_2__ 1
529// CHECK_CORE_AVX_I_M32: #define __SSE__ 1
530// CHECK_CORE_AVX_I_M32: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000531// CHECK_CORE_AVX_I_M32: #define __XSAVEOPT__ 1
532// CHECK_CORE_AVX_I_M32: #define __XSAVE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +0000533// CHECK_CORE_AVX_I_M32: #define __corei7 1
534// CHECK_CORE_AVX_I_M32: #define __corei7__ 1
535// CHECK_CORE_AVX_I_M32: #define __i386 1
536// CHECK_CORE_AVX_I_M32: #define __i386__ 1
537// CHECK_CORE_AVX_I_M32: #define __tune_corei7__ 1
538// CHECK_CORE_AVX_I_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000539
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000540// RUN: %clang -march=core-avx-i -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +0000541// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000542// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE_AVX_I_M64
Freddy Ye548e08c2023-06-29 13:29:00 +0800543// RUN: %clang -march=ivybridge -m64 -E -dM %s -o - 2>&1 \
544// RUN: -target i386-unknown-linux \
545// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE_AVX_I_M64
Craig Topper5f365e92012-04-26 07:31:30 +0000546// CHECK_CORE_AVX_I_M64: #define __AVX__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +0000547// CHECK_CORE_AVX_I_M64: #define __F16C__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000548// CHECK_CORE_AVX_I_M64: #define __MMX__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000549// CHECK_CORE_AVX_I_M64: #define __PCLMUL__ 1
Benjamin Kramer1e250392012-07-07 09:39:18 +0000550// CHECK_CORE_AVX_I_M64: #define __RDRND__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +0000551// CHECK_CORE_AVX_I_M64: #define __SSE2_MATH__ 1
552// CHECK_CORE_AVX_I_M64: #define __SSE2__ 1
553// CHECK_CORE_AVX_I_M64: #define __SSE3__ 1
554// CHECK_CORE_AVX_I_M64: #define __SSE4_1__ 1
555// CHECK_CORE_AVX_I_M64: #define __SSE4_2__ 1
556// CHECK_CORE_AVX_I_M64: #define __SSE_MATH__ 1
557// CHECK_CORE_AVX_I_M64: #define __SSE__ 1
558// CHECK_CORE_AVX_I_M64: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000559// CHECK_CORE_AVX_I_M64: #define __XSAVEOPT__ 1
560// CHECK_CORE_AVX_I_M64: #define __XSAVE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +0000561// CHECK_CORE_AVX_I_M64: #define __amd64 1
562// CHECK_CORE_AVX_I_M64: #define __amd64__ 1
563// CHECK_CORE_AVX_I_M64: #define __corei7 1
564// CHECK_CORE_AVX_I_M64: #define __corei7__ 1
565// CHECK_CORE_AVX_I_M64: #define __tune_corei7__ 1
566// CHECK_CORE_AVX_I_M64: #define __x86_64 1
567// CHECK_CORE_AVX_I_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000568
Craig Topperbba778b2012-06-03 21:46:30 +0000569// RUN: %clang -march=core-avx2 -m32 -E -dM %s -o - 2>&1 \
570// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000571// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE_AVX2_M32
Freddy Ye548e08c2023-06-29 13:29:00 +0800572// RUN: %clang -march=haswell -m32 -E -dM %s -o - 2>&1 \
573// RUN: -target i386-unknown-linux \
574// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE_AVX2_M32
Craig Topper449314e2013-08-20 07:09:39 +0000575// CHECK_CORE_AVX2_M32: #define __AVX2__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000576// CHECK_CORE_AVX2_M32: #define __AVX__ 1
577// CHECK_CORE_AVX2_M32: #define __BMI2__ 1
578// CHECK_CORE_AVX2_M32: #define __BMI__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +0000579// CHECK_CORE_AVX2_M32: #define __F16C__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000580// CHECK_CORE_AVX2_M32: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +0000581// CHECK_CORE_AVX2_M32: #define __INVPCID__ 1
Fangrui Songcbe4d972020-10-10 22:21:47 -0700582// CHECK_CORE_AVX2_M32: #define __LAHF_SAHF__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000583// CHECK_CORE_AVX2_M32: #define __LZCNT__ 1
584// CHECK_CORE_AVX2_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000585// CHECK_CORE_AVX2_M32: #define __MOVBE__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000586// CHECK_CORE_AVX2_M32: #define __PCLMUL__ 1
587// CHECK_CORE_AVX2_M32: #define __POPCNT__ 1
Benjamin Kramer1e250392012-07-07 09:39:18 +0000588// CHECK_CORE_AVX2_M32: #define __RDRND__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000589// CHECK_CORE_AVX2_M32: #define __SSE2__ 1
590// CHECK_CORE_AVX2_M32: #define __SSE3__ 1
591// CHECK_CORE_AVX2_M32: #define __SSE4_1__ 1
592// CHECK_CORE_AVX2_M32: #define __SSE4_2__ 1
593// CHECK_CORE_AVX2_M32: #define __SSE__ 1
594// CHECK_CORE_AVX2_M32: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000595// CHECK_CORE_AVX2_M32: #define __XSAVEOPT__ 1
596// CHECK_CORE_AVX2_M32: #define __XSAVE__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000597// CHECK_CORE_AVX2_M32: #define __corei7 1
598// CHECK_CORE_AVX2_M32: #define __corei7__ 1
599// CHECK_CORE_AVX2_M32: #define __i386 1
600// CHECK_CORE_AVX2_M32: #define __i386__ 1
601// CHECK_CORE_AVX2_M32: #define __tune_corei7__ 1
602// CHECK_CORE_AVX2_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000603
Craig Topperbba778b2012-06-03 21:46:30 +0000604// RUN: %clang -march=core-avx2 -m64 -E -dM %s -o - 2>&1 \
605// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000606// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE_AVX2_M64
Freddy Ye548e08c2023-06-29 13:29:00 +0800607// RUN: %clang -march=haswell -m64 -E -dM %s -o - 2>&1 \
608// RUN: -target i386-unknown-linux \
609// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CORE_AVX2_M64
Craig Topper449314e2013-08-20 07:09:39 +0000610// CHECK_CORE_AVX2_M64: #define __AVX2__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000611// CHECK_CORE_AVX2_M64: #define __AVX__ 1
612// CHECK_CORE_AVX2_M64: #define __BMI2__ 1
613// CHECK_CORE_AVX2_M64: #define __BMI__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +0000614// CHECK_CORE_AVX2_M64: #define __F16C__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000615// CHECK_CORE_AVX2_M64: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +0000616// CHECK_CORE_AVX2_M64: #define __INVPCID__ 1
Fangrui Songcbe4d972020-10-10 22:21:47 -0700617// CHECK_CORE_AVX2_M64: #define __LAHF_SAHF__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000618// CHECK_CORE_AVX2_M64: #define __LZCNT__ 1
619// CHECK_CORE_AVX2_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000620// CHECK_CORE_AVX2_M64: #define __MOVBE__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000621// CHECK_CORE_AVX2_M64: #define __PCLMUL__ 1
622// CHECK_CORE_AVX2_M64: #define __POPCNT__ 1
Benjamin Kramer1e250392012-07-07 09:39:18 +0000623// CHECK_CORE_AVX2_M64: #define __RDRND__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000624// CHECK_CORE_AVX2_M64: #define __SSE2_MATH__ 1
625// CHECK_CORE_AVX2_M64: #define __SSE2__ 1
626// CHECK_CORE_AVX2_M64: #define __SSE3__ 1
627// CHECK_CORE_AVX2_M64: #define __SSE4_1__ 1
628// CHECK_CORE_AVX2_M64: #define __SSE4_2__ 1
629// CHECK_CORE_AVX2_M64: #define __SSE_MATH__ 1
630// CHECK_CORE_AVX2_M64: #define __SSE__ 1
631// CHECK_CORE_AVX2_M64: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000632// CHECK_CORE_AVX2_M64: #define __XSAVEOPT__ 1
633// CHECK_CORE_AVX2_M64: #define __XSAVE__ 1
Craig Topperbba778b2012-06-03 21:46:30 +0000634// CHECK_CORE_AVX2_M64: #define __amd64 1
635// CHECK_CORE_AVX2_M64: #define __amd64__ 1
636// CHECK_CORE_AVX2_M64: #define __corei7 1
637// CHECK_CORE_AVX2_M64: #define __corei7__ 1
638// CHECK_CORE_AVX2_M64: #define __tune_corei7__ 1
639// CHECK_CORE_AVX2_M64: #define __x86_64 1
640// CHECK_CORE_AVX2_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000641
Robert Khasanov50e6f582014-09-19 09:53:48 +0000642// RUN: %clang -march=broadwell -m32 -E -dM %s -o - 2>&1 \
643// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000644// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BROADWELL_M32
Robert Khasanov50e6f582014-09-19 09:53:48 +0000645// CHECK_BROADWELL_M32: #define __ADX__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000646// CHECK_BROADWELL_M32: #define __AVX2__ 1
647// CHECK_BROADWELL_M32: #define __AVX__ 1
648// CHECK_BROADWELL_M32: #define __BMI2__ 1
649// CHECK_BROADWELL_M32: #define __BMI__ 1
650// CHECK_BROADWELL_M32: #define __F16C__ 1
651// CHECK_BROADWELL_M32: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +0000652// CHECK_BROADWELL_M32: #define __INVPCID__ 1
Fangrui Songcbe4d972020-10-10 22:21:47 -0700653// CHECK_BROADWELL_M32: #define __LAHF_SAHF__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000654// CHECK_BROADWELL_M32: #define __LZCNT__ 1
655// CHECK_BROADWELL_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000656// CHECK_BROADWELL_M32: #define __MOVBE__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000657// CHECK_BROADWELL_M32: #define __PCLMUL__ 1
658// CHECK_BROADWELL_M32: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000659// CHECK_BROADWELL_M32: #define __PRFCHW__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000660// CHECK_BROADWELL_M32: #define __RDRND__ 1
661// CHECK_BROADWELL_M32: #define __RDSEED__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000662// CHECK_BROADWELL_M32: #define __SSE2__ 1
663// CHECK_BROADWELL_M32: #define __SSE3__ 1
664// CHECK_BROADWELL_M32: #define __SSE4_1__ 1
665// CHECK_BROADWELL_M32: #define __SSE4_2__ 1
666// CHECK_BROADWELL_M32: #define __SSE__ 1
667// CHECK_BROADWELL_M32: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000668// CHECK_BROADWELL_M32: #define __XSAVEOPT__ 1
669// CHECK_BROADWELL_M32: #define __XSAVE__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000670// CHECK_BROADWELL_M32: #define __corei7 1
671// CHECK_BROADWELL_M32: #define __corei7__ 1
672// CHECK_BROADWELL_M32: #define __i386 1
673// CHECK_BROADWELL_M32: #define __i386__ 1
674// CHECK_BROADWELL_M32: #define __tune_corei7__ 1
675// CHECK_BROADWELL_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000676
Robert Khasanov50e6f582014-09-19 09:53:48 +0000677// RUN: %clang -march=broadwell -m64 -E -dM %s -o - 2>&1 \
678// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000679// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BROADWELL_M64
Robert Khasanov50e6f582014-09-19 09:53:48 +0000680// CHECK_BROADWELL_M64: #define __ADX__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000681// CHECK_BROADWELL_M64: #define __AVX2__ 1
682// CHECK_BROADWELL_M64: #define __AVX__ 1
683// CHECK_BROADWELL_M64: #define __BMI2__ 1
684// CHECK_BROADWELL_M64: #define __BMI__ 1
685// CHECK_BROADWELL_M64: #define __F16C__ 1
686// CHECK_BROADWELL_M64: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +0000687// CHECK_BROADWELL_M64: #define __INVPCID__ 1
Fangrui Songcbe4d972020-10-10 22:21:47 -0700688// CHECK_BROADWELL_M64: #define __LAHF_SAHF__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000689// CHECK_BROADWELL_M64: #define __LZCNT__ 1
690// CHECK_BROADWELL_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000691// CHECK_BROADWELL_M64: #define __MOVBE__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000692// CHECK_BROADWELL_M64: #define __PCLMUL__ 1
693// CHECK_BROADWELL_M64: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000694// CHECK_BROADWELL_M64: #define __PRFCHW__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000695// CHECK_BROADWELL_M64: #define __RDRND__ 1
696// CHECK_BROADWELL_M64: #define __RDSEED__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000697// CHECK_BROADWELL_M64: #define __SSE2_MATH__ 1
698// CHECK_BROADWELL_M64: #define __SSE2__ 1
699// CHECK_BROADWELL_M64: #define __SSE3__ 1
700// CHECK_BROADWELL_M64: #define __SSE4_1__ 1
701// CHECK_BROADWELL_M64: #define __SSE4_2__ 1
702// CHECK_BROADWELL_M64: #define __SSE_MATH__ 1
703// CHECK_BROADWELL_M64: #define __SSE__ 1
704// CHECK_BROADWELL_M64: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000705// CHECK_BROADWELL_M64: #define __XSAVEOPT__ 1
706// CHECK_BROADWELL_M64: #define __XSAVE__ 1
Robert Khasanov50e6f582014-09-19 09:53:48 +0000707// CHECK_BROADWELL_M64: #define __amd64 1
708// CHECK_BROADWELL_M64: #define __amd64__ 1
709// CHECK_BROADWELL_M64: #define __corei7 1
710// CHECK_BROADWELL_M64: #define __corei7__ 1
711// CHECK_BROADWELL_M64: #define __tune_corei7__ 1
712// CHECK_BROADWELL_M64: #define __x86_64 1
713// CHECK_BROADWELL_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000714
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000715// RUN: %clang -march=skylake -m32 -E -dM %s -o - 2>&1 \
716// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000717// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SKL_M32
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000718// CHECK_SKL_M32: #define __ADX__ 1
719// CHECK_SKL_M32: #define __AES__ 1
720// CHECK_SKL_M32: #define __AVX2__ 1
721// CHECK_SKL_M32: #define __AVX__ 1
722// CHECK_SKL_M32: #define __BMI2__ 1
723// CHECK_SKL_M32: #define __BMI__ 1
Craig Topper78b47872017-02-08 06:48:58 +0000724// CHECK_SKL_M32: #define __CLFLUSHOPT__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000725// CHECK_SKL_M32: #define __F16C__ 1
726// CHECK_SKL_M32: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +0000727// CHECK_SKL_M32: #define __INVPCID__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000728// CHECK_SKL_M32: #define __LZCNT__ 1
729// CHECK_SKL_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000730// CHECK_SKL_M32: #define __MOVBE__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000731// CHECK_SKL_M32: #define __PCLMUL__ 1
732// CHECK_SKL_M32: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000733// CHECK_SKL_M32: #define __PRFCHW__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000734// CHECK_SKL_M32: #define __RDRND__ 1
735// CHECK_SKL_M32: #define __RDSEED__ 1
Craig Topper204ecff2017-02-08 08:23:17 +0000736// CHECK_SKL_M32: #define __SGX__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000737// CHECK_SKL_M32: #define __SSE2__ 1
738// CHECK_SKL_M32: #define __SSE3__ 1
739// CHECK_SKL_M32: #define __SSE4_1__ 1
740// CHECK_SKL_M32: #define __SSE4_2__ 1
741// CHECK_SKL_M32: #define __SSE__ 1
742// CHECK_SKL_M32: #define __SSSE3__ 1
743// CHECK_SKL_M32: #define __XSAVEC__ 1
744// CHECK_SKL_M32: #define __XSAVEOPT__ 1
745// CHECK_SKL_M32: #define __XSAVES__ 1
746// CHECK_SKL_M32: #define __XSAVE__ 1
747// CHECK_SKL_M32: #define i386 1
748
749// RUN: %clang -march=skylake -m64 -E -dM %s -o - 2>&1 \
750// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000751// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SKL_M64
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000752// CHECK_SKL_M64: #define __ADX__ 1
753// CHECK_SKL_M64: #define __AES__ 1
754// CHECK_SKL_M64: #define __AVX2__ 1
755// CHECK_SKL_M64: #define __AVX__ 1
756// CHECK_SKL_M64: #define __BMI2__ 1
757// CHECK_SKL_M64: #define __BMI__ 1
Craig Topper78b47872017-02-08 06:48:58 +0000758// CHECK_SKL_M64: #define __CLFLUSHOPT__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000759// CHECK_SKL_M64: #define __F16C__ 1
760// CHECK_SKL_M64: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +0000761// CHECK_SKL_M64: #define __INVPCID__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000762// CHECK_SKL_M64: #define __LZCNT__ 1
763// CHECK_SKL_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000764// CHECK_SKL_M64: #define __MOVBE__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000765// CHECK_SKL_M64: #define __PCLMUL__ 1
766// CHECK_SKL_M64: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000767// CHECK_SKL_M64: #define __PRFCHW__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000768// CHECK_SKL_M64: #define __RDRND__ 1
769// CHECK_SKL_M64: #define __RDSEED__ 1
Craig Topper204ecff2017-02-08 08:23:17 +0000770// CHECK_SKL_M64: #define __SGX__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000771// CHECK_SKL_M64: #define __SSE2_MATH__ 1
772// CHECK_SKL_M64: #define __SSE2__ 1
773// CHECK_SKL_M64: #define __SSE3__ 1
774// CHECK_SKL_M64: #define __SSE4_1__ 1
775// CHECK_SKL_M64: #define __SSE4_2__ 1
776// CHECK_SKL_M64: #define __SSE_MATH__ 1
777// CHECK_SKL_M64: #define __SSE__ 1
778// CHECK_SKL_M64: #define __SSSE3__ 1
779// CHECK_SKL_M64: #define __XSAVEC__ 1
780// CHECK_SKL_M64: #define __XSAVEOPT__ 1
781// CHECK_SKL_M64: #define __XSAVES__ 1
782// CHECK_SKL_M64: #define __XSAVE__ 1
783// CHECK_SKL_M64: #define __amd64 1
784// CHECK_SKL_M64: #define __amd64__ 1
785// CHECK_SKL_M64: #define __x86_64 1
786// CHECK_SKL_M64: #define __x86_64__ 1
787
Craig Topper449314e2013-08-20 07:09:39 +0000788// RUN: %clang -march=knl -m32 -E -dM %s -o - 2>&1 \
789// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000790// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_KNL_M32
Craig Topper449314e2013-08-20 07:09:39 +0000791// CHECK_KNL_M32: #define __AES__ 1
792// CHECK_KNL_M32: #define __AVX2__ 1
Craig Topper679b53a2013-08-21 05:29:10 +0000793// CHECK_KNL_M32: #define __AVX512CD__ 1
Craig Topperaf0ca632013-08-20 07:52:37 +0000794// CHECK_KNL_M32: #define __AVX512F__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000795// CHECK_KNL_M32: #define __AVX__ 1
796// CHECK_KNL_M32: #define __BMI2__ 1
797// CHECK_KNL_M32: #define __BMI__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +0800798// CHECK_KNL_M32-NOT: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +0800799// CHECK_KNL_M32: #define __EVEX512__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000800// CHECK_KNL_M32: #define __F16C__ 1
801// CHECK_KNL_M32: #define __FMA__ 1
802// CHECK_KNL_M32: #define __LZCNT__ 1
803// CHECK_KNL_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000804// CHECK_KNL_M32: #define __MOVBE__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000805// CHECK_KNL_M32: #define __PCLMUL__ 1
806// CHECK_KNL_M32: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000807// CHECK_KNL_M32: #define __PRFCHW__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000808// CHECK_KNL_M32: #define __RDRND__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000809// CHECK_KNL_M32: #define __SSE2__ 1
810// CHECK_KNL_M32: #define __SSE3__ 1
811// CHECK_KNL_M32: #define __SSE4_1__ 1
812// CHECK_KNL_M32: #define __SSE4_2__ 1
813// CHECK_KNL_M32: #define __SSE__ 1
814// CHECK_KNL_M32: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000815// CHECK_KNL_M32: #define __XSAVEOPT__ 1
816// CHECK_KNL_M32: #define __XSAVE__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000817// CHECK_KNL_M32: #define __i386 1
818// CHECK_KNL_M32: #define __i386__ 1
819// CHECK_KNL_M32: #define __knl 1
820// CHECK_KNL_M32: #define __knl__ 1
821// CHECK_KNL_M32: #define __tune_knl__ 1
822// CHECK_KNL_M32: #define i386 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000823
Craig Topper449314e2013-08-20 07:09:39 +0000824// RUN: %clang -march=knl -m64 -E -dM %s -o - 2>&1 \
825// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000826// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_KNL_M64
Craig Topper449314e2013-08-20 07:09:39 +0000827// CHECK_KNL_M64: #define __AES__ 1
828// CHECK_KNL_M64: #define __AVX2__ 1
Craig Topper679b53a2013-08-21 05:29:10 +0000829// CHECK_KNL_M64: #define __AVX512CD__ 1
Craig Topperaf0ca632013-08-20 07:52:37 +0000830// CHECK_KNL_M64: #define __AVX512F__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000831// CHECK_KNL_M64: #define __AVX__ 1
832// CHECK_KNL_M64: #define __BMI2__ 1
833// CHECK_KNL_M64: #define __BMI__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +0800834// CHECK_KNL_M64-NOT: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +0800835// CHECK_KNL_M64: #define __EVEX512__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000836// CHECK_KNL_M64: #define __F16C__ 1
837// CHECK_KNL_M64: #define __FMA__ 1
838// CHECK_KNL_M64: #define __LZCNT__ 1
839// CHECK_KNL_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000840// CHECK_KNL_M64: #define __MOVBE__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000841// CHECK_KNL_M64: #define __PCLMUL__ 1
842// CHECK_KNL_M64: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000843// CHECK_KNL_M64: #define __PRFCHW__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000844// CHECK_KNL_M64: #define __RDRND__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000845// CHECK_KNL_M64: #define __SSE2_MATH__ 1
846// CHECK_KNL_M64: #define __SSE2__ 1
847// CHECK_KNL_M64: #define __SSE3__ 1
848// CHECK_KNL_M64: #define __SSE4_1__ 1
849// CHECK_KNL_M64: #define __SSE4_2__ 1
850// CHECK_KNL_M64: #define __SSE_MATH__ 1
851// CHECK_KNL_M64: #define __SSE__ 1
852// CHECK_KNL_M64: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000853// CHECK_KNL_M64: #define __XSAVEOPT__ 1
854// CHECK_KNL_M64: #define __XSAVE__ 1
Craig Topper449314e2013-08-20 07:09:39 +0000855// CHECK_KNL_M64: #define __amd64 1
856// CHECK_KNL_M64: #define __amd64__ 1
857// CHECK_KNL_M64: #define __knl 1
858// CHECK_KNL_M64: #define __knl__ 1
859// CHECK_KNL_M64: #define __tune_knl__ 1
860// CHECK_KNL_M64: #define __x86_64 1
861// CHECK_KNL_M64: #define __x86_64__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000862
863// RUN: %clang -march=knm -m32 -E -dM %s -o - 2>&1 \
864// RUN: -target i386-unknown-linux \
865// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_KNM_M32
866// CHECK_KNM_M32: #define __AES__ 1
867// CHECK_KNM_M32: #define __AVX2__ 1
868// CHECK_KNM_M32: #define __AVX512CD__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000869// CHECK_KNM_M32: #define __AVX512F__ 1
Craig Topper009cebf2017-10-25 17:10:58 +0000870// CHECK_KNM_M32: #define __AVX512VPOPCNTDQ__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000871// CHECK_KNM_M32: #define __AVX__ 1
872// CHECK_KNM_M32: #define __BMI2__ 1
873// CHECK_KNM_M32: #define __BMI__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +0800874// CHECK_KNM_M32-NOT: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +0800875// CHECK_KNM_M32: #define __EVEX512__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000876// CHECK_KNM_M32: #define __F16C__ 1
877// CHECK_KNM_M32: #define __FMA__ 1
878// CHECK_KNM_M32: #define __LZCNT__ 1
879// CHECK_KNM_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000880// CHECK_KNM_M32: #define __MOVBE__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000881// CHECK_KNM_M32: #define __PCLMUL__ 1
882// CHECK_KNM_M32: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000883// CHECK_KNM_M32: #define __PRFCHW__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000884// CHECK_KNM_M32: #define __RDRND__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000885// CHECK_KNM_M32: #define __SSE2__ 1
886// CHECK_KNM_M32: #define __SSE3__ 1
887// CHECK_KNM_M32: #define __SSE4_1__ 1
888// CHECK_KNM_M32: #define __SSE4_2__ 1
889// CHECK_KNM_M32: #define __SSE__ 1
890// CHECK_KNM_M32: #define __SSSE3__ 1
891// CHECK_KNM_M32: #define __XSAVEOPT__ 1
892// CHECK_KNM_M32: #define __XSAVE__ 1
893// CHECK_KNM_M32: #define __i386 1
894// CHECK_KNM_M32: #define __i386__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000895// CHECK_KNM_M32: #define i386 1
896
897// RUN: %clang -march=knm -m64 -E -dM %s -o - 2>&1 \
898// RUN: -target i386-unknown-linux \
899// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_KNM_M64
900// CHECK_KNM_M64: #define __AES__ 1
901// CHECK_KNM_M64: #define __AVX2__ 1
902// CHECK_KNM_M64: #define __AVX512CD__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000903// CHECK_KNM_M64: #define __AVX512F__ 1
Craig Topper009cebf2017-10-25 17:10:58 +0000904// CHECK_KNM_M64: #define __AVX512VPOPCNTDQ__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000905// CHECK_KNM_M64: #define __AVX__ 1
906// CHECK_KNM_M64: #define __BMI2__ 1
907// CHECK_KNM_M64: #define __BMI__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +0800908// CHECK_KNM_M64-NOT: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +0800909// CHECK_KNM_M64: #define __EVEX512__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000910// CHECK_KNM_M64: #define __F16C__ 1
911// CHECK_KNM_M64: #define __FMA__ 1
912// CHECK_KNM_M64: #define __LZCNT__ 1
913// CHECK_KNM_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000914// CHECK_KNM_M64: #define __MOVBE__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000915// CHECK_KNM_M64: #define __PCLMUL__ 1
916// CHECK_KNM_M64: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000917// CHECK_KNM_M64: #define __PRFCHW__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000918// CHECK_KNM_M64: #define __RDRND__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000919// CHECK_KNM_M64: #define __SSE2_MATH__ 1
920// CHECK_KNM_M64: #define __SSE2__ 1
921// CHECK_KNM_M64: #define __SSE3__ 1
922// CHECK_KNM_M64: #define __SSE4_1__ 1
923// CHECK_KNM_M64: #define __SSE4_2__ 1
924// CHECK_KNM_M64: #define __SSE_MATH__ 1
925// CHECK_KNM_M64: #define __SSE__ 1
926// CHECK_KNM_M64: #define __SSSE3__ 1
927// CHECK_KNM_M64: #define __XSAVEOPT__ 1
928// CHECK_KNM_M64: #define __XSAVE__ 1
929// CHECK_KNM_M64: #define __amd64 1
930// CHECK_KNM_M64: #define __amd64__ 1
Craig Topperf8c10aa2017-10-13 18:14:24 +0000931// CHECK_KNM_M64: #define __x86_64 1
932// CHECK_KNM_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +0000933
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000934// RUN: %clang -march=skylake-avx512 -m32 -E -dM %s -o - 2>&1 \
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000935// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000936// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SKX_M32
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000937// CHECK_SKX_M32: #define __AES__ 1
938// CHECK_SKX_M32: #define __AVX2__ 1
939// CHECK_SKX_M32: #define __AVX512BW__ 1
940// CHECK_SKX_M32: #define __AVX512CD__ 1
941// CHECK_SKX_M32: #define __AVX512DQ__ 1
942// CHECK_SKX_M32: #define __AVX512F__ 1
943// CHECK_SKX_M32: #define __AVX512VL__ 1
944// CHECK_SKX_M32: #define __AVX__ 1
945// CHECK_SKX_M32: #define __BMI2__ 1
946// CHECK_SKX_M32: #define __BMI__ 1
Craig Topper78b47872017-02-08 06:48:58 +0000947// CHECK_SKX_M32: #define __CLFLUSHOPT__ 1
Craig Topper8c708cf2017-02-08 07:36:58 +0000948// CHECK_SKX_M32: #define __CLWB__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +0800949// CHECK_SKX_M32: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +0800950// CHECK_SKX_M32: #define __EVEX512__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000951// CHECK_SKX_M32: #define __F16C__ 1
952// CHECK_SKX_M32: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +0000953// CHECK_SKX_M32: #define __INVPCID__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000954// CHECK_SKX_M32: #define __LZCNT__ 1
955// CHECK_SKX_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +0000956// CHECK_SKX_M32: #define __MOVBE__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000957// CHECK_SKX_M32: #define __PCLMUL__ 1
Craig Topper5bd93e92017-12-27 22:26:00 +0000958// CHECK_SKX_M32: #define __PKU__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000959// CHECK_SKX_M32: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +0000960// CHECK_SKX_M32: #define __PRFCHW__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000961// CHECK_SKX_M32: #define __RDRND__ 1
Craig Topperc0b4aba2018-01-19 00:28:42 +0000962// CHECK_SKX_M32: #define __RDSEED__ 1
Gabor Buella59665072018-04-10 15:03:03 +0000963// CHECK_SKX_M32-NOT: #define __SGX__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000964// CHECK_SKX_M32: #define __SSE2__ 1
965// CHECK_SKX_M32: #define __SSE3__ 1
966// CHECK_SKX_M32: #define __SSE4_1__ 1
967// CHECK_SKX_M32: #define __SSE4_2__ 1
968// CHECK_SKX_M32: #define __SSE__ 1
969// CHECK_SKX_M32: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +0000970// CHECK_SKX_M32: #define __XSAVEC__ 1
971// CHECK_SKX_M32: #define __XSAVEOPT__ 1
972// CHECK_SKX_M32: #define __XSAVES__ 1
973// CHECK_SKX_M32: #define __XSAVE__ 1
Craig Topper222c1722017-11-19 02:55:14 +0000974// CHECK_SKX_M32: #define __corei7 1
975// CHECK_SKX_M32: #define __corei7__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000976// CHECK_SKX_M32: #define __i386 1
977// CHECK_SKX_M32: #define __i386__ 1
Craig Topper222c1722017-11-19 02:55:14 +0000978// CHECK_SKX_M32: #define __tune_corei7__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000979// CHECK_SKX_M32: #define i386 1
980
Elena Demikhovskya89df0c2016-02-21 07:41:23 +0000981// RUN: %clang -march=skylake-avx512 -m64 -E -dM %s -o - 2>&1 \
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000982// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +0000983// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SKX_M64
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000984// CHECK_SKX_M64: #define __AES__ 1
985// CHECK_SKX_M64: #define __AVX2__ 1
986// CHECK_SKX_M64: #define __AVX512BW__ 1
987// CHECK_SKX_M64: #define __AVX512CD__ 1
988// CHECK_SKX_M64: #define __AVX512DQ__ 1
989// CHECK_SKX_M64: #define __AVX512F__ 1
990// CHECK_SKX_M64: #define __AVX512VL__ 1
991// CHECK_SKX_M64: #define __AVX__ 1
992// CHECK_SKX_M64: #define __BMI2__ 1
993// CHECK_SKX_M64: #define __BMI__ 1
Craig Topper78b47872017-02-08 06:48:58 +0000994// CHECK_SKX_M64: #define __CLFLUSHOPT__ 1
Craig Topper8c708cf2017-02-08 07:36:58 +0000995// CHECK_SKX_M64: #define __CLWB__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +0800996// CHECK_SKX_M64: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +0800997// CHECK_SKX_M64: #define __EVEX512__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +0000998// CHECK_SKX_M64: #define __F16C__ 1
999// CHECK_SKX_M64: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +00001000// CHECK_SKX_M64: #define __INVPCID__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +00001001// CHECK_SKX_M64: #define __LZCNT__ 1
1002// CHECK_SKX_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001003// CHECK_SKX_M64: #define __MOVBE__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +00001004// CHECK_SKX_M64: #define __PCLMUL__ 1
Craig Topper5bd93e92017-12-27 22:26:00 +00001005// CHECK_SKX_M64: #define __PKU__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +00001006// CHECK_SKX_M64: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +00001007// CHECK_SKX_M64: #define __PRFCHW__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +00001008// CHECK_SKX_M64: #define __RDRND__ 1
Craig Topperc0b4aba2018-01-19 00:28:42 +00001009// CHECK_SKX_M64: #define __RDSEED__ 1
Gabor Buella59665072018-04-10 15:03:03 +00001010// CHECK_SKX_M64-NOT: #define __SGX__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +00001011// CHECK_SKX_M64: #define __SSE2_MATH__ 1
1012// CHECK_SKX_M64: #define __SSE2__ 1
1013// CHECK_SKX_M64: #define __SSE3__ 1
1014// CHECK_SKX_M64: #define __SSE4_1__ 1
1015// CHECK_SKX_M64: #define __SSE4_2__ 1
1016// CHECK_SKX_M64: #define __SSE_MATH__ 1
1017// CHECK_SKX_M64: #define __SSE__ 1
1018// CHECK_SKX_M64: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00001019// CHECK_SKX_M64: #define __XSAVEC__ 1
1020// CHECK_SKX_M64: #define __XSAVEOPT__ 1
1021// CHECK_SKX_M64: #define __XSAVES__ 1
1022// CHECK_SKX_M64: #define __XSAVE__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +00001023// CHECK_SKX_M64: #define __amd64 1
1024// CHECK_SKX_M64: #define __amd64__ 1
Craig Topper222c1722017-11-19 02:55:14 +00001025// CHECK_SKX_M64: #define __corei7 1
1026// CHECK_SKX_M64: #define __corei7__ 1
1027// CHECK_SKX_M64: #define __tune_corei7__ 1
Robert Khasanov3b6616c2014-07-30 13:53:40 +00001028// CHECK_SKX_M64: #define __x86_64 1
1029// CHECK_SKX_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001030
Craig Topper5bb1bf62018-11-27 18:05:14 +00001031// RUN: %clang -march=cascadelake -m32 -E -dM %s -o - 2>&1 \
1032// RUN: -target i386-unknown-linux \
1033// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CLX_M32
1034// CHECK_CLX_M32: #define __AES__ 1
1035// CHECK_CLX_M32: #define __AVX2__ 1
1036// CHECK_CLX_M32: #define __AVX512BW__ 1
1037// CHECK_CLX_M32: #define __AVX512CD__ 1
1038// CHECK_CLX_M32: #define __AVX512DQ__ 1
1039// CHECK_CLX_M32: #define __AVX512F__ 1
1040// CHECK_CLX_M32: #define __AVX512VL__ 1
1041// CHECK_CLX_M32: #define __AVX512VNNI__ 1
1042// CHECK_CLX_M32: #define __AVX__ 1
1043// CHECK_CLX_M32: #define __BMI2__ 1
1044// CHECK_CLX_M32: #define __BMI__ 1
1045// CHECK_CLX_M32: #define __CLFLUSHOPT__ 1
1046// CHECK_CLX_M32: #define __CLWB__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08001047// CHECK_CLX_M32: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08001048// CHECK_CLX_M32: #define __EVEX512__ 1
Craig Topper5bb1bf62018-11-27 18:05:14 +00001049// CHECK_CLX_M32: #define __F16C__ 1
1050// CHECK_CLX_M32: #define __FMA__ 1
1051// CHECK_CLX_M32: #define __INVPCID__ 1
1052// CHECK_CLX_M32: #define __LZCNT__ 1
1053// CHECK_CLX_M32: #define __MMX__ 1
1054// CHECK_CLX_M32: #define __MOVBE__ 1
Craig Topper5bb1bf62018-11-27 18:05:14 +00001055// CHECK_CLX_M32: #define __PCLMUL__ 1
1056// CHECK_CLX_M32: #define __PKU__ 1
1057// CHECK_CLX_M32: #define __POPCNT__ 1
1058// CHECK_CLX_M32: #define __PRFCHW__ 1
1059// CHECK_CLX_M32: #define __RDRND__ 1
1060// CHECK_CLX_M32: #define __RDSEED__ 1
1061// CHECK_CLX_M32-NOT: #define __SGX__ 1
1062// CHECK_CLX_M32: #define __SSE2__ 1
1063// CHECK_CLX_M32: #define __SSE3__ 1
1064// CHECK_CLX_M32: #define __SSE4_1__ 1
1065// CHECK_CLX_M32: #define __SSE4_2__ 1
1066// CHECK_CLX_M32: #define __SSE__ 1
1067// CHECK_CLX_M32: #define __SSSE3__ 1
1068// CHECK_CLX_M32: #define __XSAVEC__ 1
1069// CHECK_CLX_M32: #define __XSAVEOPT__ 1
1070// CHECK_CLX_M32: #define __XSAVES__ 1
1071// CHECK_CLX_M32: #define __XSAVE__ 1
1072// CHECK_CLX_M32: #define __corei7 1
1073// CHECK_CLX_M32: #define __corei7__ 1
1074// CHECK_CLX_M32: #define __i386 1
1075// CHECK_CLX_M32: #define __i386__ 1
1076// CHECK_CLX_M32: #define __tune_corei7__ 1
1077// CHECK_CLX_M32: #define i386 1
1078
1079// RUN: %clang -march=cascadelake -m64 -E -dM %s -o - 2>&1 \
1080// RUN: -target i386-unknown-linux \
1081// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CLX_M64
1082// CHECK_CLX_M64: #define __AES__ 1
1083// CHECK_CLX_M64: #define __AVX2__ 1
1084// CHECK_CLX_M64: #define __AVX512BW__ 1
1085// CHECK_CLX_M64: #define __AVX512CD__ 1
1086// CHECK_CLX_M64: #define __AVX512DQ__ 1
1087// CHECK_CLX_M64: #define __AVX512F__ 1
1088// CHECK_CLX_M64: #define __AVX512VL__ 1
1089// CHECK_CLX_M64: #define __AVX512VNNI__ 1
1090// CHECK_CLX_M64: #define __AVX__ 1
1091// CHECK_CLX_M64: #define __BMI2__ 1
1092// CHECK_CLX_M64: #define __BMI__ 1
1093// CHECK_CLX_M64: #define __CLFLUSHOPT__ 1
1094// CHECK_CLX_M64: #define __CLWB__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08001095// CHECK_CLX_M64: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08001096// CHECK_CLX_M64: #define __EVEX512__ 1
Craig Topper5bb1bf62018-11-27 18:05:14 +00001097// CHECK_CLX_M64: #define __F16C__ 1
1098// CHECK_CLX_M64: #define __FMA__ 1
1099// CHECK_CLX_M64: #define __INVPCID__ 1
1100// CHECK_CLX_M64: #define __LZCNT__ 1
1101// CHECK_CLX_M64: #define __MMX__ 1
1102// CHECK_CLX_M64: #define __MOVBE__ 1
Craig Topper5bb1bf62018-11-27 18:05:14 +00001103// CHECK_CLX_M64: #define __PCLMUL__ 1
1104// CHECK_CLX_M64: #define __PKU__ 1
1105// CHECK_CLX_M64: #define __POPCNT__ 1
1106// CHECK_CLX_M64: #define __PRFCHW__ 1
1107// CHECK_CLX_M64: #define __RDRND__ 1
1108// CHECK_CLX_M64: #define __RDSEED__ 1
1109// CHECK_CLX_M64-NOT: #define __SGX__ 1
1110// CHECK_CLX_M64: #define __SSE2_MATH__ 1
1111// CHECK_CLX_M64: #define __SSE2__ 1
1112// CHECK_CLX_M64: #define __SSE3__ 1
1113// CHECK_CLX_M64: #define __SSE4_1__ 1
1114// CHECK_CLX_M64: #define __SSE4_2__ 1
1115// CHECK_CLX_M64: #define __SSE_MATH__ 1
1116// CHECK_CLX_M64: #define __SSE__ 1
1117// CHECK_CLX_M64: #define __SSSE3__ 1
1118// CHECK_CLX_M64: #define __XSAVEC__ 1
1119// CHECK_CLX_M64: #define __XSAVEOPT__ 1
1120// CHECK_CLX_M64: #define __XSAVES__ 1
1121// CHECK_CLX_M64: #define __XSAVE__ 1
1122// CHECK_CLX_M64: #define __amd64 1
1123// CHECK_CLX_M64: #define __amd64__ 1
1124// CHECK_CLX_M64: #define __corei7 1
1125// CHECK_CLX_M64: #define __corei7__ 1
1126// CHECK_CLX_M64: #define __tune_corei7__ 1
1127// CHECK_CLX_M64: #define __x86_64 1
1128// CHECK_CLX_M64: #define __x86_64__ 1
1129
Pengfei Wang30bcda82019-06-07 08:53:37 +00001130// RUN: %clang -march=cooperlake -m32 -E -dM %s -o - 2>&1 \
1131// RUN: -target i386-unknown-linux \
1132// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CPX_M32
1133// CHECK_CPX_M32: #define __AES__ 1
1134// CHECK_CPX_M32: #define __AVX2__ 1
1135// CHECK_CPX_M32: #define __AVX512BF16__ 1
1136// CHECK_CPX_M32: #define __AVX512BW__ 1
1137// CHECK_CPX_M32: #define __AVX512CD__ 1
1138// CHECK_CPX_M32: #define __AVX512DQ__ 1
1139// CHECK_CPX_M32: #define __AVX512F__ 1
1140// CHECK_CPX_M32: #define __AVX512VL__ 1
1141// CHECK_CPX_M32: #define __AVX512VNNI__ 1
1142// CHECK_CPX_M32: #define __AVX__ 1
1143// CHECK_CPX_M32: #define __BMI2__ 1
1144// CHECK_CPX_M32: #define __BMI__ 1
1145// CHECK_CPX_M32: #define __CLFLUSHOPT__ 1
1146// CHECK_CPX_M32: #define __CLWB__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08001147// CHECK_CPX_M32: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08001148// CHECK_CPX_M32: #define __EVEX512__ 1
Pengfei Wang30bcda82019-06-07 08:53:37 +00001149// CHECK_CPX_M32: #define __F16C__ 1
1150// CHECK_CPX_M32: #define __FMA__ 1
1151// CHECK_CPX_M32: #define __INVPCID__ 1
1152// CHECK_CPX_M32: #define __LZCNT__ 1
1153// CHECK_CPX_M32: #define __MMX__ 1
1154// CHECK_CPX_M32: #define __MOVBE__ 1
Pengfei Wang30bcda82019-06-07 08:53:37 +00001155// CHECK_CPX_M32: #define __PCLMUL__ 1
1156// CHECK_CPX_M32: #define __PKU__ 1
1157// CHECK_CPX_M32: #define __POPCNT__ 1
1158// CHECK_CPX_M32: #define __PRFCHW__ 1
1159// CHECK_CPX_M32: #define __RDRND__ 1
1160// CHECK_CPX_M32: #define __RDSEED__ 1
1161// CHECK_CPX_M32-NOT: #define __SGX__ 1
1162// CHECK_CPX_M32: #define __SSE2__ 1
1163// CHECK_CPX_M32: #define __SSE3__ 1
1164// CHECK_CPX_M32: #define __SSE4_1__ 1
1165// CHECK_CPX_M32: #define __SSE4_2__ 1
1166// CHECK_CPX_M32: #define __SSE__ 1
1167// CHECK_CPX_M32: #define __SSSE3__ 1
1168// CHECK_CPX_M32: #define __XSAVEC__ 1
1169// CHECK_CPX_M32: #define __XSAVEOPT__ 1
1170// CHECK_CPX_M32: #define __XSAVES__ 1
1171// CHECK_CPX_M32: #define __XSAVE__ 1
1172// CHECK_CPX_M32: #define __corei7 1
1173// CHECK_CPX_M32: #define __corei7__ 1
1174// CHECK_CPX_M32: #define __i386 1
1175// CHECK_CPX_M32: #define __i386__ 1
1176// CHECK_CPX_M32: #define __tune_corei7__ 1
1177// CHECK_CPX_M32: #define i386 1
1178
1179// RUN: %clang -march=cooperlake -m64 -E -dM %s -o - 2>&1 \
1180// RUN: -target i386-unknown-linux \
1181// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CPX_M64
1182// CHECK_CPX_M64: #define __AES__ 1
1183// CHECK_CPX_M64: #define __AVX2__ 1
1184// CHECK_CPX_M64: #define __AVX512BF16__ 1
1185// CHECK_CPX_M64: #define __AVX512BW__ 1
1186// CHECK_CPX_M64: #define __AVX512CD__ 1
1187// CHECK_CPX_M64: #define __AVX512DQ__ 1
1188// CHECK_CPX_M64: #define __AVX512F__ 1
1189// CHECK_CPX_M64: #define __AVX512VL__ 1
1190// CHECK_CPX_M64: #define __AVX512VNNI__ 1
1191// CHECK_CPX_M64: #define __AVX__ 1
1192// CHECK_CPX_M64: #define __BMI2__ 1
1193// CHECK_CPX_M64: #define __BMI__ 1
1194// CHECK_CPX_M64: #define __CLFLUSHOPT__ 1
1195// CHECK_CPX_M64: #define __CLWB__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08001196// CHECK_CPX_M64: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08001197// CHECK_CPX_M64: #define __EVEX512__ 1
Pengfei Wang30bcda82019-06-07 08:53:37 +00001198// CHECK_CPX_M64: #define __F16C__ 1
1199// CHECK_CPX_M64: #define __FMA__ 1
1200// CHECK_CPX_M64: #define __INVPCID__ 1
1201// CHECK_CPX_M64: #define __LZCNT__ 1
1202// CHECK_CPX_M64: #define __MMX__ 1
1203// CHECK_CPX_M64: #define __MOVBE__ 1
Pengfei Wang30bcda82019-06-07 08:53:37 +00001204// CHECK_CPX_M64: #define __PCLMUL__ 1
1205// CHECK_CPX_M64: #define __PKU__ 1
1206// CHECK_CPX_M64: #define __POPCNT__ 1
1207// CHECK_CPX_M64: #define __PRFCHW__ 1
1208// CHECK_CPX_M64: #define __RDRND__ 1
1209// CHECK_CPX_M64: #define __RDSEED__ 1
1210// CHECK_CPX_M64-NOT: #define __SGX__ 1
1211// CHECK_CPX_M64: #define __SSE2_MATH__ 1
1212// CHECK_CPX_M64: #define __SSE2__ 1
1213// CHECK_CPX_M64: #define __SSE3__ 1
1214// CHECK_CPX_M64: #define __SSE4_1__ 1
1215// CHECK_CPX_M64: #define __SSE4_2__ 1
1216// CHECK_CPX_M64: #define __SSE_MATH__ 1
1217// CHECK_CPX_M64: #define __SSE__ 1
1218// CHECK_CPX_M64: #define __SSSE3__ 1
1219// CHECK_CPX_M64: #define __XSAVEC__ 1
1220// CHECK_CPX_M64: #define __XSAVEOPT__ 1
1221// CHECK_CPX_M64: #define __XSAVES__ 1
1222// CHECK_CPX_M64: #define __XSAVE__ 1
1223// CHECK_CPX_M64: #define __amd64 1
1224// CHECK_CPX_M64: #define __amd64__ 1
1225// CHECK_CPX_M64: #define __corei7 1
1226// CHECK_CPX_M64: #define __corei7__ 1
1227// CHECK_CPX_M64: #define __tune_corei7__ 1
1228// CHECK_CPX_M64: #define __x86_64 1
1229// CHECK_CPX_M64: #define __x86_64__ 1
1230
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001231// RUN: %clang -march=cannonlake -m32 -E -dM %s -o - 2>&1 \
1232// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001233// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CNL_M32
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001234// CHECK_CNL_M32: #define __AES__ 1
1235// CHECK_CNL_M32: #define __AVX2__ 1
1236// CHECK_CNL_M32: #define __AVX512BW__ 1
1237// CHECK_CNL_M32: #define __AVX512CD__ 1
1238// CHECK_CNL_M32: #define __AVX512DQ__ 1
1239// CHECK_CNL_M32: #define __AVX512F__ 1
Craig Topperb4f83a02016-02-29 06:51:38 +00001240// CHECK_CNL_M32: #define __AVX512IFMA__ 1
1241// CHECK_CNL_M32: #define __AVX512VBMI__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001242// CHECK_CNL_M32: #define __AVX512VL__ 1
1243// CHECK_CNL_M32: #define __AVX__ 1
1244// CHECK_CNL_M32: #define __BMI2__ 1
1245// CHECK_CNL_M32: #define __BMI__ 1
Craig Topper78b47872017-02-08 06:48:58 +00001246// CHECK_CNL_M32: #define __CLFLUSHOPT__ 1
Craig Topper94a940d2018-02-21 00:16:50 +00001247// CHECK_CNL_M32-NOT: #define __CLWB__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08001248// CHECK_CNL_M32: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08001249// CHECK_CNL_M32: #define __EVEX512__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001250// CHECK_CNL_M32: #define __F16C__ 1
1251// CHECK_CNL_M32: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +00001252// CHECK_CNL_M32: #define __INVPCID__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001253// CHECK_CNL_M32: #define __LZCNT__ 1
1254// CHECK_CNL_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001255// CHECK_CNL_M32: #define __MOVBE__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001256// CHECK_CNL_M32: #define __PCLMUL__ 1
Craig Topperd2fe244a2017-12-29 06:39:16 +00001257// CHECK_CNL_M32: #define __PKU__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001258// CHECK_CNL_M32: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +00001259// CHECK_CNL_M32: #define __PRFCHW__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001260// CHECK_CNL_M32: #define __RDRND__ 1
Craig Topperc0b4aba2018-01-19 00:28:42 +00001261// CHECK_CNL_M32: #define __RDSEED__ 1
Craig Topper204ecff2017-02-08 08:23:17 +00001262// CHECK_CNL_M32: #define __SGX__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001263// CHECK_CNL_M32: #define __SHA__ 1
1264// CHECK_CNL_M32: #define __SSE2__ 1
1265// CHECK_CNL_M32: #define __SSE3__ 1
1266// CHECK_CNL_M32: #define __SSE4_1__ 1
1267// CHECK_CNL_M32: #define __SSE4_2__ 1
1268// CHECK_CNL_M32: #define __SSE__ 1
1269// CHECK_CNL_M32: #define __SSSE3__ 1
1270// CHECK_CNL_M32: #define __XSAVEC__ 1
1271// CHECK_CNL_M32: #define __XSAVEOPT__ 1
1272// CHECK_CNL_M32: #define __XSAVES__ 1
1273// CHECK_CNL_M32: #define __XSAVE__ 1
Craig Topper222c1722017-11-19 02:55:14 +00001274// CHECK_CNL_M32: #define __corei7 1
1275// CHECK_CNL_M32: #define __corei7__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001276// CHECK_CNL_M32: #define __i386 1
1277// CHECK_CNL_M32: #define __i386__ 1
Craig Topper222c1722017-11-19 02:55:14 +00001278// CHECK_CNL_M32: #define __tune_corei7__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001279// CHECK_CNL_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00001280
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001281// RUN: %clang -march=cannonlake -m64 -E -dM %s -o - 2>&1 \
1282// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00001283// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_CNL_M64
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001284// CHECK_CNL_M64: #define __AES__ 1
1285// CHECK_CNL_M64: #define __AVX2__ 1
1286// CHECK_CNL_M64: #define __AVX512BW__ 1
1287// CHECK_CNL_M64: #define __AVX512CD__ 1
1288// CHECK_CNL_M64: #define __AVX512DQ__ 1
1289// CHECK_CNL_M64: #define __AVX512F__ 1
Craig Topperb4f83a02016-02-29 06:51:38 +00001290// CHECK_CNL_M64: #define __AVX512IFMA__ 1
1291// CHECK_CNL_M64: #define __AVX512VBMI__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001292// CHECK_CNL_M64: #define __AVX512VL__ 1
1293// CHECK_CNL_M64: #define __AVX__ 1
1294// CHECK_CNL_M64: #define __BMI2__ 1
1295// CHECK_CNL_M64: #define __BMI__ 1
Craig Topper78b47872017-02-08 06:48:58 +00001296// CHECK_CNL_M64: #define __CLFLUSHOPT__ 1
Craig Topper94a940d2018-02-21 00:16:50 +00001297// CHECK_CNL_M64-NOT: #define __CLWB__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08001298// CHECK_CNL_M64: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08001299// CHECK_CNL_M64: #define __EVEX512__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001300// CHECK_CNL_M64: #define __F16C__ 1
1301// CHECK_CNL_M64: #define __FMA__ 1
Gabor Buella078bb992018-05-25 06:34:42 +00001302// CHECK_CNL_M64: #define __INVPCID__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001303// CHECK_CNL_M64: #define __LZCNT__ 1
1304// CHECK_CNL_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001305// CHECK_CNL_M64: #define __MOVBE__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001306// CHECK_CNL_M64: #define __PCLMUL__ 1
Craig Topperd2fe244a2017-12-29 06:39:16 +00001307// CHECK_CNL_M64: #define __PKU__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001308// CHECK_CNL_M64: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +00001309// CHECK_CNL_M64: #define __PRFCHW__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001310// CHECK_CNL_M64: #define __RDRND__ 1
Craig Topperc0b4aba2018-01-19 00:28:42 +00001311// CHECK_CNL_M64: #define __RDSEED__ 1
Craig Topper204ecff2017-02-08 08:23:17 +00001312// CHECK_CNL_M64: #define __SGX__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001313// CHECK_CNL_M64: #define __SHA__ 1
1314// CHECK_CNL_M64: #define __SSE2__ 1
1315// CHECK_CNL_M64: #define __SSE3__ 1
1316// CHECK_CNL_M64: #define __SSE4_1__ 1
1317// CHECK_CNL_M64: #define __SSE4_2__ 1
1318// CHECK_CNL_M64: #define __SSE__ 1
1319// CHECK_CNL_M64: #define __SSSE3__ 1
1320// CHECK_CNL_M64: #define __XSAVEC__ 1
1321// CHECK_CNL_M64: #define __XSAVEOPT__ 1
1322// CHECK_CNL_M64: #define __XSAVES__ 1
1323// CHECK_CNL_M64: #define __XSAVE__ 1
James Y Knight3508b222016-04-01 21:33:20 +00001324// CHECK_CNL_M64: #define __amd64 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001325// CHECK_CNL_M64: #define __amd64__ 1
Craig Topper222c1722017-11-19 02:55:14 +00001326// CHECK_CNL_M64: #define __corei7 1
1327// CHECK_CNL_M64: #define __corei7__ 1
1328// CHECK_CNL_M64: #define __tune_corei7__ 1
Elena Demikhovskya89df0c2016-02-21 07:41:23 +00001329// CHECK_CNL_M64: #define __x86_64 1
1330// CHECK_CNL_M64: #define __x86_64__ 1
1331
Gabor Buella8701b182018-04-10 18:58:26 +00001332// RUN: %clang -march=icelake-client -m32 -E -dM %s -o - 2>&1 \
Craig Topper546cee42017-11-19 02:55:15 +00001333// RUN: -target i386-unknown-linux \
Freddy Ye3fc1fe82021-04-13 09:24:34 +08001334// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_ICL_M32,CHECK_ICL_M32S
1335// RUN: %clang -march=rocketlake -m32 -E -dM %s -o - 2>&1 \
1336// RUN: -target i386-unknown-linux \
1337// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_ICL_M32,CHECK_RKL_M32S
Craig Topper546cee42017-11-19 02:55:15 +00001338// CHECK_ICL_M32: #define __AES__ 1
1339// CHECK_ICL_M32: #define __AVX2__ 1
Coby Tayree22685762017-12-27 10:01:00 +00001340// CHECK_ICL_M32: #define __AVX512BITALG__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001341// CHECK_ICL_M32: #define __AVX512BW__ 1
1342// CHECK_ICL_M32: #define __AVX512CD__ 1
1343// CHECK_ICL_M32: #define __AVX512DQ__ 1
1344// CHECK_ICL_M32: #define __AVX512F__ 1
1345// CHECK_ICL_M32: #define __AVX512IFMA__ 1
Coby Tayreea09663a2017-12-27 11:25:07 +00001346// CHECK_ICL_M32: #define __AVX512VBMI2__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001347// CHECK_ICL_M32: #define __AVX512VBMI__ 1
1348// CHECK_ICL_M32: #define __AVX512VL__ 1
Coby Tayree3d9c88c2017-12-27 10:37:51 +00001349// CHECK_ICL_M32: #define __AVX512VNNI__ 1
Craig Topperb36447d2017-12-27 22:25:59 +00001350// CHECK_ICL_M32: #define __AVX512VPOPCNTDQ__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001351// CHECK_ICL_M32: #define __AVX__ 1
1352// CHECK_ICL_M32: #define __BMI2__ 1
1353// CHECK_ICL_M32: #define __BMI__ 1
1354// CHECK_ICL_M32: #define __CLFLUSHOPT__ 1
Freddy Ye5cb47be2021-04-12 10:36:08 +08001355// CHECK_ICL_M32-NOT: #define __CLWB__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08001356// CHECK_ICL_M32: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08001357// CHECK_ICL_M32: #define __EVEX512__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001358// CHECK_ICL_M32: #define __F16C__ 1
1359// CHECK_ICL_M32: #define __FMA__ 1
Coby Tayreef4811eb2017-12-27 08:37:47 +00001360// CHECK_ICL_M32: #define __GFNI__ 1
Gabor Buella078bb992018-05-25 06:34:42 +00001361// CHECK_ICL_M32: #define __INVPCID__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001362// CHECK_ICL_M32: #define __LZCNT__ 1
1363// CHECK_ICL_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001364// CHECK_ICL_M32: #define __MOVBE__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001365// CHECK_ICL_M32: #define __PCLMUL__ 1
Craig Topperd2fe244a2017-12-29 06:39:16 +00001366// CHECK_ICL_M32: #define __PKU__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001367// CHECK_ICL_M32: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +00001368// CHECK_ICL_M32: #define __PRFCHW__ 1
Craig Topper8cdb9492018-01-20 18:36:52 +00001369// CHECK_ICL_M32: #define __RDPID__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001370// CHECK_ICL_M32: #define __RDRND__ 1
Craig Topperc0b4aba2018-01-19 00:28:42 +00001371// CHECK_ICL_M32: #define __RDSEED__ 1
Freddy Ye3fc1fe82021-04-13 09:24:34 +08001372// CHECK_ICL_M32S: #define __SGX__ 1
1373// CHECK_RKL_M32S-NOT: #define __SGX__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001374// CHECK_ICL_M32: #define __SHA__ 1
1375// CHECK_ICL_M32: #define __SSE2__ 1
1376// CHECK_ICL_M32: #define __SSE3__ 1
1377// CHECK_ICL_M32: #define __SSE4_1__ 1
1378// CHECK_ICL_M32: #define __SSE4_2__ 1
1379// CHECK_ICL_M32: #define __SSE__ 1
1380// CHECK_ICL_M32: #define __SSSE3__ 1
Coby Tayreea1e5f0c2017-12-27 08:16:54 +00001381// CHECK_ICL_M32: #define __VAES__ 1
Coby Tayreecf96c872017-12-27 09:00:31 +00001382// CHECK_ICL_M32: #define __VPCLMULQDQ__ 1
Gabor Buellaa0520162018-04-11 20:09:09 +00001383// CHECK_ICL_M32-NOT: #define __WBNOINVD__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001384// CHECK_ICL_M32: #define __XSAVEC__ 1
1385// CHECK_ICL_M32: #define __XSAVEOPT__ 1
1386// CHECK_ICL_M32: #define __XSAVES__ 1
1387// CHECK_ICL_M32: #define __XSAVE__ 1
1388// CHECK_ICL_M32: #define __corei7 1
1389// CHECK_ICL_M32: #define __corei7__ 1
1390// CHECK_ICL_M32: #define __i386 1
1391// CHECK_ICL_M32: #define __i386__ 1
1392// CHECK_ICL_M32: #define __tune_corei7__ 1
1393// CHECK_ICL_M32: #define i386 1
Gabor Buella8701b182018-04-10 18:58:26 +00001394
1395// RUN: %clang -march=icelake-client -m64 -E -dM %s -o - 2>&1 \
Craig Topper546cee42017-11-19 02:55:15 +00001396// RUN: -target i386-unknown-linux \
Freddy Ye3fc1fe82021-04-13 09:24:34 +08001397// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_ICL_M64,CHECK_ICL_M64S
1398// RUN: %clang -march=rocketlake -m64 -E -dM %s -o - 2>&1 \
1399// RUN: -target i386-unknown-linux \
1400// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_ICL_M64,CHECK_RKL_M64S
Craig Topper546cee42017-11-19 02:55:15 +00001401// CHECK_ICL_M64: #define __AES__ 1
1402// CHECK_ICL_M64: #define __AVX2__ 1
Coby Tayree22685762017-12-27 10:01:00 +00001403// CHECK_ICL_M64: #define __AVX512BITALG__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001404// CHECK_ICL_M64: #define __AVX512BW__ 1
1405// CHECK_ICL_M64: #define __AVX512CD__ 1
1406// CHECK_ICL_M64: #define __AVX512DQ__ 1
1407// CHECK_ICL_M64: #define __AVX512F__ 1
1408// CHECK_ICL_M64: #define __AVX512IFMA__ 1
Coby Tayreea09663a2017-12-27 11:25:07 +00001409// CHECK_ICL_M64: #define __AVX512VBMI2__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001410// CHECK_ICL_M64: #define __AVX512VBMI__ 1
1411// CHECK_ICL_M64: #define __AVX512VL__ 1
Coby Tayree3d9c88c2017-12-27 10:37:51 +00001412// CHECK_ICL_M64: #define __AVX512VNNI__ 1
Craig Topperb36447d2017-12-27 22:25:59 +00001413// CHECK_ICL_M64: #define __AVX512VPOPCNTDQ__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001414// CHECK_ICL_M64: #define __AVX__ 1
1415// CHECK_ICL_M64: #define __BMI2__ 1
1416// CHECK_ICL_M64: #define __BMI__ 1
1417// CHECK_ICL_M64: #define __CLFLUSHOPT__ 1
Freddy Ye5cb47be2021-04-12 10:36:08 +08001418// CHECK_ICL_M64-NOT: #define __CLWB__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08001419// CHECK_ICL_M64: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08001420// CHECK_ICL_M64: #define __EVEX512__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001421// CHECK_ICL_M64: #define __F16C__ 1
1422// CHECK_ICL_M64: #define __FMA__ 1
Coby Tayreef4811eb2017-12-27 08:37:47 +00001423// CHECK_ICL_M64: #define __GFNI__ 1
Gabor Buella078bb992018-05-25 06:34:42 +00001424// CHECK_ICL_M64: #define __INVPCID__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001425// CHECK_ICL_M64: #define __LZCNT__ 1
1426// CHECK_ICL_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001427// CHECK_ICL_M64: #define __MOVBE__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001428// CHECK_ICL_M64: #define __PCLMUL__ 1
Craig Topperd2fe244a2017-12-29 06:39:16 +00001429// CHECK_ICL_M64: #define __PKU__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001430// CHECK_ICL_M64: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +00001431// CHECK_ICL_M64: #define __PRFCHW__ 1
Craig Topper8cdb9492018-01-20 18:36:52 +00001432// CHECK_ICL_M64: #define __RDPID__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001433// CHECK_ICL_M64: #define __RDRND__ 1
Craig Topperc0b4aba2018-01-19 00:28:42 +00001434// CHECK_ICL_M64: #define __RDSEED__ 1
Freddy Ye3fc1fe82021-04-13 09:24:34 +08001435// CHECK_ICL_M64S: #define __SGX__ 1
1436// CHECK_RKL_M64S-NOT: #define __SGX__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001437// CHECK_ICL_M64: #define __SHA__ 1
1438// CHECK_ICL_M64: #define __SSE2__ 1
1439// CHECK_ICL_M64: #define __SSE3__ 1
1440// CHECK_ICL_M64: #define __SSE4_1__ 1
1441// CHECK_ICL_M64: #define __SSE4_2__ 1
1442// CHECK_ICL_M64: #define __SSE__ 1
1443// CHECK_ICL_M64: #define __SSSE3__ 1
Coby Tayreea1e5f0c2017-12-27 08:16:54 +00001444// CHECK_ICL_M64: #define __VAES__ 1
Coby Tayreecf96c872017-12-27 09:00:31 +00001445// CHECK_ICL_M64: #define __VPCLMULQDQ__ 1
Gabor Buellaa0520162018-04-11 20:09:09 +00001446// CHECK_ICL_M64-NOT: #define __WBNOINVD__ 1
Craig Topper546cee42017-11-19 02:55:15 +00001447// CHECK_ICL_M64: #define __XSAVEC__ 1
1448// CHECK_ICL_M64: #define __XSAVEOPT__ 1
1449// CHECK_ICL_M64: #define __XSAVES__ 1
1450// CHECK_ICL_M64: #define __XSAVE__ 1
1451// CHECK_ICL_M64: #define __amd64 1
1452// CHECK_ICL_M64: #define __amd64__ 1
1453// CHECK_ICL_M64: #define __corei7 1
1454// CHECK_ICL_M64: #define __corei7__ 1
1455// CHECK_ICL_M64: #define __tune_corei7__ 1
1456// CHECK_ICL_M64: #define __x86_64 1
1457// CHECK_ICL_M64: #define __x86_64__ 1
1458
Gabor Buella8701b182018-04-10 18:58:26 +00001459// RUN: %clang -march=icelake-server -m32 -E -dM %s -o - 2>&1 \
1460// RUN: -target i386-unknown-linux \
1461// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ICX_M32
1462// CHECK_ICX_M32: #define __AES__ 1
1463// CHECK_ICX_M32: #define __AVX2__ 1
1464// CHECK_ICX_M32: #define __AVX512BITALG__ 1
1465// CHECK_ICX_M32: #define __AVX512BW__ 1
1466// CHECK_ICX_M32: #define __AVX512CD__ 1
1467// CHECK_ICX_M32: #define __AVX512DQ__ 1
1468// CHECK_ICX_M32: #define __AVX512F__ 1
1469// CHECK_ICX_M32: #define __AVX512IFMA__ 1
1470// CHECK_ICX_M32: #define __AVX512VBMI2__ 1
1471// CHECK_ICX_M32: #define __AVX512VBMI__ 1
1472// CHECK_ICX_M32: #define __AVX512VL__ 1
1473// CHECK_ICX_M32: #define __AVX512VNNI__ 1
1474// CHECK_ICX_M32: #define __AVX512VPOPCNTDQ__ 1
1475// CHECK_ICX_M32: #define __AVX__ 1
1476// CHECK_ICX_M32: #define __BMI2__ 1
1477// CHECK_ICX_M32: #define __BMI__ 1
1478// CHECK_ICX_M32: #define __CLFLUSHOPT__ 1
1479// CHECK_ICX_M32: #define __CLWB__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08001480// CHECK_ICX_M32: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08001481// CHECK_ICX_M32: #define __EVEX512__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001482// CHECK_ICX_M32: #define __F16C__ 1
1483// CHECK_ICX_M32: #define __FMA__ 1
1484// CHECK_ICX_M32: #define __GFNI__ 1
Gabor Buella078bb992018-05-25 06:34:42 +00001485// CHECK_ICX_M32: #define __INVPCID__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001486// CHECK_ICX_M32: #define __LZCNT__ 1
1487// CHECK_ICX_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001488// CHECK_ICX_M32: #define __MOVBE__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001489// CHECK_ICX_M32: #define __PCLMUL__ 1
Gabor Buellab0f310d2018-05-08 06:49:41 +00001490// CHECK_ICX_M32: #define __PCONFIG__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001491// CHECK_ICX_M32: #define __PKU__ 1
1492// CHECK_ICX_M32: #define __POPCNT__ 1
1493// CHECK_ICX_M32: #define __PRFCHW__ 1
1494// CHECK_ICX_M32: #define __RDPID__ 1
1495// CHECK_ICX_M32: #define __RDRND__ 1
1496// CHECK_ICX_M32: #define __RDSEED__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001497// CHECK_ICX_M32: #define __SGX__ 1
1498// CHECK_ICX_M32: #define __SHA__ 1
1499// CHECK_ICX_M32: #define __SSE2__ 1
1500// CHECK_ICX_M32: #define __SSE3__ 1
1501// CHECK_ICX_M32: #define __SSE4_1__ 1
1502// CHECK_ICX_M32: #define __SSE4_2__ 1
1503// CHECK_ICX_M32: #define __SSE__ 1
1504// CHECK_ICX_M32: #define __SSSE3__ 1
1505// CHECK_ICX_M32: #define __VAES__ 1
1506// CHECK_ICX_M32: #define __VPCLMULQDQ__ 1
Gabor Buellaa0520162018-04-11 20:09:09 +00001507// CHECK_ICX_M32: #define __WBNOINVD__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001508// CHECK_ICX_M32: #define __XSAVEC__ 1
1509// CHECK_ICX_M32: #define __XSAVEOPT__ 1
1510// CHECK_ICX_M32: #define __XSAVES__ 1
1511// CHECK_ICX_M32: #define __XSAVE__ 1
1512// CHECK_ICX_M32: #define __corei7 1
1513// CHECK_ICX_M32: #define __corei7__ 1
1514// CHECK_ICX_M32: #define __i386 1
1515// CHECK_ICX_M32: #define __i386__ 1
1516// CHECK_ICX_M32: #define __tune_corei7__ 1
1517// CHECK_ICX_M32: #define i386 1
1518
1519// RUN: %clang -march=icelake-server -m64 -E -dM %s -o - 2>&1 \
1520// RUN: -target i386-unknown-linux \
1521// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ICX_M64
1522// CHECK_ICX_M64: #define __AES__ 1
1523// CHECK_ICX_M64: #define __AVX2__ 1
1524// CHECK_ICX_M64: #define __AVX512BITALG__ 1
1525// CHECK_ICX_M64: #define __AVX512BW__ 1
1526// CHECK_ICX_M64: #define __AVX512CD__ 1
1527// CHECK_ICX_M64: #define __AVX512DQ__ 1
1528// CHECK_ICX_M64: #define __AVX512F__ 1
1529// CHECK_ICX_M64: #define __AVX512IFMA__ 1
1530// CHECK_ICX_M64: #define __AVX512VBMI2__ 1
1531// CHECK_ICX_M64: #define __AVX512VBMI__ 1
1532// CHECK_ICX_M64: #define __AVX512VL__ 1
1533// CHECK_ICX_M64: #define __AVX512VNNI__ 1
1534// CHECK_ICX_M64: #define __AVX512VPOPCNTDQ__ 1
1535// CHECK_ICX_M64: #define __AVX__ 1
1536// CHECK_ICX_M64: #define __BMI2__ 1
1537// CHECK_ICX_M64: #define __BMI__ 1
1538// CHECK_ICX_M64: #define __CLFLUSHOPT__ 1
1539// CHECK_ICX_M64: #define __CLWB__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08001540// CHECK_ICX_M64: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08001541// CHECK_ICX_M64: #define __EVEX512__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001542// CHECK_ICX_M64: #define __F16C__ 1
1543// CHECK_ICX_M64: #define __FMA__ 1
1544// CHECK_ICX_M64: #define __GFNI__ 1
Gabor Buella078bb992018-05-25 06:34:42 +00001545// CHECK_ICX_M64: #define __INVPCID__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001546// CHECK_ICX_M64: #define __LZCNT__ 1
1547// CHECK_ICX_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00001548// CHECK_ICX_M64: #define __MOVBE__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001549// CHECK_ICX_M64: #define __PCLMUL__ 1
Gabor Buellab0f310d2018-05-08 06:49:41 +00001550// CHECK_ICX_M64: #define __PCONFIG__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001551// CHECK_ICX_M64: #define __PKU__ 1
1552// CHECK_ICX_M64: #define __POPCNT__ 1
1553// CHECK_ICX_M64: #define __PRFCHW__ 1
1554// CHECK_ICX_M64: #define __RDPID__ 1
1555// CHECK_ICX_M64: #define __RDRND__ 1
1556// CHECK_ICX_M64: #define __RDSEED__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001557// CHECK_ICX_M64: #define __SGX__ 1
1558// CHECK_ICX_M64: #define __SHA__ 1
1559// CHECK_ICX_M64: #define __SSE2__ 1
1560// CHECK_ICX_M64: #define __SSE3__ 1
1561// CHECK_ICX_M64: #define __SSE4_1__ 1
1562// CHECK_ICX_M64: #define __SSE4_2__ 1
1563// CHECK_ICX_M64: #define __SSE__ 1
1564// CHECK_ICX_M64: #define __SSSE3__ 1
1565// CHECK_ICX_M64: #define __VAES__ 1
1566// CHECK_ICX_M64: #define __VPCLMULQDQ__ 1
Gabor Buellaa0520162018-04-11 20:09:09 +00001567// CHECK_ICX_M64: #define __WBNOINVD__ 1
Gabor Buella8701b182018-04-10 18:58:26 +00001568// CHECK_ICX_M64: #define __XSAVEC__ 1
1569// CHECK_ICX_M64: #define __XSAVEOPT__ 1
1570// CHECK_ICX_M64: #define __XSAVES__ 1
1571// CHECK_ICX_M64: #define __XSAVE__ 1
1572// CHECK_ICX_M64: #define __amd64 1
1573// CHECK_ICX_M64: #define __amd64__ 1
1574// CHECK_ICX_M64: #define __corei7 1
1575// CHECK_ICX_M64: #define __corei7__ 1
1576// CHECK_ICX_M64: #define __tune_corei7__ 1
1577// CHECK_ICX_M64: #define __x86_64 1
1578// CHECK_ICX_M64: #define __x86_64__ 1
1579
Pengfei Wange28cbbd2019-08-12 01:29:46 +00001580// RUN: %clang -march=tigerlake -m32 -E -dM %s -o - 2>&1 \
1581// RUN: -target i386-unknown-linux \
1582// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_TGL_M32
1583// CHECK_TGL_M32: #define __AES__ 1
1584// CHECK_TGL_M32: #define __AVX2__ 1
1585// CHECK_TGL_M32: #define __AVX512BITALG__ 1
1586// CHECK_TGL_M32: #define __AVX512BW__ 1
1587// CHECK_TGL_M32: #define __AVX512CD__ 1
1588// CHECK_TGL_M32: #define __AVX512DQ__ 1
1589// CHECK_TGL_M32: #define __AVX512F__ 1
1590// CHECK_TGL_M32: #define __AVX512IFMA__ 1
1591// CHECK_TGL_M32: #define __AVX512VBMI2__ 1
1592// CHECK_TGL_M32: #define __AVX512VBMI__ 1
1593// CHECK_TGL_M32: #define __AVX512VL__ 1
1594// CHECK_TGL_M32: #define __AVX512VNNI__ 1
1595// CHECK_TGL_M32: #define __AVX512VP2INTERSECT__ 1
1596// CHECK_TGL_M32: #define __AVX512VPOPCNTDQ__ 1
1597// CHECK_TGL_M32: #define __AVX__ 1
1598// CHECK_TGL_M32: #define __BMI2__ 1
1599// CHECK_TGL_M32: #define __BMI__ 1
1600// CHECK_TGL_M32: #define __CLFLUSHOPT__ 1
1601// CHECK_TGL_M32: #define __CLWB__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08001602// CHECK_TGL_M32: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08001603// CHECK_TGL_M32: #define __EVEX512__ 1
Pengfei Wange28cbbd2019-08-12 01:29:46 +00001604// CHECK_TGL_M32: #define __F16C__ 1
1605// CHECK_TGL_M32: #define __FMA__ 1
1606// CHECK_TGL_M32: #define __GFNI__ 1
1607// CHECK_TGL_M32: #define __INVPCID__ 1
1608// CHECK_TGL_M32: #define __LZCNT__ 1
1609// CHECK_TGL_M32: #define __MMX__ 1
1610// CHECK_TGL_M32: #define __MOVBE__ 1
1611// CHECK_TGL_M32: #define __MOVDIR64B__ 1
1612// CHECK_TGL_M32: #define __MOVDIRI__ 1
Pengfei Wange28cbbd2019-08-12 01:29:46 +00001613// CHECK_TGL_M32: #define __PCLMUL__ 1
1614// CHECK_TGL_M32-NOT: #define __PCONFIG__ 1
1615// CHECK_TGL_M32: #define __PKU__ 1
1616// CHECK_TGL_M32: #define __POPCNT__ 1
1617// CHECK_TGL_M32: #define __PRFCHW__ 1
1618// CHECK_TGL_M32: #define __RDPID__ 1
1619// CHECK_TGL_M32: #define __RDRND__ 1
1620// CHECK_TGL_M32: #define __RDSEED__ 1
1621// CHECK_TGL_M32: #define __SGX__ 1
1622// CHECK_TGL_M32: #define __SHA__ 1
1623// CHECK_TGL_M32: #define __SHSTK__ 1
1624// CHECK_TGL_M32: #define __SSE2__ 1
1625// CHECK_TGL_M32: #define __SSE3__ 1
1626// CHECK_TGL_M32: #define __SSE4_1__ 1
1627// CHECK_TGL_M32: #define __SSE4_2__ 1
1628// CHECK_TGL_M32: #define __SSE__ 1
1629// CHECK_TGL_M32: #define __SSSE3__ 1
1630// CHECK_TGL_M32: #define __VAES__ 1
1631// CHECK_TGL_M32: #define __VPCLMULQDQ__ 1
1632// CHECK_TGL_M32-NOT: #define __WBNOINVD__ 1
1633// CHECK_TGL_M32: #define __XSAVEC__ 1
1634// CHECK_TGL_M32: #define __XSAVEOPT__ 1
1635// CHECK_TGL_M32: #define __XSAVES__ 1
1636// CHECK_TGL_M32: #define __XSAVE__ 1
1637// CHECK_TGL_M32: #define __corei7 1
1638// CHECK_TGL_M32: #define __corei7__ 1
1639// CHECK_TGL_M32: #define __i386 1
1640// CHECK_TGL_M32: #define __i386__ 1
1641// CHECK_TGL_M32: #define __tune_corei7__ 1
1642// CHECK_TGL_M32: #define i386 1
1643
1644// RUN: %clang -march=tigerlake -m64 -E -dM %s -o - 2>&1 \
1645// RUN: -target i386-unknown-linux \
1646// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_TGL_M64
1647// CHECK_TGL_M64: #define __AES__ 1
1648// CHECK_TGL_M64: #define __AVX2__ 1
1649// CHECK_TGL_M64: #define __AVX512BITALG__ 1
1650// CHECK_TGL_M64: #define __AVX512BW__ 1
1651// CHECK_TGL_M64: #define __AVX512CD__ 1
1652// CHECK_TGL_M64: #define __AVX512DQ__ 1
1653// CHECK_TGL_M64: #define __AVX512F__ 1
1654// CHECK_TGL_M64: #define __AVX512IFMA__ 1
1655// CHECK_TGL_M64: #define __AVX512VBMI2__ 1
1656// CHECK_TGL_M64: #define __AVX512VBMI__ 1
1657// CHECK_TGL_M64: #define __AVX512VL__ 1
1658// CHECK_TGL_M64: #define __AVX512VNNI__ 1
1659// CHECK_TGL_M64: #define __AVX512VP2INTERSECT__ 1
1660// CHECK_TGL_M64: #define __AVX512VPOPCNTDQ__ 1
1661// CHECK_TGL_M64: #define __AVX__ 1
1662// CHECK_TGL_M64: #define __BMI2__ 1
1663// CHECK_TGL_M64: #define __BMI__ 1
1664// CHECK_TGL_M64: #define __CLFLUSHOPT__ 1
1665// CHECK_TGL_M64: #define __CLWB__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08001666// CHECK_TGL_M64: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08001667// CHECK_TGL_M64: #define __EVEX512__ 1
Pengfei Wange28cbbd2019-08-12 01:29:46 +00001668// CHECK_TGL_M64: #define __F16C__ 1
1669// CHECK_TGL_M64: #define __FMA__ 1
1670// CHECK_TGL_M64: #define __GFNI__ 1
1671// CHECK_TGL_M64: #define __INVPCID__ 1
1672// CHECK_TGL_M64: #define __LZCNT__ 1
1673// CHECK_TGL_M64: #define __MMX__ 1
1674// CHECK_TGL_M64: #define __MOVBE__ 1
1675// CHECK_TGL_M64: #define __MOVDIR64B__ 1
1676// CHECK_TGL_M64: #define __MOVDIRI__ 1
Pengfei Wange28cbbd2019-08-12 01:29:46 +00001677// CHECK_TGL_M64: #define __PCLMUL__ 1
1678// CHECK_TGL_M64-NOT: #define __PCONFIG__ 1
1679// CHECK_TGL_M64: #define __PKU__ 1
1680// CHECK_TGL_M64: #define __POPCNT__ 1
1681// CHECK_TGL_M64: #define __PRFCHW__ 1
1682// CHECK_TGL_M64: #define __RDPID__ 1
1683// CHECK_TGL_M64: #define __RDRND__ 1
1684// CHECK_TGL_M64: #define __RDSEED__ 1
1685// CHECK_TGL_M64: #define __SGX__ 1
1686// CHECK_TGL_M64: #define __SHA__ 1
1687// CHECK_TGL_M64: #define __SHSTK__ 1
1688// CHECK_TGL_M64: #define __SSE2__ 1
1689// CHECK_TGL_M64: #define __SSE3__ 1
1690// CHECK_TGL_M64: #define __SSE4_1__ 1
1691// CHECK_TGL_M64: #define __SSE4_2__ 1
1692// CHECK_TGL_M64: #define __SSE__ 1
1693// CHECK_TGL_M64: #define __SSSE3__ 1
1694// CHECK_TGL_M64: #define __VAES__ 1
1695// CHECK_TGL_M64: #define __VPCLMULQDQ__ 1
1696// CHECK_TGL_M64-NOT: #define __WBNOINVD__ 1
1697// CHECK_TGL_M64: #define __XSAVEC__ 1
1698// CHECK_TGL_M64: #define __XSAVEOPT__ 1
1699// CHECK_TGL_M64: #define __XSAVES__ 1
1700// CHECK_TGL_M64: #define __XSAVE__ 1
1701// CHECK_TGL_M64: #define __amd64 1
1702// CHECK_TGL_M64: #define __amd64__ 1
1703// CHECK_TGL_M64: #define __corei7 1
1704// CHECK_TGL_M64: #define __corei7__ 1
1705// CHECK_TGL_M64: #define __tune_corei7__ 1
1706// CHECK_TGL_M64: #define __x86_64 1
1707// CHECK_TGL_M64: #define __x86_64__ 1
1708
Freddy Yee02d0812020-08-25 12:27:02 +08001709// RUN: %clang -march=sapphirerapids -m32 -E -dM %s -o - 2>&1 \
1710// RUN: -target i386-unknown-linux \
1711// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPR_M32
Freddy Ye27b8f542023-01-05 20:27:13 +08001712// RUN: %clang -march=emeraldrapids -m32 -E -dM %s -o - 2>&1 \
1713// RUN: -target i386-unknown-linux \
1714// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPR_M32
Freddy Yee02d0812020-08-25 12:27:02 +08001715// CHECK_SPR_M32: #define __AES__ 1
Joe Loser8998fa62023-02-01 10:19:27 -07001716// CHECK_SPR_M32: #define __AMX_BF16__ 1
1717// CHECK_SPR_M32: #define __AMX_INT8__ 1
1718// CHECK_SPR_M32: #define __AMX_TILE__ 1
Freddy Yee02d0812020-08-25 12:27:02 +08001719// CHECK_SPR_M32: #define __AVX2__ 1
1720// CHECK_SPR_M32: #define __AVX512BF16__ 1
1721// CHECK_SPR_M32: #define __AVX512BITALG__ 1
1722// CHECK_SPR_M32: #define __AVX512BW__ 1
1723// CHECK_SPR_M32: #define __AVX512CD__ 1
1724// CHECK_SPR_M32: #define __AVX512DQ__ 1
Wang, Pengfei6f7f5b52021-08-10 11:18:40 +08001725// CHECK_SPR_M32: #define __AVX512FP16__ 1
Freddy Yee02d0812020-08-25 12:27:02 +08001726// CHECK_SPR_M32: #define __AVX512F__ 1
1727// CHECK_SPR_M32: #define __AVX512IFMA__ 1
1728// CHECK_SPR_M32: #define __AVX512VBMI2__ 1
1729// CHECK_SPR_M32: #define __AVX512VBMI__ 1
1730// CHECK_SPR_M32: #define __AVX512VL__ 1
1731// CHECK_SPR_M32: #define __AVX512VNNI__ 1
1732// CHECK_SPR_M32: #define __AVX512VPOPCNTDQ__ 1
Liu, Chen3756f5972020-10-30 12:58:05 +08001733// CHECK_SPR_M32: #define __AVXVNNI__ 1
Freddy Yee02d0812020-08-25 12:27:02 +08001734// CHECK_SPR_M32: #define __AVX__ 1
1735// CHECK_SPR_M32: #define __BMI2__ 1
1736// CHECK_SPR_M32: #define __BMI__ 1
1737// CHECK_SPR_M32: #define __CLDEMOTE__ 1
1738// CHECK_SPR_M32: #define __CLFLUSHOPT__ 1
1739// CHECK_SPR_M32: #define __CLWB__ 1
1740// CHECK_SPR_M32: #define __ENQCMD__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08001741// CHECK_SPR_M32: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08001742// CHECK_SPR_M32: #define __EVEX512__ 1
Freddy Yee02d0812020-08-25 12:27:02 +08001743// CHECK_SPR_M32: #define __F16C__ 1
1744// CHECK_SPR_M32: #define __FMA__ 1
1745// CHECK_SPR_M32: #define __GFNI__ 1
1746// CHECK_SPR_M32: #define __INVPCID__ 1
1747// CHECK_SPR_M32: #define __LZCNT__ 1
1748// CHECK_SPR_M32: #define __MMX__ 1
1749// CHECK_SPR_M32: #define __MOVBE__ 1
1750// CHECK_SPR_M32: #define __PCLMUL__ 1
1751// CHECK_SPR_M32: #define __PCONFIG__ 1
1752// CHECK_SPR_M32: #define __PKU__ 1
1753// CHECK_SPR_M32: #define __POPCNT__ 1
1754// CHECK_SPR_M32: #define __PRFCHW__ 1
1755// CHECK_SPR_M32: #define __PTWRITE__ 1
1756// CHECK_SPR_M32: #define __RDPID__ 1
1757// CHECK_SPR_M32: #define __RDRND__ 1
1758// CHECK_SPR_M32: #define __RDSEED__ 1
1759// CHECK_SPR_M32: #define __SERIALIZE__ 1
1760// CHECK_SPR_M32: #define __SGX__ 1
1761// CHECK_SPR_M32: #define __SHA__ 1
1762// CHECK_SPR_M32: #define __SHSTK__ 1
1763// CHECK_SPR_M32: #define __SSE2__ 1
1764// CHECK_SPR_M32: #define __SSE3__ 1
1765// CHECK_SPR_M32: #define __SSE4_1__ 1
1766// CHECK_SPR_M32: #define __SSE4_2__ 1
1767// CHECK_SPR_M32: #define __SSE__ 1
1768// CHECK_SPR_M32: #define __SSSE3__ 1
1769// CHECK_SPR_M32: #define __TSXLDTRK__ 1
Tianqing Wangbe39a6f2020-10-22 16:46:07 +08001770// CHECK_SPR_M32: #define __UINTR__ 1
Freddy Yee02d0812020-08-25 12:27:02 +08001771// CHECK_SPR_M32: #define __VAES__ 1
1772// CHECK_SPR_M32: #define __VPCLMULQDQ__ 1
1773// CHECK_SPR_M32: #define __WAITPKG__ 1
1774// CHECK_SPR_M32: #define __WBNOINVD__ 1
1775// CHECK_SPR_M32: #define __XSAVEC__ 1
1776// CHECK_SPR_M32: #define __XSAVEOPT__ 1
1777// CHECK_SPR_M32: #define __XSAVES__ 1
1778// CHECK_SPR_M32: #define __XSAVE__ 1
1779// CHECK_SPR_M32: #define __corei7 1
1780// CHECK_SPR_M32: #define __corei7__ 1
1781// CHECK_SPR_M32: #define __i386 1
1782// CHECK_SPR_M32: #define __i386__ 1
1783// CHECK_SPR_M32: #define __tune_corei7__ 1
1784// CHECK_SPR_M32: #define i386 1
1785
1786// RUN: %clang -march=sapphirerapids -m64 -E -dM %s -o - 2>&1 \
1787// RUN: -target i386-unknown-linux \
1788// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPR_M64
Freddy Ye27b8f542023-01-05 20:27:13 +08001789// RUN: %clang -march=emeraldrapids -m64 -E -dM %s -o - 2>&1 \
1790// RUN: -target i386-unknown-linux \
1791// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPR_M64
Freddy Yee02d0812020-08-25 12:27:02 +08001792// CHECK_SPR_M64: #define __AES__ 1
Joe Loser8998fa62023-02-01 10:19:27 -07001793// CHECK_SPR_M64: #define __AMX_BF16__ 1
1794// CHECK_SPR_M64: #define __AMX_INT8__ 1
1795// CHECK_SPR_M64: #define __AMX_TILE__ 1
Freddy Yee02d0812020-08-25 12:27:02 +08001796// CHECK_SPR_M64: #define __AVX2__ 1
1797// CHECK_SPR_M64: #define __AVX512BF16__ 1
1798// CHECK_SPR_M64: #define __AVX512BITALG__ 1
1799// CHECK_SPR_M64: #define __AVX512BW__ 1
1800// CHECK_SPR_M64: #define __AVX512CD__ 1
1801// CHECK_SPR_M64: #define __AVX512DQ__ 1
Wang, Pengfei6f7f5b52021-08-10 11:18:40 +08001802// CHECK_SPR_M64: #define __AVX512FP16__ 1
Freddy Yee02d0812020-08-25 12:27:02 +08001803// CHECK_SPR_M64: #define __AVX512F__ 1
1804// CHECK_SPR_M64: #define __AVX512IFMA__ 1
1805// CHECK_SPR_M64: #define __AVX512VBMI2__ 1
1806// CHECK_SPR_M64: #define __AVX512VBMI__ 1
1807// CHECK_SPR_M64: #define __AVX512VL__ 1
1808// CHECK_SPR_M64: #define __AVX512VNNI__ 1
1809// CHECK_SPR_M64: #define __AVX512VPOPCNTDQ__ 1
Liu, Chen3756f5972020-10-30 12:58:05 +08001810// CHECK_SPR_M64: #define __AVXVNNI__ 1
Freddy Yee02d0812020-08-25 12:27:02 +08001811// CHECK_SPR_M64: #define __AVX__ 1
1812// CHECK_SPR_M64: #define __BMI2__ 1
1813// CHECK_SPR_M64: #define __BMI__ 1
1814// CHECK_SPR_M64: #define __CLDEMOTE__ 1
1815// CHECK_SPR_M64: #define __CLFLUSHOPT__ 1
1816// CHECK_SPR_M64: #define __CLWB__ 1
1817// CHECK_SPR_M64: #define __ENQCMD__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08001818// CHECK_SPR_M64: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08001819// CHECK_SPR_M64: #define __EVEX512__ 1
Freddy Yee02d0812020-08-25 12:27:02 +08001820// CHECK_SPR_M64: #define __F16C__ 1
1821// CHECK_SPR_M64: #define __FMA__ 1
1822// CHECK_SPR_M64: #define __GFNI__ 1
1823// CHECK_SPR_M64: #define __INVPCID__ 1
1824// CHECK_SPR_M64: #define __LZCNT__ 1
1825// CHECK_SPR_M64: #define __MMX__ 1
1826// CHECK_SPR_M64: #define __MOVBE__ 1
1827// CHECK_SPR_M64: #define __PCLMUL__ 1
1828// CHECK_SPR_M64: #define __PCONFIG__ 1
1829// CHECK_SPR_M64: #define __PKU__ 1
1830// CHECK_SPR_M64: #define __POPCNT__ 1
1831// CHECK_SPR_M64: #define __PRFCHW__ 1
1832// CHECK_SPR_M64: #define __PTWRITE__ 1
1833// CHECK_SPR_M64: #define __RDPID__ 1
1834// CHECK_SPR_M64: #define __RDRND__ 1
1835// CHECK_SPR_M64: #define __RDSEED__ 1
1836// CHECK_SPR_M64: #define __SERIALIZE__ 1
1837// CHECK_SPR_M64: #define __SGX__ 1
1838// CHECK_SPR_M64: #define __SHA__ 1
1839// CHECK_SPR_M64: #define __SHSTK__ 1
1840// CHECK_SPR_M64: #define __SSE2__ 1
1841// CHECK_SPR_M64: #define __SSE3__ 1
1842// CHECK_SPR_M64: #define __SSE4_1__ 1
1843// CHECK_SPR_M64: #define __SSE4_2__ 1
1844// CHECK_SPR_M64: #define __SSE__ 1
1845// CHECK_SPR_M64: #define __SSSE3__ 1
1846// CHECK_SPR_M64: #define __TSXLDTRK__ 1
Tianqing Wangbe39a6f2020-10-22 16:46:07 +08001847// CHECK_SPR_M64: #define __UINTR__ 1
Freddy Yee02d0812020-08-25 12:27:02 +08001848// CHECK_SPR_M64: #define __VAES__ 1
1849// CHECK_SPR_M64: #define __VPCLMULQDQ__ 1
1850// CHECK_SPR_M64: #define __WAITPKG__ 1
1851// CHECK_SPR_M64: #define __WBNOINVD__ 1
1852// CHECK_SPR_M64: #define __XSAVEC__ 1
1853// CHECK_SPR_M64: #define __XSAVEOPT__ 1
1854// CHECK_SPR_M64: #define __XSAVES__ 1
1855// CHECK_SPR_M64: #define __XSAVE__ 1
1856// CHECK_SPR_M64: #define __amd64 1
1857// CHECK_SPR_M64: #define __amd64__ 1
1858// CHECK_SPR_M64: #define __corei7 1
1859// CHECK_SPR_M64: #define __corei7__ 1
1860// CHECK_SPR_M64: #define __tune_corei7__ 1
1861// CHECK_SPR_M64: #define __x86_64 1
1862// CHECK_SPR_M64: #define __x86_64__ 1
1863
Freddy Ye84a18a22022-11-09 16:12:25 +08001864// RUN: %clang -march=graniterapids -m32 -E -dM %s -o - 2>&1 \
1865// RUN: --target=i386 \
1866// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_GNR_M32
Freddy Ye6d23a3f2023-07-25 13:47:45 +08001867// RUN: %clang -march=graniterapids-d -m32 -E -dM %s -o - 2>&1 \
1868// RUN: --target=i386 \
1869// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_GNR_M32,CHECK_GNRD_M32
Freddy Ye97836be2024-11-18 10:40:32 +08001870// RUN: %clang -march=diamondrapids -m32 -E -dM %s -o - 2>&1 \
1871// RUN: --target=i386 \
1872// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_GNR_M32,CHECK_GNRD_M32,CHECK_DMR_M32
Freddy Ye84a18a22022-11-09 16:12:25 +08001873// CHECK_GNR_M32: #define __AES__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08001874// CHECK_DMR_M32: #define __AMX_AVX512__ 1
Joe Loser8998fa62023-02-01 10:19:27 -07001875// CHECK_GNR_M32: #define __AMX_BF16__ 1
Freddy Ye6d23a3f2023-07-25 13:47:45 +08001876// CHECK_GNR_M32-NOT: #define __AMX_COMPLEX__ 1
1877// CHECK_GNRD_M32: #define __AMX_COMPLEX__ 1
Joe Loser8998fa62023-02-01 10:19:27 -07001878// CHECK_GNR_M32: #define __AMX_FP16__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08001879// CHECK_DMR_M32: #define __AMX_FP8__ 1
Joe Loser8998fa62023-02-01 10:19:27 -07001880// CHECK_GNR_M32: #define __AMX_INT8__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08001881// CHECK_DMR_M32: #define __AMX_MOVRS__ 1
1882// CHECK_DMR_M32: #define __AMX_TF32__ 1
Joe Loser8998fa62023-02-01 10:19:27 -07001883// CHECK_GNR_M32: #define __AMX_TILE__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08001884// CHECK_DMR_M32: #define __AMX_TRANSPOSE__ 1
1885// CHECK_DMR_M32: #define __AVX10_2_512__ 1
1886// CHECK_DMR_M32: #define __AVX10_2__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08001887// CHECK_GNR_M32: #define __AVX2__ 1
1888// CHECK_GNR_M32: #define __AVX512BF16__ 1
1889// CHECK_GNR_M32: #define __AVX512BITALG__ 1
1890// CHECK_GNR_M32: #define __AVX512BW__ 1
1891// CHECK_GNR_M32: #define __AVX512CD__ 1
1892// CHECK_GNR_M32: #define __AVX512DQ__ 1
1893// CHECK_GNR_M32: #define __AVX512FP16__ 1
1894// CHECK_GNR_M32: #define __AVX512F__ 1
1895// CHECK_GNR_M32: #define __AVX512IFMA__ 1
1896// CHECK_GNR_M32: #define __AVX512VBMI2__ 1
1897// CHECK_GNR_M32: #define __AVX512VBMI__ 1
1898// CHECK_GNR_M32: #define __AVX512VL__ 1
1899// CHECK_GNR_M32: #define __AVX512VNNI__ 1
1900// CHECK_GNR_M32: #define __AVX512VPOPCNTDQ__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08001901// CHECK_DMR_M32: #define __AVXIFMA__ 1
1902// CHECK_DMR_M32: #define __AVXNECONVERT__ 1
1903// CHECK_DMR_M32: #define __AVXVNNIINT16__ 1
1904// CHECK_DMR_M32: #define __AVXVNNIINT8__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08001905// CHECK_GNR_M32: #define __AVXVNNI__ 1
1906// CHECK_GNR_M32: #define __AVX__ 1
1907// CHECK_GNR_M32: #define __BMI2__ 1
1908// CHECK_GNR_M32: #define __BMI__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08001909// CHECK_DMR_M32: #define __CCMP__ 1
1910// CHECK_DMR_M32: #define __CF__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08001911// CHECK_GNR_M32: #define __CLDEMOTE__ 1
1912// CHECK_GNR_M32: #define __CLFLUSHOPT__ 1
1913// CHECK_GNR_M32: #define __CLWB__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08001914// CHECK_DMR_M32: #define __CMPCCXADD__ 1
1915// CHECK_DMR_M32: #define __EGPR__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08001916// CHECK_GNR_M32: #define __ENQCMD__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08001917// CHECK_GNR_M32: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08001918// CHECK_GNR_M32: #define __EVEX512__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08001919// CHECK_GNR_M32: #define __F16C__ 1
1920// CHECK_GNR_M32: #define __FMA__ 1
1921// CHECK_GNR_M32: #define __GFNI__ 1
1922// CHECK_GNR_M32: #define __INVPCID__ 1
1923// CHECK_GNR_M32: #define __LZCNT__ 1
1924// CHECK_GNR_M32: #define __MMX__ 1
1925// CHECK_GNR_M32: #define __MOVBE__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08001926// CHECK_DMR_M32: #define __MOVRS__ 1
1927// CHECK_DMR_M32: #define __NDD__ 1
1928// CHECK_DMR_M32: #define __NF__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08001929// CHECK_GNR_M32: #define __PCLMUL__ 1
1930// CHECK_GNR_M32: #define __PCONFIG__ 1
1931// CHECK_GNR_M32: #define __PKU__ 1
1932// CHECK_GNR_M32: #define __POPCNT__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08001933// CHECK_DMR_M32: #define __PPX__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08001934// CHECK_GNR_M32: #define __PREFETCHI__ 1
1935// CHECK_GNR_M32: #define __PRFCHW__ 1
1936// CHECK_GNR_M32: #define __PTWRITE__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08001937// CHECK_DMR_M32: #define __PUSH2POP2__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08001938// CHECK_GNR_M32: #define __RDPID__ 1
1939// CHECK_GNR_M32: #define __RDRND__ 1
1940// CHECK_GNR_M32: #define __RDSEED__ 1
1941// CHECK_GNR_M32: #define __SERIALIZE__ 1
1942// CHECK_GNR_M32: #define __SGX__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08001943// CHECK_DMR_M32: #define __SHA512__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08001944// CHECK_GNR_M32: #define __SHA__ 1
1945// CHECK_GNR_M32: #define __SHSTK__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08001946// CHECK_DMR_M32: #define __SM3__ 1
1947// CHECK_DMR_M32: #define __SM4__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08001948// CHECK_GNR_M32: #define __SSE2__ 1
1949// CHECK_GNR_M32: #define __SSE3__ 1
1950// CHECK_GNR_M32: #define __SSE4_1__ 1
1951// CHECK_GNR_M32: #define __SSE4_2__ 1
1952// CHECK_GNR_M32: #define __SSE__ 1
1953// CHECK_GNR_M32: #define __SSSE3__ 1
1954// CHECK_GNR_M32: #define __TSXLDTRK__ 1
1955// CHECK_GNR_M32: #define __UINTR__ 1
Phoebe Wang90968792024-12-16 20:29:26 +08001956// CHECK_GNR_M32-NOT: #define __USERMSR__ 1
1957// CHECK_DMR_M32: #define __USERMSR__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08001958// CHECK_GNR_M32: #define __VAES__ 1
1959// CHECK_GNR_M32: #define __VPCLMULQDQ__ 1
1960// CHECK_GNR_M32: #define __WAITPKG__ 1
1961// CHECK_GNR_M32: #define __WBNOINVD__ 1
1962// CHECK_GNR_M32: #define __XSAVEC__ 1
1963// CHECK_GNR_M32: #define __XSAVEOPT__ 1
1964// CHECK_GNR_M32: #define __XSAVES__ 1
1965// CHECK_GNR_M32: #define __XSAVE__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08001966// CHECK_DMR_M32: #define __ZU__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08001967// CHECK_GNR_M32: #define __corei7 1
1968// CHECK_GNR_M32: #define __corei7__ 1
1969// CHECK_GNR_M32: #define __i386 1
1970// CHECK_GNR_M32: #define __i386__ 1
1971// CHECK_GNR_M32: #define __tune_corei7__ 1
1972// CHECK_GNR_M32: #define i386 1
1973
1974// RUN: %clang -march=graniterapids -m64 -E -dM %s -o - 2>&1 \
1975// RUN: --target=x86_64 \
1976// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_GNR_M64
Freddy Ye6d23a3f2023-07-25 13:47:45 +08001977// RUN: %clang -march=graniterapids-d -m64 -E -dM %s -o - 2>&1 \
1978// RUN: --target=x86_64 \
1979// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_GNR_M64,CHECK_GNRD_M64
Freddy Ye97836be2024-11-18 10:40:32 +08001980// RUN: %clang -march=diamondrapids -m64 -E -dM %s -o - 2>&1 \
1981// RUN: --target=x86_64 \
1982// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_GNR_M64,CHECK_GNRD_M64,CHECK_DMR_M64
Freddy Ye84a18a22022-11-09 16:12:25 +08001983// CHECK_GNR_M64: #define __AES__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08001984// CHECK_DMR_M64: #define __AMX_AVX512__ 1
Joe Loser8998fa62023-02-01 10:19:27 -07001985// CHECK_GNR_M64: #define __AMX_BF16__ 1
Freddy Ye6d23a3f2023-07-25 13:47:45 +08001986// CHECK_GNR_M64-NOT: #define __AMX_COMPLEX__ 1
1987// CHECK_GNRD_M64: #define __AMX_COMPLEX__ 1
Joe Loser8998fa62023-02-01 10:19:27 -07001988// CHECK_GNR_M64: #define __AMX_FP16__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08001989// CHECK_DMR_M64: #define __AMX_FP8__ 1
Joe Loser8998fa62023-02-01 10:19:27 -07001990// CHECK_GNR_M64: #define __AMX_INT8__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08001991// CHECK_DMR_M64: #define __AMX_MOVRS__ 1
1992// CHECK_DMR_M64: #define __AMX_TF32__ 1
Joe Loser8998fa62023-02-01 10:19:27 -07001993// CHECK_GNR_M64: #define __AMX_TILE__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08001994// CHECK_DMR_M64: #define __AMX_TRANSPOSE__ 1
1995// CHECK_DMR_M64: #define __AVX10_2_512__ 1
1996// CHECK_DMR_M64: #define __AVX10_2__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08001997// CHECK_GNR_M64: #define __AVX2__ 1
1998// CHECK_GNR_M64: #define __AVX512BF16__ 1
1999// CHECK_GNR_M64: #define __AVX512BITALG__ 1
2000// CHECK_GNR_M64: #define __AVX512BW__ 1
2001// CHECK_GNR_M64: #define __AVX512CD__ 1
2002// CHECK_GNR_M64: #define __AVX512DQ__ 1
2003// CHECK_GNR_M64: #define __AVX512FP16__ 1
2004// CHECK_GNR_M64: #define __AVX512F__ 1
2005// CHECK_GNR_M64: #define __AVX512IFMA__ 1
2006// CHECK_GNR_M64: #define __AVX512VBMI2__ 1
2007// CHECK_GNR_M64: #define __AVX512VBMI__ 1
2008// CHECK_GNR_M64: #define __AVX512VL__ 1
2009// CHECK_GNR_M64: #define __AVX512VNNI__ 1
2010// CHECK_GNR_M64: #define __AVX512VPOPCNTDQ__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08002011// CHECK_DMR_M64: #define __AVXIFMA__ 1
2012// CHECK_DMR_M64: #define __AVXNECONVERT__ 1
2013// CHECK_DMR_M64: #define __AVXVNNIINT16__ 1
2014// CHECK_DMR_M64: #define __AVXVNNIINT8__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002015// CHECK_GNR_M64: #define __AVXVNNI__ 1
2016// CHECK_GNR_M64: #define __AVX__ 1
2017// CHECK_GNR_M64: #define __BMI2__ 1
2018// CHECK_GNR_M64: #define __BMI__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08002019// CHECK_DMR_M64: #define __CCMP__ 1
2020// CHECK_DMR_M64: #define __CF__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002021// CHECK_GNR_M64: #define __CLDEMOTE__ 1
2022// CHECK_GNR_M64: #define __CLFLUSHOPT__ 1
2023// CHECK_GNR_M64: #define __CLWB__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08002024// CHECK_DMR_M64: #define __CMPCCXADD__ 1
2025// CHECK_DMR_M64: #define __EGPR__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002026// CHECK_GNR_M64: #define __ENQCMD__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08002027// CHECK_GNR_M64: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08002028// CHECK_GNR_M64: #define __EVEX512__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002029// CHECK_GNR_M64: #define __F16C__ 1
2030// CHECK_GNR_M64: #define __FMA__ 1
2031// CHECK_GNR_M64: #define __GFNI__ 1
2032// CHECK_GNR_M64: #define __INVPCID__ 1
2033// CHECK_GNR_M64: #define __LZCNT__ 1
2034// CHECK_GNR_M64: #define __MMX__ 1
2035// CHECK_GNR_M64: #define __MOVBE__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08002036// CHECK_DMR_M64: #define __MOVRS__ 1
2037// CHECK_DMR_M64: #define __NDD__ 1
2038// CHECK_DMR_M64: #define __NF__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002039// CHECK_GNR_M64: #define __PCLMUL__ 1
2040// CHECK_GNR_M64: #define __PCONFIG__ 1
2041// CHECK_GNR_M64: #define __PKU__ 1
2042// CHECK_GNR_M64: #define __POPCNT__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08002043// CHECK_DMR_M64: #define __PPX__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002044// CHECK_GNR_M64: #define __PREFETCHI__ 1
2045// CHECK_GNR_M64: #define __PRFCHW__ 1
2046// CHECK_GNR_M64: #define __PTWRITE__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08002047// CHECK_DMR_M64: #define __PUSH2POP2__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002048// CHECK_GNR_M64: #define __RDPID__ 1
2049// CHECK_GNR_M64: #define __RDRND__ 1
2050// CHECK_GNR_M64: #define __RDSEED__ 1
2051// CHECK_GNR_M64: #define __SERIALIZE__ 1
2052// CHECK_GNR_M64: #define __SGX__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08002053// CHECK_DMR_M64: #define __SHA512__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002054// CHECK_GNR_M64: #define __SHA__ 1
2055// CHECK_GNR_M64: #define __SHSTK__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08002056// CHECK_DMR_M64: #define __SM3__ 1
2057// CHECK_DMR_M64: #define __SM4__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002058// CHECK_GNR_M64: #define __SSE2__ 1
2059// CHECK_GNR_M64: #define __SSE3__ 1
2060// CHECK_GNR_M64: #define __SSE4_1__ 1
2061// CHECK_GNR_M64: #define __SSE4_2__ 1
2062// CHECK_GNR_M64: #define __SSE__ 1
2063// CHECK_GNR_M64: #define __SSSE3__ 1
2064// CHECK_GNR_M64: #define __TSXLDTRK__ 1
2065// CHECK_GNR_M64: #define __UINTR__ 1
Phoebe Wang90968792024-12-16 20:29:26 +08002066// CHECK_GNR_M64-NOT: #define __USERMSR__ 1
2067// CHECK_DMR_M64: #define __USERMSR__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002068// CHECK_GNR_M64: #define __VAES__ 1
2069// CHECK_GNR_M64: #define __VPCLMULQDQ__ 1
2070// CHECK_GNR_M64: #define __WAITPKG__ 1
2071// CHECK_GNR_M64: #define __WBNOINVD__ 1
2072// CHECK_GNR_M64: #define __XSAVEC__ 1
2073// CHECK_GNR_M64: #define __XSAVEOPT__ 1
2074// CHECK_GNR_M64: #define __XSAVES__ 1
2075// CHECK_GNR_M64: #define __XSAVE__ 1
Freddy Ye97836be2024-11-18 10:40:32 +08002076// CHECK_DMR_M64: #define __ZU__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002077// CHECK_GNR_M64: #define __amd64 1
2078// CHECK_GNR_M64: #define __amd64__ 1
2079// CHECK_GNR_M64: #define __corei7 1
2080// CHECK_GNR_M64: #define __corei7__ 1
2081// CHECK_GNR_M64: #define __tune_corei7__ 1
2082// CHECK_GNR_M64: #define __x86_64 1
2083// CHECK_GNR_M64: #define __x86_64__ 1
2084
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002085// RUN: %clang -march=alderlake -m32 -E -dM %s -o - 2>&1 \
2086// RUN: -target i386-unknown-linux \
2087// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ADL_M32
Freddy Yea806fc22022-11-04 09:04:57 +08002088// RUN: %clang -march=raptorlake -m32 -E -dM %s -o - 2>&1 \
2089// RUN: -target i386-unknown-linux \
2090// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ADL_M32
2091// RUN: %clang -march=meteorlake -m32 -E -dM %s -o - 2>&1 \
2092// RUN: -target i386-unknown-linux \
2093// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ADL_M32
Freddy Ye6acff532023-08-21 08:48:45 +08002094// RUN: %clang -march=gracemont -m32 -E -dM %s -o - 2>&1 \
2095// RUN: -target i386-unknown-linux \
2096// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ADL_M32
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002097// CHECK_ADL_M32: #define __ADX__ 1
2098// CHECK_ADL_M32: #define __AES__ 1
2099// CHECK_ADL_M32: #define __AVX2__ 1
2100// CHECK_ADL_M32-NOT: AVX512
Liu, Chen3756f5972020-10-30 12:58:05 +08002101// CHECK_ADL_M32: #define __AVXVNNI__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002102// CHECK_ADL_M32: #define __AVX__ 1
2103// CHECK_ADL_M32: #define __BMI2__ 1
2104// CHECK_ADL_M32: #define __BMI__ 1
2105// CHECK_ADL_M32: #define __CLDEMOTE__ 1
2106// CHECK_ADL_M32: #define __CLFLUSHOPT__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002107// CHECK_ADL_M32: #define __CLWB__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002108// CHECK_ADL_M32: #define __F16C__ 1
2109// CHECK_ADL_M32: #define __FMA__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002110// CHECK_ADL_M32: #define __FSGSBASE__ 1
2111// CHECK_ADL_M32: #define __FXSR__ 1
2112// CHECK_ADL_M32: #define __GFNI__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002113// CHECK_ADL_M32: #define __HRESET__ 1
2114// CHECK_ADL_M32: #define __INVPCID__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002115// CHECK_ADL_M32: #define __KL__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002116// CHECK_ADL_M32: #define __LZCNT__ 1
2117// CHECK_ADL_M32: #define __MMX__ 1
2118// CHECK_ADL_M32: #define __MOVBE__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002119// CHECK_ADL_M32: #define __MOVDIR64B__ 1
2120// CHECK_ADL_M32: #define __MOVDIRI__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002121// CHECK_ADL_M32: #define __PCLMUL__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002122// CHECK_ADL_M32: #define __PCONFIG__ 1
2123// CHECK_ADL_M32: #define __PKU__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002124// CHECK_ADL_M32: #define __POPCNT__ 1
2125// CHECK_ADL_M32: #define __PRFCHW__ 1
2126// CHECK_ADL_M32: #define __PTWRITE__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002127// CHECK_ADL_M32: #define __RDPID__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002128// CHECK_ADL_M32: #define __RDRND__ 1
2129// CHECK_ADL_M32: #define __RDSEED__ 1
2130// CHECK_ADL_M32: #define __SERIALIZE__ 1
2131// CHECK_ADL_M32: #define __SGX__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002132// CHECK_ADL_M32: #define __SHA__ 1
2133// CHECK_ADL_M32: #define __SHSTK__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002134// CHECK_ADL_M32: #define __SSE2__ 1
2135// CHECK_ADL_M32: #define __SSE3__ 1
2136// CHECK_ADL_M32: #define __SSE4_1__ 1
2137// CHECK_ADL_M32: #define __SSE4_2__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002138// CHECK_ADL_M32: #define __SSE_MATH__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002139// CHECK_ADL_M32: #define __SSE__ 1
2140// CHECK_ADL_M32: #define __SSSE3__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002141// CHECK_ADL_M32: #define __VAES__ 1
2142// CHECK_ADL_M32: #define __VPCLMULQDQ__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002143// CHECK_ADL_M32: #define __WAITPKG__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002144// CHECK_ADL_M32: #define __WIDEKL__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002145// CHECK_ADL_M32: #define __XSAVEC__ 1
2146// CHECK_ADL_M32: #define __XSAVEOPT__ 1
2147// CHECK_ADL_M32: #define __XSAVES__ 1
2148// CHECK_ADL_M32: #define __XSAVE__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002149// CHECK_ADL_M32: #define __corei7 1
2150// CHECK_ADL_M32: #define __corei7__ 1
2151// CHECK_ADL_M32: #define __i386 1
2152// CHECK_ADL_M32: #define __i386__ 1
2153// CHECK_ADL_M32: #define __tune_corei7__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002154// CHECK_ADL_M32: #define i386 1
2155
2156// RUN: %clang -march=alderlake -m64 -E -dM %s -o - 2>&1 \
2157// RUN: -target i386-unknown-linux \
2158// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ADL_M64
Freddy Yea806fc22022-11-04 09:04:57 +08002159// RUN: %clang -march=raptorlake -m64 -E -dM %s -o - 2>&1 \
2160// RUN: -target i386-unknown-linux \
2161// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ADL_M64
2162// RUN: %clang -march=meteorlake -m64 -E -dM %s -o - 2>&1 \
2163// RUN: -target i386-unknown-linux \
2164// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ADL_M64
Freddy Ye6acff532023-08-21 08:48:45 +08002165// RUN: %clang -march=gracemont -m64 -E -dM %s -o - 2>&1 \
2166// RUN: -target i386-unknown-linux \
2167// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ADL_M64
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002168// CHECK_ADL_M64: #define __ADX__ 1
2169// CHECK_ADL_M64: #define __AES__ 1
2170// CHECK_ADL_M64: #define __AVX2__ 1
2171// CHECK_ADL_M64-NOT: AVX512
Liu, Chen3756f5972020-10-30 12:58:05 +08002172// CHECK_ADL_M64: #define __AVXVNNI__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002173// CHECK_ADL_M64: #define __AVX__ 1
2174// CHECK_ADL_M64: #define __BMI2__ 1
2175// CHECK_ADL_M64: #define __BMI__ 1
2176// CHECK_ADL_M64: #define __CLDEMOTE__ 1
2177// CHECK_ADL_M64: #define __CLFLUSHOPT__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002178// CHECK_ADL_M64: #define __CLWB__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002179// CHECK_ADL_M64: #define __F16C__ 1
2180// CHECK_ADL_M64: #define __FMA__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002181// CHECK_ADL_M64: #define __FSGSBASE__ 1
2182// CHECK_ADL_M64: #define __FXSR__ 1
2183// CHECK_ADL_M64: #define __GFNI__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002184// CHECK_ADL_M64: #define __HRESET__ 1
2185// CHECK_ADL_M64: #define __INVPCID__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002186// CHECK_ADL_M64: #define __KL__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002187// CHECK_ADL_M64: #define __LZCNT__ 1
2188// CHECK_ADL_M64: #define __MMX__ 1
2189// CHECK_ADL_M64: #define __MOVBE__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002190// CHECK_ADL_M64: #define __MOVDIR64B__ 1
2191// CHECK_ADL_M64: #define __MOVDIRI__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002192// CHECK_ADL_M64: #define __PCLMUL__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002193// CHECK_ADL_M64: #define __PCONFIG__ 1
2194// CHECK_ADL_M64: #define __PKU__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002195// CHECK_ADL_M64: #define __POPCNT__ 1
2196// CHECK_ADL_M64: #define __PRFCHW__ 1
2197// CHECK_ADL_M64: #define __PTWRITE__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002198// CHECK_ADL_M64: #define __RDPID__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002199// CHECK_ADL_M64: #define __RDRND__ 1
2200// CHECK_ADL_M64: #define __RDSEED__ 1
2201// CHECK_ADL_M64: #define __SERIALIZE__ 1
2202// CHECK_ADL_M64: #define __SGX__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002203// CHECK_ADL_M64: #define __SHA__ 1
2204// CHECK_ADL_M64: #define __SHSTK__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002205// CHECK_ADL_M64: #define __SSE2_MATH__ 1
2206// CHECK_ADL_M64: #define __SSE2__ 1
2207// CHECK_ADL_M64: #define __SSE3__ 1
2208// CHECK_ADL_M64: #define __SSE4_1__ 1
2209// CHECK_ADL_M64: #define __SSE4_2__ 1
2210// CHECK_ADL_M64: #define __SSE_MATH__ 1
2211// CHECK_ADL_M64: #define __SSE__ 1
2212// CHECK_ADL_M64: #define __SSSE3__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002213// CHECK_ADL_M64: #define __VAES__ 1
2214// CHECK_ADL_M64: #define __VPCLMULQDQ__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002215// CHECK_ADL_M64: #define __WAITPKG__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002216// CHECK_ADL_M64: #define __WIDEKL__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002217// CHECK_ADL_M64: #define __XSAVEC__ 1
2218// CHECK_ADL_M64: #define __XSAVEOPT__ 1
2219// CHECK_ADL_M64: #define __XSAVES__ 1
2220// CHECK_ADL_M64: #define __XSAVE__ 1
2221// CHECK_ADL_M64: #define __amd64 1
2222// CHECK_ADL_M64: #define __amd64__ 1
Freddy Ye5f9489b2021-03-03 16:17:37 +08002223// CHECK_ADL_M64: #define __corei7 1
2224// CHECK_ADL_M64: #define __corei7__ 1
2225// CHECK_ADL_M64: #define __tune_corei7__ 1
Benjamin Kramer39a0d682020-10-24 18:00:33 +02002226// CHECK_ADL_M64: #define __x86_64 1
2227// CHECK_ADL_M64: #define __x86_64__ 1
2228
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002229// RUN: %clang -march=atom -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002230// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002231// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATOM_M32
Freddy Ye548e08c2023-06-29 13:29:00 +08002232// RUN: %clang -march=bonnell -m32 -E -dM %s -o - 2>&1 \
2233// RUN: -target i386-unknown-linux \
2234// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATOM_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002235// CHECK_ATOM_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00002236// CHECK_ATOM_M32: #define __MOVBE__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002237// CHECK_ATOM_M32: #define __SSE2__ 1
2238// CHECK_ATOM_M32: #define __SSE3__ 1
2239// CHECK_ATOM_M32: #define __SSE__ 1
2240// CHECK_ATOM_M32: #define __SSSE3__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002241// CHECK_ATOM_M32: #define __atom 1
2242// CHECK_ATOM_M32: #define __atom__ 1
2243// CHECK_ATOM_M32: #define __i386 1
2244// CHECK_ATOM_M32: #define __i386__ 1
2245// CHECK_ATOM_M32: #define __tune_atom__ 1
2246// CHECK_ATOM_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002247
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00002248// RUN: %clang -march=atom -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002249// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002250// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATOM_M64
Freddy Ye548e08c2023-06-29 13:29:00 +08002251// RUN: %clang -march=bonnell -m64 -E -dM %s -o - 2>&1 \
2252// RUN: -target i386-unknown-linux \
2253// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATOM_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002254// CHECK_ATOM_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00002255// CHECK_ATOM_M64: #define __MOVBE__ 1
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002256// CHECK_ATOM_M64: #define __SSE2_MATH__ 1
2257// CHECK_ATOM_M64: #define __SSE2__ 1
2258// CHECK_ATOM_M64: #define __SSE3__ 1
2259// CHECK_ATOM_M64: #define __SSE_MATH__ 1
2260// CHECK_ATOM_M64: #define __SSE__ 1
2261// CHECK_ATOM_M64: #define __SSSE3__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00002262// CHECK_ATOM_M64: #define __amd64 1
2263// CHECK_ATOM_M64: #define __amd64__ 1
2264// CHECK_ATOM_M64: #define __atom 1
2265// CHECK_ATOM_M64: #define __atom__ 1
2266// CHECK_ATOM_M64: #define __tune_atom__ 1
2267// CHECK_ATOM_M64: #define __x86_64 1
2268// CHECK_ATOM_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002269
Michael Zuckermana046ef42017-06-29 13:41:04 +00002270// RUN: %clang -march=goldmont -m32 -E -dM %s -o - 2>&1 \
2271// RUN: -target i386-unknown-linux \
2272// RUN: | FileCheck %s -check-prefix=CHECK_GLM_M32
2273// CHECK_GLM_M32: #define __AES__ 1
2274// CHECK_GLM_M32: #define __CLFLUSHOPT__ 1
Michael Zuckerman35731a02017-09-25 13:49:32 +00002275// CHECK_GLM_M32: #define __FSGSBASE__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00002276// CHECK_GLM_M32: #define __FXSR__ 1
2277// CHECK_GLM_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00002278// CHECK_GLM_M32: #define __MOVBE__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00002279// CHECK_GLM_M32: #define __PCLMUL__ 1
2280// CHECK_GLM_M32: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +00002281// CHECK_GLM_M32: #define __PRFCHW__ 1
Craig Topper9dd7e802017-06-30 18:14:04 +00002282// CHECK_GLM_M32: #define __RDRND__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00002283// CHECK_GLM_M32: #define __RDSEED__ 1
2284// CHECK_GLM_M32: #define __SHA__ 1
2285// CHECK_GLM_M32: #define __SSE2__ 1
2286// CHECK_GLM_M32: #define __SSE3__ 1
2287// CHECK_GLM_M32: #define __SSE4_1__ 1
2288// CHECK_GLM_M32: #define __SSE4_2__ 1
2289// CHECK_GLM_M32: #define __SSE_MATH__ 1
2290// CHECK_GLM_M32: #define __SSE__ 1
2291// CHECK_GLM_M32: #define __SSSE3__ 1
2292// CHECK_GLM_M32: #define __XSAVEC__ 1
2293// CHECK_GLM_M32: #define __XSAVEOPT__ 1
2294// CHECK_GLM_M32: #define __XSAVES__ 1
2295// CHECK_GLM_M32: #define __XSAVE__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00002296// CHECK_GLM_M32: #define __goldmont 1
2297// CHECK_GLM_M32: #define __goldmont__ 1
2298// CHECK_GLM_M32: #define __i386 1
2299// CHECK_GLM_M32: #define __i386__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00002300// CHECK_GLM_M32: #define __tune_goldmont__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00002301// CHECK_GLM_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002302
Michael Zuckermana046ef42017-06-29 13:41:04 +00002303// RUN: %clang -march=goldmont -m64 -E -dM %s -o - 2>&1 \
2304// RUN: -target i386-unknown-linux \
2305// RUN: | FileCheck %s -check-prefix=CHECK_GLM_M64
2306// CHECK_GLM_M64: #define __AES__ 1
2307// CHECK_GLM_M64: #define __CLFLUSHOPT__ 1
Michael Zuckerman35731a02017-09-25 13:49:32 +00002308// CHECK_GLM_M64: #define __FSGSBASE__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00002309// CHECK_GLM_M64: #define __FXSR__ 1
2310// CHECK_GLM_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00002311// CHECK_GLM_M64: #define __MOVBE__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00002312// CHECK_GLM_M64: #define __PCLMUL__ 1
2313// CHECK_GLM_M64: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +00002314// CHECK_GLM_M64: #define __PRFCHW__ 1
Craig Topper9dd7e802017-06-30 18:14:04 +00002315// CHECK_GLM_M64: #define __RDRND__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00002316// CHECK_GLM_M64: #define __RDSEED__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00002317// CHECK_GLM_M64: #define __SHA__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00002318// CHECK_GLM_M64: #define __SSE2__ 1
2319// CHECK_GLM_M64: #define __SSE3__ 1
2320// CHECK_GLM_M64: #define __SSE4_1__ 1
2321// CHECK_GLM_M64: #define __SSE4_2__ 1
2322// CHECK_GLM_M64: #define __SSE__ 1
2323// CHECK_GLM_M64: #define __SSSE3__ 1
2324// CHECK_GLM_M64: #define __XSAVEC__ 1
2325// CHECK_GLM_M64: #define __XSAVEOPT__ 1
2326// CHECK_GLM_M64: #define __XSAVES__ 1
2327// CHECK_GLM_M64: #define __XSAVE__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00002328// CHECK_GLM_M64: #define __goldmont 1
2329// CHECK_GLM_M64: #define __goldmont__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00002330// CHECK_GLM_M64: #define __tune_goldmont__ 1
Michael Zuckermana046ef42017-06-29 13:41:04 +00002331// CHECK_GLM_M64: #define __x86_64 1
2332// CHECK_GLM_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002333
Gabor Buellaf594ce72018-04-16 08:10:10 +00002334// RUN: %clang -march=goldmont-plus -m32 -E -dM %s -o - 2>&1 \
2335// RUN: -target i386-unknown-linux \
2336// RUN: | FileCheck %s -check-prefix=CHECK_GLMP_M32
2337// CHECK_GLMP_M32: #define __AES__ 1
2338// CHECK_GLMP_M32: #define __CLFLUSHOPT__ 1
2339// CHECK_GLMP_M32: #define __FSGSBASE__ 1
2340// CHECK_GLMP_M32: #define __FXSR__ 1
2341// CHECK_GLMP_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00002342// CHECK_GLMP_M32: #define __MOVBE__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00002343// CHECK_GLMP_M32: #define __PCLMUL__ 1
2344// CHECK_GLMP_M32: #define __POPCNT__ 1
2345// CHECK_GLMP_M32: #define __PRFCHW__ 1
Gabor Buella3a757122018-05-10 07:28:54 +00002346// CHECK_GLMP_M32: #define __PTWRITE__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00002347// CHECK_GLMP_M32: #define __RDPID__ 1
2348// CHECK_GLMP_M32: #define __RDRND__ 1
2349// CHECK_GLMP_M32: #define __RDSEED__ 1
2350// CHECK_GLMP_M32: #define __SGX__ 1
2351// CHECK_GLMP_M32: #define __SHA__ 1
2352// CHECK_GLMP_M32: #define __SSE2__ 1
2353// CHECK_GLMP_M32: #define __SSE3__ 1
2354// CHECK_GLMP_M32: #define __SSE4_1__ 1
2355// CHECK_GLMP_M32: #define __SSE4_2__ 1
2356// CHECK_GLMP_M32: #define __SSE_MATH__ 1
2357// CHECK_GLMP_M32: #define __SSE__ 1
2358// CHECK_GLMP_M32: #define __SSSE3__ 1
2359// CHECK_GLMP_M32: #define __XSAVEC__ 1
2360// CHECK_GLMP_M32: #define __XSAVEOPT__ 1
2361// CHECK_GLMP_M32: #define __XSAVES__ 1
2362// CHECK_GLMP_M32: #define __XSAVE__ 1
2363// CHECK_GLMP_M32: #define __goldmont_plus 1
2364// CHECK_GLMP_M32: #define __goldmont_plus__ 1
2365// CHECK_GLMP_M32: #define __i386 1
2366// CHECK_GLMP_M32: #define __i386__ 1
2367// CHECK_GLMP_M32: #define __tune_goldmont_plus__ 1
2368// CHECK_GLMP_M32: #define i386 1
2369
2370// RUN: %clang -march=goldmont-plus -m64 -E -dM %s -o - 2>&1 \
2371// RUN: -target i386-unknown-linux \
2372// RUN: | FileCheck %s -check-prefix=CHECK_GLMP_M64
2373// CHECK_GLMP_M64: #define __AES__ 1
2374// CHECK_GLMP_M64: #define __CLFLUSHOPT__ 1
2375// CHECK_GLMP_M64: #define __FSGSBASE__ 1
2376// CHECK_GLMP_M64: #define __FXSR__ 1
2377// CHECK_GLMP_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00002378// CHECK_GLMP_M64: #define __MOVBE__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00002379// CHECK_GLMP_M64: #define __PCLMUL__ 1
2380// CHECK_GLMP_M64: #define __POPCNT__ 1
2381// CHECK_GLMP_M64: #define __PRFCHW__ 1
Gabor Buella3a757122018-05-10 07:28:54 +00002382// CHECK_GLMP_M64: #define __PTWRITE__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00002383// CHECK_GLMP_M64: #define __RDPID__ 1
2384// CHECK_GLMP_M64: #define __RDRND__ 1
2385// CHECK_GLMP_M64: #define __RDSEED__ 1
2386// CHECK_GLMP_M64: #define __SGX__ 1
2387// CHECK_GLMP_M64: #define __SHA__ 1
2388// CHECK_GLMP_M64: #define __SSE2__ 1
2389// CHECK_GLMP_M64: #define __SSE3__ 1
2390// CHECK_GLMP_M64: #define __SSE4_1__ 1
2391// CHECK_GLMP_M64: #define __SSE4_2__ 1
2392// CHECK_GLMP_M64: #define __SSE__ 1
2393// CHECK_GLMP_M64: #define __SSSE3__ 1
2394// CHECK_GLMP_M64: #define __XSAVEC__ 1
2395// CHECK_GLMP_M64: #define __XSAVEOPT__ 1
2396// CHECK_GLMP_M64: #define __XSAVES__ 1
2397// CHECK_GLMP_M64: #define __XSAVE__ 1
2398// CHECK_GLMP_M64: #define __goldmont_plus 1
2399// CHECK_GLMP_M64: #define __goldmont_plus__ 1
2400// CHECK_GLMP_M64: #define __tune_goldmont_plus__ 1
2401// CHECK_GLMP_M64: #define __x86_64 1
2402// CHECK_GLMP_M64: #define __x86_64__ 1
2403
2404// RUN: %clang -march=tremont -m32 -E -dM %s -o - 2>&1 \
2405// RUN: -target i386-unknown-linux \
2406// RUN: | FileCheck %s -check-prefix=CHECK_TRM_M32
2407// CHECK_TRM_M32: #define __AES__ 1
Craig Topperbb1d8bf2020-06-02 22:21:12 -07002408// CHECK_TRM_M32-NOT: #define __CLDEMOTE__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00002409// CHECK_TRM_M32: #define __CLFLUSHOPT__ 1
Craig Topperbb1d8bf2020-06-02 22:21:12 -07002410// CHECK_TRM_M32: #define __CLWB__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00002411// CHECK_TRM_M32: #define __FSGSBASE__ 1
2412// CHECK_TRM_M32: #define __FXSR__ 1
2413// CHECK_TRM_M32: #define __GFNI__ 1
2414// CHECK_TRM_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00002415// CHECK_TRM_M32: #define __MOVBE__ 1
Craig Topperbb1d8bf2020-06-02 22:21:12 -07002416// CHECK_TRM_M32-NOT: #define __MOVDIR64B__ 1
2417// CHECK_TRM_M32-NOT: #define __MOVDIRI__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00002418// CHECK_TRM_M32: #define __PCLMUL__ 1
2419// CHECK_TRM_M32: #define __POPCNT__ 1
2420// CHECK_TRM_M32: #define __PRFCHW__ 1
Gabor Buella3a757122018-05-10 07:28:54 +00002421// CHECK_TRM_M32: #define __PTWRITE__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00002422// CHECK_TRM_M32: #define __RDPID__ 1
2423// CHECK_TRM_M32: #define __RDRND__ 1
2424// CHECK_TRM_M32: #define __RDSEED__ 1
2425// CHECK_TRM_M32: #define __SGX__ 1
2426// CHECK_TRM_M32: #define __SHA__ 1
2427// CHECK_TRM_M32: #define __SSE2__ 1
2428// CHECK_TRM_M32: #define __SSE3__ 1
2429// CHECK_TRM_M32: #define __SSE4_1__ 1
2430// CHECK_TRM_M32: #define __SSE4_2__ 1
2431// CHECK_TRM_M32: #define __SSE_MATH__ 1
2432// CHECK_TRM_M32: #define __SSE__ 1
2433// CHECK_TRM_M32: #define __SSSE3__ 1
Craig Topperbb1d8bf2020-06-02 22:21:12 -07002434// CHECK_TRM_M32-NOT: #define __WAITPKG__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00002435// CHECK_TRM_M32: #define __XSAVEC__ 1
2436// CHECK_TRM_M32: #define __XSAVEOPT__ 1
2437// CHECK_TRM_M32: #define __XSAVES__ 1
2438// CHECK_TRM_M32: #define __XSAVE__ 1
2439// CHECK_TRM_M32: #define __i386 1
2440// CHECK_TRM_M32: #define __i386__ 1
2441// CHECK_TRM_M32: #define __tremont 1
2442// CHECK_TRM_M32: #define __tremont__ 1
2443// CHECK_TRM_M32: #define __tune_tremont__ 1
2444// CHECK_TRM_M32: #define i386 1
2445
2446// RUN: %clang -march=tremont -m64 -E -dM %s -o - 2>&1 \
2447// RUN: -target i386-unknown-linux \
2448// RUN: | FileCheck %s -check-prefix=CHECK_TRM_M64
2449// CHECK_TRM_M64: #define __AES__ 1
Craig Topperbb1d8bf2020-06-02 22:21:12 -07002450// CHECK_TRM_M64-NOT: #define __CLDEMOTE__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00002451// CHECK_TRM_M64: #define __CLFLUSHOPT__ 1
Craig Topperbb1d8bf2020-06-02 22:21:12 -07002452// CHECK_TRM_M64: #define __CLWB__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00002453// CHECK_TRM_M64: #define __FSGSBASE__ 1
2454// CHECK_TRM_M64: #define __FXSR__ 1
2455// CHECK_TRM_M64: #define __GFNI__ 1
2456// CHECK_TRM_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00002457// CHECK_TRM_M64: #define __MOVBE__ 1
Craig Topperbb1d8bf2020-06-02 22:21:12 -07002458// CHECK_TRM_M64-NOT: #define __MOVDIR64B__ 1
2459// CHECK_TRM_M64-NOT: #define __MOVDIRI__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00002460// CHECK_TRM_M64: #define __PCLMUL__ 1
2461// CHECK_TRM_M64: #define __POPCNT__ 1
2462// CHECK_TRM_M64: #define __PRFCHW__ 1
Gabor Buella3a757122018-05-10 07:28:54 +00002463// CHECK_TRM_M64: #define __PTWRITE__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00002464// CHECK_TRM_M64: #define __RDPID__ 1
2465// CHECK_TRM_M64: #define __RDRND__ 1
2466// CHECK_TRM_M64: #define __RDSEED__ 1
2467// CHECK_TRM_M64: #define __SGX__ 1
2468// CHECK_TRM_M64: #define __SHA__ 1
2469// CHECK_TRM_M64: #define __SSE2__ 1
2470// CHECK_TRM_M64: #define __SSE3__ 1
2471// CHECK_TRM_M64: #define __SSE4_1__ 1
2472// CHECK_TRM_M64: #define __SSE4_2__ 1
2473// CHECK_TRM_M64: #define __SSE__ 1
2474// CHECK_TRM_M64: #define __SSSE3__ 1
Craig Topperbb1d8bf2020-06-02 22:21:12 -07002475// CHECK_TRM_M64-NOT: #define __WAITPKG__ 1
Gabor Buellaf594ce72018-04-16 08:10:10 +00002476// CHECK_TRM_M64: #define __XSAVEC__ 1
2477// CHECK_TRM_M64: #define __XSAVEOPT__ 1
2478// CHECK_TRM_M64: #define __XSAVES__ 1
2479// CHECK_TRM_M64: #define __XSAVE__ 1
2480// CHECK_TRM_M64: #define __tremont 1
2481// CHECK_TRM_M64: #define __tremont__ 1
2482// CHECK_TRM_M64: #define __tune_tremont__ 1
2483// CHECK_TRM_M64: #define __x86_64 1
2484// CHECK_TRM_M64: #define __x86_64__ 1
2485
Benjamin Kramerffecc842013-08-30 14:05:34 +00002486// RUN: %clang -march=slm -m32 -E -dM %s -o - 2>&1 \
2487// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002488// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SLM_M32
Freddy Ye548e08c2023-06-29 13:29:00 +08002489// RUN: %clang -march=silvermont -m32 -E -dM %s -o - 2>&1 \
2490// RUN: -target i386-unknown-linux \
2491// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SLM_M32
Craig Topper921aff62017-12-22 05:09:38 +00002492// CHECK_SLM_M32: #define __FXSR__ 1
Benjamin Kramerffecc842013-08-30 14:05:34 +00002493// CHECK_SLM_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00002494// CHECK_SLM_M32: #define __MOVBE__ 1
Craig Topper921aff62017-12-22 05:09:38 +00002495// CHECK_SLM_M32: #define __PCLMUL__ 1
2496// CHECK_SLM_M32: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +00002497// CHECK_SLM_M32: #define __PRFCHW__ 1
Craig Topperace5c372018-01-26 19:34:45 +00002498// CHECK_SLM_M32: #define __RDRND__ 1
Benjamin Kramerffecc842013-08-30 14:05:34 +00002499// CHECK_SLM_M32: #define __SSE2__ 1
2500// CHECK_SLM_M32: #define __SSE3__ 1
2501// CHECK_SLM_M32: #define __SSE4_1__ 1
2502// CHECK_SLM_M32: #define __SSE4_2__ 1
2503// CHECK_SLM_M32: #define __SSE__ 1
2504// CHECK_SLM_M32: #define __SSSE3__ 1
2505// CHECK_SLM_M32: #define __i386 1
2506// CHECK_SLM_M32: #define __i386__ 1
2507// CHECK_SLM_M32: #define __slm 1
2508// CHECK_SLM_M32: #define __slm__ 1
2509// CHECK_SLM_M32: #define __tune_slm__ 1
2510// CHECK_SLM_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002511
Benjamin Kramerffecc842013-08-30 14:05:34 +00002512// RUN: %clang -march=slm -m64 -E -dM %s -o - 2>&1 \
2513// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002514// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SLM_M64
Freddy Ye548e08c2023-06-29 13:29:00 +08002515// RUN: %clang -march=silvermont -m64 -E -dM %s -o - 2>&1 \
2516// RUN: -target i386-unknown-linux \
2517// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SLM_M64
Craig Topper921aff62017-12-22 05:09:38 +00002518// CHECK_SLM_M64: #define __FXSR__ 1
Benjamin Kramerffecc842013-08-30 14:05:34 +00002519// CHECK_SLM_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00002520// CHECK_SLM_M64: #define __MOVBE__ 1
Craig Topper921aff62017-12-22 05:09:38 +00002521// CHECK_SLM_M64: #define __PCLMUL__ 1
2522// CHECK_SLM_M64: #define __POPCNT__ 1
Craig Topper66b110e2017-12-22 04:51:00 +00002523// CHECK_SLM_M64: #define __PRFCHW__ 1
Craig Topperace5c372018-01-26 19:34:45 +00002524// CHECK_SLM_M64: #define __RDRND__ 1
Benjamin Kramerffecc842013-08-30 14:05:34 +00002525// CHECK_SLM_M64: #define __SSE2_MATH__ 1
2526// CHECK_SLM_M64: #define __SSE2__ 1
2527// CHECK_SLM_M64: #define __SSE3__ 1
2528// CHECK_SLM_M64: #define __SSE4_1__ 1
2529// CHECK_SLM_M64: #define __SSE4_2__ 1
2530// CHECK_SLM_M64: #define __SSE_MATH__ 1
2531// CHECK_SLM_M64: #define __SSE__ 1
2532// CHECK_SLM_M64: #define __SSSE3__ 1
2533// CHECK_SLM_M64: #define __amd64 1
2534// CHECK_SLM_M64: #define __amd64__ 1
2535// CHECK_SLM_M64: #define __slm 1
2536// CHECK_SLM_M64: #define __slm__ 1
2537// CHECK_SLM_M64: #define __tune_slm__ 1
2538// CHECK_SLM_M64: #define __x86_64 1
2539// CHECK_SLM_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002540
Andrey Turetskiyfd259ff2016-04-05 15:04:26 +00002541// RUN: %clang -march=lakemont -m32 -E -dM %s -o - 2>&1 \
2542// RUN: -target i386-unknown-linux \
Craig Toppera2b907a2017-11-01 02:18:49 +00002543// RUN: | FileCheck %s -check-prefix=CHECK_LAKEMONT_M32
2544// CHECK_LAKEMONT_M32: #define __i386 1
2545// CHECK_LAKEMONT_M32: #define __i386__ 1
2546// CHECK_LAKEMONT_M32: #define __i586 1
2547// CHECK_LAKEMONT_M32: #define __i586__ 1
2548// CHECK_LAKEMONT_M32: #define __pentium 1
2549// CHECK_LAKEMONT_M32: #define __pentium__ 1
2550// CHECK_LAKEMONT_M32: #define __tune_lakemont__ 1
2551// CHECK_LAKEMONT_M32: #define i386 1
Andrey Turetskiyfd259ff2016-04-05 15:04:26 +00002552// RUN: not %clang -march=lakemont -m64 -E -dM %s -o - 2>&1 \
2553// RUN: -target i386-unknown-linux \
Craig Toppera2b907a2017-11-01 02:18:49 +00002554// RUN: | FileCheck %s -check-prefix=CHECK_LAKEMONT_M64
2555// CHECK_LAKEMONT_M64: error:
Gabor Buellac9e976c2018-04-12 18:15:39 +00002556
Freddy Ye84a18a22022-11-09 16:12:25 +08002557// RUN: %clang -march=sierraforest -m32 -E -dM %s -o - 2>&1 \
2558// RUN: --target=i386 \
2559// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SRF_M32
Freddy Ye5cc4b102023-07-25 11:00:04 +08002560// RUN: %clang -march=grandridge -m32 -E -dM %s -o - 2>&1 \
2561// RUN: --target=i386 \
Freddy Ye19e78462023-12-28 10:06:54 +08002562// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_SRF_M32
Freddy Yec9d92e62023-07-28 10:13:03 +08002563// RUN: %clang -march=arrowlake -m32 -E -dM %s -o - 2>&1 \
2564// RUN: -target i386-unknown-linux \
2565// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SRF_M32
2566// RUN: %clang -march=arrowlake-s -m32 -E -dM %s -o - 2>&1 \
2567// RUN: -target i386-unknown-linux \
2568// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_SRF_M32,CHECK_ARLS_M32
2569// RUN: %clang -march=lunarlake -m32 -E -dM %s -o - 2>&1 \
2570// RUN: -target i386-unknown-linux \
2571// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_SRF_M32,CHECK_ARLS_M32
Freddy Ye278e5332023-10-19 15:11:15 +08002572// RUN: %clang -march=pantherlake -m32 -E -dM %s -o - 2>&1 \
2573// RUN: -target i386-unknown-linux \
2574// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_SRF_M32,CHECK_ARLS_M32,CHECK_PTL_M32
2575// RUN: %clang -march=clearwaterforest -m32 -E -dM %s -o - 2>&1 \
2576// RUN: -target i386-unknown-linux \
2577// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_SRF_M32,CHECK_ARLS_M32,CHECK_PTL_M32,CHECK_CWF_M32
Freddy Ye84a18a22022-11-09 16:12:25 +08002578// CHECK_SRF_M32: #define __ADX__ 1
2579// CHECK_SRF_M32: #define __AES__ 1
2580// CHECK_SRF_M32: #define __AVX2__ 1
2581// CHECK_SRF_M32-NOT: AVX512
2582// CHECK_SRF_M32: #define __AVXIFMA__ 1
2583// CHECK_SRF_M32: #define __AVXNECONVERT__ 1
Freddy Yec9d92e62023-07-28 10:13:03 +08002584// CHECK_SRF_M32-NOT: #define __AVXVNNIINT16__ 1
2585// CHECK_ARLS_M32: #define __AVXVNNIINT16__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002586// CHECK_SRF_M32: #define __AVXVNNIINT8__ 1
2587// CHECK_SRF_M32: #define __AVXVNNI__ 1
2588// CHECK_SRF_M32: #define __AVX__ 1
2589// CHECK_SRF_M32: #define __BMI2__ 1
2590// CHECK_SRF_M32: #define __BMI__ 1
2591// CHECK_SRF_M32: #define __CLDEMOTE__ 1
2592// CHECK_SRF_M32: #define __CLFLUSHOPT__ 1
2593// CHECK_SRF_M32: #define __CLWB__ 1
2594// CHECK_SRF_M32: #define __CMPCCXADD__ 1
Freddy Ye5cc4b102023-07-25 11:00:04 +08002595// CHECK_SRF_M32: #define __ENQCMD__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002596// CHECK_SRF_M32: #define __F16C__ 1
2597// CHECK_SRF_M32: #define __FMA__ 1
2598// CHECK_SRF_M32: #define __FSGSBASE__ 1
2599// CHECK_SRF_M32: #define __FXSR__ 1
2600// CHECK_SRF_M32: #define __GFNI__ 1
2601// CHECK_SRF_M32: #define __HRESET__ 1
2602// CHECK_SRF_M32: #define __INVPCID__ 1
2603// CHECK_SRF_M32: #define __KL__ 1
2604// CHECK_SRF_M32: #define __LZCNT__ 1
2605// CHECK_SRF_M32: #define __MMX__ 1
2606// CHECK_SRF_M32: #define __MOVBE__ 1
2607// CHECK_SRF_M32: #define __MOVDIR64B__ 1
2608// CHECK_SRF_M32: #define __MOVDIRI__ 1
2609// CHECK_SRF_M32: #define __PCLMUL__ 1
2610// CHECK_SRF_M32: #define __PCONFIG__ 1
2611// CHECK_SRF_M32: #define __PKU__ 1
2612// CHECK_SRF_M32: #define __POPCNT__ 1
Freddy Ye278e5332023-10-19 15:11:15 +08002613// CHECK_SRF_M32-NOT: #define __PREFETCHI__ 1
2614// CHECK_ARLS_M32-NOT: #define __PREFETCHI__ 1
2615// CHECK_PTL_M32: #define __PREFETCHI__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002616// CHECK_SRF_M32: #define __PRFCHW__ 1
2617// CHECK_SRF_M32: #define __PTWRITE__ 1
Freddy Ye5cc4b102023-07-25 11:00:04 +08002618// CHECK_SRF_M32-NOT: #define __RAOINT__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002619// CHECK_SRF_M32: #define __RDPID__ 1
2620// CHECK_SRF_M32: #define __RDRND__ 1
2621// CHECK_SRF_M32: #define __RDSEED__ 1
2622// CHECK_SRF_M32: #define __SERIALIZE__ 1
2623// CHECK_SRF_M32: #define __SGX__ 1
Freddy Yec9d92e62023-07-28 10:13:03 +08002624// CHECK_SRF_M32-NOT: #define __SHA512__ 1
2625// CHECK_ARLS_M32: #define __SHA512__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002626// CHECK_SRF_M32: #define __SHA__ 1
2627// CHECK_SRF_M32: #define __SHSTK__ 1
Freddy Yec9d92e62023-07-28 10:13:03 +08002628// CHECK_SRF_M32-NOT: #define __SM3__ 1
2629// CHECK_ARLS_M32: #define __SM3__ 1
2630// CHECK_SRF_M32-NOT: #define __SM4__ 1
2631// CHECK_ARLS_M32: #define __SM4__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002632// CHECK_SRF_M32: #define __SSE2__ 1
2633// CHECK_SRF_M32: #define __SSE3__ 1
2634// CHECK_SRF_M32: #define __SSE4_1__ 1
2635// CHECK_SRF_M32: #define __SSE4_2__ 1
2636// CHECK_SRF_M32: #define __SSE_MATH__ 1
2637// CHECK_SRF_M32: #define __SSE__ 1
2638// CHECK_SRF_M32: #define __SSSE3__ 1
Freddy Ye5cc4b102023-07-25 11:00:04 +08002639// CHECK_SRF_M32: #define __UINTR__ 1
Freddy Ye278e5332023-10-19 15:11:15 +08002640// CHECK_SRF_M32-NOT: #define __USERMSR__ 1
2641// CHECK_ARLS_M32-NOT: #define __USERMSR__ 1
2642// CHECK_PTL_M32-NOT: #define __USERMSR__ 1
2643// CHECK_CWF_M32: #define __USERMSR__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002644// CHECK_SRF_M32: #define __VAES__ 1
2645// CHECK_SRF_M32: #define __VPCLMULQDQ__ 1
2646// CHECK_SRF_M32: #define __WAITPKG__ 1
2647// CHECK_SRF_M32: #define __WIDEKL__ 1
2648// CHECK_SRF_M32: #define __XSAVEC__ 1
2649// CHECK_SRF_M32: #define __XSAVEOPT__ 1
2650// CHECK_SRF_M32: #define __XSAVES__ 1
2651// CHECK_SRF_M32: #define __XSAVE__ 1
2652// CHECK_SRF_M32: #define __corei7 1
2653// CHECK_SRF_M32: #define __corei7__ 1
2654// CHECK_SRF_M32: #define __i386 1
2655// CHECK_SRF_M32: #define __i386__ 1
2656// CHECK_SRF_M32: #define __tune_corei7__ 1
2657// CHECK_SRF_M32: #define i386 1
2658
2659// RUN: %clang -march=sierraforest -m64 -E -dM %s -o - 2>&1 \
2660// RUN: --target=i386 \
2661// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SRF_M64
Freddy Ye5cc4b102023-07-25 11:00:04 +08002662// RUN: %clang -march=grandridge -m64 -E -dM %s -o - 2>&1 \
2663// RUN: --target=i386 \
Freddy Ye19e78462023-12-28 10:06:54 +08002664// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_SRF_M64
Freddy Yec9d92e62023-07-28 10:13:03 +08002665// RUN: %clang -march=arrowlake -m64 -E -dM %s -o - 2>&1 \
2666// RUN: -target i386-unknown-linux \
2667// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SRF_M64
2668// RUN: %clang -march=arrowlake-s -m64 -E -dM %s -o - 2>&1 \
2669// RUN: -target i386-unknown-linux \
2670// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_SRF_M64,CHECK_ARLS_M64
2671// RUN: %clang -march=lunarlake -m64 -E -dM %s -o - 2>&1 \
2672// RUN: -target i386-unknown-linux \
2673// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_SRF_M64,CHECK_ARLS_M64
Freddy Ye278e5332023-10-19 15:11:15 +08002674// RUN: %clang -march=pantherlake -m64 -E -dM %s -o - 2>&1 \
2675// RUN: -target i386-unknown-linux \
2676// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_SRF_M64,CHECK_ARLS_M64,CHECK_PTL_M64
2677// RUN: %clang -march=clearwaterforest -m64 -E -dM %s -o - 2>&1 \
2678// RUN: -target i386-unknown-linux \
2679// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_SRF_M64,CHECK_ARLS_M64,CHECK_PTL_M64,CHECK_CWF_M64
Freddy Ye84a18a22022-11-09 16:12:25 +08002680// CHECK_SRF_M64: #define __ADX__ 1
2681// CHECK_SRF_M64: #define __AES__ 1
2682// CHECK_SRF_M64: #define __AVX2__ 1
2683// CHECK_SRF_M64-NOT: AVX512
2684// CHECK_SRF_M64: #define __AVXIFMA__ 1
2685// CHECK_SRF_M64: #define __AVXNECONVERT__ 1
Freddy Yec9d92e62023-07-28 10:13:03 +08002686// CHECK_SRF_M64-NOT: #define __AVXVNNIINT16__ 1
2687// CHECK_ARLS_M64: #define __AVXVNNIINT16__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002688// CHECK_SRF_M64: #define __AVXVNNIINT8__ 1
2689// CHECK_SRF_M64: #define __AVXVNNI__ 1
2690// CHECK_SRF_M64: #define __AVX__ 1
2691// CHECK_SRF_M64: #define __BMI2__ 1
2692// CHECK_SRF_M64: #define __BMI__ 1
2693// CHECK_SRF_M64: #define __CLDEMOTE__ 1
2694// CHECK_SRF_M64: #define __CLFLUSHOPT__ 1
2695// CHECK_SRF_M64: #define __CLWB__ 1
2696// CHECK_SRF_M64: #define __CMPCCXADD__ 1
Freddy Ye5cc4b102023-07-25 11:00:04 +08002697// CHECK_SRF_M64: #define __ENQCMD__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002698// CHECK_SRF_M64: #define __F16C__ 1
2699// CHECK_SRF_M64: #define __FMA__ 1
2700// CHECK_SRF_M64: #define __FSGSBASE__ 1
2701// CHECK_SRF_M64: #define __FXSR__ 1
2702// CHECK_SRF_M64: #define __GFNI__ 1
2703// CHECK_SRF_M64: #define __HRESET__ 1
2704// CHECK_SRF_M64: #define __INVPCID__ 1
2705// CHECK_SRF_M64: #define __KL__ 1
2706// CHECK_SRF_M64: #define __LZCNT__ 1
2707// CHECK_SRF_M64: #define __MMX__ 1
2708// CHECK_SRF_M64: #define __MOVBE__ 1
2709// CHECK_SRF_M64: #define __MOVDIR64B__ 1
2710// CHECK_SRF_M64: #define __MOVDIRI__ 1
2711// CHECK_SRF_M64: #define __PCLMUL__ 1
2712// CHECK_SRF_M64: #define __PCONFIG__ 1
2713// CHECK_SRF_M64: #define __PKU__ 1
2714// CHECK_SRF_M64: #define __POPCNT__ 1
Freddy Ye278e5332023-10-19 15:11:15 +08002715// CHECK_SRF_M64-NOT: #define __PREFETCHI__ 1
2716// CHECK_ARLS_M64-NOT: #define __PREFETCHI__ 1
2717// CHECK_PTL_M64: #define __PREFETCHI__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002718// CHECK_SRF_M64: #define __PRFCHW__ 1
2719// CHECK_SRF_M64: #define __PTWRITE__ 1
Freddy Ye5cc4b102023-07-25 11:00:04 +08002720// CHECK_SRF_M64-NOT: #define __RAOINT__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002721// CHECK_SRF_M64: #define __RDPID__ 1
2722// CHECK_SRF_M64: #define __RDRND__ 1
2723// CHECK_SRF_M64: #define __RDSEED__ 1
2724// CHECK_SRF_M64: #define __SERIALIZE__ 1
2725// CHECK_SRF_M64: #define __SGX__ 1
Freddy Yec9d92e62023-07-28 10:13:03 +08002726// CHECK_SRF_M64-NOT: #define __SHA512__ 1
2727// CHECK_ARLS_M64: #define __SHA512__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002728// CHECK_SRF_M64: #define __SHA__ 1
2729// CHECK_SRF_M64: #define __SHSTK__ 1
Freddy Yec9d92e62023-07-28 10:13:03 +08002730// CHECK_SRF_M64-NOT: #define __SM3__ 1
2731// CHECK_ARLS_M64: #define __SM3__ 1
2732// CHECK_SRF_M64-NOT: #define __SM4__ 1
2733// CHECK_ARLS_M64: #define __SM4__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002734// CHECK_SRF_M64: #define __SSE2_MATH__ 1
2735// CHECK_SRF_M64: #define __SSE2__ 1
2736// CHECK_SRF_M64: #define __SSE3__ 1
2737// CHECK_SRF_M64: #define __SSE4_1__ 1
2738// CHECK_SRF_M64: #define __SSE4_2__ 1
2739// CHECK_SRF_M64: #define __SSE_MATH__ 1
2740// CHECK_SRF_M64: #define __SSE__ 1
2741// CHECK_SRF_M64: #define __SSSE3__ 1
Freddy Ye5cc4b102023-07-25 11:00:04 +08002742// CHECK_SRF_M64: #define __UINTR__ 1
Freddy Ye278e5332023-10-19 15:11:15 +08002743// CHECK_SRF_M64-NOT: #define __USERMSR__ 1
2744// CHECK_ARLS_M64-NOT: #define __USERMSR__ 1
2745// CHECK_PTL_M64-NOT: #define __USERMSR__ 1
2746// CHECK_CWF_M64: #define __USERMSR__ 1
Freddy Ye84a18a22022-11-09 16:12:25 +08002747// CHECK_SRF_M64: #define __VAES__ 1
2748// CHECK_SRF_M64: #define __VPCLMULQDQ__ 1
2749// CHECK_SRF_M64: #define __WAITPKG__ 1
2750// CHECK_SRF_M64: #define __WIDEKL__ 1
2751// CHECK_SRF_M64: #define __XSAVEC__ 1
2752// CHECK_SRF_M64: #define __XSAVEOPT__ 1
2753// CHECK_SRF_M64: #define __XSAVES__ 1
2754// CHECK_SRF_M64: #define __XSAVE__ 1
2755// CHECK_SRF_M64: #define __amd64 1
2756// CHECK_SRF_M64: #define __amd64__ 1
2757// CHECK_SRF_M64: #define __corei7 1
2758// CHECK_SRF_M64: #define __corei7__ 1
2759// CHECK_SRF_M64: #define __tune_corei7__ 1
2760// CHECK_SRF_M64: #define __x86_64 1
2761// CHECK_SRF_M64: #define __x86_64__ 1
2762
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002763// RUN: %clang -march=geode -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002764// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002765// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_GEODE_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002766// CHECK_GEODE_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002767// CHECK_GEODE_M32: #define __geode 1
2768// CHECK_GEODE_M32: #define __geode__ 1
2769// CHECK_GEODE_M32: #define __i386 1
2770// CHECK_GEODE_M32: #define __i386__ 1
2771// CHECK_GEODE_M32: #define __tune_geode__ 1
2772// CHECK_GEODE_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00002773// RUN: not %clang -march=geode -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002774// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002775// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_GEODE_M64
2776// CHECK_GEODE_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00002777
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002778// RUN: %clang -march=k6 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002779// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002780// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002781// CHECK_K6_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002782// CHECK_K6_M32: #define __i386 1
2783// CHECK_K6_M32: #define __i386__ 1
2784// CHECK_K6_M32: #define __k6 1
2785// CHECK_K6_M32: #define __k6__ 1
2786// CHECK_K6_M32: #define __tune_k6__ 1
2787// CHECK_K6_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00002788// RUN: not %clang -march=k6 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002789// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002790// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_M64
2791// CHECK_K6_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00002792
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002793// RUN: %clang -march=k6-2 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002794// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002795// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_2_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002796// CHECK_K6_2_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002797// CHECK_K6_2_M32: #define __i386 1
2798// CHECK_K6_2_M32: #define __i386__ 1
2799// CHECK_K6_2_M32: #define __k6 1
2800// CHECK_K6_2_M32: #define __k6_2__ 1
2801// CHECK_K6_2_M32: #define __k6__ 1
2802// CHECK_K6_2_M32: #define __tune_k6_2__ 1
2803// CHECK_K6_2_M32: #define __tune_k6__ 1
2804// CHECK_K6_2_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00002805// RUN: not %clang -march=k6-2 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002806// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002807// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_2_M64
2808// CHECK_K6_2_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00002809
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002810// RUN: %clang -march=k6-3 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002811// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002812// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_3_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002813// CHECK_K6_3_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002814// CHECK_K6_3_M32: #define __i386 1
2815// CHECK_K6_3_M32: #define __i386__ 1
2816// CHECK_K6_3_M32: #define __k6 1
2817// CHECK_K6_3_M32: #define __k6_3__ 1
2818// CHECK_K6_3_M32: #define __k6__ 1
2819// CHECK_K6_3_M32: #define __tune_k6_3__ 1
2820// CHECK_K6_3_M32: #define __tune_k6__ 1
2821// CHECK_K6_3_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00002822// RUN: not %clang -march=k6-3 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002823// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002824// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K6_3_M64
2825// CHECK_K6_3_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00002826
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002827// RUN: %clang -march=athlon -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002828// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002829// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002830// CHECK_ATHLON_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002831// CHECK_ATHLON_M32: #define __athlon 1
2832// CHECK_ATHLON_M32: #define __athlon__ 1
2833// CHECK_ATHLON_M32: #define __i386 1
2834// CHECK_ATHLON_M32: #define __i386__ 1
2835// CHECK_ATHLON_M32: #define __tune_athlon__ 1
2836// CHECK_ATHLON_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00002837// RUN: not %clang -march=athlon -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002838// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002839// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_M64
2840// CHECK_ATHLON_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00002841
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002842// RUN: %clang -march=athlon-tbird -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002843// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002844// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_TBIRD_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002845// CHECK_ATHLON_TBIRD_M32: #define __MMX__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002846// CHECK_ATHLON_TBIRD_M32: #define __athlon 1
2847// CHECK_ATHLON_TBIRD_M32: #define __athlon__ 1
2848// CHECK_ATHLON_TBIRD_M32: #define __i386 1
2849// CHECK_ATHLON_TBIRD_M32: #define __i386__ 1
2850// CHECK_ATHLON_TBIRD_M32: #define __tune_athlon__ 1
2851// CHECK_ATHLON_TBIRD_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00002852// RUN: not %clang -march=athlon-tbird -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002853// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002854// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_TBIRD_M64
2855// CHECK_ATHLON_TBIRD_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00002856
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002857// RUN: %clang -march=athlon-4 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002858// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002859// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_4_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002860// CHECK_ATHLON_4_M32: #define __MMX__ 1
2861// CHECK_ATHLON_4_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002862// CHECK_ATHLON_4_M32: #define __athlon 1
2863// CHECK_ATHLON_4_M32: #define __athlon__ 1
2864// CHECK_ATHLON_4_M32: #define __athlon_sse__ 1
2865// CHECK_ATHLON_4_M32: #define __i386 1
2866// CHECK_ATHLON_4_M32: #define __i386__ 1
2867// CHECK_ATHLON_4_M32: #define __tune_athlon__ 1
Chandler Carruth5d0feef2011-09-28 09:54:11 +00002868// CHECK_ATHLON_4_M32: #define __tune_athlon_sse__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002869// CHECK_ATHLON_4_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00002870// RUN: not %clang -march=athlon-4 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002871// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002872// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_4_M64
2873// CHECK_ATHLON_4_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00002874
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002875// RUN: %clang -march=athlon-xp -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002876// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002877// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_XP_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002878// CHECK_ATHLON_XP_M32: #define __MMX__ 1
2879// CHECK_ATHLON_XP_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002880// CHECK_ATHLON_XP_M32: #define __athlon 1
2881// CHECK_ATHLON_XP_M32: #define __athlon__ 1
2882// CHECK_ATHLON_XP_M32: #define __athlon_sse__ 1
2883// CHECK_ATHLON_XP_M32: #define __i386 1
2884// CHECK_ATHLON_XP_M32: #define __i386__ 1
2885// CHECK_ATHLON_XP_M32: #define __tune_athlon__ 1
Chandler Carruth5d0feef2011-09-28 09:54:11 +00002886// CHECK_ATHLON_XP_M32: #define __tune_athlon_sse__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002887// CHECK_ATHLON_XP_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00002888// RUN: not %clang -march=athlon-xp -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002889// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002890// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_XP_M64
2891// CHECK_ATHLON_XP_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00002892
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002893// RUN: %clang -march=athlon-mp -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002894// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002895// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_MP_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002896// CHECK_ATHLON_MP_M32: #define __MMX__ 1
2897// CHECK_ATHLON_MP_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002898// CHECK_ATHLON_MP_M32: #define __athlon 1
2899// CHECK_ATHLON_MP_M32: #define __athlon__ 1
2900// CHECK_ATHLON_MP_M32: #define __athlon_sse__ 1
2901// CHECK_ATHLON_MP_M32: #define __i386 1
2902// CHECK_ATHLON_MP_M32: #define __i386__ 1
2903// CHECK_ATHLON_MP_M32: #define __tune_athlon__ 1
Chandler Carruth5d0feef2011-09-28 09:54:11 +00002904// CHECK_ATHLON_MP_M32: #define __tune_athlon_sse__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002905// CHECK_ATHLON_MP_M32: #define i386 1
Rafael Espindola925213b2013-07-04 16:16:58 +00002906// RUN: not %clang -march=athlon-mp -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002907// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002908// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_MP_M64
2909// CHECK_ATHLON_MP_M64: error: {{.*}}
Gabor Buellac9e976c2018-04-12 18:15:39 +00002910
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002911// RUN: %clang -march=x86-64 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002912// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002913// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_X86_64_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002914// CHECK_X86_64_M32: #define __MMX__ 1
2915// CHECK_X86_64_M32: #define __SSE2__ 1
2916// CHECK_X86_64_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002917// CHECK_X86_64_M32: #define __i386 1
2918// CHECK_X86_64_M32: #define __i386__ 1
2919// CHECK_X86_64_M32: #define __k8 1
2920// CHECK_X86_64_M32: #define __k8__ 1
2921// CHECK_X86_64_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002922
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002923// RUN: %clang -march=k8 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002924// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002925// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K8_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002926// CHECK_K8_M32: #define __MMX__ 1
2927// CHECK_K8_M32: #define __SSE2__ 1
2928// CHECK_K8_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002929// CHECK_K8_M32: #define __i386 1
2930// CHECK_K8_M32: #define __i386__ 1
2931// CHECK_K8_M32: #define __k8 1
2932// CHECK_K8_M32: #define __k8__ 1
2933// CHECK_K8_M32: #define __tune_k8__ 1
2934// CHECK_K8_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002935
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00002936// RUN: %clang -march=k8 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002937// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002938// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K8_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002939// CHECK_K8_M64: #define __MMX__ 1
2940// CHECK_K8_M64: #define __SSE2_MATH__ 1
2941// CHECK_K8_M64: #define __SSE2__ 1
2942// CHECK_K8_M64: #define __SSE_MATH__ 1
2943// CHECK_K8_M64: #define __SSE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00002944// CHECK_K8_M64: #define __amd64 1
2945// CHECK_K8_M64: #define __amd64__ 1
2946// CHECK_K8_M64: #define __k8 1
2947// CHECK_K8_M64: #define __k8__ 1
2948// CHECK_K8_M64: #define __tune_k8__ 1
2949// CHECK_K8_M64: #define __x86_64 1
2950// CHECK_K8_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002951
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002952// RUN: %clang -march=k8-sse3 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002953// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002954// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K8_SSE3_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002955// CHECK_K8_SSE3_M32: #define __MMX__ 1
2956// CHECK_K8_SSE3_M32: #define __SSE2__ 1
2957// CHECK_K8_SSE3_M32: #define __SSE3__ 1
2958// CHECK_K8_SSE3_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002959// CHECK_K8_SSE3_M32: #define __i386 1
2960// CHECK_K8_SSE3_M32: #define __i386__ 1
2961// CHECK_K8_SSE3_M32: #define __k8 1
2962// CHECK_K8_SSE3_M32: #define __k8__ 1
2963// CHECK_K8_SSE3_M32: #define __tune_k8__ 1
2964// CHECK_K8_SSE3_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002965
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00002966// RUN: %clang -march=k8-sse3 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002967// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002968// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_K8_SSE3_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002969// CHECK_K8_SSE3_M64: #define __MMX__ 1
2970// CHECK_K8_SSE3_M64: #define __SSE2_MATH__ 1
2971// CHECK_K8_SSE3_M64: #define __SSE2__ 1
2972// CHECK_K8_SSE3_M64: #define __SSE3__ 1
2973// CHECK_K8_SSE3_M64: #define __SSE_MATH__ 1
2974// CHECK_K8_SSE3_M64: #define __SSE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00002975// CHECK_K8_SSE3_M64: #define __amd64 1
2976// CHECK_K8_SSE3_M64: #define __amd64__ 1
2977// CHECK_K8_SSE3_M64: #define __k8 1
2978// CHECK_K8_SSE3_M64: #define __k8__ 1
2979// CHECK_K8_SSE3_M64: #define __tune_k8__ 1
2980// CHECK_K8_SSE3_M64: #define __x86_64 1
2981// CHECK_K8_SSE3_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002982
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002983// RUN: %clang -march=opteron -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002984// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002985// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_OPTERON_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002986// CHECK_OPTERON_M32: #define __MMX__ 1
2987// CHECK_OPTERON_M32: #define __SSE2__ 1
2988// CHECK_OPTERON_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002989// CHECK_OPTERON_M32: #define __i386 1
2990// CHECK_OPTERON_M32: #define __i386__ 1
2991// CHECK_OPTERON_M32: #define __k8 1
2992// CHECK_OPTERON_M32: #define __k8__ 1
2993// CHECK_OPTERON_M32: #define __tune_k8__ 1
2994// CHECK_OPTERON_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00002995
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00002996// RUN: %clang -march=opteron -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00002997// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00002998// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_OPTERON_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002999// CHECK_OPTERON_M64: #define __MMX__ 1
3000// CHECK_OPTERON_M64: #define __SSE2_MATH__ 1
3001// CHECK_OPTERON_M64: #define __SSE2__ 1
3002// CHECK_OPTERON_M64: #define __SSE_MATH__ 1
3003// CHECK_OPTERON_M64: #define __SSE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00003004// CHECK_OPTERON_M64: #define __amd64 1
3005// CHECK_OPTERON_M64: #define __amd64__ 1
3006// CHECK_OPTERON_M64: #define __k8 1
3007// CHECK_OPTERON_M64: #define __k8__ 1
3008// CHECK_OPTERON_M64: #define __tune_k8__ 1
3009// CHECK_OPTERON_M64: #define __x86_64 1
3010// CHECK_OPTERON_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003011
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00003012// RUN: %clang -march=opteron-sse3 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00003013// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003014// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_OPTERON_SSE3_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00003015// CHECK_OPTERON_SSE3_M32: #define __MMX__ 1
3016// CHECK_OPTERON_SSE3_M32: #define __SSE2__ 1
3017// CHECK_OPTERON_SSE3_M32: #define __SSE3__ 1
3018// CHECK_OPTERON_SSE3_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00003019// CHECK_OPTERON_SSE3_M32: #define __i386 1
3020// CHECK_OPTERON_SSE3_M32: #define __i386__ 1
3021// CHECK_OPTERON_SSE3_M32: #define __k8 1
3022// CHECK_OPTERON_SSE3_M32: #define __k8__ 1
3023// CHECK_OPTERON_SSE3_M32: #define __tune_k8__ 1
3024// CHECK_OPTERON_SSE3_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003025
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00003026// RUN: %clang -march=opteron-sse3 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00003027// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003028// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_OPTERON_SSE3_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +00003029// CHECK_OPTERON_SSE3_M64: #define __MMX__ 1
3030// CHECK_OPTERON_SSE3_M64: #define __SSE2_MATH__ 1
3031// CHECK_OPTERON_SSE3_M64: #define __SSE2__ 1
3032// CHECK_OPTERON_SSE3_M64: #define __SSE3__ 1
3033// CHECK_OPTERON_SSE3_M64: #define __SSE_MATH__ 1
3034// CHECK_OPTERON_SSE3_M64: #define __SSE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00003035// CHECK_OPTERON_SSE3_M64: #define __amd64 1
3036// CHECK_OPTERON_SSE3_M64: #define __amd64__ 1
3037// CHECK_OPTERON_SSE3_M64: #define __k8 1
3038// CHECK_OPTERON_SSE3_M64: #define __k8__ 1
3039// CHECK_OPTERON_SSE3_M64: #define __tune_k8__ 1
3040// CHECK_OPTERON_SSE3_M64: #define __x86_64 1
3041// CHECK_OPTERON_SSE3_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003042
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00003043// RUN: %clang -march=athlon64 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00003044// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003045// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON64_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00003046// CHECK_ATHLON64_M32: #define __MMX__ 1
3047// CHECK_ATHLON64_M32: #define __SSE2__ 1
3048// CHECK_ATHLON64_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00003049// CHECK_ATHLON64_M32: #define __i386 1
3050// CHECK_ATHLON64_M32: #define __i386__ 1
3051// CHECK_ATHLON64_M32: #define __k8 1
3052// CHECK_ATHLON64_M32: #define __k8__ 1
3053// CHECK_ATHLON64_M32: #define __tune_k8__ 1
3054// CHECK_ATHLON64_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003055
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00003056// RUN: %clang -march=athlon64 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00003057// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003058// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON64_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +00003059// CHECK_ATHLON64_M64: #define __MMX__ 1
3060// CHECK_ATHLON64_M64: #define __SSE2_MATH__ 1
3061// CHECK_ATHLON64_M64: #define __SSE2__ 1
3062// CHECK_ATHLON64_M64: #define __SSE_MATH__ 1
3063// CHECK_ATHLON64_M64: #define __SSE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00003064// CHECK_ATHLON64_M64: #define __amd64 1
3065// CHECK_ATHLON64_M64: #define __amd64__ 1
3066// CHECK_ATHLON64_M64: #define __k8 1
3067// CHECK_ATHLON64_M64: #define __k8__ 1
3068// CHECK_ATHLON64_M64: #define __tune_k8__ 1
3069// CHECK_ATHLON64_M64: #define __x86_64 1
3070// CHECK_ATHLON64_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003071
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00003072// RUN: %clang -march=athlon64-sse3 -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00003073// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003074// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON64_SSE3_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00003075// CHECK_ATHLON64_SSE3_M32: #define __MMX__ 1
3076// CHECK_ATHLON64_SSE3_M32: #define __SSE2__ 1
3077// CHECK_ATHLON64_SSE3_M32: #define __SSE3__ 1
3078// CHECK_ATHLON64_SSE3_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00003079// CHECK_ATHLON64_SSE3_M32: #define __i386 1
3080// CHECK_ATHLON64_SSE3_M32: #define __i386__ 1
3081// CHECK_ATHLON64_SSE3_M32: #define __k8 1
3082// CHECK_ATHLON64_SSE3_M32: #define __k8__ 1
3083// CHECK_ATHLON64_SSE3_M32: #define __tune_k8__ 1
3084// CHECK_ATHLON64_SSE3_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003085
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00003086// RUN: %clang -march=athlon64-sse3 -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00003087// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003088// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON64_SSE3_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +00003089// CHECK_ATHLON64_SSE3_M64: #define __MMX__ 1
3090// CHECK_ATHLON64_SSE3_M64: #define __SSE2_MATH__ 1
3091// CHECK_ATHLON64_SSE3_M64: #define __SSE2__ 1
3092// CHECK_ATHLON64_SSE3_M64: #define __SSE3__ 1
3093// CHECK_ATHLON64_SSE3_M64: #define __SSE_MATH__ 1
3094// CHECK_ATHLON64_SSE3_M64: #define __SSE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00003095// CHECK_ATHLON64_SSE3_M64: #define __amd64 1
3096// CHECK_ATHLON64_SSE3_M64: #define __amd64__ 1
3097// CHECK_ATHLON64_SSE3_M64: #define __k8 1
3098// CHECK_ATHLON64_SSE3_M64: #define __k8__ 1
3099// CHECK_ATHLON64_SSE3_M64: #define __tune_k8__ 1
3100// CHECK_ATHLON64_SSE3_M64: #define __x86_64 1
3101// CHECK_ATHLON64_SSE3_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003102
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00003103// RUN: %clang -march=athlon-fx -m32 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00003104// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003105// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_FX_M32
Chandler Carruthcd99bad2011-09-28 10:36:46 +00003106// CHECK_ATHLON_FX_M32: #define __MMX__ 1
3107// CHECK_ATHLON_FX_M32: #define __SSE2__ 1
3108// CHECK_ATHLON_FX_M32: #define __SSE__ 1
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00003109// CHECK_ATHLON_FX_M32: #define __i386 1
3110// CHECK_ATHLON_FX_M32: #define __i386__ 1
3111// CHECK_ATHLON_FX_M32: #define __k8 1
3112// CHECK_ATHLON_FX_M32: #define __k8__ 1
3113// CHECK_ATHLON_FX_M32: #define __tune_k8__ 1
3114// CHECK_ATHLON_FX_M32: #define i386 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003115
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00003116// RUN: %clang -march=athlon-fx -m64 -E -dM %s -o - 2>&1 \
Simon Atanasyance005eb2012-05-09 18:49:52 +00003117// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003118// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ATHLON_FX_M64
Chandler Carruthcd99bad2011-09-28 10:36:46 +00003119// CHECK_ATHLON_FX_M64: #define __MMX__ 1
3120// CHECK_ATHLON_FX_M64: #define __SSE2_MATH__ 1
3121// CHECK_ATHLON_FX_M64: #define __SSE2__ 1
3122// CHECK_ATHLON_FX_M64: #define __SSE_MATH__ 1
3123// CHECK_ATHLON_FX_M64: #define __SSE__ 1
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00003124// CHECK_ATHLON_FX_M64: #define __amd64 1
3125// CHECK_ATHLON_FX_M64: #define __amd64__ 1
3126// CHECK_ATHLON_FX_M64: #define __k8 1
3127// CHECK_ATHLON_FX_M64: #define __k8__ 1
3128// CHECK_ATHLON_FX_M64: #define __tune_k8__ 1
3129// CHECK_ATHLON_FX_M64: #define __x86_64 1
3130// CHECK_ATHLON_FX_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003131
Eli Friedman3e94f572012-11-17 01:43:10 +00003132// RUN: %clang -march=amdfam10 -m32 -E -dM %s -o - 2>&1 \
3133// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003134// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_AMDFAM10_M32
Fangrui Songcbe4d972020-10-10 22:21:47 -07003135// CHECK_AMDFAM10_M32: #define __LAHF_SAHF__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003136// CHECK_AMDFAM10_M32: #define __LZCNT__ 1
3137// CHECK_AMDFAM10_M32: #define __MMX__ 1
3138// CHECK_AMDFAM10_M32: #define __POPCNT__ 1
Craig Topper6673d692020-06-25 11:45:09 -07003139// CHECK_AMDFAM10_M32: #define __PRFCHW__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003140// CHECK_AMDFAM10_M32: #define __SSE2_MATH__ 1
3141// CHECK_AMDFAM10_M32: #define __SSE2__ 1
3142// CHECK_AMDFAM10_M32: #define __SSE3__ 1
3143// CHECK_AMDFAM10_M32: #define __SSE4A__ 1
3144// CHECK_AMDFAM10_M32: #define __SSE_MATH__ 1
3145// CHECK_AMDFAM10_M32: #define __SSE__ 1
Craig Toppere6bb4c8e2020-09-08 10:49:32 -07003146// CHECK_AMDFAM10_M32-NOT: #define __SSSE3__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003147// CHECK_AMDFAM10_M32: #define __amdfam10 1
3148// CHECK_AMDFAM10_M32: #define __amdfam10__ 1
3149// CHECK_AMDFAM10_M32: #define __i386 1
3150// CHECK_AMDFAM10_M32: #define __i386__ 1
3151// CHECK_AMDFAM10_M32: #define __tune_amdfam10__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003152
Benjamin Kramer8ac9c222012-05-29 17:48:39 +00003153// RUN: %clang -march=amdfam10 -m64 -E -dM %s -o - 2>&1 \
3154// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003155// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_AMDFAM10_M64
Craig Toppera7db2302020-06-25 22:55:36 -07003156// CHECK_AMDFAM10_M64: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_16 1
Fangrui Songcbe4d972020-10-10 22:21:47 -07003157// CHECK_AMDFAM10_M64: #define __LAHF_SAHF__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003158// CHECK_AMDFAM10_M64: #define __LZCNT__ 1
Benjamin Kramer8ac9c222012-05-29 17:48:39 +00003159// CHECK_AMDFAM10_M64: #define __MMX__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003160// CHECK_AMDFAM10_M64: #define __POPCNT__ 1
Craig Topper6673d692020-06-25 11:45:09 -07003161// CHECK_AMDFAM10_M64: #define __PRFCHW__ 1
Benjamin Kramer8ac9c222012-05-29 17:48:39 +00003162// CHECK_AMDFAM10_M64: #define __SSE2_MATH__ 1
3163// CHECK_AMDFAM10_M64: #define __SSE2__ 1
3164// CHECK_AMDFAM10_M64: #define __SSE3__ 1
3165// CHECK_AMDFAM10_M64: #define __SSE4A__ 1
3166// CHECK_AMDFAM10_M64: #define __SSE_MATH__ 1
3167// CHECK_AMDFAM10_M64: #define __SSE__ 1
Craig Toppere6bb4c8e2020-09-08 10:49:32 -07003168// CHECK_AMDFAM10_M64-NOT: #define __SSSE3__ 1
Benjamin Kramer8ac9c222012-05-29 17:48:39 +00003169// CHECK_AMDFAM10_M64: #define __amd64 1
3170// CHECK_AMDFAM10_M64: #define __amd64__ 1
3171// CHECK_AMDFAM10_M64: #define __amdfam10 1
3172// CHECK_AMDFAM10_M64: #define __amdfam10__ 1
3173// CHECK_AMDFAM10_M64: #define __tune_amdfam10__ 1
3174// CHECK_AMDFAM10_M64: #define __x86_64 1
3175// CHECK_AMDFAM10_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003176
Eli Friedman3e94f572012-11-17 01:43:10 +00003177// RUN: %clang -march=btver1 -m32 -E -dM %s -o - 2>&1 \
3178// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003179// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BTVER1_M32
Fangrui Songcbe4d972020-10-10 22:21:47 -07003180// CHECK_BTVER1_M32: #define __LAHF_SAHF__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003181// CHECK_BTVER1_M32: #define __LZCNT__ 1
3182// CHECK_BTVER1_M32: #define __MMX__ 1
3183// CHECK_BTVER1_M32: #define __POPCNT__ 1
Yunzhong Gao61089362013-10-16 19:07:02 +00003184// CHECK_BTVER1_M32: #define __PRFCHW__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003185// CHECK_BTVER1_M32: #define __SSE2_MATH__ 1
3186// CHECK_BTVER1_M32: #define __SSE2__ 1
3187// CHECK_BTVER1_M32: #define __SSE3__ 1
3188// CHECK_BTVER1_M32: #define __SSE4A__ 1
3189// CHECK_BTVER1_M32: #define __SSE_MATH__ 1
3190// CHECK_BTVER1_M32: #define __SSE__ 1
3191// CHECK_BTVER1_M32: #define __SSSE3__ 1
3192// CHECK_BTVER1_M32: #define __btver1 1
3193// CHECK_BTVER1_M32: #define __btver1__ 1
3194// CHECK_BTVER1_M32: #define __i386 1
3195// CHECK_BTVER1_M32: #define __i386__ 1
3196// CHECK_BTVER1_M32: #define __tune_btver1__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003197
Eli Friedman3e94f572012-11-17 01:43:10 +00003198// RUN: %clang -march=btver1 -m64 -E -dM %s -o - 2>&1 \
3199// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003200// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BTVER1_M64
Fangrui Songcbe4d972020-10-10 22:21:47 -07003201// CHECK_BTVER1_M64: #define __LAHF_SAHF__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003202// CHECK_BTVER1_M64: #define __LZCNT__ 1
3203// CHECK_BTVER1_M64: #define __MMX__ 1
3204// CHECK_BTVER1_M64: #define __POPCNT__ 1
Yunzhong Gao61089362013-10-16 19:07:02 +00003205// CHECK_BTVER1_M64: #define __PRFCHW__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003206// CHECK_BTVER1_M64: #define __SSE2_MATH__ 1
3207// CHECK_BTVER1_M64: #define __SSE2__ 1
3208// CHECK_BTVER1_M64: #define __SSE3__ 1
3209// CHECK_BTVER1_M64: #define __SSE4A__ 1
3210// CHECK_BTVER1_M64: #define __SSE_MATH__ 1
3211// CHECK_BTVER1_M64: #define __SSE__ 1
3212// CHECK_BTVER1_M64: #define __SSSE3__ 1
3213// CHECK_BTVER1_M64: #define __amd64 1
3214// CHECK_BTVER1_M64: #define __amd64__ 1
3215// CHECK_BTVER1_M64: #define __btver1 1
3216// CHECK_BTVER1_M64: #define __btver1__ 1
3217// CHECK_BTVER1_M64: #define __tune_btver1__ 1
3218// CHECK_BTVER1_M64: #define __x86_64 1
3219// CHECK_BTVER1_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003220
Benjamin Kramer914d7e02013-05-03 10:47:15 +00003221// RUN: %clang -march=btver2 -m32 -E -dM %s -o - 2>&1 \
3222// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003223// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BTVER2_M32
Benjamin Kramer914d7e02013-05-03 10:47:15 +00003224// CHECK_BTVER2_M32: #define __AES__ 1
3225// CHECK_BTVER2_M32: #define __AVX__ 1
Andrea Di Biagio9760a442014-11-06 12:08:57 +00003226// CHECK_BTVER2_M32: #define __BMI__ 1
3227// CHECK_BTVER2_M32: #define __F16C__ 1
Benjamin Kramer914d7e02013-05-03 10:47:15 +00003228// CHECK_BTVER2_M32: #define __LZCNT__ 1
3229// CHECK_BTVER2_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00003230// CHECK_BTVER2_M32: #define __MOVBE__ 1
Andrea Di Biagio9760a442014-11-06 12:08:57 +00003231// CHECK_BTVER2_M32: #define __PCLMUL__ 1
Benjamin Kramer914d7e02013-05-03 10:47:15 +00003232// CHECK_BTVER2_M32: #define __POPCNT__ 1
Yunzhong Gao61089362013-10-16 19:07:02 +00003233// CHECK_BTVER2_M32: #define __PRFCHW__ 1
Benjamin Kramer914d7e02013-05-03 10:47:15 +00003234// CHECK_BTVER2_M32: #define __SSE2_MATH__ 1
3235// CHECK_BTVER2_M32: #define __SSE2__ 1
3236// CHECK_BTVER2_M32: #define __SSE3__ 1
3237// CHECK_BTVER2_M32: #define __SSE4A__ 1
3238// CHECK_BTVER2_M32: #define __SSE_MATH__ 1
3239// CHECK_BTVER2_M32: #define __SSE__ 1
3240// CHECK_BTVER2_M32: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00003241// CHECK_BTVER2_M32: #define __XSAVEOPT__ 1
3242// CHECK_BTVER2_M32: #define __XSAVE__ 1
Benjamin Kramer914d7e02013-05-03 10:47:15 +00003243// CHECK_BTVER2_M32: #define __btver2 1
3244// CHECK_BTVER2_M32: #define __btver2__ 1
3245// CHECK_BTVER2_M32: #define __i386 1
3246// CHECK_BTVER2_M32: #define __i386__ 1
3247// CHECK_BTVER2_M32: #define __tune_btver2__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003248
Benjamin Kramer914d7e02013-05-03 10:47:15 +00003249// RUN: %clang -march=btver2 -m64 -E -dM %s -o - 2>&1 \
3250// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003251// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BTVER2_M64
Benjamin Kramer914d7e02013-05-03 10:47:15 +00003252// CHECK_BTVER2_M64: #define __AES__ 1
3253// CHECK_BTVER2_M64: #define __AVX__ 1
Andrea Di Biagio9760a442014-11-06 12:08:57 +00003254// CHECK_BTVER2_M64: #define __BMI__ 1
3255// CHECK_BTVER2_M64: #define __F16C__ 1
Benjamin Kramer914d7e02013-05-03 10:47:15 +00003256// CHECK_BTVER2_M64: #define __LZCNT__ 1
3257// CHECK_BTVER2_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00003258// CHECK_BTVER2_M64: #define __MOVBE__ 1
Andrea Di Biagio9760a442014-11-06 12:08:57 +00003259// CHECK_BTVER2_M64: #define __PCLMUL__ 1
Benjamin Kramer914d7e02013-05-03 10:47:15 +00003260// CHECK_BTVER2_M64: #define __POPCNT__ 1
Yunzhong Gao61089362013-10-16 19:07:02 +00003261// CHECK_BTVER2_M64: #define __PRFCHW__ 1
Benjamin Kramer914d7e02013-05-03 10:47:15 +00003262// CHECK_BTVER2_M64: #define __SSE2_MATH__ 1
3263// CHECK_BTVER2_M64: #define __SSE2__ 1
3264// CHECK_BTVER2_M64: #define __SSE3__ 1
3265// CHECK_BTVER2_M64: #define __SSE4A__ 1
3266// CHECK_BTVER2_M64: #define __SSE_MATH__ 1
3267// CHECK_BTVER2_M64: #define __SSE__ 1
3268// CHECK_BTVER2_M64: #define __SSSE3__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00003269// CHECK_BTVER2_M64: #define __XSAVEOPT__ 1
3270// CHECK_BTVER2_M64: #define __XSAVE__ 1
Benjamin Kramer914d7e02013-05-03 10:47:15 +00003271// CHECK_BTVER2_M64: #define __amd64 1
3272// CHECK_BTVER2_M64: #define __amd64__ 1
3273// CHECK_BTVER2_M64: #define __btver2 1
3274// CHECK_BTVER2_M64: #define __btver2__ 1
3275// CHECK_BTVER2_M64: #define __tune_btver2__ 1
3276// CHECK_BTVER2_M64: #define __x86_64 1
3277// CHECK_BTVER2_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003278
Eli Friedman3e94f572012-11-17 01:43:10 +00003279// RUN: %clang -march=bdver1 -m32 -E -dM %s -o - 2>&1 \
3280// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003281// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER1_M32
Eli Friedman3e94f572012-11-17 01:43:10 +00003282// CHECK_BDVER1_M32: #define __AES__ 1
3283// CHECK_BDVER1_M32: #define __AVX__ 1
3284// CHECK_BDVER1_M32: #define __FMA4__ 1
Simon Pilgrim0fd1b6c2017-05-08 17:25:48 +00003285// CHECK_BDVER1_M32: #define __LWP__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003286// CHECK_BDVER1_M32: #define __LZCNT__ 1
3287// CHECK_BDVER1_M32: #define __MMX__ 1
3288// CHECK_BDVER1_M32: #define __PCLMUL__ 1
3289// CHECK_BDVER1_M32: #define __POPCNT__ 1
Yunzhong Gao61089362013-10-16 19:07:02 +00003290// CHECK_BDVER1_M32: #define __PRFCHW__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003291// CHECK_BDVER1_M32: #define __SSE2_MATH__ 1
3292// CHECK_BDVER1_M32: #define __SSE2__ 1
3293// CHECK_BDVER1_M32: #define __SSE3__ 1
3294// CHECK_BDVER1_M32: #define __SSE4A__ 1
3295// CHECK_BDVER1_M32: #define __SSE4_1__ 1
3296// CHECK_BDVER1_M32: #define __SSE4_2__ 1
3297// CHECK_BDVER1_M32: #define __SSE_MATH__ 1
3298// CHECK_BDVER1_M32: #define __SSE__ 1
3299// CHECK_BDVER1_M32: #define __SSSE3__ 1
3300// CHECK_BDVER1_M32: #define __XOP__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00003301// CHECK_BDVER1_M32: #define __XSAVE__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003302// CHECK_BDVER1_M32: #define __bdver1 1
3303// CHECK_BDVER1_M32: #define __bdver1__ 1
3304// CHECK_BDVER1_M32: #define __i386 1
3305// CHECK_BDVER1_M32: #define __i386__ 1
3306// CHECK_BDVER1_M32: #define __tune_bdver1__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003307
Benjamin Kramer8ac9c222012-05-29 17:48:39 +00003308// RUN: %clang -march=bdver1 -m64 -E -dM %s -o - 2>&1 \
3309// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003310// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER1_M64
Eli Friedman3e94f572012-11-17 01:43:10 +00003311// CHECK_BDVER1_M64: #define __AES__ 1
3312// CHECK_BDVER1_M64: #define __AVX__ 1
Craig Topperf561a9562012-06-09 22:24:14 +00003313// CHECK_BDVER1_M64: #define __FMA4__ 1
Simon Pilgrim0fd1b6c2017-05-08 17:25:48 +00003314// CHECK_BDVER1_M64: #define __LWP__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003315// CHECK_BDVER1_M64: #define __LZCNT__ 1
Benjamin Kramer8ac9c222012-05-29 17:48:39 +00003316// CHECK_BDVER1_M64: #define __MMX__ 1
Craig Topperf561a9562012-06-09 22:24:14 +00003317// CHECK_BDVER1_M64: #define __PCLMUL__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003318// CHECK_BDVER1_M64: #define __POPCNT__ 1
Yunzhong Gao61089362013-10-16 19:07:02 +00003319// CHECK_BDVER1_M64: #define __PRFCHW__ 1
Benjamin Kramer8ac9c222012-05-29 17:48:39 +00003320// CHECK_BDVER1_M64: #define __SSE2_MATH__ 1
3321// CHECK_BDVER1_M64: #define __SSE2__ 1
3322// CHECK_BDVER1_M64: #define __SSE3__ 1
3323// CHECK_BDVER1_M64: #define __SSE4A__ 1
3324// CHECK_BDVER1_M64: #define __SSE4_1__ 1
3325// CHECK_BDVER1_M64: #define __SSE4_2__ 1
3326// CHECK_BDVER1_M64: #define __SSE_MATH__ 1
3327// CHECK_BDVER1_M64: #define __SSE__ 1
3328// CHECK_BDVER1_M64: #define __SSSE3__ 1
Craig Topperf561a9562012-06-09 22:24:14 +00003329// CHECK_BDVER1_M64: #define __XOP__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00003330// CHECK_BDVER1_M64: #define __XSAVE__ 1
Benjamin Kramer8ac9c222012-05-29 17:48:39 +00003331// CHECK_BDVER1_M64: #define __amd64 1
3332// CHECK_BDVER1_M64: #define __amd64__ 1
3333// CHECK_BDVER1_M64: #define __bdver1 1
3334// CHECK_BDVER1_M64: #define __bdver1__ 1
3335// CHECK_BDVER1_M64: #define __tune_bdver1__ 1
3336// CHECK_BDVER1_M64: #define __x86_64 1
3337// CHECK_BDVER1_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003338
Eli Friedman3e94f572012-11-17 01:43:10 +00003339// RUN: %clang -march=bdver2 -m32 -E -dM %s -o - 2>&1 \
3340// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003341// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER2_M32
Eli Friedman3e94f572012-11-17 01:43:10 +00003342// CHECK_BDVER2_M32: #define __AES__ 1
3343// CHECK_BDVER2_M32: #define __AVX__ 1
3344// CHECK_BDVER2_M32: #define __BMI__ 1
3345// CHECK_BDVER2_M32: #define __F16C__ 1
3346// CHECK_BDVER2_M32: #define __FMA4__ 1
3347// CHECK_BDVER2_M32: #define __FMA__ 1
Simon Pilgrim0fd1b6c2017-05-08 17:25:48 +00003348// CHECK_BDVER2_M32: #define __LWP__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003349// CHECK_BDVER2_M32: #define __LZCNT__ 1
3350// CHECK_BDVER2_M32: #define __MMX__ 1
3351// CHECK_BDVER2_M32: #define __PCLMUL__ 1
3352// CHECK_BDVER2_M32: #define __POPCNT__ 1
Yunzhong Gao61089362013-10-16 19:07:02 +00003353// CHECK_BDVER2_M32: #define __PRFCHW__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003354// CHECK_BDVER2_M32: #define __SSE2_MATH__ 1
3355// CHECK_BDVER2_M32: #define __SSE2__ 1
3356// CHECK_BDVER2_M32: #define __SSE3__ 1
3357// CHECK_BDVER2_M32: #define __SSE4A__ 1
3358// CHECK_BDVER2_M32: #define __SSE4_1__ 1
3359// CHECK_BDVER2_M32: #define __SSE4_2__ 1
3360// CHECK_BDVER2_M32: #define __SSE_MATH__ 1
3361// CHECK_BDVER2_M32: #define __SSE__ 1
3362// CHECK_BDVER2_M32: #define __SSSE3__ 1
Yunzhong Gao1f6aeeb2013-09-24 19:00:58 +00003363// CHECK_BDVER2_M32: #define __TBM__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003364// CHECK_BDVER2_M32: #define __XOP__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00003365// CHECK_BDVER2_M32: #define __XSAVE__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003366// CHECK_BDVER2_M32: #define __bdver2 1
3367// CHECK_BDVER2_M32: #define __bdver2__ 1
3368// CHECK_BDVER2_M32: #define __i386 1
3369// CHECK_BDVER2_M32: #define __i386__ 1
3370// CHECK_BDVER2_M32: #define __tune_bdver2__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003371
Eli Friedman3e94f572012-11-17 01:43:10 +00003372// RUN: %clang -march=bdver2 -m64 -E -dM %s -o - 2>&1 \
3373// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003374// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER2_M64
Eli Friedman3e94f572012-11-17 01:43:10 +00003375// CHECK_BDVER2_M64: #define __AES__ 1
3376// CHECK_BDVER2_M64: #define __AVX__ 1
3377// CHECK_BDVER2_M64: #define __BMI__ 1
3378// CHECK_BDVER2_M64: #define __F16C__ 1
3379// CHECK_BDVER2_M64: #define __FMA4__ 1
3380// CHECK_BDVER2_M64: #define __FMA__ 1
Simon Pilgrim0fd1b6c2017-05-08 17:25:48 +00003381// CHECK_BDVER2_M64: #define __LWP__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003382// CHECK_BDVER2_M64: #define __LZCNT__ 1
3383// CHECK_BDVER2_M64: #define __MMX__ 1
3384// CHECK_BDVER2_M64: #define __PCLMUL__ 1
3385// CHECK_BDVER2_M64: #define __POPCNT__ 1
Yunzhong Gao61089362013-10-16 19:07:02 +00003386// CHECK_BDVER2_M64: #define __PRFCHW__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003387// CHECK_BDVER2_M64: #define __SSE2_MATH__ 1
3388// CHECK_BDVER2_M64: #define __SSE2__ 1
3389// CHECK_BDVER2_M64: #define __SSE3__ 1
3390// CHECK_BDVER2_M64: #define __SSE4A__ 1
3391// CHECK_BDVER2_M64: #define __SSE4_1__ 1
3392// CHECK_BDVER2_M64: #define __SSE4_2__ 1
3393// CHECK_BDVER2_M64: #define __SSE_MATH__ 1
3394// CHECK_BDVER2_M64: #define __SSE__ 1
3395// CHECK_BDVER2_M64: #define __SSSE3__ 1
Yunzhong Gao1f6aeeb2013-09-24 19:00:58 +00003396// CHECK_BDVER2_M64: #define __TBM__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003397// CHECK_BDVER2_M64: #define __XOP__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00003398// CHECK_BDVER2_M64: #define __XSAVE__ 1
Eli Friedman3e94f572012-11-17 01:43:10 +00003399// CHECK_BDVER2_M64: #define __amd64 1
3400// CHECK_BDVER2_M64: #define __amd64__ 1
3401// CHECK_BDVER2_M64: #define __bdver2 1
3402// CHECK_BDVER2_M64: #define __bdver2__ 1
3403// CHECK_BDVER2_M64: #define __tune_bdver2__ 1
3404// CHECK_BDVER2_M64: #define __x86_64 1
3405// CHECK_BDVER2_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003406
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00003407// RUN: %clang -march=bdver3 -m32 -E -dM %s -o - 2>&1 \
3408// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003409// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER3_M32
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00003410// CHECK_BDVER3_M32: #define __AES__ 1
3411// CHECK_BDVER3_M32: #define __AVX__ 1
3412// CHECK_BDVER3_M32: #define __BMI__ 1
3413// CHECK_BDVER3_M32: #define __F16C__ 1
3414// CHECK_BDVER3_M32: #define __FMA4__ 1
3415// CHECK_BDVER3_M32: #define __FMA__ 1
Andrea Di Biagio9760a442014-11-06 12:08:57 +00003416// CHECK_BDVER3_M32: #define __FSGSBASE__ 1
Simon Pilgrim0fd1b6c2017-05-08 17:25:48 +00003417// CHECK_BDVER3_M32: #define __LWP__ 1
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00003418// CHECK_BDVER3_M32: #define __LZCNT__ 1
3419// CHECK_BDVER3_M32: #define __MMX__ 1
3420// CHECK_BDVER3_M32: #define __PCLMUL__ 1
3421// CHECK_BDVER3_M32: #define __POPCNT__ 1
3422// CHECK_BDVER3_M32: #define __PRFCHW__ 1
3423// CHECK_BDVER3_M32: #define __SSE2_MATH__ 1
3424// CHECK_BDVER3_M32: #define __SSE2__ 1
3425// CHECK_BDVER3_M32: #define __SSE3__ 1
3426// CHECK_BDVER3_M32: #define __SSE4A__ 1
3427// CHECK_BDVER3_M32: #define __SSE4_1__ 1
3428// CHECK_BDVER3_M32: #define __SSE4_2__ 1
3429// CHECK_BDVER3_M32: #define __SSE_MATH__ 1
3430// CHECK_BDVER3_M32: #define __SSE__ 1
3431// CHECK_BDVER3_M32: #define __SSSE3__ 1
3432// CHECK_BDVER3_M32: #define __TBM__ 1
3433// CHECK_BDVER3_M32: #define __XOP__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00003434// CHECK_BDVER3_M32: #define __XSAVEOPT__ 1
3435// CHECK_BDVER3_M32: #define __XSAVE__ 1
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00003436// CHECK_BDVER3_M32: #define __bdver3 1
3437// CHECK_BDVER3_M32: #define __bdver3__ 1
3438// CHECK_BDVER3_M32: #define __i386 1
3439// CHECK_BDVER3_M32: #define __i386__ 1
3440// CHECK_BDVER3_M32: #define __tune_bdver3__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003441
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00003442// RUN: %clang -march=bdver3 -m64 -E -dM %s -o - 2>&1 \
3443// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003444// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER3_M64
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00003445// CHECK_BDVER3_M64: #define __AES__ 1
3446// CHECK_BDVER3_M64: #define __AVX__ 1
3447// CHECK_BDVER3_M64: #define __BMI__ 1
3448// CHECK_BDVER3_M64: #define __F16C__ 1
3449// CHECK_BDVER3_M64: #define __FMA4__ 1
3450// CHECK_BDVER3_M64: #define __FMA__ 1
Andrea Di Biagio9760a442014-11-06 12:08:57 +00003451// CHECK_BDVER3_M64: #define __FSGSBASE__ 1
Simon Pilgrim0fd1b6c2017-05-08 17:25:48 +00003452// CHECK_BDVER3_M64: #define __LWP__ 1
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00003453// CHECK_BDVER3_M64: #define __LZCNT__ 1
3454// CHECK_BDVER3_M64: #define __MMX__ 1
3455// CHECK_BDVER3_M64: #define __PCLMUL__ 1
3456// CHECK_BDVER3_M64: #define __POPCNT__ 1
3457// CHECK_BDVER3_M64: #define __PRFCHW__ 1
3458// CHECK_BDVER3_M64: #define __SSE2_MATH__ 1
3459// CHECK_BDVER3_M64: #define __SSE2__ 1
3460// CHECK_BDVER3_M64: #define __SSE3__ 1
3461// CHECK_BDVER3_M64: #define __SSE4A__ 1
3462// CHECK_BDVER3_M64: #define __SSE4_1__ 1
3463// CHECK_BDVER3_M64: #define __SSE4_2__ 1
3464// CHECK_BDVER3_M64: #define __SSE_MATH__ 1
3465// CHECK_BDVER3_M64: #define __SSE__ 1
3466// CHECK_BDVER3_M64: #define __SSSE3__ 1
3467// CHECK_BDVER3_M64: #define __TBM__ 1
3468// CHECK_BDVER3_M64: #define __XOP__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00003469// CHECK_BDVER3_M64: #define __XSAVEOPT__ 1
3470// CHECK_BDVER3_M64: #define __XSAVE__ 1
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00003471// CHECK_BDVER3_M64: #define __amd64 1
3472// CHECK_BDVER3_M64: #define __amd64__ 1
3473// CHECK_BDVER3_M64: #define __bdver3 1
3474// CHECK_BDVER3_M64: #define __bdver3__ 1
3475// CHECK_BDVER3_M64: #define __tune_bdver3__ 1
3476// CHECK_BDVER3_M64: #define __x86_64 1
3477// CHECK_BDVER3_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003478
Benjamin Kramer56c58222014-05-02 15:47:51 +00003479// RUN: %clang -march=bdver4 -m32 -E -dM %s -o - 2>&1 \
3480// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003481// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER4_M32
Benjamin Kramer56c58222014-05-02 15:47:51 +00003482// CHECK_BDVER4_M32: #define __AES__ 1
3483// CHECK_BDVER4_M32: #define __AVX2__ 1
3484// CHECK_BDVER4_M32: #define __AVX__ 1
3485// CHECK_BDVER4_M32: #define __BMI2__ 1
3486// CHECK_BDVER4_M32: #define __BMI__ 1
3487// CHECK_BDVER4_M32: #define __F16C__ 1
3488// CHECK_BDVER4_M32: #define __FMA4__ 1
3489// CHECK_BDVER4_M32: #define __FMA__ 1
Andrea Di Biagio9760a442014-11-06 12:08:57 +00003490// CHECK_BDVER4_M32: #define __FSGSBASE__ 1
Simon Pilgrim0fd1b6c2017-05-08 17:25:48 +00003491// CHECK_BDVER4_M32: #define __LWP__ 1
Benjamin Kramer56c58222014-05-02 15:47:51 +00003492// CHECK_BDVER4_M32: #define __LZCNT__ 1
3493// CHECK_BDVER4_M32: #define __MMX__ 1
Craig Topper9e8b5a22020-06-26 23:32:17 -07003494// CHECK_BDVER4_M32: #define __MOVBE__ 1
Benjamin Kramer56c58222014-05-02 15:47:51 +00003495// CHECK_BDVER4_M32: #define __PCLMUL__ 1
3496// CHECK_BDVER4_M32: #define __POPCNT__ 1
3497// CHECK_BDVER4_M32: #define __PRFCHW__ 1
Craig Topper9e8b5a22020-06-26 23:32:17 -07003498// CHECK_BDVER4_M32: #define __RDRND__ 1
Benjamin Kramer56c58222014-05-02 15:47:51 +00003499// CHECK_BDVER4_M32: #define __SSE2_MATH__ 1
3500// CHECK_BDVER4_M32: #define __SSE2__ 1
3501// CHECK_BDVER4_M32: #define __SSE3__ 1
3502// CHECK_BDVER4_M32: #define __SSE4A__ 1
3503// CHECK_BDVER4_M32: #define __SSE4_1__ 1
3504// CHECK_BDVER4_M32: #define __SSE4_2__ 1
3505// CHECK_BDVER4_M32: #define __SSE_MATH__ 1
3506// CHECK_BDVER4_M32: #define __SSE__ 1
3507// CHECK_BDVER4_M32: #define __SSSE3__ 1
3508// CHECK_BDVER4_M32: #define __TBM__ 1
3509// CHECK_BDVER4_M32: #define __XOP__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00003510// CHECK_BDVER4_M32: #define __XSAVE__ 1
Benjamin Kramer56c58222014-05-02 15:47:51 +00003511// CHECK_BDVER4_M32: #define __bdver4 1
3512// CHECK_BDVER4_M32: #define __bdver4__ 1
3513// CHECK_BDVER4_M32: #define __i386 1
3514// CHECK_BDVER4_M32: #define __i386__ 1
3515// CHECK_BDVER4_M32: #define __tune_bdver4__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003516
Benjamin Kramer56c58222014-05-02 15:47:51 +00003517// RUN: %clang -march=bdver4 -m64 -E -dM %s -o - 2>&1 \
3518// RUN: -target i386-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00003519// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_BDVER4_M64
Benjamin Kramer56c58222014-05-02 15:47:51 +00003520// CHECK_BDVER4_M64: #define __AES__ 1
3521// CHECK_BDVER4_M64: #define __AVX2__ 1
3522// CHECK_BDVER4_M64: #define __AVX__ 1
3523// CHECK_BDVER4_M64: #define __BMI2__ 1
3524// CHECK_BDVER4_M64: #define __BMI__ 1
3525// CHECK_BDVER4_M64: #define __F16C__ 1
3526// CHECK_BDVER4_M64: #define __FMA4__ 1
3527// CHECK_BDVER4_M64: #define __FMA__ 1
Andrea Di Biagio9760a442014-11-06 12:08:57 +00003528// CHECK_BDVER4_M64: #define __FSGSBASE__ 1
Simon Pilgrim0fd1b6c2017-05-08 17:25:48 +00003529// CHECK_BDVER4_M64: #define __LWP__ 1
Benjamin Kramer56c58222014-05-02 15:47:51 +00003530// CHECK_BDVER4_M64: #define __LZCNT__ 1
3531// CHECK_BDVER4_M64: #define __MMX__ 1
Craig Topper9e8b5a22020-06-26 23:32:17 -07003532// CHECK_BDVER4_M64: #define __MOVBE__ 1
Benjamin Kramer56c58222014-05-02 15:47:51 +00003533// CHECK_BDVER4_M64: #define __PCLMUL__ 1
3534// CHECK_BDVER4_M64: #define __POPCNT__ 1
3535// CHECK_BDVER4_M64: #define __PRFCHW__ 1
Craig Topper9e8b5a22020-06-26 23:32:17 -07003536// CHECK_BDVER4_M64: #define __RDRND__ 1
Benjamin Kramer56c58222014-05-02 15:47:51 +00003537// CHECK_BDVER4_M64: #define __SSE2_MATH__ 1
3538// CHECK_BDVER4_M64: #define __SSE2__ 1
3539// CHECK_BDVER4_M64: #define __SSE3__ 1
3540// CHECK_BDVER4_M64: #define __SSE4A__ 1
3541// CHECK_BDVER4_M64: #define __SSE4_1__ 1
3542// CHECK_BDVER4_M64: #define __SSE4_2__ 1
3543// CHECK_BDVER4_M64: #define __SSE_MATH__ 1
3544// CHECK_BDVER4_M64: #define __SSE__ 1
3545// CHECK_BDVER4_M64: #define __SSSE3__ 1
3546// CHECK_BDVER4_M64: #define __TBM__ 1
3547// CHECK_BDVER4_M64: #define __XOP__ 1
Craig Topperda9fe562015-10-15 05:23:38 +00003548// CHECK_BDVER4_M64: #define __XSAVE__ 1
Benjamin Kramer56c58222014-05-02 15:47:51 +00003549// CHECK_BDVER4_M64: #define __amd64 1
3550// CHECK_BDVER4_M64: #define __amd64__ 1
3551// CHECK_BDVER4_M64: #define __bdver4 1
3552// CHECK_BDVER4_M64: #define __bdver4__ 1
3553// CHECK_BDVER4_M64: #define __tune_bdver4__ 1
3554// CHECK_BDVER4_M64: #define __x86_64 1
3555// CHECK_BDVER4_M64: #define __x86_64__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003556
Craig Topperc45744a2017-01-10 06:02:12 +00003557// RUN: %clang -march=znver1 -m32 -E -dM %s -o - 2>&1 \
3558// RUN: -target i386-unknown-linux \
3559// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER1_M32
Craig Topperc45744a2017-01-10 06:02:12 +00003560// CHECK_ZNVER1_M32: #define __ADX__ 1
3561// CHECK_ZNVER1_M32: #define __AES__ 1
3562// CHECK_ZNVER1_M32: #define __AVX2__ 1
3563// CHECK_ZNVER1_M32: #define __AVX__ 1
3564// CHECK_ZNVER1_M32: #define __BMI2__ 1
3565// CHECK_ZNVER1_M32: #define __BMI__ 1
Craig Topper78b47872017-02-08 06:48:58 +00003566// CHECK_ZNVER1_M32: #define __CLFLUSHOPT__ 1
Craig Topper45742262017-02-09 06:10:14 +00003567// CHECK_ZNVER1_M32: #define __CLZERO__ 1
Craig Topperc45744a2017-01-10 06:02:12 +00003568// CHECK_ZNVER1_M32: #define __F16C__ 1
Craig Topperf886f072020-06-30 09:58:48 -07003569// CHECK_ZNVER1_M32-NOT: #define __FMA4__ 1
Craig Topperc45744a2017-01-10 06:02:12 +00003570// CHECK_ZNVER1_M32: #define __FMA__ 1
3571// CHECK_ZNVER1_M32: #define __FSGSBASE__ 1
3572// CHECK_ZNVER1_M32: #define __LZCNT__ 1
3573// CHECK_ZNVER1_M32: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00003574// CHECK_ZNVER1_M32: #define __MOVBE__ 1
Craig Topperc45744a2017-01-10 06:02:12 +00003575// CHECK_ZNVER1_M32: #define __PCLMUL__ 1
3576// CHECK_ZNVER1_M32: #define __POPCNT__ 1
3577// CHECK_ZNVER1_M32: #define __PRFCHW__ 1
3578// CHECK_ZNVER1_M32: #define __RDRND__ 1
3579// CHECK_ZNVER1_M32: #define __RDSEED__ 1
3580// CHECK_ZNVER1_M32: #define __SHA__ 1
3581// CHECK_ZNVER1_M32: #define __SSE2_MATH__ 1
3582// CHECK_ZNVER1_M32: #define __SSE2__ 1
3583// CHECK_ZNVER1_M32: #define __SSE3__ 1
3584// CHECK_ZNVER1_M32: #define __SSE4A__ 1
3585// CHECK_ZNVER1_M32: #define __SSE4_1__ 1
3586// CHECK_ZNVER1_M32: #define __SSE4_2__ 1
3587// CHECK_ZNVER1_M32: #define __SSE_MATH__ 1
3588// CHECK_ZNVER1_M32: #define __SSE__ 1
3589// CHECK_ZNVER1_M32: #define __SSSE3__ 1
Craig Topperf886f072020-06-30 09:58:48 -07003590// CHECK_ZNVER1_M32-NOT: #define __TBM__ 1
3591// CHECK_ZNVER1_M32-NOT: #define __XOP__ 1
Craig Topperc45744a2017-01-10 06:02:12 +00003592// CHECK_ZNVER1_M32: #define __XSAVEC__ 1
3593// CHECK_ZNVER1_M32: #define __XSAVEOPT__ 1
3594// CHECK_ZNVER1_M32: #define __XSAVES__ 1
3595// CHECK_ZNVER1_M32: #define __XSAVE__ 1
3596// CHECK_ZNVER1_M32: #define __i386 1
3597// CHECK_ZNVER1_M32: #define __i386__ 1
3598// CHECK_ZNVER1_M32: #define __tune_znver1__ 1
3599// CHECK_ZNVER1_M32: #define __znver1 1
3600// CHECK_ZNVER1_M32: #define __znver1__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003601
Craig Topperc45744a2017-01-10 06:02:12 +00003602// RUN: %clang -march=znver1 -m64 -E -dM %s -o - 2>&1 \
3603// RUN: -target i386-unknown-linux \
3604// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER1_M64
Craig Topperc45744a2017-01-10 06:02:12 +00003605// CHECK_ZNVER1_M64: #define __ADX__ 1
3606// CHECK_ZNVER1_M64: #define __AES__ 1
3607// CHECK_ZNVER1_M64: #define __AVX2__ 1
3608// CHECK_ZNVER1_M64: #define __AVX__ 1
3609// CHECK_ZNVER1_M64: #define __BMI2__ 1
3610// CHECK_ZNVER1_M64: #define __BMI__ 1
Craig Topper78b47872017-02-08 06:48:58 +00003611// CHECK_ZNVER1_M64: #define __CLFLUSHOPT__ 1
Craig Topper45742262017-02-09 06:10:14 +00003612// CHECK_ZNVER1_M64: #define __CLZERO__ 1
Craig Topperc45744a2017-01-10 06:02:12 +00003613// CHECK_ZNVER1_M64: #define __F16C__ 1
Craig Topperf886f072020-06-30 09:58:48 -07003614// CHECK_ZNVER1_M64-NOT: #define __FMA4__ 1
Craig Topperc45744a2017-01-10 06:02:12 +00003615// CHECK_ZNVER1_M64: #define __FMA__ 1
3616// CHECK_ZNVER1_M64: #define __FSGSBASE__ 1
Fangrui Songcbe4d972020-10-10 22:21:47 -07003617// CHECK_ZNVER1_M64: #define __LAHF_SAHF__ 1
Craig Topperc45744a2017-01-10 06:02:12 +00003618// CHECK_ZNVER1_M64: #define __LZCNT__ 1
3619// CHECK_ZNVER1_M64: #define __MMX__ 1
Craig Topper6ad92202018-09-28 17:09:51 +00003620// CHECK_ZNVER1_M64: #define __MOVBE__ 1
Craig Topperc45744a2017-01-10 06:02:12 +00003621// CHECK_ZNVER1_M64: #define __PCLMUL__ 1
3622// CHECK_ZNVER1_M64: #define __POPCNT__ 1
3623// CHECK_ZNVER1_M64: #define __PRFCHW__ 1
3624// CHECK_ZNVER1_M64: #define __RDRND__ 1
3625// CHECK_ZNVER1_M64: #define __RDSEED__ 1
3626// CHECK_ZNVER1_M64: #define __SHA__ 1
3627// CHECK_ZNVER1_M64: #define __SSE2_MATH__ 1
3628// CHECK_ZNVER1_M64: #define __SSE2__ 1
3629// CHECK_ZNVER1_M64: #define __SSE3__ 1
3630// CHECK_ZNVER1_M64: #define __SSE4A__ 1
3631// CHECK_ZNVER1_M64: #define __SSE4_1__ 1
3632// CHECK_ZNVER1_M64: #define __SSE4_2__ 1
3633// CHECK_ZNVER1_M64: #define __SSE_MATH__ 1
3634// CHECK_ZNVER1_M64: #define __SSE__ 1
3635// CHECK_ZNVER1_M64: #define __SSSE3__ 1
Craig Topperf886f072020-06-30 09:58:48 -07003636// CHECK_ZNVER1_M64-NOT: #define __TBM__ 1
3637// CHECK_ZNVER1_M64-NOT: #define __XOP__ 1
Craig Topperc45744a2017-01-10 06:02:12 +00003638// CHECK_ZNVER1_M64: #define __XSAVEC__ 1
3639// CHECK_ZNVER1_M64: #define __XSAVEOPT__ 1
3640// CHECK_ZNVER1_M64: #define __XSAVES__ 1
3641// CHECK_ZNVER1_M64: #define __XSAVE__ 1
3642// CHECK_ZNVER1_M64: #define __amd64 1
3643// CHECK_ZNVER1_M64: #define __amd64__ 1
3644// CHECK_ZNVER1_M64: #define __tune_znver1__ 1
3645// CHECK_ZNVER1_M64: #define __x86_64 1
3646// CHECK_ZNVER1_M64: #define __x86_64__ 1
3647// CHECK_ZNVER1_M64: #define __znver1 1
3648// CHECK_ZNVER1_M64: #define __znver1__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00003649
Ganesh Gopalasubramanian4f171d22019-02-26 17:15:36 +00003650// RUN: %clang -march=znver2 -m32 -E -dM %s -o - 2>&1 \
3651// RUN: -target i386-unknown-linux \
3652// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER2_M32
Ganesh Gopalasubramanian4f171d22019-02-26 17:15:36 +00003653// CHECK_ZNVER2_M32: #define __ADX__ 1
3654// CHECK_ZNVER2_M32: #define __AES__ 1
3655// CHECK_ZNVER2_M32: #define __AVX2__ 1
3656// CHECK_ZNVER2_M32: #define __AVX__ 1
3657// CHECK_ZNVER2_M32: #define __BMI2__ 1
3658// CHECK_ZNVER2_M32: #define __BMI__ 1
3659// CHECK_ZNVER2_M32: #define __CLFLUSHOPT__ 1
3660// CHECK_ZNVER2_M32: #define __CLWB__ 1
3661// CHECK_ZNVER2_M32: #define __CLZERO__ 1
3662// CHECK_ZNVER2_M32: #define __F16C__ 1
Craig Topperf886f072020-06-30 09:58:48 -07003663// CHECK_ZNVER2_M32-NOT: #define __FMA4__ 1
Ganesh Gopalasubramanian4f171d22019-02-26 17:15:36 +00003664// CHECK_ZNVER2_M32: #define __FMA__ 1
3665// CHECK_ZNVER2_M32: #define __FSGSBASE__ 1
Fangrui Songcbe4d972020-10-10 22:21:47 -07003666// CHECK_ZNVER2_M32: #define __LAHF_SAHF__ 1
Ganesh Gopalasubramanian4f171d22019-02-26 17:15:36 +00003667// CHECK_ZNVER2_M32: #define __LZCNT__ 1
3668// CHECK_ZNVER2_M32: #define __MMX__ 1
3669// CHECK_ZNVER2_M32: #define __PCLMUL__ 1
3670// CHECK_ZNVER2_M32: #define __POPCNT__ 1
3671// CHECK_ZNVER2_M32: #define __PRFCHW__ 1
3672// CHECK_ZNVER2_M32: #define __RDPID__ 1
Simon Pilgrim6e19e6c2022-08-11 15:48:30 +01003673// CHECK_ZNVER2_M32: #define __RDPRU__ 1
Ganesh Gopalasubramanian4f171d22019-02-26 17:15:36 +00003674// CHECK_ZNVER2_M32: #define __RDRND__ 1
3675// CHECK_ZNVER2_M32: #define __RDSEED__ 1
3676// CHECK_ZNVER2_M32: #define __SHA__ 1
3677// CHECK_ZNVER2_M32: #define __SSE2_MATH__ 1
3678// CHECK_ZNVER2_M32: #define __SSE2__ 1
3679// CHECK_ZNVER2_M32: #define __SSE3__ 1
3680// CHECK_ZNVER2_M32: #define __SSE4A__ 1
3681// CHECK_ZNVER2_M32: #define __SSE4_1__ 1
3682// CHECK_ZNVER2_M32: #define __SSE4_2__ 1
3683// CHECK_ZNVER2_M32: #define __SSE_MATH__ 1
3684// CHECK_ZNVER2_M32: #define __SSE__ 1
3685// CHECK_ZNVER2_M32: #define __SSSE3__ 1
Craig Topperf886f072020-06-30 09:58:48 -07003686// CHECK_ZNVER2_M32-NOT: #define __TBM__ 1
Ganesh Gopalasubramanian4f171d22019-02-26 17:15:36 +00003687// CHECK_ZNVER2_M32: #define __WBNOINVD__ 1
Craig Topperf886f072020-06-30 09:58:48 -07003688// CHECK_ZNVER2_M32-NOT: #define __XOP__ 1
Ganesh Gopalasubramanian4f171d22019-02-26 17:15:36 +00003689// CHECK_ZNVER2_M32: #define __XSAVEC__ 1
3690// CHECK_ZNVER2_M32: #define __XSAVEOPT__ 1
3691// CHECK_ZNVER2_M32: #define __XSAVES__ 1
3692// CHECK_ZNVER2_M32: #define __XSAVE__ 1
3693// CHECK_ZNVER2_M32: #define __i386 1
3694// CHECK_ZNVER2_M32: #define __i386__ 1
3695// CHECK_ZNVER2_M32: #define __tune_znver2__ 1
3696// CHECK_ZNVER2_M32: #define __znver2 1
3697// CHECK_ZNVER2_M32: #define __znver2__ 1
3698
3699// RUN: %clang -march=znver2 -m64 -E -dM %s -o - 2>&1 \
3700// RUN: -target i386-unknown-linux \
3701// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER2_M64
Ganesh Gopalasubramanian4f171d22019-02-26 17:15:36 +00003702// CHECK_ZNVER2_M64: #define __ADX__ 1
3703// CHECK_ZNVER2_M64: #define __AES__ 1
3704// CHECK_ZNVER2_M64: #define __AVX2__ 1
3705// CHECK_ZNVER2_M64: #define __AVX__ 1
3706// CHECK_ZNVER2_M64: #define __BMI2__ 1
3707// CHECK_ZNVER2_M64: #define __BMI__ 1
3708// CHECK_ZNVER2_M64: #define __CLFLUSHOPT__ 1
3709// CHECK_ZNVER2_M64: #define __CLWB__ 1
3710// CHECK_ZNVER2_M64: #define __CLZERO__ 1
3711// CHECK_ZNVER2_M64: #define __F16C__ 1
Craig Topperf886f072020-06-30 09:58:48 -07003712// CHECK_ZNVER2_M64-NOT: #define __FMA4__ 1
Ganesh Gopalasubramanian4f171d22019-02-26 17:15:36 +00003713// CHECK_ZNVER2_M64: #define __FMA__ 1
3714// CHECK_ZNVER2_M64: #define __FSGSBASE__ 1
Fangrui Songcbe4d972020-10-10 22:21:47 -07003715// CHECK_ZNVER2_M64: #define __LAHF_SAHF__ 1
Ganesh Gopalasubramanian4f171d22019-02-26 17:15:36 +00003716// CHECK_ZNVER2_M64: #define __LZCNT__ 1
3717// CHECK_ZNVER2_M64: #define __MMX__ 1
3718// CHECK_ZNVER2_M64: #define __PCLMUL__ 1
3719// CHECK_ZNVER2_M64: #define __POPCNT__ 1
3720// CHECK_ZNVER2_M64: #define __PRFCHW__ 1
3721// CHECK_ZNVER2_M64: #define __RDPID__ 1
Simon Pilgrim6e19e6c2022-08-11 15:48:30 +01003722// CHECK_ZNVER2_M64: #define __RDPRU__ 1
Ganesh Gopalasubramanian4f171d22019-02-26 17:15:36 +00003723// CHECK_ZNVER2_M64: #define __RDRND__ 1
3724// CHECK_ZNVER2_M64: #define __RDSEED__ 1
3725// CHECK_ZNVER2_M64: #define __SHA__ 1
3726// CHECK_ZNVER2_M64: #define __SSE2_MATH__ 1
3727// CHECK_ZNVER2_M64: #define __SSE2__ 1
3728// CHECK_ZNVER2_M64: #define __SSE3__ 1
3729// CHECK_ZNVER2_M64: #define __SSE4A__ 1
3730// CHECK_ZNVER2_M64: #define __SSE4_1__ 1
3731// CHECK_ZNVER2_M64: #define __SSE4_2__ 1
3732// CHECK_ZNVER2_M64: #define __SSE_MATH__ 1
3733// CHECK_ZNVER2_M64: #define __SSE__ 1
3734// CHECK_ZNVER2_M64: #define __SSSE3__ 1
Craig Topperf886f072020-06-30 09:58:48 -07003735// CHECK_ZNVER2_M64-NOT: #define __TBM__ 1
Ganesh Gopalasubramanian4f171d22019-02-26 17:15:36 +00003736// CHECK_ZNVER2_M64: #define __WBNOINVD__ 1
Craig Topperf886f072020-06-30 09:58:48 -07003737// CHECK_ZNVER2_M64-NOT: #define __XOP__ 1
Ganesh Gopalasubramanian4f171d22019-02-26 17:15:36 +00003738// CHECK_ZNVER2_M64: #define __XSAVEC__ 1
3739// CHECK_ZNVER2_M64: #define __XSAVEOPT__ 1
3740// CHECK_ZNVER2_M64: #define __XSAVES__ 1
3741// CHECK_ZNVER2_M64: #define __XSAVE__ 1
3742// CHECK_ZNVER2_M64: #define __amd64 1
3743// CHECK_ZNVER2_M64: #define __amd64__ 1
3744// CHECK_ZNVER2_M64: #define __tune_znver2__ 1
3745// CHECK_ZNVER2_M64: #define __x86_64 1
3746// CHECK_ZNVER2_M64: #define __x86_64__ 1
3747// CHECK_ZNVER2_M64: #define __znver2 1
3748// CHECK_ZNVER2_M64: #define __znver2__ 1
3749
Benjamin Kramerbd2cf962020-10-24 18:00:20 +02003750// RUN: %clang -march=znver3 -m32 -E -dM %s -o - 2>&1 \
3751// RUN: -target i386-unknown-linux \
3752// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER3_M32
Benjamin Kramerbd2cf962020-10-24 18:00:20 +02003753// CHECK_ZNVER3_M32: #define __ADX__ 1
3754// CHECK_ZNVER3_M32: #define __AES__ 1
3755// CHECK_ZNVER3_M32: #define __AVX2__ 1
3756// CHECK_ZNVER3_M32: #define __AVX__ 1
3757// CHECK_ZNVER3_M32: #define __BMI2__ 1
3758// CHECK_ZNVER3_M32: #define __BMI__ 1
3759// CHECK_ZNVER3_M32: #define __CLFLUSHOPT__ 1
3760// CHECK_ZNVER3_M32: #define __CLWB__ 1
3761// CHECK_ZNVER3_M32: #define __CLZERO__ 1
3762// CHECK_ZNVER3_M32: #define __F16C__ 1
3763// CHECK_ZNVER3_M32-NOT: #define __FMA4__ 1
3764// CHECK_ZNVER3_M32: #define __FMA__ 1
3765// CHECK_ZNVER3_M32: #define __FSGSBASE__ 1
3766// CHECK_ZNVER3_M32: #define __LZCNT__ 1
3767// CHECK_ZNVER3_M32: #define __MMX__ 1
3768// CHECK_ZNVER3_M32: #define __PCLMUL__ 1
3769// CHECK_ZNVER3_M32: #define __PKU__ 1
3770// CHECK_ZNVER3_M32: #define __POPCNT__ 1
3771// CHECK_ZNVER3_M32: #define __PRFCHW__ 1
3772// CHECK_ZNVER3_M32: #define __RDPID__ 1
Simon Pilgrim6e19e6c2022-08-11 15:48:30 +01003773// CHECK_ZNVER3_M32: #define __RDPRU__ 1
Benjamin Kramerbd2cf962020-10-24 18:00:20 +02003774// CHECK_ZNVER3_M32: #define __RDRND__ 1
3775// CHECK_ZNVER3_M32: #define __RDSEED__ 1
3776// CHECK_ZNVER3_M32: #define __SHA__ 1
3777// CHECK_ZNVER3_M32: #define __SSE2_MATH__ 1
3778// CHECK_ZNVER3_M32: #define __SSE2__ 1
3779// CHECK_ZNVER3_M32: #define __SSE3__ 1
3780// CHECK_ZNVER3_M32: #define __SSE4A__ 1
3781// CHECK_ZNVER3_M32: #define __SSE4_1__ 1
3782// CHECK_ZNVER3_M32: #define __SSE4_2__ 1
3783// CHECK_ZNVER3_M32: #define __SSE_MATH__ 1
3784// CHECK_ZNVER3_M32: #define __SSE__ 1
3785// CHECK_ZNVER3_M32: #define __SSSE3__ 1
3786// CHECK_ZNVER3_M32-NOT: #define __TBM__ 1
3787// CHECK_ZNVER3_M32: #define __WBNOINVD__ 1
3788// CHECK_ZNVER3_M32-NOT: #define __XOP__ 1
3789// CHECK_ZNVER3_M32: #define __XSAVEC__ 1
3790// CHECK_ZNVER3_M32: #define __XSAVEOPT__ 1
3791// CHECK_ZNVER3_M32: #define __XSAVES__ 1
3792// CHECK_ZNVER3_M32: #define __XSAVE__ 1
3793// CHECK_ZNVER3_M32: #define __i386 1
3794// CHECK_ZNVER3_M32: #define __i386__ 1
3795// CHECK_ZNVER3_M32: #define __tune_znver3__ 1
3796// CHECK_ZNVER3_M32: #define __znver3 1
3797// CHECK_ZNVER3_M32: #define __znver3__ 1
3798
3799// RUN: %clang -march=znver3 -m64 -E -dM %s -o - 2>&1 \
3800// RUN: -target i386-unknown-linux \
3801// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER3_M64
Benjamin Kramerbd2cf962020-10-24 18:00:20 +02003802// CHECK_ZNVER3_M64: #define __ADX__ 1
3803// CHECK_ZNVER3_M64: #define __AES__ 1
3804// CHECK_ZNVER3_M64: #define __AVX2__ 1
3805// CHECK_ZNVER3_M64: #define __AVX__ 1
3806// CHECK_ZNVER3_M64: #define __BMI2__ 1
3807// CHECK_ZNVER3_M64: #define __BMI__ 1
3808// CHECK_ZNVER3_M64: #define __CLFLUSHOPT__ 1
3809// CHECK_ZNVER3_M64: #define __CLWB__ 1
3810// CHECK_ZNVER3_M64: #define __CLZERO__ 1
3811// CHECK_ZNVER3_M64: #define __F16C__ 1
3812// CHECK_ZNVER3_M64-NOT: #define __FMA4__ 1
3813// CHECK_ZNVER3_M64: #define __FMA__ 1
3814// CHECK_ZNVER3_M64: #define __FSGSBASE__ 1
3815// CHECK_ZNVER3_M64: #define __LZCNT__ 1
3816// CHECK_ZNVER3_M64: #define __MMX__ 1
3817// CHECK_ZNVER3_M64: #define __PCLMUL__ 1
3818// CHECK_ZNVER3_M64: #define __PKU__ 1
3819// CHECK_ZNVER3_M64: #define __POPCNT__ 1
3820// CHECK_ZNVER3_M64: #define __PRFCHW__ 1
3821// CHECK_ZNVER3_M64: #define __RDPID__ 1
Simon Pilgrim6e19e6c2022-08-11 15:48:30 +01003822// CHECK_ZNVER3_M64: #define __RDPRU__ 1
Benjamin Kramerbd2cf962020-10-24 18:00:20 +02003823// CHECK_ZNVER3_M64: #define __RDRND__ 1
3824// CHECK_ZNVER3_M64: #define __RDSEED__ 1
3825// CHECK_ZNVER3_M64: #define __SHA__ 1
3826// CHECK_ZNVER3_M64: #define __SSE2_MATH__ 1
3827// CHECK_ZNVER3_M64: #define __SSE2__ 1
3828// CHECK_ZNVER3_M64: #define __SSE3__ 1
3829// CHECK_ZNVER3_M64: #define __SSE4A__ 1
3830// CHECK_ZNVER3_M64: #define __SSE4_1__ 1
3831// CHECK_ZNVER3_M64: #define __SSE4_2__ 1
3832// CHECK_ZNVER3_M64: #define __SSE_MATH__ 1
3833// CHECK_ZNVER3_M64: #define __SSE__ 1
3834// CHECK_ZNVER3_M64: #define __SSSE3__ 1
3835// CHECK_ZNVER3_M64-NOT: #define __TBM__ 1
3836// CHECK_ZNVER3_M64: #define __VAES__ 1
3837// CHECK_ZNVER3_M64: #define __VPCLMULQDQ__ 1
3838// CHECK_ZNVER3_M64: #define __WBNOINVD__ 1
3839// CHECK_ZNVER3_M64-NOT: #define __XOP__ 1
3840// CHECK_ZNVER3_M64: #define __XSAVEC__ 1
3841// CHECK_ZNVER3_M64: #define __XSAVEOPT__ 1
3842// CHECK_ZNVER3_M64: #define __XSAVES__ 1
3843// CHECK_ZNVER3_M64: #define __XSAVE__ 1
3844// CHECK_ZNVER3_M64: #define __amd64 1
3845// CHECK_ZNVER3_M64: #define __amd64__ 1
3846// CHECK_ZNVER3_M64: #define __tune_znver3__ 1
3847// CHECK_ZNVER3_M64: #define __x86_64 1
3848// CHECK_ZNVER3_M64: #define __x86_64__ 1
3849// CHECK_ZNVER3_M64: #define __znver3 1
3850// CHECK_ZNVER3_M64: #define __znver3__ 1
3851
Ganesh Gopalasubramanian1f057e32022-12-15 19:28:34 +05303852// RUN: %clang -march=znver4 -m32 -E -dM %s -o - 2>&1 \
3853// RUN: -target i386-unknown-linux \
3854// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER4_M32
Ganesh Gopalasubramanian1f057e32022-12-15 19:28:34 +05303855// CHECK_ZNVER4_M32: #define __ADX__ 1
3856// CHECK_ZNVER4_M32: #define __AES__ 1
3857// CHECK_ZNVER4_M32: #define __AVX2__ 1
3858// CHECK_ZNVER4_M32: #define __AVX512BF16__ 1
3859// CHECK_ZNVER4_M32: #define __AVX512BITALG__ 1
3860// CHECK_ZNVER4_M32: #define __AVX512BW__ 1
3861// CHECK_ZNVER4_M32: #define __AVX512CD__ 1
3862// CHECK_ZNVER4_M32: #define __AVX512DQ__ 1
3863// CHECK_ZNVER4_M32: #define __AVX512F__ 1
3864// CHECK_ZNVER4_M32: #define __AVX512IFMA__ 1
3865// CHECK_ZNVER4_M32: #define __AVX512VBMI2__ 1
3866// CHECK_ZNVER4_M32: #define __AVX512VBMI__ 1
3867// CHECK_ZNVER4_M32: #define __AVX512VL__ 1
3868// CHECK_ZNVER4_M32: #define __AVX512VNNI__ 1
3869// CHECK_ZNVER4_M32: #define __AVX512VPOPCNTDQ__ 1
3870// CHECK_ZNVER4_M32: #define __AVX__ 1
3871// CHECK_ZNVER4_M32: #define __BMI2__ 1
3872// CHECK_ZNVER4_M32: #define __BMI__ 1
3873// CHECK_ZNVER4_M32: #define __CLFLUSHOPT__ 1
3874// CHECK_ZNVER4_M32: #define __CLWB__ 1
3875// CHECK_ZNVER4_M32: #define __CLZERO__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08003876// CHECK_ZNVER4_M32: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08003877// CHECK_ZNVER4_M32: #define __EVEX512__ 1
Ganesh Gopalasubramanian1f057e32022-12-15 19:28:34 +05303878// CHECK_ZNVER4_M32: #define __F16C__ 1
3879// CHECK_ZNVER4_M32-NOT: #define __FMA4__ 1
3880// CHECK_ZNVER4_M32: #define __FMA__ 1
3881// CHECK_ZNVER4_M32: #define __FSGSBASE__ 1
3882// CHECK_ZNVER4_M32: #define __GFNI__ 1
3883// CHECK_ZNVER4_M32: #define __LZCNT__ 1
3884// CHECK_ZNVER4_M32: #define __MMX__ 1
3885// CHECK_ZNVER4_M32: #define __PCLMUL__ 1
3886// CHECK_ZNVER4_M32: #define __PKU__ 1
3887// CHECK_ZNVER4_M32: #define __POPCNT__ 1
3888// CHECK_ZNVER4_M32: #define __PRFCHW__ 1
3889// CHECK_ZNVER4_M32: #define __RDPID__ 1
3890// CHECK_ZNVER4_M32: #define __RDPRU__ 1
3891// CHECK_ZNVER4_M32: #define __RDRND__ 1
3892// CHECK_ZNVER4_M32: #define __RDSEED__ 1
3893// CHECK_ZNVER4_M32: #define __SHA__ 1
3894// CHECK_ZNVER4_M32: #define __SSE2_MATH__ 1
3895// CHECK_ZNVER4_M32: #define __SSE2__ 1
3896// CHECK_ZNVER4_M32: #define __SSE3__ 1
3897// CHECK_ZNVER4_M32: #define __SSE4A__ 1
3898// CHECK_ZNVER4_M32: #define __SSE4_1__ 1
3899// CHECK_ZNVER4_M32: #define __SSE4_2__ 1
3900// CHECK_ZNVER4_M32: #define __SSE_MATH__ 1
3901// CHECK_ZNVER4_M32: #define __SSE__ 1
3902// CHECK_ZNVER4_M32: #define __SSSE3__ 1
3903// CHECK_ZNVER4_M32-NOT: #define __TBM__ 1
3904// CHECK_ZNVER4_M32: #define __WBNOINVD__ 1
3905// CHECK_ZNVER4_M32-NOT: #define __XOP__ 1
3906// CHECK_ZNVER4_M32: #define __XSAVEC__ 1
3907// CHECK_ZNVER4_M32: #define __XSAVEOPT__ 1
3908// CHECK_ZNVER4_M32: #define __XSAVES__ 1
3909// CHECK_ZNVER4_M32: #define __XSAVE__ 1
3910// CHECK_ZNVER4_M32: #define __i386 1
3911// CHECK_ZNVER4_M32: #define __i386__ 1
3912// CHECK_ZNVER4_M32: #define __tune_znver4__ 1
3913// CHECK_ZNVER4_M32: #define __znver4 1
3914// CHECK_ZNVER4_M32: #define __znver4__ 1
3915
3916// RUN: %clang -march=znver4 -m64 -E -dM %s -o - 2>&1 \
3917// RUN: -target i386-unknown-linux \
3918// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER4_M64
Ganesh Gopalasubramanian1f057e32022-12-15 19:28:34 +05303919// CHECK_ZNVER4_M64: #define __ADX__ 1
3920// CHECK_ZNVER4_M64: #define __AES__ 1
3921// CHECK_ZNVER4_M64: #define __AVX2__ 1
3922// CHECK_ZNVER4_M64: #define __AVX512BF16__ 1
3923// CHECK_ZNVER4_M64: #define __AVX512BITALG__ 1
3924// CHECK_ZNVER4_M64: #define __AVX512BW__ 1
3925// CHECK_ZNVER4_M64: #define __AVX512CD__ 1
3926// CHECK_ZNVER4_M64: #define __AVX512DQ__ 1
3927// CHECK_ZNVER4_M64: #define __AVX512F__ 1
3928// CHECK_ZNVER4_M64: #define __AVX512IFMA__ 1
3929// CHECK_ZNVER4_M64: #define __AVX512VBMI2__ 1
3930// CHECK_ZNVER4_M64: #define __AVX512VBMI__ 1
3931// CHECK_ZNVER4_M64: #define __AVX512VL__ 1
3932// CHECK_ZNVER4_M64: #define __AVX512VNNI__ 1
3933// CHECK_ZNVER4_M64: #define __AVX512VPOPCNTDQ__ 1
3934// CHECK_ZNVER4_M64: #define __AVX__ 1
3935// CHECK_ZNVER4_M64: #define __BMI2__ 1
3936// CHECK_ZNVER4_M64: #define __BMI__ 1
3937// CHECK_ZNVER4_M64: #define __CLFLUSHOPT__ 1
3938// CHECK_ZNVER4_M64: #define __CLWB__ 1
3939// CHECK_ZNVER4_M64: #define __CLZERO__ 1
Phoebe Wangc78aeab2023-11-07 14:39:24 +08003940// CHECK_ZNVER4_M64: #define __EVEX256__ 1
XinWang10057ec762023-10-10 09:32:32 +08003941// CHECK_ZNVER4_M64: #define __EVEX512__ 1
Ganesh Gopalasubramanian1f057e32022-12-15 19:28:34 +05303942// CHECK_ZNVER4_M64: #define __F16C__ 1
3943// CHECK_ZNVER4_M64-NOT: #define __FMA4__ 1
3944// CHECK_ZNVER4_M64: #define __FMA__ 1
3945// CHECK_ZNVER4_M64: #define __FSGSBASE__ 1
3946// CHECK_ZNVER4_M64: #define __GFNI__ 1
3947// CHECK_ZNVER4_M64: #define __LZCNT__ 1
3948// CHECK_ZNVER4_M64: #define __MMX__ 1
3949// CHECK_ZNVER4_M64: #define __PCLMUL__ 1
3950// CHECK_ZNVER4_M64: #define __PKU__ 1
3951// CHECK_ZNVER4_M64: #define __POPCNT__ 1
3952// CHECK_ZNVER4_M64: #define __PRFCHW__ 1
3953// CHECK_ZNVER4_M64: #define __RDPID__ 1
3954// CHECK_ZNVER4_M64: #define __RDPRU__ 1
3955// CHECK_ZNVER4_M64: #define __RDRND__ 1
3956// CHECK_ZNVER4_M64: #define __RDSEED__ 1
3957// CHECK_ZNVER4_M64: #define __SHA__ 1
3958// CHECK_ZNVER4_M64: #define __SSE2_MATH__ 1
3959// CHECK_ZNVER4_M64: #define __SSE2__ 1
3960// CHECK_ZNVER4_M64: #define __SSE3__ 1
3961// CHECK_ZNVER4_M64: #define __SSE4A__ 1
3962// CHECK_ZNVER4_M64: #define __SSE4_1__ 1
3963// CHECK_ZNVER4_M64: #define __SSE4_2__ 1
3964// CHECK_ZNVER4_M64: #define __SSE_MATH__ 1
3965// CHECK_ZNVER4_M64: #define __SSE__ 1
3966// CHECK_ZNVER4_M64: #define __SSSE3__ 1
3967// CHECK_ZNVER4_M64-NOT: #define __TBM__ 1
3968// CHECK_ZNVER4_M64: #define __VAES__ 1
3969// CHECK_ZNVER4_M64: #define __VPCLMULQDQ__ 1
3970// CHECK_ZNVER4_M64: #define __WBNOINVD__ 1
3971// CHECK_ZNVER4_M64-NOT: #define __XOP__ 1
3972// CHECK_ZNVER4_M64: #define __XSAVEC__ 1
3973// CHECK_ZNVER4_M64: #define __XSAVEOPT__ 1
3974// CHECK_ZNVER4_M64: #define __XSAVES__ 1
3975// CHECK_ZNVER4_M64: #define __XSAVE__ 1
3976// CHECK_ZNVER4_M64: #define __amd64 1
3977// CHECK_ZNVER4_M64: #define __amd64__ 1
3978// CHECK_ZNVER4_M64: #define __tune_znver4__ 1
3979// CHECK_ZNVER4_M64: #define __x86_64 1
3980// CHECK_ZNVER4_M64: #define __x86_64__ 1
3981// CHECK_ZNVER4_M64: #define __znver4 1
3982// CHECK_ZNVER4_M64: #define __znver4__ 1
3983
Ganesh02e41862024-09-13 22:15:33 +05303984// RUN: %clang -march=znver5 -m32 -E -dM %s -o - 2>&1 \
3985// RUN: -target i386-unknown-linux \
3986// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER5_M32
3987// CHECK_ZNVER5_M32-NOT: #define __3dNOW_A__ 1
3988// CHECK_ZNVER5_M32-NOT: #define __3dNOW__ 1
3989// CHECK_ZNVER5_M32: #define __ADX__ 1
3990// CHECK_ZNVER5_M32: #define __AES__ 1
3991// CHECK_ZNVER5_M32: #define __AVX2__ 1
3992// CHECK_ZNVER5_M32: #define __AVX512BF16__ 1
3993// CHECK_ZNVER5_M32: #define __AVX512BITALG__ 1
3994// CHECK_ZNVER5_M32: #define __AVX512BW__ 1
3995// CHECK_ZNVER5_M32: #define __AVX512CD__ 1
3996// CHECK_ZNVER5_M32: #define __AVX512DQ__ 1
3997// CHECK_ZNVER5_M32: #define __AVX512F__ 1
3998// CHECK_ZNVER5_M32: #define __AVX512IFMA__ 1
3999// CHECK_ZNVER5_M32: #define __AVX512VBMI2__ 1
4000// CHECK_ZNVER5_M32: #define __AVX512VBMI__ 1
4001// CHECK_ZNVER5_M32: #define __AVX512VL__ 1
4002// CHECK_ZNVER5_M32: #define __AVX512VNNI__ 1
4003// CHECK_ZNVER5_M32: #define __AVX512VP2INTERSECT__ 1
4004// CHECK_ZNVER5_M32: #define __AVX512VPOPCNTDQ__ 1
4005// CHECK_ZNVER5_M32: #define __AVXVNNI__ 1
4006// CHECK_ZNVER5_M32: #define __AVX__ 1
4007// CHECK_ZNVER5_M32: #define __BMI2__ 1
4008// CHECK_ZNVER5_M32: #define __BMI__ 1
4009// CHECK_ZNVER5_M32: #define __CLFLUSHOPT__ 1
4010// CHECK_ZNVER5_M32: #define __CLWB__ 1
4011// CHECK_ZNVER5_M32: #define __CLZERO__ 1
4012// CHECK_ZNVER5_M32: #define __F16C__ 1
4013// CHECK_ZNVER5_M32-NOT: #define __FMA4__ 1
4014// CHECK_ZNVER5_M32: #define __FMA__ 1
4015// CHECK_ZNVER5_M32: #define __FSGSBASE__ 1
4016// CHECK_ZNVER5_M32: #define __GFNI__ 1
4017// CHECK_ZNVER5_M32: #define __LZCNT__ 1
4018// CHECK_ZNVER5_M32: #define __MMX__ 1
4019// CHECK_ZNVER5_M32: #define __MOVDIR64B__ 1
4020// CHECK_ZNVER5_M32: #define __MOVDIRI__ 1
4021// CHECK_ZNVER5_M32: #define __PCLMUL__ 1
4022// CHECK_ZNVER5_M32: #define __PKU__ 1
4023// CHECK_ZNVER5_M32: #define __POPCNT__ 1
4024// CHECK_ZNVER5_M32: #define __PREFETCHI__ 1
4025// CHECK_ZNVER5_M32: #define __PRFCHW__ 1
4026// CHECK_ZNVER5_M32: #define __RDPID__ 1
4027// CHECK_ZNVER5_M32: #define __RDPRU__ 1
4028// CHECK_ZNVER5_M32: #define __RDRND__ 1
4029// CHECK_ZNVER5_M32: #define __RDSEED__ 1
4030// CHECK_ZNVER5_M32: #define __SHA__ 1
4031// CHECK_ZNVER5_M32: #define __SSE2_MATH__ 1
4032// CHECK_ZNVER5_M32: #define __SSE2__ 1
4033// CHECK_ZNVER5_M32: #define __SSE3__ 1
4034// CHECK_ZNVER5_M32: #define __SSE4A__ 1
4035// CHECK_ZNVER5_M32: #define __SSE4_1__ 1
4036// CHECK_ZNVER5_M32: #define __SSE4_2__ 1
4037// CHECK_ZNVER5_M32: #define __SSE_MATH__ 1
4038// CHECK_ZNVER5_M32: #define __SSE__ 1
4039// CHECK_ZNVER5_M32: #define __SSSE3__ 1
4040// CHECK_ZNVER5_M32-NOT: #define __TBM__ 1
4041// CHECK_ZNVER5_M32: #define __WBNOINVD__ 1
4042// CHECK_ZNVER5_M32-NOT: #define __XOP__ 1
4043// CHECK_ZNVER5_M32: #define __XSAVEC__ 1
4044// CHECK_ZNVER5_M32: #define __XSAVEOPT__ 1
4045// CHECK_ZNVER5_M32: #define __XSAVES__ 1
4046// CHECK_ZNVER5_M32: #define __XSAVE__ 1
4047// CHECK_ZNVER5_M32: #define __i386 1
4048// CHECK_ZNVER5_M32: #define __i386__ 1
4049// CHECK_ZNVER5_M32: #define __tune_znver5__ 1
4050// CHECK_ZNVER5_M32: #define __znver5 1
4051// CHECK_ZNVER5_M32: #define __znver5__ 1
4052
4053// RUN: %clang -march=znver5 -m64 -E -dM %s -o - 2>&1 \
4054// RUN: -target i386-unknown-linux \
4055// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER5_M64
4056// CHECK_ZNVER5_M64-NOT: #define __3dNOW_A__ 1
4057// CHECK_ZNVER5_M64-NOT: #define __3dNOW__ 1
4058// CHECK_ZNVER5_M64: #define __ADX__ 1
4059// CHECK_ZNVER5_M64: #define __AES__ 1
4060// CHECK_ZNVER5_M64: #define __AVX2__ 1
4061// CHECK_ZNVER5_M64: #define __AVX512BF16__ 1
4062// CHECK_ZNVER5_M64: #define __AVX512BITALG__ 1
4063// CHECK_ZNVER5_M64: #define __AVX512BW__ 1
4064// CHECK_ZNVER5_M64: #define __AVX512CD__ 1
4065// CHECK_ZNVER5_M64: #define __AVX512DQ__ 1
4066// CHECK_ZNVER5_M64: #define __AVX512F__ 1
4067// CHECK_ZNVER5_M64: #define __AVX512IFMA__ 1
4068// CHECK_ZNVER5_M64: #define __AVX512VBMI2__ 1
4069// CHECK_ZNVER5_M64: #define __AVX512VBMI__ 1
4070// CHECK_ZNVER5_M64: #define __AVX512VL__ 1
4071// CHECK_ZNVER5_M64: #define __AVX512VNNI__ 1
4072// CHECK_ZNVER5_M64: #define __AVX512VP2INTERSECT__ 1
4073// CHECK_ZNVER5_M64: #define __AVX512VPOPCNTDQ__ 1
4074// CHECK_ZNVER5_M64: #define __AVXVNNI__ 1
4075// CHECK_ZNVER5_M64: #define __AVX__ 1
4076// CHECK_ZNVER5_M64: #define __BMI2__ 1
4077// CHECK_ZNVER5_M64: #define __BMI__ 1
4078// CHECK_ZNVER5_M64: #define __CLFLUSHOPT__ 1
4079// CHECK_ZNVER5_M64: #define __CLWB__ 1
4080// CHECK_ZNVER5_M64: #define __CLZERO__ 1
4081// CHECK_ZNVER5_M64: #define __F16C__ 1
4082// CHECK_ZNVER5_M64-NOT: #define __FMA4__ 1
4083// CHECK_ZNVER5_M64: #define __FMA__ 1
4084// CHECK_ZNVER5_M64: #define __FSGSBASE__ 1
4085// CHECK_ZNVER5_M64: #define __GFNI__ 1
4086// CHECK_ZNVER5_M64: #define __LZCNT__ 1
4087// CHECK_ZNVER5_M64: #define __MMX__ 1
4088// CHECK_ZNVER5_M64: #define __MOVDIR64B__ 1
4089// CHECK_ZNVER5_M64: #define __MOVDIRI__ 1
4090// CHECK_ZNVER5_M64: #define __PCLMUL__ 1
4091// CHECK_ZNVER5_M64: #define __PKU__ 1
4092// CHECK_ZNVER5_M64: #define __POPCNT__ 1
4093// CHECK_ZNVER5_M64: #define __PREFETCHI__ 1
4094// CHECK_ZNVER5_M64: #define __PRFCHW__ 1
4095// CHECK_ZNVER5_M64: #define __RDPID__ 1
4096// CHECK_ZNVER5_M64: #define __RDPRU__ 1
4097// CHECK_ZNVER5_M64: #define __RDRND__ 1
4098// CHECK_ZNVER5_M64: #define __RDSEED__ 1
4099// CHECK_ZNVER5_M64: #define __SHA__ 1
4100// CHECK_ZNVER5_M64: #define __SSE2_MATH__ 1
4101// CHECK_ZNVER5_M64: #define __SSE2__ 1
4102// CHECK_ZNVER5_M64: #define __SSE3__ 1
4103// CHECK_ZNVER5_M64: #define __SSE4A__ 1
4104// CHECK_ZNVER5_M64: #define __SSE4_1__ 1
4105// CHECK_ZNVER5_M64: #define __SSE4_2__ 1
4106// CHECK_ZNVER5_M64: #define __SSE_MATH__ 1
4107// CHECK_ZNVER5_M64: #define __SSE__ 1
4108// CHECK_ZNVER5_M64: #define __SSSE3__ 1
4109// CHECK_ZNVER5_M64-NOT: #define __TBM__ 1
4110// CHECK_ZNVER5_M64: #define __VAES__ 1
4111// CHECK_ZNVER5_M64: #define __VPCLMULQDQ__ 1
4112// CHECK_ZNVER5_M64: #define __WBNOINVD__ 1
4113// CHECK_ZNVER5_M64-NOT: #define __XOP__ 1
4114// CHECK_ZNVER5_M64: #define __XSAVEC__ 1
4115// CHECK_ZNVER5_M64: #define __XSAVEOPT__ 1
4116// CHECK_ZNVER5_M64: #define __XSAVES__ 1
4117// CHECK_ZNVER5_M64: #define __XSAVE__ 1
4118// CHECK_ZNVER5_M64: #define __amd64 1
4119// CHECK_ZNVER5_M64: #define __amd64__ 1
4120// CHECK_ZNVER5_M64: #define __tune_znver5__ 1
4121// CHECK_ZNVER5_M64: #define __x86_64 1
4122// CHECK_ZNVER5_M64: #define __x86_64__ 1
4123// CHECK_ZNVER5_M64: #define __znver5 1
4124// CHECK_ZNVER5_M64: #define __znver5__ 1
4125
Chandler Carruthe83c3d92011-09-28 10:17:41 +00004126// End X86/GCC/Linux tests ------------------
Eric Christopher2fe3b4a2013-10-16 21:19:26 +00004127
4128// Begin PPC/GCC/Linux tests ----------------
Eric Christopherd26d8832017-04-15 06:15:00 +00004129// Check that VSX also turns on altivec.
4130// RUN: %clang -mvsx -E -dM %s -o - 2>&1 \
4131// RUN: -target powerpc-unknown-linux \
4132// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_VSX_M32
Eric Christopherd26d8832017-04-15 06:15:00 +00004133// CHECK_PPC_VSX_M32: #define __ALTIVEC__ 1
4134// CHECK_PPC_VSX_M32: #define __VSX__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00004135
Eric Christopher2fe3b4a2013-10-16 21:19:26 +00004136// RUN: %clang -mvsx -E -dM %s -o - 2>&1 \
4137// RUN: -target powerpc64-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00004138// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_VSX_M64
James Y Knight3508b222016-04-01 21:33:20 +00004139// CHECK_PPC_VSX_M64: #define __VSX__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00004140
Bill Schmidt59eb7672014-10-10 15:09:43 +00004141// RUN: %clang -mpower8-vector -E -dM %s -o - 2>&1 \
4142// RUN: -target powerpc64-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00004143// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_POWER8_VECTOR_M64
James Y Knight3508b222016-04-01 21:33:20 +00004144// CHECK_PPC_POWER8_VECTOR_M64: #define __POWER8_VECTOR__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00004145
Nemanja Ivanovic10e2b5d2016-09-27 10:45:22 +00004146// RUN: %clang -mpower9-vector -E -dM %s -o - 2>&1 \
4147// RUN: -target powerpc64-unknown-linux \
4148// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_POWER9_VECTOR_M64
Nemanja Ivanovic10e2b5d2016-09-27 10:45:22 +00004149// CHECK_PPC_POWER9_VECTOR_M64: #define __POWER9_VECTOR__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00004150
Nemanja Ivanovic55e757d2015-03-04 21:48:22 +00004151// RUN: %clang -mcrypto -E -dM %s -o - 2>&1 \
4152// RUN: -target powerpc64-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00004153// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_CRYPTO_M64
James Y Knight3508b222016-04-01 21:33:20 +00004154// CHECK_PPC_CRYPTO_M64: #define __CRYPTO__ 1
Eric Christopher74fa24f2017-03-20 21:12:53 +00004155
4156// HTM is available on power8 or later which includes all of powerpc64le as an
4157// ABI choice. Test that, the cpus, and the option.
4158// RUN: %clang -mhtm -E -dM %s -o - 2>&1 \
4159// RUN: -target powerpc64-unknown-linux \
4160// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_HTM
4161// RUN: %clang -E -dM %s -o - 2>&1 \
4162// RUN: -target powerpc64le-unknown-linux \
4163// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_HTM
4164// RUN: %clang -mcpu=pwr8 -E -dM %s -o - 2>&1 \
4165// RUN: -target powerpc64-unknown-linux \
4166// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_HTM
4167// RUN: %clang -mcpu=pwr9 -E -dM %s -o - 2>&1 \
4168// RUN: -target powerpc64-unknown-linux \
4169// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_HTM
Eric Christopher74fa24f2017-03-20 21:12:53 +00004170// CHECK_PPC_HTM: #define __HTM__ 1
4171
Hal Finkela57b8902015-10-01 13:39:49 +00004172// RUN: %clang -mcpu=ppc64 -E -dM %s -o - 2>&1 \
4173// RUN: -target powerpc64-unknown-unknown \
James Y Knight3508b222016-04-01 21:33:20 +00004174// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_GCC_ATOMICS
Nemanja Ivanovice97e1112015-05-14 20:02:24 +00004175// RUN: %clang -mcpu=pwr8 -E -dM %s -o - 2>&1 \
4176// RUN: -target powerpc64-unknown-unknown \
James Y Knight3508b222016-04-01 21:33:20 +00004177// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_GCC_ATOMICS
Nemanja Ivanovice97e1112015-05-14 20:02:24 +00004178// RUN: %clang -E -dM %s -o - 2>&1 \
4179// RUN: -target powerpc64le-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00004180// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_PPC_GCC_ATOMICS
James Y Knight3508b222016-04-01 21:33:20 +00004181// CHECK_PPC_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4182// CHECK_PPC_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4183// CHECK_PPC_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4184// CHECK_PPC_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00004185
Nemanja Ivanovice97e1112015-05-14 20:02:24 +00004186// End PPC/GCC/Linux tests ------------------
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00004187
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00004188// Begin Sparc/GCC/Linux tests ----------------
Gabor Buellac9e976c2018-04-12 18:15:39 +00004189
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00004190// RUN: %clang -E -dM %s -o - 2>&1 \
4191// RUN: -target sparc-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00004192// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPARC
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00004193// CHECK_SPARC: #define __BIG_ENDIAN__ 1
4194// CHECK_SPARC: #define __sparc 1
4195// CHECK_SPARC: #define __sparc__ 1
Joerg Sonnenbergerec353d32015-11-09 23:39:45 +00004196// CHECK_SPARC-NOT: #define __sparcv9 1
Joerg Sonnenberger4ecfa622015-11-10 19:28:17 +00004197// CHECK_SPARC-NOT: #define __sparcv9__ 1
Rainer Orth39e30502024-09-21 19:53:35 +02004198// CHECK_SPARC: #define __sparc_v9__ 1
4199// CHECK_SPARC-NOT: #define __sparcv8 1
Joerg Sonnenbergerec353d32015-11-09 23:39:45 +00004200// CHECK_SPARC-NOT: #define __sparcv9 1
Joerg Sonnenberger4ecfa622015-11-10 19:28:17 +00004201// CHECK_SPARC-NOT: #define __sparcv9__ 1
Joerg Sonnenbergerec353d32015-11-09 23:39:45 +00004202
Gabor Buellac9e976c2018-04-12 18:15:39 +00004203// RUN: %clang -mcpu=v9 -E -dM %s -o - 2>&1 \
4204// RUN: -target sparc-unknown-linux \
4205// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPARC-V9
Joerg Sonnenbergerec353d32015-11-09 23:39:45 +00004206// CHECK_SPARC-V9-NOT: #define __sparcv8 1
Rainer Orth76e85ae2020-09-11 09:53:19 +02004207// CHECK_SPARC-V9-NOT: #define __sparcv8__ 1
Joerg Sonnenberger4ecfa622015-11-10 19:28:17 +00004208// CHECK_SPARC-V9: #define __sparc_v9__ 1
John Paul Adrian Glaubitz5061eb62022-01-21 09:57:17 -08004209// CHECK_SPARC-V9-NOT: #define __sparcv9 1
4210// CHECK_SPARC-V9-NOT: #define __sparcv9__ 1
Rainer Orth76e85ae2020-09-11 09:53:19 +02004211
4212// RUN: %clang -E -dM %s -o - 2>&1 \
4213// RUN: -target sparc-sun-solaris \
4214// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPARC_SOLARIS_GCC_ATOMICS
4215// CHECK_SPARC_SOLARIS_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4216// CHECK_SPARC_SOLARIS_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4217// CHECK_SPARC_SOLARIS_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4218// CHECK_SPARC_SOLARIS_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
4219
4220// RUN: %clang -mcpu=v8 -E -dM %s -o - 2>&1 \
4221// RUN: -target sparc-sun-solaris \
4222// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPARC_SOLARIS_GCC_ATOMICS-V8
4223// CHECK_SPARC_SOLARIS_GCC_ATOMICS-V8-NOT: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4224// CHECK_SPARC_SOLARIS_GCC_ATOMICS-V8-NOT: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4225// CHECK_SPARC_SOLARIS_GCC_ATOMICS-V8-NOT: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4226// CHECK_SPARC_SOLARIS_GCC_ATOMICS-V8-NOT: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00004227
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00004228// RUN: %clang -E -dM %s -o - 2>&1 \
4229// RUN: -target sparcel-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00004230// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPARCEL
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00004231// CHECK_SPARCEL: #define __LITTLE_ENDIAN__ 1
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00004232// CHECK_SPARCEL: #define __sparc 1
4233// CHECK_SPARCEL: #define __sparc__ 1
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00004234// CHECK_SPARCEL: #define __sparcv8 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00004235
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00004236// RUN: %clang -E -dM %s -o - 2>&1 \
4237// RUN: -target sparcv9-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00004238// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPARCV9
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00004239// CHECK_SPARCV9: #define __BIG_ENDIAN__ 1
4240// CHECK_SPARCV9: #define __sparc 1
4241// CHECK_SPARCV9: #define __sparc64__ 1
4242// CHECK_SPARCV9: #define __sparc__ 1
4243// CHECK_SPARCV9: #define __sparc_v9__ 1
4244// CHECK_SPARCV9: #define __sparcv9 1
4245// CHECK_SPARCV9: #define __sparcv9__ 1
4246
Brad Smith5fe17132020-08-11 00:04:24 -04004247// RUN: %clang -E -dM %s -o - 2>&1 \
4248// RUN: -target sparcv9-unknown-linux \
4249// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SPARCV9_GCC_ATOMICS
4250// CHECK_SPARCV9_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4251// CHECK_SPARCV9_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4252// CHECK_SPARCV9_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4253// CHECK_SPARCV9_GCC_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
4254
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00004255// Begin SystemZ/GCC/Linux tests ----------------
Gabor Buellac9e976c2018-04-12 18:15:39 +00004256
Sean Perrye62bf7c2024-09-09 15:24:16 -04004257// RUN: %clang -E -dM %s -o - 2>&1 \
4258// RUN: -target s390x-ibm-zos \
4259// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ZOS
4260// CHECK_SYSTEMZ_ZOS: #define __ARCH__ 10
4261// CHECK_SYSTEMZ_ZOS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4262// CHECK_SYSTEMZ_ZOS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4263// CHECK_SYSTEMZ_ZOS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4264// CHECK_SYSTEMZ_ZOS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
4265// CHECK_SYSTEMZ_ZOS: #define __HTM__ 1
4266// CHECK_SYSTEMZ_ZOS: #define __LONG_DOUBLE_128__ 1
4267// CHECK_SYSTEMZ_ZOS: #define __s390__ 1
4268// CHECK_SYSTEMZ_ZOS: #define __s390x__ 1
4269// CHECK_SYSTEMZ_ZOS: #define __zarch__ 1
4270
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00004271// RUN: %clang -march=arch8 -E -dM %s -o - 2>&1 \
4272// RUN: -target s390x-unknown-linux \
4273// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH8
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00004274// RUN: %clang -march=z10 -E -dM %s -o - 2>&1 \
4275// RUN: -target s390x-unknown-linux \
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00004276// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH8
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00004277// CHECK_SYSTEMZ_ARCH8: #define __ARCH__ 8
4278// CHECK_SYSTEMZ_ARCH8: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4279// CHECK_SYSTEMZ_ARCH8: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4280// CHECK_SYSTEMZ_ARCH8: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4281// CHECK_SYSTEMZ_ARCH8: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
Sean Perrye62bf7c2024-09-09 15:24:16 -04004282// CHECK_SYSTEMZ_ARCH8-NOT: #define __HTM__ 1
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00004283// CHECK_SYSTEMZ_ARCH8: #define __LONG_DOUBLE_128__ 1
4284// CHECK_SYSTEMZ_ARCH8: #define __s390__ 1
4285// CHECK_SYSTEMZ_ARCH8: #define __s390x__ 1
4286// CHECK_SYSTEMZ_ARCH8: #define __zarch__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00004287
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00004288// RUN: %clang -march=arch9 -E -dM %s -o - 2>&1 \
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00004289// RUN: -target s390x-unknown-linux \
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00004290// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH9
4291// RUN: %clang -march=z196 -E -dM %s -o - 2>&1 \
4292// RUN: -target s390x-unknown-linux \
4293// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH9
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00004294// CHECK_SYSTEMZ_ARCH9: #define __ARCH__ 9
4295// CHECK_SYSTEMZ_ARCH9: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4296// CHECK_SYSTEMZ_ARCH9: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4297// CHECK_SYSTEMZ_ARCH9: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4298// CHECK_SYSTEMZ_ARCH9: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
Sean Perrye62bf7c2024-09-09 15:24:16 -04004299// CHECK_SYSTEMZ_ARCH9-NOT: #define __HTM__ 1
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00004300// CHECK_SYSTEMZ_ARCH9: #define __LONG_DOUBLE_128__ 1
4301// CHECK_SYSTEMZ_ARCH9: #define __s390__ 1
4302// CHECK_SYSTEMZ_ARCH9: #define __s390x__ 1
4303// CHECK_SYSTEMZ_ARCH9: #define __zarch__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00004304
Ulrich Weigand30354eb2016-10-31 14:38:05 +00004305// RUN: %clang -march=arch10 -E -dM %s -o - 2>&1 \
4306// RUN: -target s390x-unknown-linux \
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00004307// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH10
4308// RUN: %clang -march=zEC12 -E -dM %s -o - 2>&1 \
4309// RUN: -target s390x-unknown-linux \
4310// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH10
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00004311// CHECK_SYSTEMZ_ARCH10: #define __ARCH__ 10
4312// CHECK_SYSTEMZ_ARCH10: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4313// CHECK_SYSTEMZ_ARCH10: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4314// CHECK_SYSTEMZ_ARCH10: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4315// CHECK_SYSTEMZ_ARCH10: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
4316// CHECK_SYSTEMZ_ARCH10: #define __HTM__ 1
4317// CHECK_SYSTEMZ_ARCH10: #define __LONG_DOUBLE_128__ 1
4318// CHECK_SYSTEMZ_ARCH10: #define __s390__ 1
4319// CHECK_SYSTEMZ_ARCH10: #define __s390x__ 1
4320// CHECK_SYSTEMZ_ARCH10: #define __zarch__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00004321
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00004322// RUN: %clang -march=arch11 -E -dM %s -o - 2>&1 \
4323// RUN: -target s390x-unknown-linux \
4324// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH11
4325// RUN: %clang -march=z13 -E -dM %s -o - 2>&1 \
4326// RUN: -target s390x-unknown-linux \
4327// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH11
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00004328// CHECK_SYSTEMZ_ARCH11: #define __ARCH__ 11
4329// CHECK_SYSTEMZ_ARCH11: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4330// CHECK_SYSTEMZ_ARCH11: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4331// CHECK_SYSTEMZ_ARCH11: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4332// CHECK_SYSTEMZ_ARCH11: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
4333// CHECK_SYSTEMZ_ARCH11: #define __HTM__ 1
4334// CHECK_SYSTEMZ_ARCH11: #define __LONG_DOUBLE_128__ 1
4335// CHECK_SYSTEMZ_ARCH11: #define __VX__ 1
4336// CHECK_SYSTEMZ_ARCH11: #define __s390__ 1
4337// CHECK_SYSTEMZ_ARCH11: #define __s390x__ 1
4338// CHECK_SYSTEMZ_ARCH11: #define __zarch__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00004339
Ulrich Weigandcac24ab2017-07-17 17:45:57 +00004340// RUN: %clang -march=arch12 -E -dM %s -o - 2>&1 \
4341// RUN: -target s390x-unknown-linux \
4342// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH12
4343// RUN: %clang -march=z14 -E -dM %s -o - 2>&1 \
4344// RUN: -target s390x-unknown-linux \
4345// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH12
Ulrich Weigandcac24ab2017-07-17 17:45:57 +00004346// CHECK_SYSTEMZ_ARCH12: #define __ARCH__ 12
4347// CHECK_SYSTEMZ_ARCH12: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4348// CHECK_SYSTEMZ_ARCH12: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4349// CHECK_SYSTEMZ_ARCH12: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4350// CHECK_SYSTEMZ_ARCH12: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
4351// CHECK_SYSTEMZ_ARCH12: #define __HTM__ 1
4352// CHECK_SYSTEMZ_ARCH12: #define __LONG_DOUBLE_128__ 1
4353// CHECK_SYSTEMZ_ARCH12: #define __VX__ 1
4354// CHECK_SYSTEMZ_ARCH12: #define __s390__ 1
4355// CHECK_SYSTEMZ_ARCH12: #define __s390x__ 1
4356// CHECK_SYSTEMZ_ARCH12: #define __zarch__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00004357
Ulrich Weigandb98bf602019-07-12 18:14:51 +00004358// RUN: %clang -march=arch13 -E -dM %s -o - 2>&1 \
4359// RUN: -target s390x-unknown-linux \
4360// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH13
Ulrich Weigand48b40832019-09-20 23:06:03 +00004361// RUN: %clang -march=z15 -E -dM %s -o - 2>&1 \
4362// RUN: -target s390x-unknown-linux \
4363// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH13
Ulrich Weigandb98bf602019-07-12 18:14:51 +00004364// CHECK_SYSTEMZ_ARCH13: #define __ARCH__ 13
4365// CHECK_SYSTEMZ_ARCH13: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4366// CHECK_SYSTEMZ_ARCH13: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4367// CHECK_SYSTEMZ_ARCH13: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4368// CHECK_SYSTEMZ_ARCH13: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
4369// CHECK_SYSTEMZ_ARCH13: #define __HTM__ 1
4370// CHECK_SYSTEMZ_ARCH13: #define __LONG_DOUBLE_128__ 1
4371// CHECK_SYSTEMZ_ARCH13: #define __VX__ 1
4372// CHECK_SYSTEMZ_ARCH13: #define __s390__ 1
4373// CHECK_SYSTEMZ_ARCH13: #define __s390x__ 1
4374// CHECK_SYSTEMZ_ARCH13: #define __zarch__ 1
4375
Ulrich Weigand8cd81202021-07-20 18:14:38 +02004376// RUN: %clang -march=arch14 -E -dM %s -o - 2>&1 \
4377// RUN: -target s390x-unknown-linux \
4378// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH14
Ulrich Weigand1283ccb2022-04-21 19:55:58 +02004379// RUN: %clang -march=z16 -E -dM %s -o - 2>&1 \
4380// RUN: -target s390x-unknown-linux \
4381// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH14
Ulrich Weigand8cd81202021-07-20 18:14:38 +02004382// CHECK_SYSTEMZ_ARCH14: #define __ARCH__ 14
4383// CHECK_SYSTEMZ_ARCH14: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4384// CHECK_SYSTEMZ_ARCH14: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4385// CHECK_SYSTEMZ_ARCH14: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4386// CHECK_SYSTEMZ_ARCH14: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
4387// CHECK_SYSTEMZ_ARCH14: #define __HTM__ 1
4388// CHECK_SYSTEMZ_ARCH14: #define __LONG_DOUBLE_128__ 1
4389// CHECK_SYSTEMZ_ARCH14: #define __VX__ 1
4390// CHECK_SYSTEMZ_ARCH14: #define __s390__ 1
4391// CHECK_SYSTEMZ_ARCH14: #define __s390x__ 1
4392// CHECK_SYSTEMZ_ARCH14: #define __zarch__ 1
4393
Ulrich Weigand8424bf202025-01-20 19:23:18 +01004394// RUN: %clang -march=arch15 -E -dM %s -o - 2>&1 \
4395// RUN: -target s390x-unknown-linux \
4396// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ARCH15
4397// CHECK_SYSTEMZ_ARCH15: #define __ARCH__ 15
4398// CHECK_SYSTEMZ_ARCH15: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4399// CHECK_SYSTEMZ_ARCH15: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4400// CHECK_SYSTEMZ_ARCH15: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4401// CHECK_SYSTEMZ_ARCH15: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
4402// CHECK_SYSTEMZ_ARCH15: #define __HTM__ 1
4403// CHECK_SYSTEMZ_ARCH15: #define __LONG_DOUBLE_128__ 1
4404// CHECK_SYSTEMZ_ARCH15: #define __VX__ 1
4405// CHECK_SYSTEMZ_ARCH15: #define __s390__ 1
4406// CHECK_SYSTEMZ_ARCH15: #define __s390x__ 1
4407// CHECK_SYSTEMZ_ARCH15: #define __zarch__ 1
4408
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00004409// RUN: %clang -mhtm -E -dM %s -o - 2>&1 \
4410// RUN: -target s390x-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00004411// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_HTM
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00004412// CHECK_SYSTEMZ_HTM: #define __HTM__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00004413
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00004414// RUN: %clang -mvx -E -dM %s -o - 2>&1 \
4415// RUN: -target s390x-unknown-linux \
4416// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_VX
Ulrich Weigand82a86cb2017-02-06 17:04:22 +00004417// CHECK_SYSTEMZ_VX: #define __VX__ 1
Gabor Buellac9e976c2018-04-12 18:15:39 +00004418
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004419// RUN: %clang -fzvector -E -dM %s -o - 2>&1 \
4420// RUN: -target s390x-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00004421// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ZVECTOR
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004422// RUN: %clang -mzvector -E -dM %s -o - 2>&1 \
4423// RUN: -target s390x-unknown-linux \
James Y Knight3508b222016-04-01 21:33:20 +00004424// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_SYSTEMZ_ZVECTOR
Ulrich Weigand8424bf202025-01-20 19:23:18 +01004425// CHECK_SYSTEMZ_ZVECTOR: #define __VEC__ 10305
Matt Arsenault5e020b22016-02-27 09:06:26 +00004426
Joseph Huber7155c1e2024-01-30 21:44:43 -06004427// Begin nvptx tests ----------------
4428
4429// RUN: %clang -march=sm_75 -E -dM %s -o - 2>&1 \
4430// RUN: -target nvptx64-unknown-unknown \
4431// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_NVPTX,CHECK_ARCH_SM_75
4432// RUN: %clang -E -dM %s -o - 2>&1 \
4433// RUN: -target nvptx64-unknown-unknown \
4434// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_NVPTX,CHECK_ARCH_UNSET
4435// CHECK_ARCH_SM_75: #define __CUDA_ARCH__ 750
4436// CHECK_ARCH_UNSET-NOT: #define __CUDA_ARCH__
4437// CHECK_NVPTX: #define __NVPTX__ 1
4438
Matt Arsenault5e020b22016-02-27 09:06:26 +00004439// Begin amdgcn tests ----------------
Gabor Buellac9e976c2018-04-12 18:15:39 +00004440
Joseph Huberf2a78e62024-01-30 13:05:29 -06004441// RUN: %clang -mcpu=gfx803 -E -dM %s -o - 2>&1 \
Matt Arsenault5e020b22016-02-27 09:06:26 +00004442// RUN: -target amdgcn-unknown-unknown \
Joseph Huberf2a78e62024-01-30 13:05:29 -06004443// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_AMDGCN,CHECK_AMDGCN_803
4444// RUN: %clang -E -dM %s -o - 2>&1 \
4445// RUN: -target amdgcn-unknown-unknown \
4446// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_AMDGCN,CHECK_AMDGCN_NONE
Matt Arsenault5e020b22016-02-27 09:06:26 +00004447// CHECK_AMDGCN: #define __AMDGCN__ 1
Joseph Huberf2a78e62024-01-30 13:05:29 -06004448// CHECK_AMDGCN_803: #define __HAS_FMAF__ 1
4449// CHECK_AMDGCN_803: #define __HAS_FP64__ 1
4450// CHECK_AMDGCN_803: #define __HAS_LDEXPF__ 1
4451// CHECK_AMDGCN_NONE-NOT: #define __HAS_FMAF__
4452// CHECK_AMDGCN_NONE-NOT: #define __HAS_FP64__
4453// CHECK_AMDGCN_NONE-NOT: #define __HAS_LDEXPF__
4454// CHECK_AMDGCN_NONE-NOT: #define __AMDGCN_WAVEFRONT_SIZE__
Matt Arsenault5e020b22016-02-27 09:06:26 +00004455
4456// Begin r600 tests ----------------
Gabor Buellac9e976c2018-04-12 18:15:39 +00004457
Matt Arsenault5e020b22016-02-27 09:06:26 +00004458// RUN: %clang -march=amdgcn -E -dM %s -o - 2>&1 \
4459// RUN: -target r600-unknown-unknown \
James Y Knight3508b222016-04-01 21:33:20 +00004460// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_R600
Matt Arsenault5e020b22016-02-27 09:06:26 +00004461// CHECK_R600: #define __R600__ 1
Jan Veselycda72c92017-10-19 20:40:13 +00004462// CHECK_R600-NOT: #define __HAS_FMAF__ 1
4463
4464// RUN: %clang -march=amdgcn -mcpu=cypress -E -dM %s -o - 2>&1 \
4465// RUN: -target r600-unknown-unknown \
4466// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_R600_FP64
4467// CHECK_R600_FP64-DAG: #define __R600__ 1
4468// CHECK_R600_FP64-DAG: #define __HAS_FMAF__ 1
Brad Smith2784b242022-12-29 04:54:39 -05004469
Joseph Huberf2a78e62024-01-30 13:05:29 -06004470// Begin HIP host tests -----------
4471
Joseph Huber626fe712024-01-30 13:16:32 -06004472// RUN: %clang -x hip -E -dM %s -o - 2>&1 --offload-host-only -nogpulib \
4473// RUN: -nogpuinc --offload-arch=gfx803 -target x86_64-unknown-linux \
Joseph Huberf2a78e62024-01-30 13:05:29 -06004474// RUN: | FileCheck -match-full-lines %s -check-prefixes=CHECK_HIP_HOST
4475// CHECK_HIP_HOST: #define __AMDGCN_WAVEFRONT_SIZE__ 64
4476// CHECK_HIP_HOST: #define __AMDGPU__ 1
4477// CHECK_HIP_HOST: #define __AMD__ 1
4478
Ben Shi16f94512023-01-12 19:58:53 +08004479// Begin avr tests ----------------
4480
4481// RUN: %clang --target=avr -mmcu=atmega328 -E -dM %s -o - 2>&1 \
4482// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK-AVR0
4483// CHECK-AVR0: #define __AVR_ARCH__ 5
4484// CHECK-AVR0: #define __AVR_ATmega328__ 1
4485// CHECK-AVR0: #define __flash __attribute__((__address_space__(1)))
4486// RUN: %clang --target=avr -mmcu=atmega2560 -E -dM %s -o - 2>&1 \
4487// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK-AVR1
4488// CHECK-AVR1: #define __AVR_ARCH__ 6
4489// CHECK-AVR1: #define __AVR_ATmega2560__ 1
4490// CHECK-AVR1: #define __flash __attribute__((__address_space__(1)))
4491// CHECK-AVR1: #define __flash1 __attribute__((__address_space__(2)))
4492// CHECK-AVR1: #define __flash2 __attribute__((__address_space__(3)))
4493// CHECK-AVR1: #define __flash3 __attribute__((__address_space__(4)))
4494
Brad Smith2784b242022-12-29 04:54:39 -05004495// Begin M68k tests ----------------
4496
4497// RUN: %clang -mcpu=68000 -E -dM %s -o - 2>&1 \
4498// RUN: -target m68k-unknown-linux \
4499// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_M68K_68000_ATOMICS
4500// RUN: %clang -mcpu=68010 -E -dM %s -o - 2>&1 \
4501// RUN: -target m68k-unknown-linux \
4502// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_M68K_68000_ATOMICS
4503// RUN: %clang -mcpu=68020 -E -dM %s -o - 2>&1 \
4504// RUN: -target m68k-unknown-linux \
4505// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_M68K_68020_ATOMICS
4506
4507// CHECK_M68K_68000_ATOMICS-NOT: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP
4508// CHECK_M68K_68020_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4509// CHECK_M68K_68020_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4510// CHECK_M68K_68020_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
Brad Smithd227c3b2023-01-05 04:39:46 -05004511
4512// Begin Hexagon tests ----------------
4513
4514// RUN: %clang -E -dM %s -o - 2>&1 \
4515// RUN: --target=hexagon-unknown-linux \
4516// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_HEXAGON_ATOMICS
4517
4518// CHECK_HEXAGON_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4519// CHECK_HEXAGON_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4520// CHECK_HEXAGON_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4521// CHECK_HEXAGON_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
4522
4523// Begin VE tests ----------------
4524
4525// RUN: %clang -E -dM %s -o - 2>&1 \
4526// RUN: --target=ve-unknown-linux \
4527// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_VE_ATOMICS
4528
4529// CHECK_VE_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4530// CHECK_VE_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4531// CHECK_VE_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4532// CHECK_VE_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
4533
4534// Begin WebAssembly tests ----------------
4535
4536// RUN: %clang -E -dM %s -o - 2>&1 \
4537// RUN: --target=wasm32-unknown-unknown \
4538// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_WASM_ATOMICS
4539// RUN: %clang -E -dM %s -o - 2>&1 \
4540// RUN: --target=wasm64-unknown-unknown \
4541// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_WASM_ATOMICS
4542
4543// CHECK_WASM_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4544// CHECK_WASM_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4545// CHECK_WASM_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4546// CHECK_WASM_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
Brad Smithf70d17f2023-01-05 20:18:59 -05004547
4548// Begin LoongArch tests ----------------
4549
4550// RUN: %clang -E -dM %s -o - 2>&1 \
4551// RUN: --target=loongarch32-unknown-linux-gnu \
4552// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_LA32_ATOMICS
4553// CHECK_LA32_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4554// CHECK_LA32_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4555// CHECK_LA32_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4556
4557// RUN: %clang -E -dM %s -o - 2>&1 \
4558// RUN: --target=loongarch64-unknown-linux-gnu \
4559// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_LA64_ATOMICS
4560// CHECK_LA64_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
4561// CHECK_LA64_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
4562// CHECK_LA64_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
4563// CHECK_LA64_ATOMICS: #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1