Back to home page

EIC code displayed by LXR

 
 

    


Warning, /include/llvm/TargetParser/X86TargetParser.def is written in an unsupported language. File is not indexed.

0001 //===- X86TargetParser.def - X86 target parsing defines ---------*- C++ -*-===//
0002 //
0003 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
0004 // See https://llvm.org/LICENSE.txt for license information.
0005 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
0006 //
0007 //===----------------------------------------------------------------------===//
0008 //
0009 // This file provides defines to build up the X86 target parser's logic.
0010 //
0011 //===----------------------------------------------------------------------===//
0012 
0013 // NOTE: NO INCLUDE GUARD DESIRED!
0014 
0015 #ifndef X86_VENDOR
0016 #define X86_VENDOR(ENUM, STR)
0017 #endif
0018 X86_VENDOR(VENDOR_INTEL, "intel")
0019 X86_VENDOR(VENDOR_AMD,   "amd")
0020 #undef X86_VENDOR
0021 
0022 // This macro is used for cpu types present in compiler-rt/libgcc.
0023 #ifndef X86_CPU_TYPE
0024 #define X86_CPU_TYPE(ENUM, STR)
0025 #endif
0026 
0027 #ifndef X86_CPU_TYPE_ALIAS
0028 #define X86_CPU_TYPE_ALIAS(ENUM, STR)
0029 #endif
0030 
0031 // This list must match what is implemented in libgcc and compilert-rt. Clang
0032 // uses this to know how to implement __builtin_cpu_is.
0033 X86_CPU_TYPE(INTEL_BONNELL,       "bonnell")
0034 X86_CPU_TYPE(INTEL_CORE2,         "core2")
0035 X86_CPU_TYPE(INTEL_COREI7,        "corei7")
0036 X86_CPU_TYPE(AMDFAM10H,           "amdfam10h")
0037 X86_CPU_TYPE(AMDFAM15H,           "amdfam15h")
0038 X86_CPU_TYPE(INTEL_SILVERMONT,    "silvermont")
0039 X86_CPU_TYPE(INTEL_KNL,           "knl")
0040 X86_CPU_TYPE(AMD_BTVER1,          "btver1")
0041 X86_CPU_TYPE(AMD_BTVER2,          "btver2")
0042 X86_CPU_TYPE(AMDFAM17H,           "amdfam17h")
0043 X86_CPU_TYPE(INTEL_KNM,           "knm")
0044 X86_CPU_TYPE(INTEL_GOLDMONT,      "goldmont")
0045 X86_CPU_TYPE(INTEL_GOLDMONT_PLUS, "goldmont-plus")
0046 X86_CPU_TYPE(INTEL_TREMONT,       "tremont")
0047 X86_CPU_TYPE(AMDFAM19H,           "amdfam19h")
0048 X86_CPU_TYPE(ZHAOXIN_FAM7H,       "zhaoxin_fam7h")
0049 X86_CPU_TYPE(INTEL_SIERRAFOREST,  "sierraforest")
0050 X86_CPU_TYPE(INTEL_GRANDRIDGE,    "grandridge")
0051 X86_CPU_TYPE(INTEL_CLEARWATERFOREST, "clearwaterforest")
0052 X86_CPU_TYPE(AMDFAM1AH,           "amdfam1ah")
0053 
0054 // Alternate names supported by __builtin_cpu_is and target multiversioning.
0055 X86_CPU_TYPE_ALIAS(INTEL_BONNELL,    "atom")
0056 X86_CPU_TYPE_ALIAS(AMDFAM10H,        "amdfam10")
0057 X86_CPU_TYPE_ALIAS(AMDFAM15H,        "amdfam15")
0058 X86_CPU_TYPE_ALIAS(AMDFAM1AH,        "amdfam1a")
0059 X86_CPU_TYPE_ALIAS(INTEL_SILVERMONT, "slm")
0060 
0061 #undef X86_CPU_TYPE_ALIAS
0062 #undef X86_CPU_TYPE
0063 
0064 // This macro is used for cpu subtypes present in compiler-rt/libgcc.
0065 #ifndef X86_CPU_SUBTYPE
0066 #define X86_CPU_SUBTYPE(ENUM, STR)
0067 #endif
0068 
0069 #ifndef X86_CPU_SUBTYPE_ALIAS
0070 #define X86_CPU_SUBTYPE_ALIAS(ENUM, STR)
0071 #endif
0072 
0073 // This list must match what is implemented in libgcc and compilert-rt. Clang
0074 // uses this to know how to implement __builtin_cpu_is.
0075 X86_CPU_SUBTYPE(INTEL_COREI7_NEHALEM,        "nehalem")
0076 X86_CPU_SUBTYPE(INTEL_COREI7_WESTMERE,       "westmere")
0077 X86_CPU_SUBTYPE(INTEL_COREI7_SANDYBRIDGE,    "sandybridge")
0078 X86_CPU_SUBTYPE(AMDFAM10H_BARCELONA,         "barcelona")
0079 X86_CPU_SUBTYPE(AMDFAM10H_SHANGHAI,          "shanghai")
0080 X86_CPU_SUBTYPE(AMDFAM10H_ISTANBUL,          "istanbul")
0081 X86_CPU_SUBTYPE(AMDFAM15H_BDVER1,            "bdver1")
0082 X86_CPU_SUBTYPE(AMDFAM15H_BDVER2,            "bdver2")
0083 X86_CPU_SUBTYPE(AMDFAM15H_BDVER3,            "bdver3")
0084 X86_CPU_SUBTYPE(AMDFAM15H_BDVER4,            "bdver4")
0085 X86_CPU_SUBTYPE(AMDFAM17H_ZNVER1,            "znver1")
0086 X86_CPU_SUBTYPE(INTEL_COREI7_IVYBRIDGE,      "ivybridge")
0087 X86_CPU_SUBTYPE(INTEL_COREI7_HASWELL,        "haswell")
0088 X86_CPU_SUBTYPE(INTEL_COREI7_BROADWELL,      "broadwell")
0089 X86_CPU_SUBTYPE(INTEL_COREI7_SKYLAKE,        "skylake")
0090 X86_CPU_SUBTYPE(INTEL_COREI7_SKYLAKE_AVX512, "skylake-avx512")
0091 X86_CPU_SUBTYPE(INTEL_COREI7_CANNONLAKE,     "cannonlake")
0092 X86_CPU_SUBTYPE(INTEL_COREI7_ICELAKE_CLIENT, "icelake-client")
0093 X86_CPU_SUBTYPE(INTEL_COREI7_ICELAKE_SERVER, "icelake-server")
0094 X86_CPU_SUBTYPE(AMDFAM17H_ZNVER2,            "znver2")
0095 X86_CPU_SUBTYPE(INTEL_COREI7_CASCADELAKE,    "cascadelake")
0096 X86_CPU_SUBTYPE(INTEL_COREI7_TIGERLAKE,      "tigerlake")
0097 X86_CPU_SUBTYPE(INTEL_COREI7_COOPERLAKE,     "cooperlake")
0098 X86_CPU_SUBTYPE(INTEL_COREI7_SAPPHIRERAPIDS, "sapphirerapids")
0099 X86_CPU_SUBTYPE(INTEL_COREI7_ALDERLAKE,      "alderlake")
0100 X86_CPU_SUBTYPE(AMDFAM19H_ZNVER3,            "znver3")
0101 X86_CPU_SUBTYPE(INTEL_COREI7_ROCKETLAKE,     "rocketlake")
0102 X86_CPU_SUBTYPE(ZHAOXIN_FAM7H_LUJIAZUI,      "zhaoxin_fam7h_lujiazui")
0103 X86_CPU_SUBTYPE(AMDFAM19H_ZNVER4,            "znver4")
0104 X86_CPU_SUBTYPE(INTEL_COREI7_GRANITERAPIDS,  "graniterapids")
0105 X86_CPU_SUBTYPE(INTEL_COREI7_GRANITERAPIDS_D,"graniterapids-d")
0106 X86_CPU_SUBTYPE(INTEL_COREI7_ARROWLAKE,      "arrowlake")
0107 X86_CPU_SUBTYPE(INTEL_COREI7_ARROWLAKE_S,    "arrowlake-s")
0108 X86_CPU_SUBTYPE(INTEL_COREI7_PANTHERLAKE,    "pantherlake")
0109 X86_CPU_SUBTYPE(AMDFAM1AH_ZNVER5,            "znver5")
0110 X86_CPU_SUBTYPE(INTEL_COREI7_DIAMONDRAPIDS,  "diamondrapids")
0111 
0112 // Alternate names supported by __builtin_cpu_is and target multiversioning.
0113 X86_CPU_SUBTYPE_ALIAS(INTEL_COREI7_ALDERLAKE, "raptorlake")
0114 X86_CPU_SUBTYPE_ALIAS(INTEL_COREI7_ALDERLAKE, "meteorlake")
0115 X86_CPU_SUBTYPE_ALIAS(INTEL_COREI7_SAPPHIRERAPIDS, "emeraldrapids")
0116 X86_CPU_SUBTYPE_ALIAS(INTEL_COREI7_ARROWLAKE_S,"lunarlake")
0117 X86_CPU_SUBTYPE_ALIAS(INTEL_COREI7_ALDERLAKE, "gracemont")
0118 
0119 #undef X86_CPU_SUBTYPE_ALIAS
0120 #undef X86_CPU_SUBTYPE
0121 
0122 // This macro is used for cpu types present in compiler-rt/libgcc. The third
0123 // parameter PRIORITY is as required by the attribute 'target' checking. Note
0124 // that not all are supported/prioritized by GCC, so synchronization with GCC's
0125 // implementation may require changing some existing values.
0126 //
0127 // We cannot just re-sort the list though because its order is dictated by the
0128 // order of bits in CodeGenFunction::GetX86CpuSupportsMask.
0129 // We cannot re-adjust the position of X86_FEATURE_COMPAT at the whole list.
0130 #ifndef X86_FEATURE_COMPAT
0131 #define X86_FEATURE_COMPAT(ENUM, STR, PRIORITY) X86_FEATURE(ENUM, STR)
0132 #endif
0133 
0134 #ifndef X86_FEATURE
0135 #define X86_FEATURE(ENUM, STR)
0136 #endif
0137 
0138 #ifndef X86_MICROARCH_LEVEL
0139 #define X86_MICROARCH_LEVEL(ENUM, STR, PRIORITY)
0140 #endif
0141 
0142 X86_FEATURE_COMPAT(CMOV,            "cmov",                  0)
0143 X86_FEATURE_COMPAT(MMX,             "mmx",                   1)
0144 X86_FEATURE_COMPAT(POPCNT,          "popcnt",                9)
0145 X86_FEATURE_COMPAT(SSE,             "sse",                   2)
0146 X86_FEATURE_COMPAT(SSE2,            "sse2",                  3)
0147 X86_FEATURE_COMPAT(SSE3,            "sse3",                  4)
0148 X86_FEATURE_COMPAT(SSSE3,           "ssse3",                 5)
0149 X86_FEATURE_COMPAT(SSE4_1,          "sse4.1",                7)
0150 X86_FEATURE_COMPAT(SSE4_2,          "sse4.2",                8)
0151 X86_FEATURE_COMPAT(AVX,             "avx",                   12)
0152 X86_FEATURE_COMPAT(AVX2,            "avx2",                  18)
0153 X86_FEATURE_COMPAT(SSE4_A,          "sse4a",                 6)
0154 X86_FEATURE_COMPAT(FMA4,            "fma4",                  14)
0155 X86_FEATURE_COMPAT(XOP,             "xop",                   15)
0156 X86_FEATURE_COMPAT(FMA,             "fma",                   16)
0157 X86_FEATURE_COMPAT(AVX512F,         "avx512f",               19)
0158 X86_FEATURE_COMPAT(BMI,             "bmi",                   13)
0159 X86_FEATURE_COMPAT(BMI2,            "bmi2",                  17)
0160 X86_FEATURE_COMPAT(AES,             "aes",                   10)
0161 X86_FEATURE_COMPAT(PCLMUL,          "pclmul",                11)
0162 X86_FEATURE_COMPAT(AVX512VL,        "avx512vl",              20)
0163 X86_FEATURE_COMPAT(AVX512BW,        "avx512bw",              21)
0164 X86_FEATURE_COMPAT(AVX512DQ,        "avx512dq",              22)
0165 X86_FEATURE_COMPAT(AVX512CD,        "avx512cd",              23)
0166 X86_FEATURE       (NF,              "nf")
0167 X86_FEATURE       (CF,              "cf")
0168 X86_FEATURE_COMPAT(AVX512VBMI,      "avx512vbmi",            24)
0169 X86_FEATURE_COMPAT(AVX512IFMA,      "avx512ifma",            25)
0170 X86_FEATURE_COMPAT(AVX5124VNNIW,    "avx5124vnniw",          26)
0171 X86_FEATURE_COMPAT(AVX5124FMAPS,    "avx5124fmaps",          27)
0172 X86_FEATURE_COMPAT(AVX512VPOPCNTDQ, "avx512vpopcntdq",       28)
0173 X86_FEATURE_COMPAT(AVX512VBMI2,     "avx512vbmi2",           29)
0174 X86_FEATURE_COMPAT(GFNI,            "gfni",                  30)
0175 X86_FEATURE_COMPAT(VPCLMULQDQ,      "vpclmulqdq",            31)
0176 X86_FEATURE_COMPAT(AVX512VNNI,      "avx512vnni",            32)
0177 X86_FEATURE_COMPAT(AVX512BITALG,    "avx512bitalg",          33)
0178 X86_FEATURE_COMPAT(AVX512BF16,      "avx512bf16",            34)
0179 X86_FEATURE_COMPAT(AVX512VP2INTERSECT, "avx512vp2intersect", 35)
0180 // Below Features has some missings comparing to gcc, it's because gcc has some
0181 // not one-to-one mapped in llvm.
0182 
0183 // FIXME: dummy features were added to keep the numeric values of later features
0184 // stable. Since the values need to be ABI stable, they should be changed to
0185 // have explicitly assigned values, and then these dummy features removed.
0186 X86_FEATURE       (DUMMYFEATURE1,   "__dummyfeature1")
0187 X86_FEATURE       (DUMMYFEATURE2,   "__dummyfeature2")
0188 X86_FEATURE_COMPAT(ADX,             "adx",                    0)
0189 X86_FEATURE       (64BIT,           "64bit")
0190 X86_FEATURE_COMPAT(CLDEMOTE,        "cldemote",               0)
0191 X86_FEATURE_COMPAT(CLFLUSHOPT,      "clflushopt",             0)
0192 X86_FEATURE_COMPAT(CLWB,            "clwb",                   0)
0193 X86_FEATURE_COMPAT(CLZERO,          "clzero",                 0)
0194 X86_FEATURE_COMPAT(CMPXCHG16B,      "cx16",                   0)
0195 X86_FEATURE       (CMPXCHG8B,       "cx8")
0196 X86_FEATURE_COMPAT(ENQCMD,          "enqcmd",                 0)
0197 X86_FEATURE_COMPAT(F16C,            "f16c",                   0)
0198 X86_FEATURE_COMPAT(FSGSBASE,        "fsgsbase",               0)
0199 X86_FEATURE       (CRC32,           "crc32")
0200 X86_FEATURE       (INVPCID,         "invpcid")
0201 X86_FEATURE       (RDPRU,           "rdpru")
0202 X86_FEATURE       (SAHF,            "sahf")
0203 X86_FEATURE       (VZEROUPPER,      "vzeroupper")
0204 X86_FEATURE_COMPAT(LWP,             "lwp",                    0)
0205 X86_FEATURE_COMPAT(LZCNT,           "lzcnt",                  0)
0206 X86_FEATURE_COMPAT(MOVBE,           "movbe",                  0)
0207 X86_FEATURE_COMPAT(MOVDIR64B,       "movdir64b",              0)
0208 X86_FEATURE_COMPAT(MOVDIRI,         "movdiri",                0)
0209 X86_FEATURE_COMPAT(MWAITX,          "mwaitx",                 0)
0210 X86_FEATURE       (X87,             "x87")
0211 X86_FEATURE_COMPAT(PCONFIG,         "pconfig",                0)
0212 X86_FEATURE_COMPAT(PKU,             "pku",                    0)
0213 X86_FEATURE       (EVEX512,         "evex512")
0214 X86_FEATURE_COMPAT(PRFCHW,          "prfchw",                 0)
0215 X86_FEATURE_COMPAT(PTWRITE,         "ptwrite",                0)
0216 X86_FEATURE_COMPAT(RDPID,           "rdpid",                  0)
0217 X86_FEATURE_COMPAT(RDRND,           "rdrnd",                  0)
0218 X86_FEATURE_COMPAT(RDSEED,          "rdseed",                 0)
0219 X86_FEATURE_COMPAT(RTM,             "rtm",                    0)
0220 X86_FEATURE_COMPAT(SERIALIZE,       "serialize",              0)
0221 X86_FEATURE_COMPAT(SGX,             "sgx",                    0)
0222 X86_FEATURE_COMPAT(SHA,             "sha",                    0)
0223 X86_FEATURE_COMPAT(SHSTK,           "shstk",                  0)
0224 X86_FEATURE_COMPAT(TBM,             "tbm",                    0)
0225 X86_FEATURE_COMPAT(TSXLDTRK,        "tsxldtrk",               0)
0226 X86_FEATURE_COMPAT(VAES,            "vaes",                   0)
0227 X86_FEATURE_COMPAT(WAITPKG,         "waitpkg",                0)
0228 X86_FEATURE_COMPAT(WBNOINVD,        "wbnoinvd",               0)
0229 X86_FEATURE_COMPAT(XSAVE,           "xsave",                  0)
0230 X86_FEATURE_COMPAT(XSAVEC,          "xsavec",                 0)
0231 X86_FEATURE_COMPAT(XSAVEOPT,        "xsaveopt",               0)
0232 X86_FEATURE_COMPAT(XSAVES,          "xsaves",                 0)
0233 X86_FEATURE_COMPAT(AMX_TILE,        "amx-tile",               0)
0234 X86_FEATURE_COMPAT(AMX_INT8,        "amx-int8",               0)
0235 X86_FEATURE_COMPAT(AMX_BF16,        "amx-bf16",               0)
0236 X86_FEATURE_COMPAT(UINTR,           "uintr",                  0)
0237 X86_FEATURE_COMPAT(HRESET,          "hreset",                 0)
0238 X86_FEATURE_COMPAT(KL,              "kl",                     0)
0239 X86_FEATURE       (FXSR,            "fxsr")
0240 X86_FEATURE_COMPAT(WIDEKL,          "widekl",                 0)
0241 X86_FEATURE_COMPAT(AVXVNNI,         "avxvnni",                0)
0242 X86_FEATURE_COMPAT(AVX512FP16,      "avx512fp16",             0)
0243 X86_FEATURE       (CCMP,            "ccmp")
0244 X86_FEATURE       (Push2Pop2,       "push2pop2")
0245 X86_FEATURE       (PPX,             "ppx")
0246 X86_FEATURE       (NDD,             "ndd")
0247 X86_FEATURE_COMPAT(AVXIFMA,         "avxifma",                0)
0248 X86_FEATURE_COMPAT(AVXVNNIINT8,     "avxvnniint8",            0)
0249 X86_FEATURE_COMPAT(AVXNECONVERT,    "avxneconvert",           0)
0250 X86_FEATURE_COMPAT(CMPCCXADD,       "cmpccxadd",              0)
0251 X86_FEATURE_COMPAT(AMX_FP16,        "amx-fp16",               0)
0252 X86_FEATURE_COMPAT(PREFETCHI,       "prefetchi",              0)
0253 X86_FEATURE_COMPAT(RAOINT,          "raoint",                 0)
0254 X86_FEATURE_COMPAT(AMX_COMPLEX,     "amx-complex",            0)
0255 X86_FEATURE_COMPAT(AVXVNNIINT16,    "avxvnniint16",           0)
0256 X86_FEATURE_COMPAT(SM3,             "sm3",                    0)
0257 X86_FEATURE_COMPAT(SHA512,          "sha512",                 0)
0258 X86_FEATURE_COMPAT(SM4,             "sm4",                    0)
0259 X86_FEATURE       (EGPR,            "egpr")
0260 X86_FEATURE_COMPAT(USERMSR,         "usermsr",                0)
0261 X86_FEATURE_COMPAT(AVX10_1,         "avx10.1-256",           36)
0262 X86_FEATURE_COMPAT(AVX10_1_512,     "avx10.1-512",           37)
0263 X86_FEATURE_COMPAT(AVX10_2,         "avx10.2-256",            0)
0264 X86_FEATURE_COMPAT(AVX10_2_512,     "avx10.2-512",            0)
0265 //FIXME: make MOVRS _COMPAT defined when gcc landed relate patch.
0266 X86_FEATURE       (MOVRS,           "movrs")
0267 X86_FEATURE       (ZU,              "zu")
0268 X86_FEATURE       (AMX_FP8,         "amx-fp8")
0269 X86_FEATURE       (AMX_TRANSPOSE,   "amx-transpose")
0270 X86_FEATURE       (AMX_MOVRS,       "amx-movrs")
0271 X86_FEATURE       (AMX_AVX512,      "amx-avx512")
0272 X86_FEATURE       (AMX_TF32,        "amx-tf32")
0273 // These features aren't really CPU features, but the frontend can set them.
0274 X86_FEATURE       (RETPOLINE_EXTERNAL_THUNK,    "retpoline-external-thunk")
0275 X86_FEATURE       (RETPOLINE_INDIRECT_BRANCHES, "retpoline-indirect-branches")
0276 X86_FEATURE       (RETPOLINE_INDIRECT_CALLS,    "retpoline-indirect-calls")
0277 X86_FEATURE       (LVI_CFI,                     "lvi-cfi")
0278 X86_FEATURE       (LVI_LOAD_HARDENING,          "lvi-load-hardening")
0279 
0280 X86_MICROARCH_LEVEL(X86_64_BASELINE,"x86-64",               95)
0281 X86_MICROARCH_LEVEL(X86_64_V2,      "x86-64-v2",            96)
0282 X86_MICROARCH_LEVEL(X86_64_V3,      "x86-64-v3",            97)
0283 X86_MICROARCH_LEVEL(X86_64_V4,      "x86-64-v4",            98)
0284 X86_MICROARCH_LEVEL(APXF,           "apxf",                111)
0285 #undef X86_FEATURE_COMPAT
0286 #undef X86_FEATURE
0287 #undef X86_MICROARCH_LEVEL