| 1 | /* Constants and data structures for x86 CPU features. |
| 2 | This file is part of the GNU C Library. |
| 3 | Copyright (C) 2008-2020 Free Software Foundation, Inc. |
| 4 | |
| 5 | The GNU C Library is free software; you can redistribute it and/or |
| 6 | modify it under the terms of the GNU Lesser General Public |
| 7 | License as published by the Free Software Foundation; either |
| 8 | version 2.1 of the License, or (at your option) any later version. |
| 9 | |
| 10 | The GNU C Library is distributed in the hope that it will be useful, |
| 11 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| 13 | Lesser General Public License for more details. |
| 14 | |
| 15 | You should have received a copy of the GNU Lesser General Public |
| 16 | License along with the GNU C Library; if not, see |
| 17 | <https://www.gnu.org/licenses/>. */ |
| 18 | |
| 19 | #ifndef _SYS_PLATFORM_X86_H |
| 20 | # error "Never include <bits/platform/x86.h> directly; use <sys/platform/x86.h> instead." |
| 21 | #endif |
| 22 | |
| 23 | enum |
| 24 | { |
| 25 | CPUID_INDEX_1 = 0, |
| 26 | CPUID_INDEX_7, |
| 27 | CPUID_INDEX_80000001, |
| 28 | CPUID_INDEX_D_ECX_1, |
| 29 | CPUID_INDEX_80000007, |
| 30 | CPUID_INDEX_80000008, |
| 31 | CPUID_INDEX_7_ECX_1, |
| 32 | CPUID_INDEX_19 |
| 33 | }; |
| 34 | |
| 35 | struct cpuid_feature |
| 36 | { |
| 37 | unsigned int cpuid_array[4]; |
| 38 | unsigned int usable_array[4]; |
| 39 | }; |
| 40 | |
| 41 | enum cpuid_register_index |
| 42 | { |
| 43 | cpuid_register_index_eax = 0, |
| 44 | cpuid_register_index_ebx, |
| 45 | cpuid_register_index_ecx, |
| 46 | cpuid_register_index_edx |
| 47 | }; |
| 48 | |
| 49 | /* CPU features. */ |
| 50 | |
| 51 | enum |
| 52 | { |
| 53 | x86_cpu_index_1_ecx |
| 54 | = (CPUID_INDEX_1 * 8 * 4 * sizeof (unsigned int) |
| 55 | + cpuid_register_index_ecx * 8 * sizeof (unsigned int)), |
| 56 | |
| 57 | x86_cpu_SSE3 = x86_cpu_index_1_ecx, |
| 58 | x86_cpu_PCLMULQDQ = x86_cpu_index_1_ecx + 1, |
| 59 | x86_cpu_DTES64 = x86_cpu_index_1_ecx + 2, |
| 60 | x86_cpu_MONITOR = x86_cpu_index_1_ecx + 3, |
| 61 | x86_cpu_DS_CPL = x86_cpu_index_1_ecx + 4, |
| 62 | x86_cpu_VMX = x86_cpu_index_1_ecx + 5, |
| 63 | x86_cpu_SMX = x86_cpu_index_1_ecx + 6, |
| 64 | x86_cpu_EIST = x86_cpu_index_1_ecx + 7, |
| 65 | x86_cpu_TM2 = x86_cpu_index_1_ecx + 8, |
| 66 | x86_cpu_SSSE3 = x86_cpu_index_1_ecx + 9, |
| 67 | x86_cpu_CNXT_ID = x86_cpu_index_1_ecx + 10, |
| 68 | x86_cpu_SDBG = x86_cpu_index_1_ecx + 11, |
| 69 | x86_cpu_FMA = x86_cpu_index_1_ecx + 12, |
| 70 | x86_cpu_CMPXCHG16B = x86_cpu_index_1_ecx + 13, |
| 71 | x86_cpu_XTPRUPDCTRL = x86_cpu_index_1_ecx + 14, |
| 72 | x86_cpu_PDCM = x86_cpu_index_1_ecx + 15, |
| 73 | x86_cpu_INDEX_1_ECX_16 = x86_cpu_index_1_ecx + 16, |
| 74 | x86_cpu_PCID = x86_cpu_index_1_ecx + 17, |
| 75 | x86_cpu_DCA = x86_cpu_index_1_ecx + 18, |
| 76 | x86_cpu_SSE4_1 = x86_cpu_index_1_ecx + 19, |
| 77 | x86_cpu_SSE4_2 = x86_cpu_index_1_ecx + 20, |
| 78 | x86_cpu_X2APIC = x86_cpu_index_1_ecx + 21, |
| 79 | x86_cpu_MOVBE = x86_cpu_index_1_ecx + 22, |
| 80 | x86_cpu_POPCNT = x86_cpu_index_1_ecx + 23, |
| 81 | x86_cpu_TSC_DEADLINE = x86_cpu_index_1_ecx + 24, |
| 82 | x86_cpu_AES = x86_cpu_index_1_ecx + 25, |
| 83 | x86_cpu_XSAVE = x86_cpu_index_1_ecx + 26, |
| 84 | x86_cpu_OSXSAVE = x86_cpu_index_1_ecx + 27, |
| 85 | x86_cpu_AVX = x86_cpu_index_1_ecx + 28, |
| 86 | x86_cpu_F16C = x86_cpu_index_1_ecx + 29, |
| 87 | x86_cpu_RDRAND = x86_cpu_index_1_ecx + 30, |
| 88 | x86_cpu_INDEX_1_ECX_31 = x86_cpu_index_1_ecx + 31, |
| 89 | |
| 90 | x86_cpu_index_1_edx |
| 91 | = (CPUID_INDEX_1 * 8 * 4 * sizeof (unsigned int) |
| 92 | + cpuid_register_index_edx * 8 * sizeof (unsigned int)), |
| 93 | |
| 94 | x86_cpu_FPU = x86_cpu_index_1_edx, |
| 95 | x86_cpu_VME = x86_cpu_index_1_edx + 1, |
| 96 | x86_cpu_DE = x86_cpu_index_1_edx + 2, |
| 97 | x86_cpu_PSE = x86_cpu_index_1_edx + 3, |
| 98 | x86_cpu_TSC = x86_cpu_index_1_edx + 4, |
| 99 | x86_cpu_MSR = x86_cpu_index_1_edx + 5, |
| 100 | x86_cpu_PAE = x86_cpu_index_1_edx + 6, |
| 101 | x86_cpu_MCE = x86_cpu_index_1_edx + 7, |
| 102 | x86_cpu_CX8 = x86_cpu_index_1_edx + 8, |
| 103 | x86_cpu_APIC = x86_cpu_index_1_edx + 9, |
| 104 | x86_cpu_INDEX_1_EDX_10 = x86_cpu_index_1_edx + 10, |
| 105 | x86_cpu_SEP = x86_cpu_index_1_edx + 11, |
| 106 | x86_cpu_MTRR = x86_cpu_index_1_edx + 12, |
| 107 | x86_cpu_PGE = x86_cpu_index_1_edx + 13, |
| 108 | x86_cpu_MCA = x86_cpu_index_1_edx + 14, |
| 109 | x86_cpu_CMOV = x86_cpu_index_1_edx + 15, |
| 110 | x86_cpu_PAT = x86_cpu_index_1_edx + 16, |
| 111 | x86_cpu_PSE_36 = x86_cpu_index_1_edx + 17, |
| 112 | x86_cpu_PSN = x86_cpu_index_1_edx + 18, |
| 113 | x86_cpu_CLFSH = x86_cpu_index_1_edx + 19, |
| 114 | x86_cpu_INDEX_1_EDX_20 = x86_cpu_index_1_edx + 20, |
| 115 | x86_cpu_DS = x86_cpu_index_1_edx + 21, |
| 116 | x86_cpu_ACPI = x86_cpu_index_1_edx + 22, |
| 117 | x86_cpu_MMX = x86_cpu_index_1_edx + 23, |
| 118 | x86_cpu_FXSR = x86_cpu_index_1_edx + 24, |
| 119 | x86_cpu_SSE = x86_cpu_index_1_edx + 25, |
| 120 | x86_cpu_SSE2 = x86_cpu_index_1_edx + 26, |
| 121 | x86_cpu_SS = x86_cpu_index_1_edx + 27, |
| 122 | x86_cpu_HTT = x86_cpu_index_1_edx + 28, |
| 123 | x86_cpu_TM = x86_cpu_index_1_edx + 29, |
| 124 | x86_cpu_INDEX_1_EDX_30 = x86_cpu_index_1_edx + 30, |
| 125 | x86_cpu_PBE = x86_cpu_index_1_edx + 31, |
| 126 | |
| 127 | x86_cpu_index_7_ebx |
| 128 | = (CPUID_INDEX_7 * 8 * 4 * sizeof (unsigned int) |
| 129 | + cpuid_register_index_ebx * 8 * sizeof (unsigned int)), |
| 130 | |
| 131 | x86_cpu_FSGSBASE = x86_cpu_index_7_ebx, |
| 132 | x86_cpu_TSC_ADJUST = x86_cpu_index_7_ebx + 1, |
| 133 | x86_cpu_SGX = x86_cpu_index_7_ebx + 2, |
| 134 | x86_cpu_BMI1 = x86_cpu_index_7_ebx + 3, |
| 135 | x86_cpu_HLE = x86_cpu_index_7_ebx + 4, |
| 136 | x86_cpu_AVX2 = x86_cpu_index_7_ebx + 5, |
| 137 | x86_cpu_INDEX_7_EBX_6 = x86_cpu_index_7_ebx + 6, |
| 138 | x86_cpu_SMEP = x86_cpu_index_7_ebx + 7, |
| 139 | x86_cpu_BMI2 = x86_cpu_index_7_ebx + 8, |
| 140 | x86_cpu_ERMS = x86_cpu_index_7_ebx + 9, |
| 141 | x86_cpu_INVPCID = x86_cpu_index_7_ebx + 10, |
| 142 | x86_cpu_RTM = x86_cpu_index_7_ebx + 11, |
| 143 | x86_cpu_RDT_M = x86_cpu_index_7_ebx + 12, |
| 144 | x86_cpu_DEPR_FPU_CS_DS = x86_cpu_index_7_ebx + 13, |
| 145 | x86_cpu_MPX = x86_cpu_index_7_ebx + 14, |
| 146 | x86_cpu_RDT_A = x86_cpu_index_7_ebx + 15, |
| 147 | x86_cpu_AVX512F = x86_cpu_index_7_ebx + 16, |
| 148 | x86_cpu_AVX512DQ = x86_cpu_index_7_ebx + 17, |
| 149 | x86_cpu_RDSEED = x86_cpu_index_7_ebx + 18, |
| 150 | x86_cpu_ADX = x86_cpu_index_7_ebx + 19, |
| 151 | x86_cpu_SMAP = x86_cpu_index_7_ebx + 20, |
| 152 | x86_cpu_AVX512_IFMA = x86_cpu_index_7_ebx + 21, |
| 153 | x86_cpu_INDEX_7_EBX_22 = x86_cpu_index_7_ebx + 22, |
| 154 | x86_cpu_CLFLUSHOPT = x86_cpu_index_7_ebx + 23, |
| 155 | x86_cpu_CLWB = x86_cpu_index_7_ebx + 24, |
| 156 | x86_cpu_TRACE = x86_cpu_index_7_ebx + 25, |
| 157 | x86_cpu_AVX512PF = x86_cpu_index_7_ebx + 26, |
| 158 | x86_cpu_AVX512ER = x86_cpu_index_7_ebx + 27, |
| 159 | x86_cpu_AVX512CD = x86_cpu_index_7_ebx + 28, |
| 160 | x86_cpu_SHA = x86_cpu_index_7_ebx + 29, |
| 161 | x86_cpu_AVX512BW = x86_cpu_index_7_ebx + 30, |
| 162 | x86_cpu_AVX512VL = x86_cpu_index_7_ebx + 31, |
| 163 | |
| 164 | x86_cpu_index_7_ecx |
| 165 | = (CPUID_INDEX_7 * 8 * 4 * sizeof (unsigned int) |
| 166 | + cpuid_register_index_ecx * 8 * sizeof (unsigned int)), |
| 167 | |
| 168 | x86_cpu_PREFETCHWT1 = x86_cpu_index_7_ecx, |
| 169 | x86_cpu_AVX512_VBMI = x86_cpu_index_7_ecx + 1, |
| 170 | x86_cpu_UMIP = x86_cpu_index_7_ecx + 2, |
| 171 | x86_cpu_PKU = x86_cpu_index_7_ecx + 3, |
| 172 | x86_cpu_OSPKE = x86_cpu_index_7_ecx + 4, |
| 173 | x86_cpu_WAITPKG = x86_cpu_index_7_ecx + 5, |
| 174 | x86_cpu_AVX512_VBMI2 = x86_cpu_index_7_ecx + 6, |
| 175 | x86_cpu_SHSTK = x86_cpu_index_7_ecx + 7, |
| 176 | x86_cpu_GFNI = x86_cpu_index_7_ecx + 8, |
| 177 | x86_cpu_VAES = x86_cpu_index_7_ecx + 9, |
| 178 | x86_cpu_VPCLMULQDQ = x86_cpu_index_7_ecx + 10, |
| 179 | x86_cpu_AVX512_VNNI = x86_cpu_index_7_ecx + 11, |
| 180 | x86_cpu_AVX512_BITALG = x86_cpu_index_7_ecx + 12, |
| 181 | x86_cpu_INDEX_7_ECX_13 = x86_cpu_index_7_ecx + 13, |
| 182 | x86_cpu_AVX512_VPOPCNTDQ = x86_cpu_index_7_ecx + 14, |
| 183 | x86_cpu_INDEX_7_ECX_1 = x86_cpu_index_7_ecx + 15, |
| 184 | x86_cpu_INDEX_7_ECX_16 = x86_cpu_index_7_ecx + 16, |
| 185 | /* Note: Bits 17-21: The value of MAWAU used by the BNDLDX and BNDSTX |
| 186 | instructions in 64-bit mode. */ |
| 187 | x86_cpu_RDPID = x86_cpu_index_7_ecx + 22, |
| 188 | x86_cpu_KL = x86_cpu_index_7_ecx + 23, |
| 189 | x86_cpu_INDEX_7_ECX_24 = x86_cpu_index_7_ecx + 24, |
| 190 | x86_cpu_CLDEMOTE = x86_cpu_index_7_ecx + 25, |
| 191 | x86_cpu_INDEX_7_ECX_26 = x86_cpu_index_7_ecx + 26, |
| 192 | x86_cpu_MOVDIRI = x86_cpu_index_7_ecx + 27, |
| 193 | x86_cpu_MOVDIR64B = x86_cpu_index_7_ecx + 28, |
| 194 | x86_cpu_ENQCMD = x86_cpu_index_7_ecx + 29, |
| 195 | x86_cpu_SGX_LC = x86_cpu_index_7_ecx + 30, |
| 196 | x86_cpu_PKS = x86_cpu_index_7_ecx + 31, |
| 197 | |
| 198 | x86_cpu_index_7_edx |
| 199 | = (CPUID_INDEX_7 * 8 * 4 * sizeof (unsigned int) |
| 200 | + cpuid_register_index_edx * 8 * sizeof (unsigned int)), |
| 201 | |
| 202 | x86_cpu_INDEX_7_EDX_0 = x86_cpu_index_7_edx, |
| 203 | x86_cpu_INDEX_7_EDX_1 = x86_cpu_index_7_edx + 1, |
| 204 | x86_cpu_AVX512_4VNNIW = x86_cpu_index_7_edx + 2, |
| 205 | x86_cpu_AVX512_4FMAPS = x86_cpu_index_7_edx + 3, |
| 206 | x86_cpu_FSRM = x86_cpu_index_7_edx + 4, |
| 207 | x86_cpu_UINTR = x86_cpu_index_7_edx + 5, |
| 208 | x86_cpu_INDEX_7_EDX_6 = x86_cpu_index_7_edx + 6, |
| 209 | x86_cpu_INDEX_7_EDX_7 = x86_cpu_index_7_edx + 7, |
| 210 | x86_cpu_AVX512_VP2INTERSECT = x86_cpu_index_7_edx + 8, |
| 211 | x86_cpu_INDEX_7_EDX_9 = x86_cpu_index_7_edx + 9, |
| 212 | x86_cpu_MD_CLEAR = x86_cpu_index_7_edx + 10, |
| 213 | x86_cpu_INDEX_7_EDX_11 = x86_cpu_index_7_edx + 11, |
| 214 | x86_cpu_INDEX_7_EDX_12 = x86_cpu_index_7_edx + 12, |
| 215 | x86_cpu_INDEX_7_EDX_13 = x86_cpu_index_7_edx + 13, |
| 216 | x86_cpu_SERIALIZE = x86_cpu_index_7_edx + 14, |
| 217 | x86_cpu_HYBRID = x86_cpu_index_7_edx + 15, |
| 218 | x86_cpu_TSXLDTRK = x86_cpu_index_7_edx + 16, |
| 219 | x86_cpu_INDEX_7_EDX_17 = x86_cpu_index_7_edx + 17, |
| 220 | x86_cpu_PCONFIG = x86_cpu_index_7_edx + 18, |
| 221 | x86_cpu_INDEX_7_EDX_19 = x86_cpu_index_7_edx + 19, |
| 222 | x86_cpu_IBT = x86_cpu_index_7_edx + 20, |
| 223 | x86_cpu_INDEX_7_EDX_21 = x86_cpu_index_7_edx + 21, |
| 224 | x86_cpu_AMX_BF16 = x86_cpu_index_7_edx + 22, |
| 225 | x86_cpu_AVX512_FP16 = x86_cpu_index_7_edx + 23, |
| 226 | x86_cpu_AMX_TILE = x86_cpu_index_7_edx + 24, |
| 227 | x86_cpu_AMX_INT8 = x86_cpu_index_7_edx + 25, |
| 228 | x86_cpu_IBRS_IBPB = x86_cpu_index_7_edx + 26, |
| 229 | x86_cpu_STIBP = x86_cpu_index_7_edx + 27, |
| 230 | x86_cpu_L1D_FLUSH = x86_cpu_index_7_edx + 28, |
| 231 | x86_cpu_ARCH_CAPABILITIES = x86_cpu_index_7_edx + 29, |
| 232 | x86_cpu_CORE_CAPABILITIES = x86_cpu_index_7_edx + 30, |
| 233 | x86_cpu_SSBD = x86_cpu_index_7_edx + 31, |
| 234 | |
| 235 | x86_cpu_index_80000001_ecx |
| 236 | = (CPUID_INDEX_80000001 * 8 * 4 * sizeof (unsigned int) |
| 237 | + cpuid_register_index_ecx * 8 * sizeof (unsigned int)), |
| 238 | |
| 239 | x86_cpu_LAHF64_SAHF64 = x86_cpu_index_80000001_ecx, |
| 240 | x86_cpu_SVM = x86_cpu_index_80000001_ecx + 2, |
| 241 | x86_cpu_LZCNT = x86_cpu_index_80000001_ecx + 5, |
| 242 | x86_cpu_SSE4A = x86_cpu_index_80000001_ecx + 6, |
| 243 | x86_cpu_PREFETCHW = x86_cpu_index_80000001_ecx + 8, |
| 244 | x86_cpu_XOP = x86_cpu_index_80000001_ecx + 11, |
| 245 | x86_cpu_LWP = x86_cpu_index_80000001_ecx + 15, |
| 246 | x86_cpu_FMA4 = x86_cpu_index_80000001_ecx + 16, |
| 247 | x86_cpu_TBM = x86_cpu_index_80000001_ecx + 20, |
| 248 | |
| 249 | x86_cpu_index_80000001_edx |
| 250 | = (CPUID_INDEX_80000001 * 8 * 4 * sizeof (unsigned int) |
| 251 | + cpuid_register_index_edx * 8 * sizeof (unsigned int)), |
| 252 | |
| 253 | x86_cpu_SYSCALL_SYSRET = x86_cpu_index_80000001_edx + 11, |
| 254 | x86_cpu_NX = x86_cpu_index_80000001_edx + 20, |
| 255 | x86_cpu_PAGE1GB = x86_cpu_index_80000001_edx + 26, |
| 256 | x86_cpu_RDTSCP = x86_cpu_index_80000001_edx + 27, |
| 257 | x86_cpu_LM = x86_cpu_index_80000001_edx + 29, |
| 258 | |
| 259 | x86_cpu_index_d_ecx_1_eax |
| 260 | = (CPUID_INDEX_D_ECX_1 * 8 * 4 * sizeof (unsigned int) |
| 261 | + cpuid_register_index_eax * 8 * sizeof (unsigned int)), |
| 262 | |
| 263 | x86_cpu_XSAVEOPT = x86_cpu_index_d_ecx_1_eax, |
| 264 | x86_cpu_XSAVEC = x86_cpu_index_d_ecx_1_eax + 1, |
| 265 | x86_cpu_XGETBV_ECX_1 = x86_cpu_index_d_ecx_1_eax + 2, |
| 266 | x86_cpu_XSAVES = x86_cpu_index_d_ecx_1_eax + 3, |
| 267 | x86_cpu_XFD = x86_cpu_index_d_ecx_1_eax + 4, |
| 268 | |
| 269 | x86_cpu_index_80000007_edx |
| 270 | = (CPUID_INDEX_80000007 * 8 * 4 * sizeof (unsigned int) |
| 271 | + cpuid_register_index_edx * 8 * sizeof (unsigned int)), |
| 272 | |
| 273 | x86_cpu_INVARIANT_TSC = x86_cpu_index_80000007_edx + 8, |
| 274 | |
| 275 | x86_cpu_index_80000008_ebx |
| 276 | = (CPUID_INDEX_80000008 * 8 * 4 * sizeof (unsigned int) |
| 277 | + cpuid_register_index_ebx * 8 * sizeof (unsigned int)), |
| 278 | |
| 279 | x86_cpu_WBNOINVD = x86_cpu_index_80000008_ebx + 9, |
| 280 | |
| 281 | x86_cpu_index_7_ecx_1_eax |
| 282 | = (CPUID_INDEX_7_ECX_1 * 8 * 4 * sizeof (unsigned int) |
| 283 | + cpuid_register_index_eax * 8 * sizeof (unsigned int)), |
| 284 | |
| 285 | x86_cpu_AVX_VNNI = x86_cpu_index_7_ecx_1_eax + 4, |
| 286 | x86_cpu_AVX512_BF16 = x86_cpu_index_7_ecx_1_eax + 5, |
| 287 | x86_cpu_FZLRM = x86_cpu_index_7_ecx_1_eax + 10, |
| 288 | x86_cpu_FSRS = x86_cpu_index_7_ecx_1_eax + 11, |
| 289 | x86_cpu_FSRCS = x86_cpu_index_7_ecx_1_eax + 12, |
| 290 | x86_cpu_HRESET = x86_cpu_index_7_ecx_1_eax + 22, |
| 291 | x86_cpu_LAM = x86_cpu_index_7_ecx_1_eax + 26, |
| 292 | |
| 293 | x86_cpu_index_19_ebx |
| 294 | = (CPUID_INDEX_19 * 8 * 4 * sizeof (unsigned int) |
| 295 | + cpuid_register_index_ebx * 8 * sizeof (unsigned int)), |
| 296 | |
| 297 | x86_cpu_AESKLE = x86_cpu_index_19_ebx, |
| 298 | x86_cpu_WIDE_KL = x86_cpu_index_19_ebx + 2 |
| 299 | }; |
| 300 | |