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#ifndef X86_FEATURE_COMPAT
126#define X86_FEATURE_COMPAT(ENUM, STR, PRIORITY) X86_FEATURE(ENUM, STR)
127#endif
128
129#ifndef X86_FEATURE
130#define X86_FEATURE(ENUM, STR)
131#endif
132
133#ifndef X86_MICROARCH_LEVEL
134#define X86_MICROARCH_LEVEL(ENUM, STR, PRIORITY)
135#endif
136
137X86_FEATURE_COMPAT(CMOV,            "cmov",                  0)
138X86_FEATURE_COMPAT(MMX,             "mmx",                   1)
139X86_FEATURE_COMPAT(POPCNT,          "popcnt",                9)
140X86_FEATURE_COMPAT(SSE,             "sse",                   2)
141X86_FEATURE_COMPAT(SSE2,            "sse2",                  3)
142X86_FEATURE_COMPAT(SSE3,            "sse3",                  4)
143X86_FEATURE_COMPAT(SSSE3,           "ssse3",                 5)
144X86_FEATURE_COMPAT(SSE4_1,          "sse4.1",                7)
145X86_FEATURE_COMPAT(SSE4_2,          "sse4.2",                8)
146X86_FEATURE_COMPAT(AVX,             "avx",                   12)
147X86_FEATURE_COMPAT(AVX2,            "avx2",                  18)
148X86_FEATURE_COMPAT(SSE4_A,          "sse4a",                 6)
149X86_FEATURE_COMPAT(FMA4,            "fma4",                  14)
150X86_FEATURE_COMPAT(XOP,             "xop",                   15)
151X86_FEATURE_COMPAT(FMA,             "fma",                   16)
152X86_FEATURE_COMPAT(AVX512F,         "avx512f",               19)
153X86_FEATURE_COMPAT(BMI,             "bmi",                   13)
154X86_FEATURE_COMPAT(BMI2,            "bmi2",                  17)
155X86_FEATURE_COMPAT(AES,             "aes",                   10)
156X86_FEATURE_COMPAT(PCLMUL,          "pclmul",                11)
157X86_FEATURE_COMPAT(AVX512VL,        "avx512vl",              20)
158X86_FEATURE_COMPAT(AVX512BW,        "avx512bw",              21)
159X86_FEATURE_COMPAT(AVX512DQ,        "avx512dq",              22)
160X86_FEATURE_COMPAT(AVX512CD,        "avx512cd",              23)
161X86_FEATURE_COMPAT(AVX512ER,        "avx512er",              24)
162X86_FEATURE_COMPAT(AVX512PF,        "avx512pf",              25)
163X86_FEATURE_COMPAT(AVX512VBMI,      "avx512vbmi",            26)
164X86_FEATURE_COMPAT(AVX512IFMA,      "avx512ifma",            27)
165X86_FEATURE_COMPAT(AVX5124VNNIW,    "avx5124vnniw",          28)
166X86_FEATURE_COMPAT(AVX5124FMAPS,    "avx5124fmaps",          29)
167X86_FEATURE_COMPAT(AVX512VPOPCNTDQ, "avx512vpopcntdq",       30)
168X86_FEATURE_COMPAT(AVX512VBMI2,     "avx512vbmi2",           31)
169X86_FEATURE_COMPAT(GFNI,            "gfni",                  32)
170X86_FEATURE_COMPAT(VPCLMULQDQ,      "vpclmulqdq",            33)
171X86_FEATURE_COMPAT(AVX512VNNI,      "avx512vnni",            34)
172X86_FEATURE_COMPAT(AVX512BITALG,    "avx512bitalg",          35)
173X86_FEATURE_COMPAT(AVX512BF16,      "avx512bf16",            36)
174X86_FEATURE_COMPAT(AVX512VP2INTERSECT, "avx512vp2intersect", 37)
175// Features below here are not in libgcc/compiler-rt.
176X86_FEATURE       (3DNOW,           "3dnow")
177X86_FEATURE       (3DNOWA,          "3dnowa")
178X86_FEATURE       (64BIT,           "64bit")
179X86_FEATURE       (ADX,             "adx")
180X86_FEATURE       (AMX_BF16,        "amx-bf16")
181X86_FEATURE       (AMX_COMPLEX,     "amx-complex")
182X86_FEATURE       (AMX_INT8,        "amx-int8")
183X86_FEATURE       (AMX_TILE,        "amx-tile")
184X86_FEATURE       (CLDEMOTE,        "cldemote")
185X86_FEATURE       (CLFLUSHOPT,      "clflushopt")
186X86_FEATURE       (CLWB,            "clwb")
187X86_FEATURE       (CLZERO,          "clzero")
188X86_FEATURE       (CMPXCHG16B,      "cx16")
189X86_FEATURE       (CMPXCHG8B,       "cx8")
190X86_FEATURE       (CRC32,           "crc32")
191X86_FEATURE       (ENQCMD,          "enqcmd")
192X86_FEATURE       (F16C,            "f16c")
193X86_FEATURE       (FSGSBASE,        "fsgsbase")
194X86_FEATURE       (FXSR,            "fxsr")
195X86_FEATURE       (INVPCID,         "invpcid")
196X86_FEATURE       (KL,              "kl")
197X86_FEATURE       (WIDEKL,          "widekl")
198X86_FEATURE       (LWP,             "lwp")
199X86_FEATURE       (LZCNT,           "lzcnt")
200X86_FEATURE       (MOVBE,           "movbe")
201X86_FEATURE       (MOVDIR64B,       "movdir64b")
202X86_FEATURE       (MOVDIRI,         "movdiri")
203X86_FEATURE       (MWAITX,          "mwaitx")
204X86_FEATURE       (PCONFIG,         "pconfig")
205X86_FEATURE       (PKU,             "pku")
206X86_FEATURE       (PREFETCHI,       "prefetchi")
207X86_FEATURE       (PREFETCHWT1,     "prefetchwt1")
208X86_FEATURE       (PRFCHW,          "prfchw")
209X86_FEATURE       (PTWRITE,         "ptwrite")
210X86_FEATURE       (RDPID,           "rdpid")
211X86_FEATURE       (RDPRU,           "rdpru")
212X86_FEATURE       (RDRND,           "rdrnd")
213X86_FEATURE       (RDSEED,          "rdseed")
214X86_FEATURE       (RTM,             "rtm")
215X86_FEATURE       (SAHF,            "sahf")
216X86_FEATURE       (SERIALIZE,       "serialize")
217X86_FEATURE       (SGX,             "sgx")
218X86_FEATURE       (SHA,             "sha")
219X86_FEATURE       (SHSTK,           "shstk")
220X86_FEATURE       (TBM,             "tbm")
221X86_FEATURE       (TSXLDTRK,        "tsxldtrk")
222X86_FEATURE       (UINTR,           "uintr")
223X86_FEATURE       (VAES,            "vaes")
224X86_FEATURE       (VZEROUPPER,      "vzeroupper")
225X86_FEATURE       (WAITPKG,         "waitpkg")
226X86_FEATURE       (WBNOINVD,        "wbnoinvd")
227X86_FEATURE       (X87,             "x87")
228X86_FEATURE       (XSAVE,           "xsave")
229X86_FEATURE       (XSAVEC,          "xsavec")
230X86_FEATURE       (XSAVEOPT,        "xsaveopt")
231X86_FEATURE       (XSAVES,          "xsaves")
232X86_FEATURE       (HRESET,          "hreset")
233X86_FEATURE       (RAOINT,          "raoint")
234X86_FEATURE       (AVX512FP16,      "avx512fp16")
235X86_FEATURE       (AMX_FP16,        "amx-fp16")
236X86_FEATURE       (CMPCCXADD,       "cmpccxadd")
237X86_FEATURE       (AVXNECONVERT,    "avxneconvert")
238X86_FEATURE       (AVXVNNI,         "avxvnni")
239X86_FEATURE       (AVXIFMA,         "avxifma")
240X86_FEATURE       (AVXVNNIINT8,     "avxvnniint8")
241X86_FEATURE       (SHA512,          "sha512")
242X86_FEATURE       (SM3,             "sm3")
243X86_FEATURE       (SM4,             "sm4")
244X86_FEATURE       (AVXVNNIINT16,    "avxvnniint16")
245X86_FEATURE       (EVEX512,         "evex512")
246X86_FEATURE       (AVX10_1,         "avx10.1-256")
247X86_FEATURE       (AVX10_1_512,     "avx10.1-512")
248X86_FEATURE       (USERMSR,         "usermsr")
249X86_FEATURE       (EGPR,            "egpr")
250X86_FEATURE       (Push2Pop2,       "push2pop2")
251X86_FEATURE       (PPX,             "ppx")
252X86_FEATURE       (NDD,             "ndd")
253X86_FEATURE       (CCMP,            "ccmp")
254X86_FEATURE       (CF,              "cf")
255// These features aren't really CPU features, but the frontend can set them.
256X86_FEATURE       (RETPOLINE_EXTERNAL_THUNK,    "retpoline-external-thunk")
257X86_FEATURE       (RETPOLINE_INDIRECT_BRANCHES, "retpoline-indirect-branches")
258X86_FEATURE       (RETPOLINE_INDIRECT_CALLS,    "retpoline-indirect-calls")
259X86_FEATURE       (LVI_CFI,                     "lvi-cfi")
260X86_FEATURE       (LVI_LOAD_HARDENING,          "lvi-load-hardening")
261
262X86_MICROARCH_LEVEL(X86_64_BASELINE,"x86-64",               95)
263X86_MICROARCH_LEVEL(X86_64_V2,      "x86-64-v2",            96)
264X86_MICROARCH_LEVEL(X86_64_V3,      "x86-64-v3",            97)
265X86_MICROARCH_LEVEL(X86_64_V4,      "x86-64-v4",            98)
266#undef X86_FEATURE_COMPAT
267#undef X86_FEATURE
268#undef X86_MICROARCH_LEVEL
269