1//===- X86TargetParser.def - X86 target parsing defines ---------*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file provides defines to build up the X86 target parser's logic.
10//
11//===----------------------------------------------------------------------===//
12
13// NOTE: NO INCLUDE GUARD DESIRED!
14
15#ifndef X86_VENDOR
16#define X86_VENDOR(ENUM, STR)
17#endif
18X86_VENDOR(VENDOR_INTEL, "intel")
19X86_VENDOR(VENDOR_AMD, "amd")
20#undef X86_VENDOR
21
22// This macro is used for cpu types present in compiler-rt/libgcc.
23#ifndef X86_CPU_TYPE
24#define X86_CPU_TYPE(ENUM, STR)
25#endif
26
27#ifndef X86_CPU_TYPE_ALIAS
28#define X86_CPU_TYPE_ALIAS(ENUM, STR)
29#endif
30
31// This list must match what is implemented in libgcc and compilert-rt. Clang
32// uses this to know how to implement __builtin_cpu_is.
33X86_CPU_TYPE(INTEL_BONNELL, "bonnell")
34X86_CPU_TYPE(INTEL_CORE2, "core2")
35X86_CPU_TYPE(INTEL_COREI7, "corei7")
36X86_CPU_TYPE(AMDFAM10H, "amdfam10h")
37X86_CPU_TYPE(AMDFAM15H, "amdfam15h")
38X86_CPU_TYPE(INTEL_SILVERMONT, "silvermont")
39X86_CPU_TYPE(INTEL_KNL, "knl")
40X86_CPU_TYPE(AMD_BTVER1, "btver1")
41X86_CPU_TYPE(AMD_BTVER2, "btver2")
42X86_CPU_TYPE(AMDFAM17H, "amdfam17h")
43X86_CPU_TYPE(INTEL_KNM, "knm")
44X86_CPU_TYPE(INTEL_GOLDMONT, "goldmont")
45X86_CPU_TYPE(INTEL_GOLDMONT_PLUS, "goldmont-plus")
46X86_CPU_TYPE(INTEL_TREMONT, "tremont")
47X86_CPU_TYPE(AMDFAM19H, "amdfam19h")
48X86_CPU_TYPE(ZHAOXIN_FAM7H, "zhaoxin_fam7h")
49X86_CPU_TYPE(INTEL_SIERRAFOREST, "sierraforest")
50X86_CPU_TYPE(INTEL_GRANDRIDGE, "grandridge")
51X86_CPU_TYPE(INTEL_CLEARWATERFOREST, "clearwaterforest")
52
53// Alternate names supported by __builtin_cpu_is and target multiversioning.
54X86_CPU_TYPE_ALIAS(INTEL_BONNELL, "atom")
55X86_CPU_TYPE_ALIAS(AMDFAM10H, "amdfam10")
56X86_CPU_TYPE_ALIAS(AMDFAM15H, "amdfam15")
57X86_CPU_TYPE_ALIAS(INTEL_SILVERMONT, "slm")
58
59#undef X86_CPU_TYPE_ALIAS
60#undef X86_CPU_TYPE
61
62// This macro is used for cpu subtypes present in compiler-rt/libgcc.
63#ifndef X86_CPU_SUBTYPE
64#define X86_CPU_SUBTYPE(ENUM, STR)
65#endif
66
67#ifndef X86_CPU_SUBTYPE_ALIAS
68#define X86_CPU_SUBTYPE_ALIAS(ENUM, STR)
69#endif
70
71// This list must match what is implemented in libgcc and compilert-rt. Clang
72// uses this to know how to implement __builtin_cpu_is.
73X86_CPU_SUBTYPE(INTEL_COREI7_NEHALEM, "nehalem")
74X86_CPU_SUBTYPE(INTEL_COREI7_WESTMERE, "westmere")
75X86_CPU_SUBTYPE(INTEL_COREI7_SANDYBRIDGE, "sandybridge")
76X86_CPU_SUBTYPE(AMDFAM10H_BARCELONA, "barcelona")
77X86_CPU_SUBTYPE(AMDFAM10H_SHANGHAI, "shanghai")
78X86_CPU_SUBTYPE(AMDFAM10H_ISTANBUL, "istanbul")
79X86_CPU_SUBTYPE(AMDFAM15H_BDVER1, "bdver1")
80X86_CPU_SUBTYPE(AMDFAM15H_BDVER2, "bdver2")
81X86_CPU_SUBTYPE(AMDFAM15H_BDVER3, "bdver3")
82X86_CPU_SUBTYPE(AMDFAM15H_BDVER4, "bdver4")
83X86_CPU_SUBTYPE(AMDFAM17H_ZNVER1, "znver1")
84X86_CPU_SUBTYPE(INTEL_COREI7_IVYBRIDGE, "ivybridge")
85X86_CPU_SUBTYPE(INTEL_COREI7_HASWELL, "haswell")
86X86_CPU_SUBTYPE(INTEL_COREI7_BROADWELL, "broadwell")
87X86_CPU_SUBTYPE(INTEL_COREI7_SKYLAKE, "skylake")
88X86_CPU_SUBTYPE(INTEL_COREI7_SKYLAKE_AVX512, "skylake-avx512")
89X86_CPU_SUBTYPE(INTEL_COREI7_CANNONLAKE, "cannonlake")
90X86_CPU_SUBTYPE(INTEL_COREI7_ICELAKE_CLIENT, "icelake-client")
91X86_CPU_SUBTYPE(INTEL_COREI7_ICELAKE_SERVER, "icelake-server")
92X86_CPU_SUBTYPE(AMDFAM17H_ZNVER2, "znver2")
93X86_CPU_SUBTYPE(INTEL_COREI7_CASCADELAKE, "cascadelake")
94X86_CPU_SUBTYPE(INTEL_COREI7_TIGERLAKE, "tigerlake")
95X86_CPU_SUBTYPE(INTEL_COREI7_COOPERLAKE, "cooperlake")
96X86_CPU_SUBTYPE(INTEL_COREI7_SAPPHIRERAPIDS, "sapphirerapids")
97X86_CPU_SUBTYPE(INTEL_COREI7_ALDERLAKE, "alderlake")
98X86_CPU_SUBTYPE(AMDFAM19H_ZNVER3, "znver3")
99X86_CPU_SUBTYPE(INTEL_COREI7_ROCKETLAKE, "rocketlake")
100X86_CPU_SUBTYPE(ZHAOXIN_FAM7H_LUJIAZUI, "zhaoxin_fam7h_lujiazui")
101X86_CPU_SUBTYPE(AMDFAM19H_ZNVER4, "znver4")
102X86_CPU_SUBTYPE(INTEL_COREI7_GRANITERAPIDS, "graniterapids")
103X86_CPU_SUBTYPE(INTEL_COREI7_GRANITERAPIDS_D,"graniterapids-d")
104X86_CPU_SUBTYPE(INTEL_COREI7_ARROWLAKE, "arrowlake")
105X86_CPU_SUBTYPE(INTEL_COREI7_ARROWLAKE_S, "arrowlake-s")
106X86_CPU_SUBTYPE(INTEL_COREI7_PANTHERLAKE, "pantherlake")
107
108// Alternate names supported by __builtin_cpu_is and target multiversioning.
109X86_CPU_SUBTYPE_ALIAS(INTEL_COREI7_ALDERLAKE, "raptorlake")
110X86_CPU_SUBTYPE_ALIAS(INTEL_COREI7_ALDERLAKE, "meteorlake")
111X86_CPU_SUBTYPE_ALIAS(INTEL_COREI7_SAPPHIRERAPIDS, "emeraldrapids")
112X86_CPU_SUBTYPE_ALIAS(INTEL_COREI7_ARROWLAKE_S,"lunarlake")
113X86_CPU_SUBTYPE_ALIAS(INTEL_COREI7_ALDERLAKE, "gracemont")
114
115#undef X86_CPU_SUBTYPE_ALIAS
116#undef X86_CPU_SUBTYPE
117
118// This macro is used for cpu types present in compiler-rt/libgcc. The third
119// parameter PRIORITY is as required by the attribute 'target' checking. Note
120// that not all are supported/prioritized by GCC, so synchronization with GCC's
121// implementation may require changing some existing values.
122//
123// We cannot just re-sort the list though because its order is dictated by the
124// order of bits in CodeGenFunction::GetX86CpuSupportsMask.
125// We cannot re-adjust the position of X86_FEATURE_COMPAT at the whole list.
126#ifndef X86_FEATURE_COMPAT
127#define X86_FEATURE_COMPAT(ENUM, STR, PRIORITY) X86_FEATURE(ENUM, STR)
128#endif
129
130#ifndef X86_FEATURE
131#define X86_FEATURE(ENUM, STR)
132#endif
133
134#ifndef X86_MICROARCH_LEVEL
135#define X86_MICROARCH_LEVEL(ENUM, STR, PRIORITY)
136#endif
137
138X86_FEATURE_COMPAT(CMOV, "cmov", 0)
139X86_FEATURE_COMPAT(MMX, "mmx", 1)
140X86_FEATURE_COMPAT(POPCNT, "popcnt", 9)
141X86_FEATURE_COMPAT(SSE, "sse", 2)
142X86_FEATURE_COMPAT(SSE2, "sse2", 3)
143X86_FEATURE_COMPAT(SSE3, "sse3", 4)
144X86_FEATURE_COMPAT(SSSE3, "ssse3", 5)
145X86_FEATURE_COMPAT(SSE4_1, "sse4.1", 7)
146X86_FEATURE_COMPAT(SSE4_2, "sse4.2", 8)
147X86_FEATURE_COMPAT(AVX, "avx", 12)
148X86_FEATURE_COMPAT(AVX2, "avx2", 18)
149X86_FEATURE_COMPAT(SSE4_A, "sse4a", 6)
150X86_FEATURE_COMPAT(FMA4, "fma4", 14)
151X86_FEATURE_COMPAT(XOP, "xop", 15)
152X86_FEATURE_COMPAT(FMA, "fma", 16)
153X86_FEATURE_COMPAT(AVX512F, "avx512f", 19)
154X86_FEATURE_COMPAT(BMI, "bmi", 13)
155X86_FEATURE_COMPAT(BMI2, "bmi2", 17)
156X86_FEATURE_COMPAT(AES, "aes", 10)
157X86_FEATURE_COMPAT(PCLMUL, "pclmul", 11)
158X86_FEATURE_COMPAT(AVX512VL, "avx512vl", 20)
159X86_FEATURE_COMPAT(AVX512BW, "avx512bw", 21)
160X86_FEATURE_COMPAT(AVX512DQ, "avx512dq", 22)
161X86_FEATURE_COMPAT(AVX512CD, "avx512cd", 23)
162X86_FEATURE_COMPAT(AVX512ER, "avx512er", 24)
163X86_FEATURE_COMPAT(AVX512PF, "avx512pf", 25)
164X86_FEATURE_COMPAT(AVX512VBMI, "avx512vbmi", 26)
165X86_FEATURE_COMPAT(AVX512IFMA, "avx512ifma", 27)
166X86_FEATURE_COMPAT(AVX5124VNNIW, "avx5124vnniw", 28)
167X86_FEATURE_COMPAT(AVX5124FMAPS, "avx5124fmaps", 29)
168X86_FEATURE_COMPAT(AVX512VPOPCNTDQ, "avx512vpopcntdq", 30)
169X86_FEATURE_COMPAT(AVX512VBMI2, "avx512vbmi2", 31)
170X86_FEATURE_COMPAT(GFNI, "gfni", 32)
171X86_FEATURE_COMPAT(VPCLMULQDQ, "vpclmulqdq", 33)
172X86_FEATURE_COMPAT(AVX512VNNI, "avx512vnni", 34)
173X86_FEATURE_COMPAT(AVX512BITALG, "avx512bitalg", 35)
174X86_FEATURE_COMPAT(AVX512BF16, "avx512bf16", 36)
175X86_FEATURE_COMPAT(AVX512VP2INTERSECT, "avx512vp2intersect", 37)
176// Below Features has some missings comparing to gcc, it's because gcc has some
177// not one-to-one mapped in llvm.
178X86_FEATURE_COMPAT(3DNOW, "3dnow", 0)
179X86_FEATURE (3DNOWA, "3dnowa")
180X86_FEATURE_COMPAT(ADX, "adx", 0)
181X86_FEATURE (64BIT, "64bit")
182X86_FEATURE_COMPAT(CLDEMOTE, "cldemote", 0)
183X86_FEATURE_COMPAT(CLFLUSHOPT, "clflushopt", 0)
184X86_FEATURE_COMPAT(CLWB, "clwb", 0)
185X86_FEATURE_COMPAT(CLZERO, "clzero", 0)
186X86_FEATURE_COMPAT(CMPXCHG16B, "cx16", 0)
187X86_FEATURE (CMPXCHG8B, "cx8")
188X86_FEATURE_COMPAT(ENQCMD, "enqcmd", 0)
189X86_FEATURE_COMPAT(F16C, "f16c", 0)
190X86_FEATURE_COMPAT(FSGSBASE, "fsgsbase", 0)
191X86_FEATURE (CRC32, "crc32")
192X86_FEATURE (INVPCID, "invpcid")
193X86_FEATURE (RDPRU, "rdpru")
194X86_FEATURE (SAHF, "sahf")
195X86_FEATURE (VZEROUPPER, "vzeroupper")
196X86_FEATURE_COMPAT(LWP, "lwp", 0)
197X86_FEATURE_COMPAT(LZCNT, "lzcnt", 0)
198X86_FEATURE_COMPAT(MOVBE, "movbe", 0)
199X86_FEATURE_COMPAT(MOVDIR64B, "movdir64b", 0)
200X86_FEATURE_COMPAT(MOVDIRI, "movdiri", 0)
201X86_FEATURE_COMPAT(MWAITX, "mwaitx", 0)
202X86_FEATURE (X87, "x87")
203X86_FEATURE_COMPAT(PCONFIG, "pconfig", 0)
204X86_FEATURE_COMPAT(PKU, "pku", 0)
205X86_FEATURE_COMPAT(PREFETCHWT1, "prefetchwt1", 0)
206X86_FEATURE_COMPAT(PRFCHW, "prfchw", 0)
207X86_FEATURE_COMPAT(PTWRITE, "ptwrite", 0)
208X86_FEATURE_COMPAT(RDPID, "rdpid", 0)
209X86_FEATURE_COMPAT(RDRND, "rdrnd", 0)
210X86_FEATURE_COMPAT(RDSEED, "rdseed", 0)
211X86_FEATURE_COMPAT(RTM, "rtm", 0)
212X86_FEATURE_COMPAT(SERIALIZE, "serialize", 0)
213X86_FEATURE_COMPAT(SGX, "sgx", 0)
214X86_FEATURE_COMPAT(SHA, "sha", 0)
215X86_FEATURE_COMPAT(SHSTK, "shstk", 0)
216X86_FEATURE_COMPAT(TBM, "tbm", 0)
217X86_FEATURE_COMPAT(TSXLDTRK, "tsxldtrk", 0)
218X86_FEATURE_COMPAT(VAES, "vaes", 0)
219X86_FEATURE_COMPAT(WAITPKG, "waitpkg", 0)
220X86_FEATURE_COMPAT(WBNOINVD, "wbnoinvd", 0)
221X86_FEATURE_COMPAT(XSAVE, "xsave", 0)
222X86_FEATURE_COMPAT(XSAVEC, "xsavec", 0)
223X86_FEATURE_COMPAT(XSAVEOPT, "xsaveopt", 0)
224X86_FEATURE_COMPAT(XSAVES, "xsaves", 0)
225X86_FEATURE_COMPAT(AMX_TILE, "amx-tile", 0)
226X86_FEATURE_COMPAT(AMX_INT8, "amx-int8", 0)
227X86_FEATURE_COMPAT(AMX_BF16, "amx-bf16", 0)
228X86_FEATURE_COMPAT(UINTR, "uintr", 0)
229X86_FEATURE_COMPAT(HRESET, "hreset", 0)
230X86_FEATURE_COMPAT(KL, "kl", 0)
231X86_FEATURE (FXSR, "fxsr")
232X86_FEATURE_COMPAT(WIDEKL, "widekl", 0)
233X86_FEATURE_COMPAT(AVXVNNI, "avxvnni", 0)
234X86_FEATURE_COMPAT(AVX512FP16, "avx512fp16", 0)
235X86_FEATURE (CCMP, "ccmp")
236X86_FEATURE (Push2Pop2, "push2pop2")
237X86_FEATURE (PPX, "ppx")
238X86_FEATURE (NDD, "ndd")
239X86_FEATURE_COMPAT(AVXIFMA, "avxifma", 0)
240X86_FEATURE_COMPAT(AVXVNNIINT8, "avxvnniint8", 0)
241X86_FEATURE_COMPAT(AVXNECONVERT, "avxneconvert", 0)
242X86_FEATURE_COMPAT(CMPCCXADD, "cmpccxadd", 0)
243X86_FEATURE_COMPAT(AMX_FP16, "amx-fp16", 0)
244X86_FEATURE_COMPAT(PREFETCHI, "prefetchi", 0)
245X86_FEATURE_COMPAT(RAOINT, "raoint", 0)
246X86_FEATURE_COMPAT(AMX_COMPLEX, "amx-complex", 0)
247X86_FEATURE_COMPAT(AVXVNNIINT16, "avxvnniint16", 0)
248X86_FEATURE_COMPAT(SM3, "sm3", 0)
249X86_FEATURE_COMPAT(SHA512, "sha512", 0)
250X86_FEATURE_COMPAT(SM4, "sm4", 0)
251X86_FEATURE (EGPR, "egpr")
252X86_FEATURE_COMPAT(USERMSR, "usermsr", 0)
253X86_FEATURE_COMPAT(AVX10_1, "avx10.1-256", 0)
254X86_FEATURE_COMPAT(AVX10_1_512, "avx10.1-512", 0)
255X86_FEATURE (EVEX512, "evex512")
256X86_FEATURE (CF, "cf")
257// These features aren't really CPU features, but the frontend can set them.
258X86_FEATURE (RETPOLINE_EXTERNAL_THUNK, "retpoline-external-thunk")
259X86_FEATURE (RETPOLINE_INDIRECT_BRANCHES, "retpoline-indirect-branches")
260X86_FEATURE (RETPOLINE_INDIRECT_CALLS, "retpoline-indirect-calls")
261X86_FEATURE (LVI_CFI, "lvi-cfi")
262X86_FEATURE (LVI_LOAD_HARDENING, "lvi-load-hardening")
263
264X86_MICROARCH_LEVEL(X86_64_BASELINE,"x86-64", 95)
265X86_MICROARCH_LEVEL(X86_64_V2, "x86-64-v2", 96)
266X86_MICROARCH_LEVEL(X86_64_V3, "x86-64-v3", 97)
267X86_MICROARCH_LEVEL(X86_64_V4, "x86-64-v4", 98)
268X86_MICROARCH_LEVEL(APXF, "apxf", 111)
269#undef X86_FEATURE_COMPAT
270#undef X86_FEATURE
271#undef X86_MICROARCH_LEVEL
272

source code of llvm/include/llvm/TargetParser/X86TargetParser.def