optionrom: simplify Makefile
[qemu/ar7.git] / target / i386 / cpu.c
blob588f32e1362157c388a6e2504c01c0179a1c526e
1 /*
2 * i386 CPUID helper functions
4 * Copyright (c) 2003 Fabrice Bellard
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, see <http://www.gnu.org/licenses/>.
20 #include "qemu/osdep.h"
21 #include "qemu/units.h"
22 #include "qemu/cutils.h"
23 #include "qemu/bitops.h"
24 #include "qemu/qemu-print.h"
26 #include "cpu.h"
27 #include "exec/exec-all.h"
28 #include "sysemu/kvm.h"
29 #include "sysemu/reset.h"
30 #include "sysemu/hvf.h"
31 #include "sysemu/cpus.h"
32 #include "sysemu/xen.h"
33 #include "kvm_i386.h"
34 #include "sev_i386.h"
36 #include "qemu/error-report.h"
37 #include "qemu/module.h"
38 #include "qemu/option.h"
39 #include "qemu/config-file.h"
40 #include "qapi/error.h"
41 #include "qapi/qapi-visit-machine.h"
42 #include "qapi/qapi-visit-run-state.h"
43 #include "qapi/qmp/qdict.h"
44 #include "qapi/qmp/qerror.h"
45 #include "qapi/visitor.h"
46 #include "qom/qom-qobject.h"
47 #include "sysemu/arch_init.h"
48 #include "qapi/qapi-commands-machine-target.h"
50 #include "standard-headers/asm-x86/kvm_para.h"
52 #include "sysemu/sysemu.h"
53 #include "sysemu/tcg.h"
54 #include "hw/qdev-properties.h"
55 #include "hw/i386/topology.h"
56 #ifndef CONFIG_USER_ONLY
57 #include "exec/address-spaces.h"
58 #include "hw/i386/apic_internal.h"
59 #include "hw/boards.h"
60 #endif
62 #include "disas/capstone.h"
64 /* Helpers for building CPUID[2] descriptors: */
66 struct CPUID2CacheDescriptorInfo {
67 enum CacheType type;
68 int level;
69 int size;
70 int line_size;
71 int associativity;
75 * Known CPUID 2 cache descriptors.
76 * From Intel SDM Volume 2A, CPUID instruction
78 struct CPUID2CacheDescriptorInfo cpuid2_cache_descriptors[] = {
79 [0x06] = { .level = 1, .type = INSTRUCTION_CACHE, .size = 8 * KiB,
80 .associativity = 4, .line_size = 32, },
81 [0x08] = { .level = 1, .type = INSTRUCTION_CACHE, .size = 16 * KiB,
82 .associativity = 4, .line_size = 32, },
83 [0x09] = { .level = 1, .type = INSTRUCTION_CACHE, .size = 32 * KiB,
84 .associativity = 4, .line_size = 64, },
85 [0x0A] = { .level = 1, .type = DATA_CACHE, .size = 8 * KiB,
86 .associativity = 2, .line_size = 32, },
87 [0x0C] = { .level = 1, .type = DATA_CACHE, .size = 16 * KiB,
88 .associativity = 4, .line_size = 32, },
89 [0x0D] = { .level = 1, .type = DATA_CACHE, .size = 16 * KiB,
90 .associativity = 4, .line_size = 64, },
91 [0x0E] = { .level = 1, .type = DATA_CACHE, .size = 24 * KiB,
92 .associativity = 6, .line_size = 64, },
93 [0x1D] = { .level = 2, .type = UNIFIED_CACHE, .size = 128 * KiB,
94 .associativity = 2, .line_size = 64, },
95 [0x21] = { .level = 2, .type = UNIFIED_CACHE, .size = 256 * KiB,
96 .associativity = 8, .line_size = 64, },
97 /* lines per sector is not supported cpuid2_cache_descriptor(),
98 * so descriptors 0x22, 0x23 are not included
100 [0x24] = { .level = 2, .type = UNIFIED_CACHE, .size = 1 * MiB,
101 .associativity = 16, .line_size = 64, },
102 /* lines per sector is not supported cpuid2_cache_descriptor(),
103 * so descriptors 0x25, 0x20 are not included
105 [0x2C] = { .level = 1, .type = DATA_CACHE, .size = 32 * KiB,
106 .associativity = 8, .line_size = 64, },
107 [0x30] = { .level = 1, .type = INSTRUCTION_CACHE, .size = 32 * KiB,
108 .associativity = 8, .line_size = 64, },
109 [0x41] = { .level = 2, .type = UNIFIED_CACHE, .size = 128 * KiB,
110 .associativity = 4, .line_size = 32, },
111 [0x42] = { .level = 2, .type = UNIFIED_CACHE, .size = 256 * KiB,
112 .associativity = 4, .line_size = 32, },
113 [0x43] = { .level = 2, .type = UNIFIED_CACHE, .size = 512 * KiB,
114 .associativity = 4, .line_size = 32, },
115 [0x44] = { .level = 2, .type = UNIFIED_CACHE, .size = 1 * MiB,
116 .associativity = 4, .line_size = 32, },
117 [0x45] = { .level = 2, .type = UNIFIED_CACHE, .size = 2 * MiB,
118 .associativity = 4, .line_size = 32, },
119 [0x46] = { .level = 3, .type = UNIFIED_CACHE, .size = 4 * MiB,
120 .associativity = 4, .line_size = 64, },
121 [0x47] = { .level = 3, .type = UNIFIED_CACHE, .size = 8 * MiB,
122 .associativity = 8, .line_size = 64, },
123 [0x48] = { .level = 2, .type = UNIFIED_CACHE, .size = 3 * MiB,
124 .associativity = 12, .line_size = 64, },
125 /* Descriptor 0x49 depends on CPU family/model, so it is not included */
126 [0x4A] = { .level = 3, .type = UNIFIED_CACHE, .size = 6 * MiB,
127 .associativity = 12, .line_size = 64, },
128 [0x4B] = { .level = 3, .type = UNIFIED_CACHE, .size = 8 * MiB,
129 .associativity = 16, .line_size = 64, },
130 [0x4C] = { .level = 3, .type = UNIFIED_CACHE, .size = 12 * MiB,
131 .associativity = 12, .line_size = 64, },
132 [0x4D] = { .level = 3, .type = UNIFIED_CACHE, .size = 16 * MiB,
133 .associativity = 16, .line_size = 64, },
134 [0x4E] = { .level = 2, .type = UNIFIED_CACHE, .size = 6 * MiB,
135 .associativity = 24, .line_size = 64, },
136 [0x60] = { .level = 1, .type = DATA_CACHE, .size = 16 * KiB,
137 .associativity = 8, .line_size = 64, },
138 [0x66] = { .level = 1, .type = DATA_CACHE, .size = 8 * KiB,
139 .associativity = 4, .line_size = 64, },
140 [0x67] = { .level = 1, .type = DATA_CACHE, .size = 16 * KiB,
141 .associativity = 4, .line_size = 64, },
142 [0x68] = { .level = 1, .type = DATA_CACHE, .size = 32 * KiB,
143 .associativity = 4, .line_size = 64, },
144 [0x78] = { .level = 2, .type = UNIFIED_CACHE, .size = 1 * MiB,
145 .associativity = 4, .line_size = 64, },
146 /* lines per sector is not supported cpuid2_cache_descriptor(),
147 * so descriptors 0x79, 0x7A, 0x7B, 0x7C are not included.
149 [0x7D] = { .level = 2, .type = UNIFIED_CACHE, .size = 2 * MiB,
150 .associativity = 8, .line_size = 64, },
151 [0x7F] = { .level = 2, .type = UNIFIED_CACHE, .size = 512 * KiB,
152 .associativity = 2, .line_size = 64, },
153 [0x80] = { .level = 2, .type = UNIFIED_CACHE, .size = 512 * KiB,
154 .associativity = 8, .line_size = 64, },
155 [0x82] = { .level = 2, .type = UNIFIED_CACHE, .size = 256 * KiB,
156 .associativity = 8, .line_size = 32, },
157 [0x83] = { .level = 2, .type = UNIFIED_CACHE, .size = 512 * KiB,
158 .associativity = 8, .line_size = 32, },
159 [0x84] = { .level = 2, .type = UNIFIED_CACHE, .size = 1 * MiB,
160 .associativity = 8, .line_size = 32, },
161 [0x85] = { .level = 2, .type = UNIFIED_CACHE, .size = 2 * MiB,
162 .associativity = 8, .line_size = 32, },
163 [0x86] = { .level = 2, .type = UNIFIED_CACHE, .size = 512 * KiB,
164 .associativity = 4, .line_size = 64, },
165 [0x87] = { .level = 2, .type = UNIFIED_CACHE, .size = 1 * MiB,
166 .associativity = 8, .line_size = 64, },
167 [0xD0] = { .level = 3, .type = UNIFIED_CACHE, .size = 512 * KiB,
168 .associativity = 4, .line_size = 64, },
169 [0xD1] = { .level = 3, .type = UNIFIED_CACHE, .size = 1 * MiB,
170 .associativity = 4, .line_size = 64, },
171 [0xD2] = { .level = 3, .type = UNIFIED_CACHE, .size = 2 * MiB,
172 .associativity = 4, .line_size = 64, },
173 [0xD6] = { .level = 3, .type = UNIFIED_CACHE, .size = 1 * MiB,
174 .associativity = 8, .line_size = 64, },
175 [0xD7] = { .level = 3, .type = UNIFIED_CACHE, .size = 2 * MiB,
176 .associativity = 8, .line_size = 64, },
177 [0xD8] = { .level = 3, .type = UNIFIED_CACHE, .size = 4 * MiB,
178 .associativity = 8, .line_size = 64, },
179 [0xDC] = { .level = 3, .type = UNIFIED_CACHE, .size = 1.5 * MiB,
180 .associativity = 12, .line_size = 64, },
181 [0xDD] = { .level = 3, .type = UNIFIED_CACHE, .size = 3 * MiB,
182 .associativity = 12, .line_size = 64, },
183 [0xDE] = { .level = 3, .type = UNIFIED_CACHE, .size = 6 * MiB,
184 .associativity = 12, .line_size = 64, },
185 [0xE2] = { .level = 3, .type = UNIFIED_CACHE, .size = 2 * MiB,
186 .associativity = 16, .line_size = 64, },
187 [0xE3] = { .level = 3, .type = UNIFIED_CACHE, .size = 4 * MiB,
188 .associativity = 16, .line_size = 64, },
189 [0xE4] = { .level = 3, .type = UNIFIED_CACHE, .size = 8 * MiB,
190 .associativity = 16, .line_size = 64, },
191 [0xEA] = { .level = 3, .type = UNIFIED_CACHE, .size = 12 * MiB,
192 .associativity = 24, .line_size = 64, },
193 [0xEB] = { .level = 3, .type = UNIFIED_CACHE, .size = 18 * MiB,
194 .associativity = 24, .line_size = 64, },
195 [0xEC] = { .level = 3, .type = UNIFIED_CACHE, .size = 24 * MiB,
196 .associativity = 24, .line_size = 64, },
200 * "CPUID leaf 2 does not report cache descriptor information,
201 * use CPUID leaf 4 to query cache parameters"
203 #define CACHE_DESCRIPTOR_UNAVAILABLE 0xFF
206 * Return a CPUID 2 cache descriptor for a given cache.
207 * If no known descriptor is found, return CACHE_DESCRIPTOR_UNAVAILABLE
209 static uint8_t cpuid2_cache_descriptor(CPUCacheInfo *cache)
211 int i;
213 assert(cache->size > 0);
214 assert(cache->level > 0);
215 assert(cache->line_size > 0);
216 assert(cache->associativity > 0);
217 for (i = 0; i < ARRAY_SIZE(cpuid2_cache_descriptors); i++) {
218 struct CPUID2CacheDescriptorInfo *d = &cpuid2_cache_descriptors[i];
219 if (d->level == cache->level && d->type == cache->type &&
220 d->size == cache->size && d->line_size == cache->line_size &&
221 d->associativity == cache->associativity) {
222 return i;
226 return CACHE_DESCRIPTOR_UNAVAILABLE;
229 /* CPUID Leaf 4 constants: */
231 /* EAX: */
232 #define CACHE_TYPE_D 1
233 #define CACHE_TYPE_I 2
234 #define CACHE_TYPE_UNIFIED 3
236 #define CACHE_LEVEL(l) (l << 5)
238 #define CACHE_SELF_INIT_LEVEL (1 << 8)
240 /* EDX: */
241 #define CACHE_NO_INVD_SHARING (1 << 0)
242 #define CACHE_INCLUSIVE (1 << 1)
243 #define CACHE_COMPLEX_IDX (1 << 2)
245 /* Encode CacheType for CPUID[4].EAX */
246 #define CACHE_TYPE(t) (((t) == DATA_CACHE) ? CACHE_TYPE_D : \
247 ((t) == INSTRUCTION_CACHE) ? CACHE_TYPE_I : \
248 ((t) == UNIFIED_CACHE) ? CACHE_TYPE_UNIFIED : \
249 0 /* Invalid value */)
252 /* Encode cache info for CPUID[4] */
253 static void encode_cache_cpuid4(CPUCacheInfo *cache,
254 int num_apic_ids, int num_cores,
255 uint32_t *eax, uint32_t *ebx,
256 uint32_t *ecx, uint32_t *edx)
258 assert(cache->size == cache->line_size * cache->associativity *
259 cache->partitions * cache->sets);
261 assert(num_apic_ids > 0);
262 *eax = CACHE_TYPE(cache->type) |
263 CACHE_LEVEL(cache->level) |
264 (cache->self_init ? CACHE_SELF_INIT_LEVEL : 0) |
265 ((num_cores - 1) << 26) |
266 ((num_apic_ids - 1) << 14);
268 assert(cache->line_size > 0);
269 assert(cache->partitions > 0);
270 assert(cache->associativity > 0);
271 /* We don't implement fully-associative caches */
272 assert(cache->associativity < cache->sets);
273 *ebx = (cache->line_size - 1) |
274 ((cache->partitions - 1) << 12) |
275 ((cache->associativity - 1) << 22);
277 assert(cache->sets > 0);
278 *ecx = cache->sets - 1;
280 *edx = (cache->no_invd_sharing ? CACHE_NO_INVD_SHARING : 0) |
281 (cache->inclusive ? CACHE_INCLUSIVE : 0) |
282 (cache->complex_indexing ? CACHE_COMPLEX_IDX : 0);
285 /* Encode cache info for CPUID[0x80000005].ECX or CPUID[0x80000005].EDX */
286 static uint32_t encode_cache_cpuid80000005(CPUCacheInfo *cache)
288 assert(cache->size % 1024 == 0);
289 assert(cache->lines_per_tag > 0);
290 assert(cache->associativity > 0);
291 assert(cache->line_size > 0);
292 return ((cache->size / 1024) << 24) | (cache->associativity << 16) |
293 (cache->lines_per_tag << 8) | (cache->line_size);
296 #define ASSOC_FULL 0xFF
298 /* AMD associativity encoding used on CPUID Leaf 0x80000006: */
299 #define AMD_ENC_ASSOC(a) (a <= 1 ? a : \
300 a == 2 ? 0x2 : \
301 a == 4 ? 0x4 : \
302 a == 8 ? 0x6 : \
303 a == 16 ? 0x8 : \
304 a == 32 ? 0xA : \
305 a == 48 ? 0xB : \
306 a == 64 ? 0xC : \
307 a == 96 ? 0xD : \
308 a == 128 ? 0xE : \
309 a == ASSOC_FULL ? 0xF : \
310 0 /* invalid value */)
313 * Encode cache info for CPUID[0x80000006].ECX and CPUID[0x80000006].EDX
314 * @l3 can be NULL.
316 static void encode_cache_cpuid80000006(CPUCacheInfo *l2,
317 CPUCacheInfo *l3,
318 uint32_t *ecx, uint32_t *edx)
320 assert(l2->size % 1024 == 0);
321 assert(l2->associativity > 0);
322 assert(l2->lines_per_tag > 0);
323 assert(l2->line_size > 0);
324 *ecx = ((l2->size / 1024) << 16) |
325 (AMD_ENC_ASSOC(l2->associativity) << 12) |
326 (l2->lines_per_tag << 8) | (l2->line_size);
328 if (l3) {
329 assert(l3->size % (512 * 1024) == 0);
330 assert(l3->associativity > 0);
331 assert(l3->lines_per_tag > 0);
332 assert(l3->line_size > 0);
333 *edx = ((l3->size / (512 * 1024)) << 18) |
334 (AMD_ENC_ASSOC(l3->associativity) << 12) |
335 (l3->lines_per_tag << 8) | (l3->line_size);
336 } else {
337 *edx = 0;
341 /* Encode cache info for CPUID[8000001D] */
342 static void encode_cache_cpuid8000001d(CPUCacheInfo *cache,
343 X86CPUTopoInfo *topo_info,
344 uint32_t *eax, uint32_t *ebx,
345 uint32_t *ecx, uint32_t *edx)
347 uint32_t l3_cores;
348 unsigned nodes = MAX(topo_info->nodes_per_pkg, 1);
350 assert(cache->size == cache->line_size * cache->associativity *
351 cache->partitions * cache->sets);
353 *eax = CACHE_TYPE(cache->type) | CACHE_LEVEL(cache->level) |
354 (cache->self_init ? CACHE_SELF_INIT_LEVEL : 0);
356 /* L3 is shared among multiple cores */
357 if (cache->level == 3) {
358 l3_cores = DIV_ROUND_UP((topo_info->dies_per_pkg *
359 topo_info->cores_per_die *
360 topo_info->threads_per_core),
361 nodes);
362 *eax |= (l3_cores - 1) << 14;
363 } else {
364 *eax |= ((topo_info->threads_per_core - 1) << 14);
367 assert(cache->line_size > 0);
368 assert(cache->partitions > 0);
369 assert(cache->associativity > 0);
370 /* We don't implement fully-associative caches */
371 assert(cache->associativity < cache->sets);
372 *ebx = (cache->line_size - 1) |
373 ((cache->partitions - 1) << 12) |
374 ((cache->associativity - 1) << 22);
376 assert(cache->sets > 0);
377 *ecx = cache->sets - 1;
379 *edx = (cache->no_invd_sharing ? CACHE_NO_INVD_SHARING : 0) |
380 (cache->inclusive ? CACHE_INCLUSIVE : 0) |
381 (cache->complex_indexing ? CACHE_COMPLEX_IDX : 0);
384 /* Encode cache info for CPUID[8000001E] */
385 static void encode_topo_cpuid8000001e(X86CPUTopoInfo *topo_info, X86CPU *cpu,
386 uint32_t *eax, uint32_t *ebx,
387 uint32_t *ecx, uint32_t *edx)
389 X86CPUTopoIDs topo_ids = {0};
390 unsigned long nodes = MAX(topo_info->nodes_per_pkg, 1);
391 int shift;
393 x86_topo_ids_from_apicid_epyc(cpu->apic_id, topo_info, &topo_ids);
395 *eax = cpu->apic_id;
397 * CPUID_Fn8000001E_EBX
398 * 31:16 Reserved
399 * 15:8 Threads per core (The number of threads per core is
400 * Threads per core + 1)
401 * 7:0 Core id (see bit decoding below)
402 * SMT:
403 * 4:3 node id
404 * 2 Core complex id
405 * 1:0 Core id
406 * Non SMT:
407 * 5:4 node id
408 * 3 Core complex id
409 * 1:0 Core id
411 *ebx = ((topo_info->threads_per_core - 1) << 8) | (topo_ids.node_id << 3) |
412 (topo_ids.core_id);
414 * CPUID_Fn8000001E_ECX
415 * 31:11 Reserved
416 * 10:8 Nodes per processor (Nodes per processor is number of nodes + 1)
417 * 7:0 Node id (see bit decoding below)
418 * 2 Socket id
419 * 1:0 Node id
421 if (nodes <= 4) {
422 *ecx = ((nodes - 1) << 8) | (topo_ids.pkg_id << 2) | topo_ids.node_id;
423 } else {
425 * Node id fix up. Actual hardware supports up to 4 nodes. But with
426 * more than 32 cores, we may end up with more than 4 nodes.
427 * Node id is a combination of socket id and node id. Only requirement
428 * here is that this number should be unique accross the system.
429 * Shift the socket id to accommodate more nodes. We dont expect both
430 * socket id and node id to be big number at the same time. This is not
431 * an ideal config but we need to to support it. Max nodes we can have
432 * is 32 (255/8) with 8 cores per node and 255 max cores. We only need
433 * 5 bits for nodes. Find the left most set bit to represent the total
434 * number of nodes. find_last_bit returns last set bit(0 based). Left
435 * shift(+1) the socket id to represent all the nodes.
437 nodes -= 1;
438 shift = find_last_bit(&nodes, 8);
439 *ecx = (nodes << 8) | (topo_ids.pkg_id << (shift + 1)) |
440 topo_ids.node_id;
442 *edx = 0;
446 * Definitions of the hardcoded cache entries we expose:
447 * These are legacy cache values. If there is a need to change any
448 * of these values please use builtin_x86_defs
451 /* L1 data cache: */
452 static CPUCacheInfo legacy_l1d_cache = {
453 .type = DATA_CACHE,
454 .level = 1,
455 .size = 32 * KiB,
456 .self_init = 1,
457 .line_size = 64,
458 .associativity = 8,
459 .sets = 64,
460 .partitions = 1,
461 .no_invd_sharing = true,
464 /*FIXME: CPUID leaf 0x80000005 is inconsistent with leaves 2 & 4 */
465 static CPUCacheInfo legacy_l1d_cache_amd = {
466 .type = DATA_CACHE,
467 .level = 1,
468 .size = 64 * KiB,
469 .self_init = 1,
470 .line_size = 64,
471 .associativity = 2,
472 .sets = 512,
473 .partitions = 1,
474 .lines_per_tag = 1,
475 .no_invd_sharing = true,
478 /* L1 instruction cache: */
479 static CPUCacheInfo legacy_l1i_cache = {
480 .type = INSTRUCTION_CACHE,
481 .level = 1,
482 .size = 32 * KiB,
483 .self_init = 1,
484 .line_size = 64,
485 .associativity = 8,
486 .sets = 64,
487 .partitions = 1,
488 .no_invd_sharing = true,
491 /*FIXME: CPUID leaf 0x80000005 is inconsistent with leaves 2 & 4 */
492 static CPUCacheInfo legacy_l1i_cache_amd = {
493 .type = INSTRUCTION_CACHE,
494 .level = 1,
495 .size = 64 * KiB,
496 .self_init = 1,
497 .line_size = 64,
498 .associativity = 2,
499 .sets = 512,
500 .partitions = 1,
501 .lines_per_tag = 1,
502 .no_invd_sharing = true,
505 /* Level 2 unified cache: */
506 static CPUCacheInfo legacy_l2_cache = {
507 .type = UNIFIED_CACHE,
508 .level = 2,
509 .size = 4 * MiB,
510 .self_init = 1,
511 .line_size = 64,
512 .associativity = 16,
513 .sets = 4096,
514 .partitions = 1,
515 .no_invd_sharing = true,
518 /*FIXME: CPUID leaf 2 descriptor is inconsistent with CPUID leaf 4 */
519 static CPUCacheInfo legacy_l2_cache_cpuid2 = {
520 .type = UNIFIED_CACHE,
521 .level = 2,
522 .size = 2 * MiB,
523 .line_size = 64,
524 .associativity = 8,
528 /*FIXME: CPUID leaf 0x80000006 is inconsistent with leaves 2 & 4 */
529 static CPUCacheInfo legacy_l2_cache_amd = {
530 .type = UNIFIED_CACHE,
531 .level = 2,
532 .size = 512 * KiB,
533 .line_size = 64,
534 .lines_per_tag = 1,
535 .associativity = 16,
536 .sets = 512,
537 .partitions = 1,
540 /* Level 3 unified cache: */
541 static CPUCacheInfo legacy_l3_cache = {
542 .type = UNIFIED_CACHE,
543 .level = 3,
544 .size = 16 * MiB,
545 .line_size = 64,
546 .associativity = 16,
547 .sets = 16384,
548 .partitions = 1,
549 .lines_per_tag = 1,
550 .self_init = true,
551 .inclusive = true,
552 .complex_indexing = true,
555 /* TLB definitions: */
557 #define L1_DTLB_2M_ASSOC 1
558 #define L1_DTLB_2M_ENTRIES 255
559 #define L1_DTLB_4K_ASSOC 1
560 #define L1_DTLB_4K_ENTRIES 255
562 #define L1_ITLB_2M_ASSOC 1
563 #define L1_ITLB_2M_ENTRIES 255
564 #define L1_ITLB_4K_ASSOC 1
565 #define L1_ITLB_4K_ENTRIES 255
567 #define L2_DTLB_2M_ASSOC 0 /* disabled */
568 #define L2_DTLB_2M_ENTRIES 0 /* disabled */
569 #define L2_DTLB_4K_ASSOC 4
570 #define L2_DTLB_4K_ENTRIES 512
572 #define L2_ITLB_2M_ASSOC 0 /* disabled */
573 #define L2_ITLB_2M_ENTRIES 0 /* disabled */
574 #define L2_ITLB_4K_ASSOC 4
575 #define L2_ITLB_4K_ENTRIES 512
577 /* CPUID Leaf 0x14 constants: */
578 #define INTEL_PT_MAX_SUBLEAF 0x1
580 * bit[00]: IA32_RTIT_CTL.CR3 filter can be set to 1 and IA32_RTIT_CR3_MATCH
581 * MSR can be accessed;
582 * bit[01]: Support Configurable PSB and Cycle-Accurate Mode;
583 * bit[02]: Support IP Filtering, TraceStop filtering, and preservation
584 * of Intel PT MSRs across warm reset;
585 * bit[03]: Support MTC timing packet and suppression of COFI-based packets;
587 #define INTEL_PT_MINIMAL_EBX 0xf
589 * bit[00]: Tracing can be enabled with IA32_RTIT_CTL.ToPA = 1 and
590 * IA32_RTIT_OUTPUT_BASE and IA32_RTIT_OUTPUT_MASK_PTRS MSRs can be
591 * accessed;
592 * bit[01]: ToPA tables can hold any number of output entries, up to the
593 * maximum allowed by the MaskOrTableOffset field of
594 * IA32_RTIT_OUTPUT_MASK_PTRS;
595 * bit[02]: Support Single-Range Output scheme;
597 #define INTEL_PT_MINIMAL_ECX 0x7
598 /* generated packets which contain IP payloads have LIP values */
599 #define INTEL_PT_IP_LIP (1 << 31)
600 #define INTEL_PT_ADDR_RANGES_NUM 0x2 /* Number of configurable address ranges */
601 #define INTEL_PT_ADDR_RANGES_NUM_MASK 0x3
602 #define INTEL_PT_MTC_BITMAP (0x0249 << 16) /* Support ART(0,3,6,9) */
603 #define INTEL_PT_CYCLE_BITMAP 0x1fff /* Support 0,2^(0~11) */
604 #define INTEL_PT_PSB_BITMAP (0x003f << 16) /* Support 2K,4K,8K,16K,32K,64K */
606 static void x86_cpu_vendor_words2str(char *dst, uint32_t vendor1,
607 uint32_t vendor2, uint32_t vendor3)
609 int i;
610 for (i = 0; i < 4; i++) {
611 dst[i] = vendor1 >> (8 * i);
612 dst[i + 4] = vendor2 >> (8 * i);
613 dst[i + 8] = vendor3 >> (8 * i);
615 dst[CPUID_VENDOR_SZ] = '\0';
618 #define I486_FEATURES (CPUID_FP87 | CPUID_VME | CPUID_PSE)
619 #define PENTIUM_FEATURES (I486_FEATURES | CPUID_DE | CPUID_TSC | \
620 CPUID_MSR | CPUID_MCE | CPUID_CX8 | CPUID_MMX | CPUID_APIC)
621 #define PENTIUM2_FEATURES (PENTIUM_FEATURES | CPUID_PAE | CPUID_SEP | \
622 CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV | CPUID_PAT | \
623 CPUID_PSE36 | CPUID_FXSR)
624 #define PENTIUM3_FEATURES (PENTIUM2_FEATURES | CPUID_SSE)
625 #define PPRO_FEATURES (CPUID_FP87 | CPUID_DE | CPUID_PSE | CPUID_TSC | \
626 CPUID_MSR | CPUID_MCE | CPUID_CX8 | CPUID_PGE | CPUID_CMOV | \
627 CPUID_PAT | CPUID_FXSR | CPUID_MMX | CPUID_SSE | CPUID_SSE2 | \
628 CPUID_PAE | CPUID_SEP | CPUID_APIC)
630 #define TCG_FEATURES (CPUID_FP87 | CPUID_PSE | CPUID_TSC | CPUID_MSR | \
631 CPUID_PAE | CPUID_MCE | CPUID_CX8 | CPUID_APIC | CPUID_SEP | \
632 CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV | CPUID_PAT | \
633 CPUID_PSE36 | CPUID_CLFLUSH | CPUID_ACPI | CPUID_MMX | \
634 CPUID_FXSR | CPUID_SSE | CPUID_SSE2 | CPUID_SS | CPUID_DE)
635 /* partly implemented:
636 CPUID_MTRR, CPUID_MCA, CPUID_CLFLUSH (needed for Win64) */
637 /* missing:
638 CPUID_VME, CPUID_DTS, CPUID_SS, CPUID_HT, CPUID_TM, CPUID_PBE */
639 #define TCG_EXT_FEATURES (CPUID_EXT_SSE3 | CPUID_EXT_PCLMULQDQ | \
640 CPUID_EXT_MONITOR | CPUID_EXT_SSSE3 | CPUID_EXT_CX16 | \
641 CPUID_EXT_SSE41 | CPUID_EXT_SSE42 | CPUID_EXT_POPCNT | \
642 CPUID_EXT_XSAVE | /* CPUID_EXT_OSXSAVE is dynamic */ \
643 CPUID_EXT_MOVBE | CPUID_EXT_AES | CPUID_EXT_HYPERVISOR | \
644 CPUID_EXT_RDRAND)
645 /* missing:
646 CPUID_EXT_DTES64, CPUID_EXT_DSCPL, CPUID_EXT_VMX, CPUID_EXT_SMX,
647 CPUID_EXT_EST, CPUID_EXT_TM2, CPUID_EXT_CID, CPUID_EXT_FMA,
648 CPUID_EXT_XTPR, CPUID_EXT_PDCM, CPUID_EXT_PCID, CPUID_EXT_DCA,
649 CPUID_EXT_X2APIC, CPUID_EXT_TSC_DEADLINE_TIMER, CPUID_EXT_AVX,
650 CPUID_EXT_F16C */
652 #ifdef TARGET_X86_64
653 #define TCG_EXT2_X86_64_FEATURES (CPUID_EXT2_SYSCALL | CPUID_EXT2_LM)
654 #else
655 #define TCG_EXT2_X86_64_FEATURES 0
656 #endif
658 #define TCG_EXT2_FEATURES ((TCG_FEATURES & CPUID_EXT2_AMD_ALIASES) | \
659 CPUID_EXT2_NX | CPUID_EXT2_MMXEXT | CPUID_EXT2_RDTSCP | \
660 CPUID_EXT2_3DNOW | CPUID_EXT2_3DNOWEXT | CPUID_EXT2_PDPE1GB | \
661 TCG_EXT2_X86_64_FEATURES)
662 #define TCG_EXT3_FEATURES (CPUID_EXT3_LAHF_LM | CPUID_EXT3_SVM | \
663 CPUID_EXT3_CR8LEG | CPUID_EXT3_ABM | CPUID_EXT3_SSE4A)
664 #define TCG_EXT4_FEATURES 0
665 #define TCG_SVM_FEATURES CPUID_SVM_NPT
666 #define TCG_KVM_FEATURES 0
667 #define TCG_7_0_EBX_FEATURES (CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_SMAP | \
668 CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ADX | \
669 CPUID_7_0_EBX_PCOMMIT | CPUID_7_0_EBX_CLFLUSHOPT | \
670 CPUID_7_0_EBX_CLWB | CPUID_7_0_EBX_MPX | CPUID_7_0_EBX_FSGSBASE | \
671 CPUID_7_0_EBX_ERMS)
672 /* missing:
673 CPUID_7_0_EBX_HLE, CPUID_7_0_EBX_AVX2,
674 CPUID_7_0_EBX_INVPCID, CPUID_7_0_EBX_RTM,
675 CPUID_7_0_EBX_RDSEED */
676 #define TCG_7_0_ECX_FEATURES (CPUID_7_0_ECX_PKU | \
677 /* CPUID_7_0_ECX_OSPKE is dynamic */ \
678 CPUID_7_0_ECX_LA57)
679 #define TCG_7_0_EDX_FEATURES 0
680 #define TCG_7_1_EAX_FEATURES 0
681 #define TCG_APM_FEATURES 0
682 #define TCG_6_EAX_FEATURES CPUID_6_EAX_ARAT
683 #define TCG_XSAVE_FEATURES (CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XGETBV1)
684 /* missing:
685 CPUID_XSAVE_XSAVEC, CPUID_XSAVE_XSAVES */
687 typedef enum FeatureWordType {
688 CPUID_FEATURE_WORD,
689 MSR_FEATURE_WORD,
690 } FeatureWordType;
692 typedef struct FeatureWordInfo {
693 FeatureWordType type;
694 /* feature flags names are taken from "Intel Processor Identification and
695 * the CPUID Instruction" and AMD's "CPUID Specification".
696 * In cases of disagreement between feature naming conventions,
697 * aliases may be added.
699 const char *feat_names[64];
700 union {
701 /* If type==CPUID_FEATURE_WORD */
702 struct {
703 uint32_t eax; /* Input EAX for CPUID */
704 bool needs_ecx; /* CPUID instruction uses ECX as input */
705 uint32_t ecx; /* Input ECX value for CPUID */
706 int reg; /* output register (R_* constant) */
707 } cpuid;
708 /* If type==MSR_FEATURE_WORD */
709 struct {
710 uint32_t index;
711 } msr;
713 uint64_t tcg_features; /* Feature flags supported by TCG */
714 uint64_t unmigratable_flags; /* Feature flags known to be unmigratable */
715 uint64_t migratable_flags; /* Feature flags known to be migratable */
716 /* Features that shouldn't be auto-enabled by "-cpu host" */
717 uint64_t no_autoenable_flags;
718 } FeatureWordInfo;
720 static FeatureWordInfo feature_word_info[FEATURE_WORDS] = {
721 [FEAT_1_EDX] = {
722 .type = CPUID_FEATURE_WORD,
723 .feat_names = {
724 "fpu", "vme", "de", "pse",
725 "tsc", "msr", "pae", "mce",
726 "cx8", "apic", NULL, "sep",
727 "mtrr", "pge", "mca", "cmov",
728 "pat", "pse36", "pn" /* Intel psn */, "clflush" /* Intel clfsh */,
729 NULL, "ds" /* Intel dts */, "acpi", "mmx",
730 "fxsr", "sse", "sse2", "ss",
731 "ht" /* Intel htt */, "tm", "ia64", "pbe",
733 .cpuid = {.eax = 1, .reg = R_EDX, },
734 .tcg_features = TCG_FEATURES,
736 [FEAT_1_ECX] = {
737 .type = CPUID_FEATURE_WORD,
738 .feat_names = {
739 "pni" /* Intel,AMD sse3 */, "pclmulqdq", "dtes64", "monitor",
740 "ds-cpl", "vmx", "smx", "est",
741 "tm2", "ssse3", "cid", NULL,
742 "fma", "cx16", "xtpr", "pdcm",
743 NULL, "pcid", "dca", "sse4.1",
744 "sse4.2", "x2apic", "movbe", "popcnt",
745 "tsc-deadline", "aes", "xsave", NULL /* osxsave */,
746 "avx", "f16c", "rdrand", "hypervisor",
748 .cpuid = { .eax = 1, .reg = R_ECX, },
749 .tcg_features = TCG_EXT_FEATURES,
751 /* Feature names that are already defined on feature_name[] but
752 * are set on CPUID[8000_0001].EDX on AMD CPUs don't have their
753 * names on feat_names below. They are copied automatically
754 * to features[FEAT_8000_0001_EDX] if and only if CPU vendor is AMD.
756 [FEAT_8000_0001_EDX] = {
757 .type = CPUID_FEATURE_WORD,
758 .feat_names = {
759 NULL /* fpu */, NULL /* vme */, NULL /* de */, NULL /* pse */,
760 NULL /* tsc */, NULL /* msr */, NULL /* pae */, NULL /* mce */,
761 NULL /* cx8 */, NULL /* apic */, NULL, "syscall",
762 NULL /* mtrr */, NULL /* pge */, NULL /* mca */, NULL /* cmov */,
763 NULL /* pat */, NULL /* pse36 */, NULL, NULL /* Linux mp */,
764 "nx", NULL, "mmxext", NULL /* mmx */,
765 NULL /* fxsr */, "fxsr-opt", "pdpe1gb", "rdtscp",
766 NULL, "lm", "3dnowext", "3dnow",
768 .cpuid = { .eax = 0x80000001, .reg = R_EDX, },
769 .tcg_features = TCG_EXT2_FEATURES,
771 [FEAT_8000_0001_ECX] = {
772 .type = CPUID_FEATURE_WORD,
773 .feat_names = {
774 "lahf-lm", "cmp-legacy", "svm", "extapic",
775 "cr8legacy", "abm", "sse4a", "misalignsse",
776 "3dnowprefetch", "osvw", "ibs", "xop",
777 "skinit", "wdt", NULL, "lwp",
778 "fma4", "tce", NULL, "nodeid-msr",
779 NULL, "tbm", "topoext", "perfctr-core",
780 "perfctr-nb", NULL, NULL, NULL,
781 NULL, NULL, NULL, NULL,
783 .cpuid = { .eax = 0x80000001, .reg = R_ECX, },
784 .tcg_features = TCG_EXT3_FEATURES,
786 * TOPOEXT is always allowed but can't be enabled blindly by
787 * "-cpu host", as it requires consistent cache topology info
788 * to be provided so it doesn't confuse guests.
790 .no_autoenable_flags = CPUID_EXT3_TOPOEXT,
792 [FEAT_C000_0001_EDX] = {
793 .type = CPUID_FEATURE_WORD,
794 .feat_names = {
795 NULL, NULL, "xstore", "xstore-en",
796 NULL, NULL, "xcrypt", "xcrypt-en",
797 "ace2", "ace2-en", "phe", "phe-en",
798 "pmm", "pmm-en", NULL, NULL,
799 NULL, NULL, NULL, NULL,
800 NULL, NULL, NULL, NULL,
801 NULL, NULL, NULL, NULL,
802 NULL, NULL, NULL, NULL,
804 .cpuid = { .eax = 0xC0000001, .reg = R_EDX, },
805 .tcg_features = TCG_EXT4_FEATURES,
807 [FEAT_KVM] = {
808 .type = CPUID_FEATURE_WORD,
809 .feat_names = {
810 "kvmclock", "kvm-nopiodelay", "kvm-mmu", "kvmclock",
811 "kvm-asyncpf", "kvm-steal-time", "kvm-pv-eoi", "kvm-pv-unhalt",
812 NULL, "kvm-pv-tlb-flush", NULL, "kvm-pv-ipi",
813 "kvm-poll-control", "kvm-pv-sched-yield", NULL, NULL,
814 NULL, NULL, NULL, NULL,
815 NULL, NULL, NULL, NULL,
816 "kvmclock-stable-bit", NULL, NULL, NULL,
817 NULL, NULL, NULL, NULL,
819 .cpuid = { .eax = KVM_CPUID_FEATURES, .reg = R_EAX, },
820 .tcg_features = TCG_KVM_FEATURES,
822 [FEAT_KVM_HINTS] = {
823 .type = CPUID_FEATURE_WORD,
824 .feat_names = {
825 "kvm-hint-dedicated", NULL, NULL, NULL,
826 NULL, NULL, NULL, NULL,
827 NULL, NULL, NULL, NULL,
828 NULL, NULL, NULL, NULL,
829 NULL, NULL, NULL, NULL,
830 NULL, NULL, NULL, NULL,
831 NULL, NULL, NULL, NULL,
832 NULL, NULL, NULL, NULL,
834 .cpuid = { .eax = KVM_CPUID_FEATURES, .reg = R_EDX, },
835 .tcg_features = TCG_KVM_FEATURES,
837 * KVM hints aren't auto-enabled by -cpu host, they need to be
838 * explicitly enabled in the command-line.
840 .no_autoenable_flags = ~0U,
843 * .feat_names are commented out for Hyper-V enlightenments because we
844 * don't want to have two different ways for enabling them on QEMU command
845 * line. Some features (e.g. "hyperv_time", "hyperv_vapic", ...) require
846 * enabling several feature bits simultaneously, exposing these bits
847 * individually may just confuse guests.
849 [FEAT_HYPERV_EAX] = {
850 .type = CPUID_FEATURE_WORD,
851 .feat_names = {
852 NULL /* hv_msr_vp_runtime_access */, NULL /* hv_msr_time_refcount_access */,
853 NULL /* hv_msr_synic_access */, NULL /* hv_msr_stimer_access */,
854 NULL /* hv_msr_apic_access */, NULL /* hv_msr_hypercall_access */,
855 NULL /* hv_vpindex_access */, NULL /* hv_msr_reset_access */,
856 NULL /* hv_msr_stats_access */, NULL /* hv_reftsc_access */,
857 NULL /* hv_msr_idle_access */, NULL /* hv_msr_frequency_access */,
858 NULL /* hv_msr_debug_access */, NULL /* hv_msr_reenlightenment_access */,
859 NULL, NULL,
860 NULL, NULL, NULL, NULL,
861 NULL, NULL, NULL, NULL,
862 NULL, NULL, NULL, NULL,
863 NULL, NULL, NULL, NULL,
865 .cpuid = { .eax = 0x40000003, .reg = R_EAX, },
867 [FEAT_HYPERV_EBX] = {
868 .type = CPUID_FEATURE_WORD,
869 .feat_names = {
870 NULL /* hv_create_partitions */, NULL /* hv_access_partition_id */,
871 NULL /* hv_access_memory_pool */, NULL /* hv_adjust_message_buffers */,
872 NULL /* hv_post_messages */, NULL /* hv_signal_events */,
873 NULL /* hv_create_port */, NULL /* hv_connect_port */,
874 NULL /* hv_access_stats */, NULL, NULL, NULL /* hv_debugging */,
875 NULL /* hv_cpu_power_management */, NULL /* hv_configure_profiler */,
876 NULL, NULL,
877 NULL, NULL, NULL, NULL,
878 NULL, NULL, NULL, NULL,
879 NULL, NULL, NULL, NULL,
880 NULL, NULL, NULL, NULL,
882 .cpuid = { .eax = 0x40000003, .reg = R_EBX, },
884 [FEAT_HYPERV_EDX] = {
885 .type = CPUID_FEATURE_WORD,
886 .feat_names = {
887 NULL /* hv_mwait */, NULL /* hv_guest_debugging */,
888 NULL /* hv_perf_monitor */, NULL /* hv_cpu_dynamic_part */,
889 NULL /* hv_hypercall_params_xmm */, NULL /* hv_guest_idle_state */,
890 NULL, NULL,
891 NULL, NULL, NULL /* hv_guest_crash_msr */, NULL,
892 NULL, NULL, NULL, NULL,
893 NULL, NULL, NULL, NULL,
894 NULL, NULL, NULL, NULL,
895 NULL, NULL, NULL, NULL,
896 NULL, NULL, NULL, NULL,
898 .cpuid = { .eax = 0x40000003, .reg = R_EDX, },
900 [FEAT_HV_RECOMM_EAX] = {
901 .type = CPUID_FEATURE_WORD,
902 .feat_names = {
903 NULL /* hv_recommend_pv_as_switch */,
904 NULL /* hv_recommend_pv_tlbflush_local */,
905 NULL /* hv_recommend_pv_tlbflush_remote */,
906 NULL /* hv_recommend_msr_apic_access */,
907 NULL /* hv_recommend_msr_reset */,
908 NULL /* hv_recommend_relaxed_timing */,
909 NULL /* hv_recommend_dma_remapping */,
910 NULL /* hv_recommend_int_remapping */,
911 NULL /* hv_recommend_x2apic_msrs */,
912 NULL /* hv_recommend_autoeoi_deprecation */,
913 NULL /* hv_recommend_pv_ipi */,
914 NULL /* hv_recommend_ex_hypercalls */,
915 NULL /* hv_hypervisor_is_nested */,
916 NULL /* hv_recommend_int_mbec */,
917 NULL /* hv_recommend_evmcs */,
918 NULL,
919 NULL, NULL, NULL, NULL,
920 NULL, NULL, NULL, NULL,
921 NULL, NULL, NULL, NULL,
922 NULL, NULL, NULL, NULL,
924 .cpuid = { .eax = 0x40000004, .reg = R_EAX, },
926 [FEAT_HV_NESTED_EAX] = {
927 .type = CPUID_FEATURE_WORD,
928 .cpuid = { .eax = 0x4000000A, .reg = R_EAX, },
930 [FEAT_SVM] = {
931 .type = CPUID_FEATURE_WORD,
932 .feat_names = {
933 "npt", "lbrv", "svm-lock", "nrip-save",
934 "tsc-scale", "vmcb-clean", "flushbyasid", "decodeassists",
935 NULL, NULL, "pause-filter", NULL,
936 "pfthreshold", NULL, NULL, NULL,
937 NULL, NULL, NULL, NULL,
938 NULL, NULL, NULL, NULL,
939 NULL, NULL, NULL, NULL,
940 NULL, NULL, NULL, NULL,
942 .cpuid = { .eax = 0x8000000A, .reg = R_EDX, },
943 .tcg_features = TCG_SVM_FEATURES,
945 [FEAT_7_0_EBX] = {
946 .type = CPUID_FEATURE_WORD,
947 .feat_names = {
948 "fsgsbase", "tsc-adjust", NULL, "bmi1",
949 "hle", "avx2", NULL, "smep",
950 "bmi2", "erms", "invpcid", "rtm",
951 NULL, NULL, "mpx", NULL,
952 "avx512f", "avx512dq", "rdseed", "adx",
953 "smap", "avx512ifma", "pcommit", "clflushopt",
954 "clwb", "intel-pt", "avx512pf", "avx512er",
955 "avx512cd", "sha-ni", "avx512bw", "avx512vl",
957 .cpuid = {
958 .eax = 7,
959 .needs_ecx = true, .ecx = 0,
960 .reg = R_EBX,
962 .tcg_features = TCG_7_0_EBX_FEATURES,
964 [FEAT_7_0_ECX] = {
965 .type = CPUID_FEATURE_WORD,
966 .feat_names = {
967 NULL, "avx512vbmi", "umip", "pku",
968 NULL /* ospke */, "waitpkg", "avx512vbmi2", NULL,
969 "gfni", "vaes", "vpclmulqdq", "avx512vnni",
970 "avx512bitalg", NULL, "avx512-vpopcntdq", NULL,
971 "la57", NULL, NULL, NULL,
972 NULL, NULL, "rdpid", NULL,
973 NULL, "cldemote", NULL, "movdiri",
974 "movdir64b", NULL, NULL, NULL,
976 .cpuid = {
977 .eax = 7,
978 .needs_ecx = true, .ecx = 0,
979 .reg = R_ECX,
981 .tcg_features = TCG_7_0_ECX_FEATURES,
983 [FEAT_7_0_EDX] = {
984 .type = CPUID_FEATURE_WORD,
985 .feat_names = {
986 NULL, NULL, "avx512-4vnniw", "avx512-4fmaps",
987 "fsrm", NULL, NULL, NULL,
988 "avx512-vp2intersect", NULL, "md-clear", NULL,
989 NULL, NULL, "serialize", NULL,
990 "tsx-ldtrk", NULL, NULL /* pconfig */, NULL,
991 NULL, NULL, NULL, NULL,
992 NULL, NULL, "spec-ctrl", "stibp",
993 NULL, "arch-capabilities", "core-capability", "ssbd",
995 .cpuid = {
996 .eax = 7,
997 .needs_ecx = true, .ecx = 0,
998 .reg = R_EDX,
1000 .tcg_features = TCG_7_0_EDX_FEATURES,
1002 [FEAT_7_1_EAX] = {
1003 .type = CPUID_FEATURE_WORD,
1004 .feat_names = {
1005 NULL, NULL, NULL, NULL,
1006 NULL, "avx512-bf16", NULL, NULL,
1007 NULL, NULL, NULL, NULL,
1008 NULL, NULL, NULL, NULL,
1009 NULL, NULL, NULL, NULL,
1010 NULL, NULL, NULL, NULL,
1011 NULL, NULL, NULL, NULL,
1012 NULL, NULL, NULL, NULL,
1014 .cpuid = {
1015 .eax = 7,
1016 .needs_ecx = true, .ecx = 1,
1017 .reg = R_EAX,
1019 .tcg_features = TCG_7_1_EAX_FEATURES,
1021 [FEAT_8000_0007_EDX] = {
1022 .type = CPUID_FEATURE_WORD,
1023 .feat_names = {
1024 NULL, NULL, NULL, NULL,
1025 NULL, NULL, NULL, NULL,
1026 "invtsc", NULL, NULL, NULL,
1027 NULL, NULL, NULL, NULL,
1028 NULL, NULL, NULL, NULL,
1029 NULL, NULL, NULL, NULL,
1030 NULL, NULL, NULL, NULL,
1031 NULL, NULL, NULL, NULL,
1033 .cpuid = { .eax = 0x80000007, .reg = R_EDX, },
1034 .tcg_features = TCG_APM_FEATURES,
1035 .unmigratable_flags = CPUID_APM_INVTSC,
1037 [FEAT_8000_0008_EBX] = {
1038 .type = CPUID_FEATURE_WORD,
1039 .feat_names = {
1040 "clzero", NULL, "xsaveerptr", NULL,
1041 NULL, NULL, NULL, NULL,
1042 NULL, "wbnoinvd", NULL, NULL,
1043 "ibpb", NULL, NULL, "amd-stibp",
1044 NULL, NULL, NULL, NULL,
1045 NULL, NULL, NULL, NULL,
1046 "amd-ssbd", "virt-ssbd", "amd-no-ssb", NULL,
1047 NULL, NULL, NULL, NULL,
1049 .cpuid = { .eax = 0x80000008, .reg = R_EBX, },
1050 .tcg_features = 0,
1051 .unmigratable_flags = 0,
1053 [FEAT_XSAVE] = {
1054 .type = CPUID_FEATURE_WORD,
1055 .feat_names = {
1056 "xsaveopt", "xsavec", "xgetbv1", "xsaves",
1057 NULL, NULL, NULL, NULL,
1058 NULL, NULL, NULL, NULL,
1059 NULL, NULL, NULL, NULL,
1060 NULL, NULL, NULL, NULL,
1061 NULL, NULL, NULL, NULL,
1062 NULL, NULL, NULL, NULL,
1063 NULL, NULL, NULL, NULL,
1065 .cpuid = {
1066 .eax = 0xd,
1067 .needs_ecx = true, .ecx = 1,
1068 .reg = R_EAX,
1070 .tcg_features = TCG_XSAVE_FEATURES,
1072 [FEAT_6_EAX] = {
1073 .type = CPUID_FEATURE_WORD,
1074 .feat_names = {
1075 NULL, NULL, "arat", NULL,
1076 NULL, NULL, NULL, NULL,
1077 NULL, NULL, NULL, NULL,
1078 NULL, NULL, NULL, NULL,
1079 NULL, NULL, NULL, NULL,
1080 NULL, NULL, NULL, NULL,
1081 NULL, NULL, NULL, NULL,
1082 NULL, NULL, NULL, NULL,
1084 .cpuid = { .eax = 6, .reg = R_EAX, },
1085 .tcg_features = TCG_6_EAX_FEATURES,
1087 [FEAT_XSAVE_COMP_LO] = {
1088 .type = CPUID_FEATURE_WORD,
1089 .cpuid = {
1090 .eax = 0xD,
1091 .needs_ecx = true, .ecx = 0,
1092 .reg = R_EAX,
1094 .tcg_features = ~0U,
1095 .migratable_flags = XSTATE_FP_MASK | XSTATE_SSE_MASK |
1096 XSTATE_YMM_MASK | XSTATE_BNDREGS_MASK | XSTATE_BNDCSR_MASK |
1097 XSTATE_OPMASK_MASK | XSTATE_ZMM_Hi256_MASK | XSTATE_Hi16_ZMM_MASK |
1098 XSTATE_PKRU_MASK,
1100 [FEAT_XSAVE_COMP_HI] = {
1101 .type = CPUID_FEATURE_WORD,
1102 .cpuid = {
1103 .eax = 0xD,
1104 .needs_ecx = true, .ecx = 0,
1105 .reg = R_EDX,
1107 .tcg_features = ~0U,
1109 /*Below are MSR exposed features*/
1110 [FEAT_ARCH_CAPABILITIES] = {
1111 .type = MSR_FEATURE_WORD,
1112 .feat_names = {
1113 "rdctl-no", "ibrs-all", "rsba", "skip-l1dfl-vmentry",
1114 "ssb-no", "mds-no", "pschange-mc-no", "tsx-ctrl",
1115 "taa-no", NULL, NULL, NULL,
1116 NULL, NULL, NULL, NULL,
1117 NULL, NULL, NULL, NULL,
1118 NULL, NULL, NULL, NULL,
1119 NULL, NULL, NULL, NULL,
1120 NULL, NULL, NULL, NULL,
1122 .msr = {
1123 .index = MSR_IA32_ARCH_CAPABILITIES,
1126 [FEAT_CORE_CAPABILITY] = {
1127 .type = MSR_FEATURE_WORD,
1128 .feat_names = {
1129 NULL, NULL, NULL, NULL,
1130 NULL, "split-lock-detect", NULL, NULL,
1131 NULL, NULL, NULL, NULL,
1132 NULL, NULL, NULL, NULL,
1133 NULL, NULL, NULL, NULL,
1134 NULL, NULL, NULL, NULL,
1135 NULL, NULL, NULL, NULL,
1136 NULL, NULL, NULL, NULL,
1138 .msr = {
1139 .index = MSR_IA32_CORE_CAPABILITY,
1142 [FEAT_PERF_CAPABILITIES] = {
1143 .type = MSR_FEATURE_WORD,
1144 .feat_names = {
1145 NULL, NULL, NULL, NULL,
1146 NULL, NULL, NULL, NULL,
1147 NULL, NULL, NULL, NULL,
1148 NULL, "full-width-write", NULL, NULL,
1149 NULL, NULL, NULL, NULL,
1150 NULL, NULL, NULL, NULL,
1151 NULL, NULL, NULL, NULL,
1152 NULL, NULL, NULL, NULL,
1154 .msr = {
1155 .index = MSR_IA32_PERF_CAPABILITIES,
1159 [FEAT_VMX_PROCBASED_CTLS] = {
1160 .type = MSR_FEATURE_WORD,
1161 .feat_names = {
1162 NULL, NULL, "vmx-vintr-pending", "vmx-tsc-offset",
1163 NULL, NULL, NULL, "vmx-hlt-exit",
1164 NULL, "vmx-invlpg-exit", "vmx-mwait-exit", "vmx-rdpmc-exit",
1165 "vmx-rdtsc-exit", NULL, NULL, "vmx-cr3-load-noexit",
1166 "vmx-cr3-store-noexit", NULL, NULL, "vmx-cr8-load-exit",
1167 "vmx-cr8-store-exit", "vmx-flexpriority", "vmx-vnmi-pending", "vmx-movdr-exit",
1168 "vmx-io-exit", "vmx-io-bitmap", NULL, "vmx-mtf",
1169 "vmx-msr-bitmap", "vmx-monitor-exit", "vmx-pause-exit", "vmx-secondary-ctls",
1171 .msr = {
1172 .index = MSR_IA32_VMX_TRUE_PROCBASED_CTLS,
1176 [FEAT_VMX_SECONDARY_CTLS] = {
1177 .type = MSR_FEATURE_WORD,
1178 .feat_names = {
1179 "vmx-apicv-xapic", "vmx-ept", "vmx-desc-exit", "vmx-rdtscp-exit",
1180 "vmx-apicv-x2apic", "vmx-vpid", "vmx-wbinvd-exit", "vmx-unrestricted-guest",
1181 "vmx-apicv-register", "vmx-apicv-vid", "vmx-ple", "vmx-rdrand-exit",
1182 "vmx-invpcid-exit", "vmx-vmfunc", "vmx-shadow-vmcs", "vmx-encls-exit",
1183 "vmx-rdseed-exit", "vmx-pml", NULL, NULL,
1184 "vmx-xsaves", NULL, NULL, NULL,
1185 NULL, NULL, NULL, NULL,
1186 NULL, NULL, NULL, NULL,
1188 .msr = {
1189 .index = MSR_IA32_VMX_PROCBASED_CTLS2,
1193 [FEAT_VMX_PINBASED_CTLS] = {
1194 .type = MSR_FEATURE_WORD,
1195 .feat_names = {
1196 "vmx-intr-exit", NULL, NULL, "vmx-nmi-exit",
1197 NULL, "vmx-vnmi", "vmx-preemption-timer", "vmx-posted-intr",
1198 NULL, NULL, NULL, NULL,
1199 NULL, NULL, NULL, NULL,
1200 NULL, NULL, NULL, NULL,
1201 NULL, NULL, NULL, NULL,
1202 NULL, NULL, NULL, NULL,
1203 NULL, NULL, NULL, NULL,
1205 .msr = {
1206 .index = MSR_IA32_VMX_TRUE_PINBASED_CTLS,
1210 [FEAT_VMX_EXIT_CTLS] = {
1211 .type = MSR_FEATURE_WORD,
1213 * VMX_VM_EXIT_HOST_ADDR_SPACE_SIZE is copied from
1214 * the LM CPUID bit.
1216 .feat_names = {
1217 NULL, NULL, "vmx-exit-nosave-debugctl", NULL,
1218 NULL, NULL, NULL, NULL,
1219 NULL, NULL /* vmx-exit-host-addr-space-size */, NULL, NULL,
1220 "vmx-exit-load-perf-global-ctrl", NULL, NULL, "vmx-exit-ack-intr",
1221 NULL, NULL, "vmx-exit-save-pat", "vmx-exit-load-pat",
1222 "vmx-exit-save-efer", "vmx-exit-load-efer",
1223 "vmx-exit-save-preemption-timer", "vmx-exit-clear-bndcfgs",
1224 NULL, "vmx-exit-clear-rtit-ctl", NULL, NULL,
1225 NULL, NULL, NULL, NULL,
1227 .msr = {
1228 .index = MSR_IA32_VMX_TRUE_EXIT_CTLS,
1232 [FEAT_VMX_ENTRY_CTLS] = {
1233 .type = MSR_FEATURE_WORD,
1234 .feat_names = {
1235 NULL, NULL, "vmx-entry-noload-debugctl", NULL,
1236 NULL, NULL, NULL, NULL,
1237 NULL, "vmx-entry-ia32e-mode", NULL, NULL,
1238 NULL, "vmx-entry-load-perf-global-ctrl", "vmx-entry-load-pat", "vmx-entry-load-efer",
1239 "vmx-entry-load-bndcfgs", NULL, "vmx-entry-load-rtit-ctl", NULL,
1240 NULL, NULL, NULL, NULL,
1241 NULL, NULL, NULL, NULL,
1242 NULL, NULL, NULL, NULL,
1244 .msr = {
1245 .index = MSR_IA32_VMX_TRUE_ENTRY_CTLS,
1249 [FEAT_VMX_MISC] = {
1250 .type = MSR_FEATURE_WORD,
1251 .feat_names = {
1252 NULL, NULL, NULL, NULL,
1253 NULL, "vmx-store-lma", "vmx-activity-hlt", "vmx-activity-shutdown",
1254 "vmx-activity-wait-sipi", NULL, NULL, NULL,
1255 NULL, NULL, NULL, NULL,
1256 NULL, NULL, NULL, NULL,
1257 NULL, NULL, NULL, NULL,
1258 NULL, NULL, NULL, NULL,
1259 NULL, "vmx-vmwrite-vmexit-fields", "vmx-zero-len-inject", NULL,
1261 .msr = {
1262 .index = MSR_IA32_VMX_MISC,
1266 [FEAT_VMX_EPT_VPID_CAPS] = {
1267 .type = MSR_FEATURE_WORD,
1268 .feat_names = {
1269 "vmx-ept-execonly", NULL, NULL, NULL,
1270 NULL, NULL, "vmx-page-walk-4", "vmx-page-walk-5",
1271 NULL, NULL, NULL, NULL,
1272 NULL, NULL, NULL, NULL,
1273 "vmx-ept-2mb", "vmx-ept-1gb", NULL, NULL,
1274 "vmx-invept", "vmx-eptad", "vmx-ept-advanced-exitinfo", NULL,
1275 NULL, "vmx-invept-single-context", "vmx-invept-all-context", NULL,
1276 NULL, NULL, NULL, NULL,
1277 "vmx-invvpid", NULL, NULL, NULL,
1278 NULL, NULL, NULL, NULL,
1279 "vmx-invvpid-single-addr", "vmx-invept-single-context",
1280 "vmx-invvpid-all-context", "vmx-invept-single-context-noglobals",
1281 NULL, NULL, NULL, NULL,
1282 NULL, NULL, NULL, NULL,
1283 NULL, NULL, NULL, NULL,
1284 NULL, NULL, NULL, NULL,
1285 NULL, NULL, NULL, NULL,
1287 .msr = {
1288 .index = MSR_IA32_VMX_EPT_VPID_CAP,
1292 [FEAT_VMX_BASIC] = {
1293 .type = MSR_FEATURE_WORD,
1294 .feat_names = {
1295 [54] = "vmx-ins-outs",
1296 [55] = "vmx-true-ctls",
1298 .msr = {
1299 .index = MSR_IA32_VMX_BASIC,
1301 /* Just to be safe - we don't support setting the MSEG version field. */
1302 .no_autoenable_flags = MSR_VMX_BASIC_DUAL_MONITOR,
1305 [FEAT_VMX_VMFUNC] = {
1306 .type = MSR_FEATURE_WORD,
1307 .feat_names = {
1308 [0] = "vmx-eptp-switching",
1310 .msr = {
1311 .index = MSR_IA32_VMX_VMFUNC,
1317 typedef struct FeatureMask {
1318 FeatureWord index;
1319 uint64_t mask;
1320 } FeatureMask;
1322 typedef struct FeatureDep {
1323 FeatureMask from, to;
1324 } FeatureDep;
1326 static FeatureDep feature_dependencies[] = {
1328 .from = { FEAT_7_0_EDX, CPUID_7_0_EDX_ARCH_CAPABILITIES },
1329 .to = { FEAT_ARCH_CAPABILITIES, ~0ull },
1332 .from = { FEAT_7_0_EDX, CPUID_7_0_EDX_CORE_CAPABILITY },
1333 .to = { FEAT_CORE_CAPABILITY, ~0ull },
1336 .from = { FEAT_1_ECX, CPUID_EXT_PDCM },
1337 .to = { FEAT_PERF_CAPABILITIES, ~0ull },
1340 .from = { FEAT_1_ECX, CPUID_EXT_VMX },
1341 .to = { FEAT_VMX_PROCBASED_CTLS, ~0ull },
1344 .from = { FEAT_1_ECX, CPUID_EXT_VMX },
1345 .to = { FEAT_VMX_PINBASED_CTLS, ~0ull },
1348 .from = { FEAT_1_ECX, CPUID_EXT_VMX },
1349 .to = { FEAT_VMX_EXIT_CTLS, ~0ull },
1352 .from = { FEAT_1_ECX, CPUID_EXT_VMX },
1353 .to = { FEAT_VMX_ENTRY_CTLS, ~0ull },
1356 .from = { FEAT_1_ECX, CPUID_EXT_VMX },
1357 .to = { FEAT_VMX_MISC, ~0ull },
1360 .from = { FEAT_1_ECX, CPUID_EXT_VMX },
1361 .to = { FEAT_VMX_BASIC, ~0ull },
1364 .from = { FEAT_8000_0001_EDX, CPUID_EXT2_LM },
1365 .to = { FEAT_VMX_ENTRY_CTLS, VMX_VM_ENTRY_IA32E_MODE },
1368 .from = { FEAT_VMX_PROCBASED_CTLS, VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS },
1369 .to = { FEAT_VMX_SECONDARY_CTLS, ~0ull },
1372 .from = { FEAT_XSAVE, CPUID_XSAVE_XSAVES },
1373 .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_XSAVES },
1376 .from = { FEAT_1_ECX, CPUID_EXT_RDRAND },
1377 .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_RDRAND_EXITING },
1380 .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_INVPCID },
1381 .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_ENABLE_INVPCID },
1384 .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_RDSEED },
1385 .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_RDSEED_EXITING },
1388 .from = { FEAT_8000_0001_EDX, CPUID_EXT2_RDTSCP },
1389 .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_RDTSCP },
1392 .from = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_ENABLE_EPT },
1393 .to = { FEAT_VMX_EPT_VPID_CAPS, 0xffffffffull },
1396 .from = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_ENABLE_EPT },
1397 .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST },
1400 .from = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_ENABLE_VPID },
1401 .to = { FEAT_VMX_EPT_VPID_CAPS, 0xffffffffull << 32 },
1404 .from = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_ENABLE_VMFUNC },
1405 .to = { FEAT_VMX_VMFUNC, ~0ull },
1408 .from = { FEAT_8000_0001_ECX, CPUID_EXT3_SVM },
1409 .to = { FEAT_SVM, ~0ull },
1413 typedef struct X86RegisterInfo32 {
1414 /* Name of register */
1415 const char *name;
1416 /* QAPI enum value register */
1417 X86CPURegister32 qapi_enum;
1418 } X86RegisterInfo32;
1420 #define REGISTER(reg) \
1421 [R_##reg] = { .name = #reg, .qapi_enum = X86_CPU_REGISTER32_##reg }
1422 static const X86RegisterInfo32 x86_reg_info_32[CPU_NB_REGS32] = {
1423 REGISTER(EAX),
1424 REGISTER(ECX),
1425 REGISTER(EDX),
1426 REGISTER(EBX),
1427 REGISTER(ESP),
1428 REGISTER(EBP),
1429 REGISTER(ESI),
1430 REGISTER(EDI),
1432 #undef REGISTER
1434 typedef struct ExtSaveArea {
1435 uint32_t feature, bits;
1436 uint32_t offset, size;
1437 } ExtSaveArea;
1439 static const ExtSaveArea x86_ext_save_areas[] = {
1440 [XSTATE_FP_BIT] = {
1441 /* x87 FP state component is always enabled if XSAVE is supported */
1442 .feature = FEAT_1_ECX, .bits = CPUID_EXT_XSAVE,
1443 /* x87 state is in the legacy region of the XSAVE area */
1444 .offset = 0,
1445 .size = sizeof(X86LegacyXSaveArea) + sizeof(X86XSaveHeader),
1447 [XSTATE_SSE_BIT] = {
1448 /* SSE state component is always enabled if XSAVE is supported */
1449 .feature = FEAT_1_ECX, .bits = CPUID_EXT_XSAVE,
1450 /* SSE state is in the legacy region of the XSAVE area */
1451 .offset = 0,
1452 .size = sizeof(X86LegacyXSaveArea) + sizeof(X86XSaveHeader),
1454 [XSTATE_YMM_BIT] =
1455 { .feature = FEAT_1_ECX, .bits = CPUID_EXT_AVX,
1456 .offset = offsetof(X86XSaveArea, avx_state),
1457 .size = sizeof(XSaveAVX) },
1458 [XSTATE_BNDREGS_BIT] =
1459 { .feature = FEAT_7_0_EBX, .bits = CPUID_7_0_EBX_MPX,
1460 .offset = offsetof(X86XSaveArea, bndreg_state),
1461 .size = sizeof(XSaveBNDREG) },
1462 [XSTATE_BNDCSR_BIT] =
1463 { .feature = FEAT_7_0_EBX, .bits = CPUID_7_0_EBX_MPX,
1464 .offset = offsetof(X86XSaveArea, bndcsr_state),
1465 .size = sizeof(XSaveBNDCSR) },
1466 [XSTATE_OPMASK_BIT] =
1467 { .feature = FEAT_7_0_EBX, .bits = CPUID_7_0_EBX_AVX512F,
1468 .offset = offsetof(X86XSaveArea, opmask_state),
1469 .size = sizeof(XSaveOpmask) },
1470 [XSTATE_ZMM_Hi256_BIT] =
1471 { .feature = FEAT_7_0_EBX, .bits = CPUID_7_0_EBX_AVX512F,
1472 .offset = offsetof(X86XSaveArea, zmm_hi256_state),
1473 .size = sizeof(XSaveZMM_Hi256) },
1474 [XSTATE_Hi16_ZMM_BIT] =
1475 { .feature = FEAT_7_0_EBX, .bits = CPUID_7_0_EBX_AVX512F,
1476 .offset = offsetof(X86XSaveArea, hi16_zmm_state),
1477 .size = sizeof(XSaveHi16_ZMM) },
1478 [XSTATE_PKRU_BIT] =
1479 { .feature = FEAT_7_0_ECX, .bits = CPUID_7_0_ECX_PKU,
1480 .offset = offsetof(X86XSaveArea, pkru_state),
1481 .size = sizeof(XSavePKRU) },
1484 static uint32_t xsave_area_size(uint64_t mask)
1486 int i;
1487 uint64_t ret = 0;
1489 for (i = 0; i < ARRAY_SIZE(x86_ext_save_areas); i++) {
1490 const ExtSaveArea *esa = &x86_ext_save_areas[i];
1491 if ((mask >> i) & 1) {
1492 ret = MAX(ret, esa->offset + esa->size);
1495 return ret;
1498 static inline bool accel_uses_host_cpuid(void)
1500 return kvm_enabled() || hvf_enabled();
1503 static inline uint64_t x86_cpu_xsave_components(X86CPU *cpu)
1505 return ((uint64_t)cpu->env.features[FEAT_XSAVE_COMP_HI]) << 32 |
1506 cpu->env.features[FEAT_XSAVE_COMP_LO];
1509 const char *get_register_name_32(unsigned int reg)
1511 if (reg >= CPU_NB_REGS32) {
1512 return NULL;
1514 return x86_reg_info_32[reg].name;
1518 * Returns the set of feature flags that are supported and migratable by
1519 * QEMU, for a given FeatureWord.
1521 static uint64_t x86_cpu_get_migratable_flags(FeatureWord w)
1523 FeatureWordInfo *wi = &feature_word_info[w];
1524 uint64_t r = 0;
1525 int i;
1527 for (i = 0; i < 64; i++) {
1528 uint64_t f = 1ULL << i;
1530 /* If the feature name is known, it is implicitly considered migratable,
1531 * unless it is explicitly set in unmigratable_flags */
1532 if ((wi->migratable_flags & f) ||
1533 (wi->feat_names[i] && !(wi->unmigratable_flags & f))) {
1534 r |= f;
1537 return r;
1540 void host_cpuid(uint32_t function, uint32_t count,
1541 uint32_t *eax, uint32_t *ebx, uint32_t *ecx, uint32_t *edx)
1543 uint32_t vec[4];
1545 #ifdef __x86_64__
1546 asm volatile("cpuid"
1547 : "=a"(vec[0]), "=b"(vec[1]),
1548 "=c"(vec[2]), "=d"(vec[3])
1549 : "0"(function), "c"(count) : "cc");
1550 #elif defined(__i386__)
1551 asm volatile("pusha \n\t"
1552 "cpuid \n\t"
1553 "mov %%eax, 0(%2) \n\t"
1554 "mov %%ebx, 4(%2) \n\t"
1555 "mov %%ecx, 8(%2) \n\t"
1556 "mov %%edx, 12(%2) \n\t"
1557 "popa"
1558 : : "a"(function), "c"(count), "S"(vec)
1559 : "memory", "cc");
1560 #else
1561 abort();
1562 #endif
1564 if (eax)
1565 *eax = vec[0];
1566 if (ebx)
1567 *ebx = vec[1];
1568 if (ecx)
1569 *ecx = vec[2];
1570 if (edx)
1571 *edx = vec[3];
1574 void host_vendor_fms(char *vendor, int *family, int *model, int *stepping)
1576 uint32_t eax, ebx, ecx, edx;
1578 host_cpuid(0x0, 0, &eax, &ebx, &ecx, &edx);
1579 x86_cpu_vendor_words2str(vendor, ebx, edx, ecx);
1581 host_cpuid(0x1, 0, &eax, &ebx, &ecx, &edx);
1582 if (family) {
1583 *family = ((eax >> 8) & 0x0F) + ((eax >> 20) & 0xFF);
1585 if (model) {
1586 *model = ((eax >> 4) & 0x0F) | ((eax & 0xF0000) >> 12);
1588 if (stepping) {
1589 *stepping = eax & 0x0F;
1593 /* CPU class name definitions: */
1595 /* Return type name for a given CPU model name
1596 * Caller is responsible for freeing the returned string.
1598 static char *x86_cpu_type_name(const char *model_name)
1600 return g_strdup_printf(X86_CPU_TYPE_NAME("%s"), model_name);
1603 static ObjectClass *x86_cpu_class_by_name(const char *cpu_model)
1605 g_autofree char *typename = x86_cpu_type_name(cpu_model);
1606 return object_class_by_name(typename);
1609 static char *x86_cpu_class_get_model_name(X86CPUClass *cc)
1611 const char *class_name = object_class_get_name(OBJECT_CLASS(cc));
1612 assert(g_str_has_suffix(class_name, X86_CPU_TYPE_SUFFIX));
1613 return g_strndup(class_name,
1614 strlen(class_name) - strlen(X86_CPU_TYPE_SUFFIX));
1617 typedef struct PropValue {
1618 const char *prop, *value;
1619 } PropValue;
1621 typedef struct X86CPUVersionDefinition {
1622 X86CPUVersion version;
1623 const char *alias;
1624 const char *note;
1625 PropValue *props;
1626 } X86CPUVersionDefinition;
1628 /* Base definition for a CPU model */
1629 typedef struct X86CPUDefinition {
1630 const char *name;
1631 uint32_t level;
1632 uint32_t xlevel;
1633 /* vendor is zero-terminated, 12 character ASCII string */
1634 char vendor[CPUID_VENDOR_SZ + 1];
1635 int family;
1636 int model;
1637 int stepping;
1638 FeatureWordArray features;
1639 const char *model_id;
1640 CPUCaches *cache_info;
1642 /* Use AMD EPYC encoding for apic id */
1643 bool use_epyc_apic_id_encoding;
1646 * Definitions for alternative versions of CPU model.
1647 * List is terminated by item with version == 0.
1648 * If NULL, version 1 will be registered automatically.
1650 const X86CPUVersionDefinition *versions;
1651 } X86CPUDefinition;
1653 /* Reference to a specific CPU model version */
1654 struct X86CPUModel {
1655 /* Base CPU definition */
1656 X86CPUDefinition *cpudef;
1657 /* CPU model version */
1658 X86CPUVersion version;
1659 const char *note;
1661 * If true, this is an alias CPU model.
1662 * This matters only for "-cpu help" and query-cpu-definitions
1664 bool is_alias;
1667 /* Get full model name for CPU version */
1668 static char *x86_cpu_versioned_model_name(X86CPUDefinition *cpudef,
1669 X86CPUVersion version)
1671 assert(version > 0);
1672 return g_strdup_printf("%s-v%d", cpudef->name, (int)version);
1675 static const X86CPUVersionDefinition *x86_cpu_def_get_versions(X86CPUDefinition *def)
1677 /* When X86CPUDefinition::versions is NULL, we register only v1 */
1678 static const X86CPUVersionDefinition default_version_list[] = {
1679 { 1 },
1680 { /* end of list */ }
1683 return def->versions ?: default_version_list;
1686 bool cpu_x86_use_epyc_apic_id_encoding(const char *cpu_type)
1688 X86CPUClass *xcc = X86_CPU_CLASS(object_class_by_name(cpu_type));
1690 assert(xcc);
1691 if (xcc->model && xcc->model->cpudef) {
1692 return xcc->model->cpudef->use_epyc_apic_id_encoding;
1693 } else {
1694 return false;
1698 static CPUCaches epyc_cache_info = {
1699 .l1d_cache = &(CPUCacheInfo) {
1700 .type = DATA_CACHE,
1701 .level = 1,
1702 .size = 32 * KiB,
1703 .line_size = 64,
1704 .associativity = 8,
1705 .partitions = 1,
1706 .sets = 64,
1707 .lines_per_tag = 1,
1708 .self_init = 1,
1709 .no_invd_sharing = true,
1711 .l1i_cache = &(CPUCacheInfo) {
1712 .type = INSTRUCTION_CACHE,
1713 .level = 1,
1714 .size = 64 * KiB,
1715 .line_size = 64,
1716 .associativity = 4,
1717 .partitions = 1,
1718 .sets = 256,
1719 .lines_per_tag = 1,
1720 .self_init = 1,
1721 .no_invd_sharing = true,
1723 .l2_cache = &(CPUCacheInfo) {
1724 .type = UNIFIED_CACHE,
1725 .level = 2,
1726 .size = 512 * KiB,
1727 .line_size = 64,
1728 .associativity = 8,
1729 .partitions = 1,
1730 .sets = 1024,
1731 .lines_per_tag = 1,
1733 .l3_cache = &(CPUCacheInfo) {
1734 .type = UNIFIED_CACHE,
1735 .level = 3,
1736 .size = 8 * MiB,
1737 .line_size = 64,
1738 .associativity = 16,
1739 .partitions = 1,
1740 .sets = 8192,
1741 .lines_per_tag = 1,
1742 .self_init = true,
1743 .inclusive = true,
1744 .complex_indexing = true,
1748 static CPUCaches epyc_rome_cache_info = {
1749 .l1d_cache = &(CPUCacheInfo) {
1750 .type = DATA_CACHE,
1751 .level = 1,
1752 .size = 32 * KiB,
1753 .line_size = 64,
1754 .associativity = 8,
1755 .partitions = 1,
1756 .sets = 64,
1757 .lines_per_tag = 1,
1758 .self_init = 1,
1759 .no_invd_sharing = true,
1761 .l1i_cache = &(CPUCacheInfo) {
1762 .type = INSTRUCTION_CACHE,
1763 .level = 1,
1764 .size = 32 * KiB,
1765 .line_size = 64,
1766 .associativity = 8,
1767 .partitions = 1,
1768 .sets = 64,
1769 .lines_per_tag = 1,
1770 .self_init = 1,
1771 .no_invd_sharing = true,
1773 .l2_cache = &(CPUCacheInfo) {
1774 .type = UNIFIED_CACHE,
1775 .level = 2,
1776 .size = 512 * KiB,
1777 .line_size = 64,
1778 .associativity = 8,
1779 .partitions = 1,
1780 .sets = 1024,
1781 .lines_per_tag = 1,
1783 .l3_cache = &(CPUCacheInfo) {
1784 .type = UNIFIED_CACHE,
1785 .level = 3,
1786 .size = 16 * MiB,
1787 .line_size = 64,
1788 .associativity = 16,
1789 .partitions = 1,
1790 .sets = 16384,
1791 .lines_per_tag = 1,
1792 .self_init = true,
1793 .inclusive = true,
1794 .complex_indexing = true,
1798 /* The following VMX features are not supported by KVM and are left out in the
1799 * CPU definitions:
1801 * Dual-monitor support (all processors)
1802 * Entry to SMM
1803 * Deactivate dual-monitor treatment
1804 * Number of CR3-target values
1805 * Shutdown activity state
1806 * Wait-for-SIPI activity state
1807 * PAUSE-loop exiting (Westmere and newer)
1808 * EPT-violation #VE (Broadwell and newer)
1809 * Inject event with insn length=0 (Skylake and newer)
1810 * Conceal non-root operation from PT
1811 * Conceal VM exits from PT
1812 * Conceal VM entries from PT
1813 * Enable ENCLS exiting
1814 * Mode-based execute control (XS/XU)
1815 s TSC scaling (Skylake Server and newer)
1816 * GPA translation for PT (IceLake and newer)
1817 * User wait and pause
1818 * ENCLV exiting
1819 * Load IA32_RTIT_CTL
1820 * Clear IA32_RTIT_CTL
1821 * Advanced VM-exit information for EPT violations
1822 * Sub-page write permissions
1823 * PT in VMX operation
1826 static X86CPUDefinition builtin_x86_defs[] = {
1828 .name = "qemu64",
1829 .level = 0xd,
1830 .vendor = CPUID_VENDOR_AMD,
1831 .family = 6,
1832 .model = 6,
1833 .stepping = 3,
1834 .features[FEAT_1_EDX] =
1835 PPRO_FEATURES |
1836 CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA |
1837 CPUID_PSE36,
1838 .features[FEAT_1_ECX] =
1839 CPUID_EXT_SSE3 | CPUID_EXT_CX16,
1840 .features[FEAT_8000_0001_EDX] =
1841 CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX,
1842 .features[FEAT_8000_0001_ECX] =
1843 CPUID_EXT3_LAHF_LM | CPUID_EXT3_SVM,
1844 .xlevel = 0x8000000A,
1845 .model_id = "QEMU Virtual CPU version " QEMU_HW_VERSION,
1848 .name = "phenom",
1849 .level = 5,
1850 .vendor = CPUID_VENDOR_AMD,
1851 .family = 16,
1852 .model = 2,
1853 .stepping = 3,
1854 /* Missing: CPUID_HT */
1855 .features[FEAT_1_EDX] =
1856 PPRO_FEATURES |
1857 CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA |
1858 CPUID_PSE36 | CPUID_VME,
1859 .features[FEAT_1_ECX] =
1860 CPUID_EXT_SSE3 | CPUID_EXT_MONITOR | CPUID_EXT_CX16 |
1861 CPUID_EXT_POPCNT,
1862 .features[FEAT_8000_0001_EDX] =
1863 CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX |
1864 CPUID_EXT2_3DNOW | CPUID_EXT2_3DNOWEXT | CPUID_EXT2_MMXEXT |
1865 CPUID_EXT2_FFXSR | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP,
1866 /* Missing: CPUID_EXT3_CMP_LEG, CPUID_EXT3_EXTAPIC,
1867 CPUID_EXT3_CR8LEG,
1868 CPUID_EXT3_MISALIGNSSE, CPUID_EXT3_3DNOWPREFETCH,
1869 CPUID_EXT3_OSVW, CPUID_EXT3_IBS */
1870 .features[FEAT_8000_0001_ECX] =
1871 CPUID_EXT3_LAHF_LM | CPUID_EXT3_SVM |
1872 CPUID_EXT3_ABM | CPUID_EXT3_SSE4A,
1873 /* Missing: CPUID_SVM_LBRV */
1874 .features[FEAT_SVM] =
1875 CPUID_SVM_NPT,
1876 .xlevel = 0x8000001A,
1877 .model_id = "AMD Phenom(tm) 9550 Quad-Core Processor"
1880 .name = "core2duo",
1881 .level = 10,
1882 .vendor = CPUID_VENDOR_INTEL,
1883 .family = 6,
1884 .model = 15,
1885 .stepping = 11,
1886 /* Missing: CPUID_DTS, CPUID_HT, CPUID_TM, CPUID_PBE */
1887 .features[FEAT_1_EDX] =
1888 PPRO_FEATURES |
1889 CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA |
1890 CPUID_PSE36 | CPUID_VME | CPUID_ACPI | CPUID_SS,
1891 /* Missing: CPUID_EXT_DTES64, CPUID_EXT_DSCPL, CPUID_EXT_EST,
1892 * CPUID_EXT_TM2, CPUID_EXT_XTPR, CPUID_EXT_PDCM, CPUID_EXT_VMX */
1893 .features[FEAT_1_ECX] =
1894 CPUID_EXT_SSE3 | CPUID_EXT_MONITOR | CPUID_EXT_SSSE3 |
1895 CPUID_EXT_CX16,
1896 .features[FEAT_8000_0001_EDX] =
1897 CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX,
1898 .features[FEAT_8000_0001_ECX] =
1899 CPUID_EXT3_LAHF_LM,
1900 .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS,
1901 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE,
1902 .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT,
1903 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
1904 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
1905 VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS,
1906 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
1907 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
1908 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
1909 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
1910 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
1911 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
1912 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
1913 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
1914 VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
1915 VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
1916 .features[FEAT_VMX_SECONDARY_CTLS] =
1917 VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES,
1918 .xlevel = 0x80000008,
1919 .model_id = "Intel(R) Core(TM)2 Duo CPU T7700 @ 2.40GHz",
1922 .name = "kvm64",
1923 .level = 0xd,
1924 .vendor = CPUID_VENDOR_INTEL,
1925 .family = 15,
1926 .model = 6,
1927 .stepping = 1,
1928 /* Missing: CPUID_HT */
1929 .features[FEAT_1_EDX] =
1930 PPRO_FEATURES | CPUID_VME |
1931 CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA |
1932 CPUID_PSE36,
1933 /* Missing: CPUID_EXT_POPCNT, CPUID_EXT_MONITOR */
1934 .features[FEAT_1_ECX] =
1935 CPUID_EXT_SSE3 | CPUID_EXT_CX16,
1936 /* Missing: CPUID_EXT2_PDPE1GB, CPUID_EXT2_RDTSCP */
1937 .features[FEAT_8000_0001_EDX] =
1938 CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX,
1939 /* Missing: CPUID_EXT3_LAHF_LM, CPUID_EXT3_CMP_LEG, CPUID_EXT3_EXTAPIC,
1940 CPUID_EXT3_CR8LEG, CPUID_EXT3_ABM, CPUID_EXT3_SSE4A,
1941 CPUID_EXT3_MISALIGNSSE, CPUID_EXT3_3DNOWPREFETCH,
1942 CPUID_EXT3_OSVW, CPUID_EXT3_IBS, CPUID_EXT3_SVM */
1943 .features[FEAT_8000_0001_ECX] =
1945 /* VMX features from Cedar Mill/Prescott */
1946 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE,
1947 .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT,
1948 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
1949 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
1950 VMX_PIN_BASED_NMI_EXITING,
1951 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
1952 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
1953 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
1954 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
1955 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
1956 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
1957 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
1958 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING,
1959 .xlevel = 0x80000008,
1960 .model_id = "Common KVM processor"
1963 .name = "qemu32",
1964 .level = 4,
1965 .vendor = CPUID_VENDOR_INTEL,
1966 .family = 6,
1967 .model = 6,
1968 .stepping = 3,
1969 .features[FEAT_1_EDX] =
1970 PPRO_FEATURES,
1971 .features[FEAT_1_ECX] =
1972 CPUID_EXT_SSE3,
1973 .xlevel = 0x80000004,
1974 .model_id = "QEMU Virtual CPU version " QEMU_HW_VERSION,
1977 .name = "kvm32",
1978 .level = 5,
1979 .vendor = CPUID_VENDOR_INTEL,
1980 .family = 15,
1981 .model = 6,
1982 .stepping = 1,
1983 .features[FEAT_1_EDX] =
1984 PPRO_FEATURES | CPUID_VME |
1985 CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA | CPUID_PSE36,
1986 .features[FEAT_1_ECX] =
1987 CPUID_EXT_SSE3,
1988 .features[FEAT_8000_0001_ECX] =
1990 /* VMX features from Yonah */
1991 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE,
1992 .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT,
1993 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
1994 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
1995 VMX_PIN_BASED_NMI_EXITING,
1996 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
1997 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
1998 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
1999 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
2000 VMX_CPU_BASED_MOV_DR_EXITING | VMX_CPU_BASED_UNCOND_IO_EXITING |
2001 VMX_CPU_BASED_USE_IO_BITMAPS | VMX_CPU_BASED_MONITOR_EXITING |
2002 VMX_CPU_BASED_PAUSE_EXITING | VMX_CPU_BASED_USE_MSR_BITMAPS,
2003 .xlevel = 0x80000008,
2004 .model_id = "Common 32-bit KVM processor"
2007 .name = "coreduo",
2008 .level = 10,
2009 .vendor = CPUID_VENDOR_INTEL,
2010 .family = 6,
2011 .model = 14,
2012 .stepping = 8,
2013 /* Missing: CPUID_DTS, CPUID_HT, CPUID_TM, CPUID_PBE */
2014 .features[FEAT_1_EDX] =
2015 PPRO_FEATURES | CPUID_VME |
2016 CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA | CPUID_ACPI |
2017 CPUID_SS,
2018 /* Missing: CPUID_EXT_EST, CPUID_EXT_TM2 , CPUID_EXT_XTPR,
2019 * CPUID_EXT_PDCM, CPUID_EXT_VMX */
2020 .features[FEAT_1_ECX] =
2021 CPUID_EXT_SSE3 | CPUID_EXT_MONITOR,
2022 .features[FEAT_8000_0001_EDX] =
2023 CPUID_EXT2_NX,
2024 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE,
2025 .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT,
2026 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
2027 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
2028 VMX_PIN_BASED_NMI_EXITING,
2029 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
2030 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
2031 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
2032 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
2033 VMX_CPU_BASED_MOV_DR_EXITING | VMX_CPU_BASED_UNCOND_IO_EXITING |
2034 VMX_CPU_BASED_USE_IO_BITMAPS | VMX_CPU_BASED_MONITOR_EXITING |
2035 VMX_CPU_BASED_PAUSE_EXITING | VMX_CPU_BASED_USE_MSR_BITMAPS,
2036 .xlevel = 0x80000008,
2037 .model_id = "Genuine Intel(R) CPU T2600 @ 2.16GHz",
2040 .name = "486",
2041 .level = 1,
2042 .vendor = CPUID_VENDOR_INTEL,
2043 .family = 4,
2044 .model = 8,
2045 .stepping = 0,
2046 .features[FEAT_1_EDX] =
2047 I486_FEATURES,
2048 .xlevel = 0,
2049 .model_id = "",
2052 .name = "pentium",
2053 .level = 1,
2054 .vendor = CPUID_VENDOR_INTEL,
2055 .family = 5,
2056 .model = 4,
2057 .stepping = 3,
2058 .features[FEAT_1_EDX] =
2059 PENTIUM_FEATURES,
2060 .xlevel = 0,
2061 .model_id = "",
2064 .name = "pentium2",
2065 .level = 2,
2066 .vendor = CPUID_VENDOR_INTEL,
2067 .family = 6,
2068 .model = 5,
2069 .stepping = 2,
2070 .features[FEAT_1_EDX] =
2071 PENTIUM2_FEATURES,
2072 .xlevel = 0,
2073 .model_id = "",
2076 .name = "pentium3",
2077 .level = 3,
2078 .vendor = CPUID_VENDOR_INTEL,
2079 .family = 6,
2080 .model = 7,
2081 .stepping = 3,
2082 .features[FEAT_1_EDX] =
2083 PENTIUM3_FEATURES,
2084 .xlevel = 0,
2085 .model_id = "",
2088 .name = "athlon",
2089 .level = 2,
2090 .vendor = CPUID_VENDOR_AMD,
2091 .family = 6,
2092 .model = 2,
2093 .stepping = 3,
2094 .features[FEAT_1_EDX] =
2095 PPRO_FEATURES | CPUID_PSE36 | CPUID_VME | CPUID_MTRR |
2096 CPUID_MCA,
2097 .features[FEAT_8000_0001_EDX] =
2098 CPUID_EXT2_MMXEXT | CPUID_EXT2_3DNOW | CPUID_EXT2_3DNOWEXT,
2099 .xlevel = 0x80000008,
2100 .model_id = "QEMU Virtual CPU version " QEMU_HW_VERSION,
2103 .name = "n270",
2104 .level = 10,
2105 .vendor = CPUID_VENDOR_INTEL,
2106 .family = 6,
2107 .model = 28,
2108 .stepping = 2,
2109 /* Missing: CPUID_DTS, CPUID_HT, CPUID_TM, CPUID_PBE */
2110 .features[FEAT_1_EDX] =
2111 PPRO_FEATURES |
2112 CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA | CPUID_VME |
2113 CPUID_ACPI | CPUID_SS,
2114 /* Some CPUs got no CPUID_SEP */
2115 /* Missing: CPUID_EXT_DSCPL, CPUID_EXT_EST, CPUID_EXT_TM2,
2116 * CPUID_EXT_XTPR */
2117 .features[FEAT_1_ECX] =
2118 CPUID_EXT_SSE3 | CPUID_EXT_MONITOR | CPUID_EXT_SSSE3 |
2119 CPUID_EXT_MOVBE,
2120 .features[FEAT_8000_0001_EDX] =
2121 CPUID_EXT2_NX,
2122 .features[FEAT_8000_0001_ECX] =
2123 CPUID_EXT3_LAHF_LM,
2124 .xlevel = 0x80000008,
2125 .model_id = "Intel(R) Atom(TM) CPU N270 @ 1.60GHz",
2128 .name = "Conroe",
2129 .level = 10,
2130 .vendor = CPUID_VENDOR_INTEL,
2131 .family = 6,
2132 .model = 15,
2133 .stepping = 3,
2134 .features[FEAT_1_EDX] =
2135 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
2136 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
2137 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
2138 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
2139 CPUID_DE | CPUID_FP87,
2140 .features[FEAT_1_ECX] =
2141 CPUID_EXT_SSSE3 | CPUID_EXT_SSE3,
2142 .features[FEAT_8000_0001_EDX] =
2143 CPUID_EXT2_LM | CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
2144 .features[FEAT_8000_0001_ECX] =
2145 CPUID_EXT3_LAHF_LM,
2146 .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS,
2147 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE,
2148 .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT,
2149 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
2150 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
2151 VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS,
2152 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
2153 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
2154 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
2155 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
2156 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
2157 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
2158 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
2159 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
2160 VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
2161 VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
2162 .features[FEAT_VMX_SECONDARY_CTLS] =
2163 VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES,
2164 .xlevel = 0x80000008,
2165 .model_id = "Intel Celeron_4x0 (Conroe/Merom Class Core 2)",
2168 .name = "Penryn",
2169 .level = 10,
2170 .vendor = CPUID_VENDOR_INTEL,
2171 .family = 6,
2172 .model = 23,
2173 .stepping = 3,
2174 .features[FEAT_1_EDX] =
2175 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
2176 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
2177 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
2178 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
2179 CPUID_DE | CPUID_FP87,
2180 .features[FEAT_1_ECX] =
2181 CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
2182 CPUID_EXT_SSE3,
2183 .features[FEAT_8000_0001_EDX] =
2184 CPUID_EXT2_LM | CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
2185 .features[FEAT_8000_0001_ECX] =
2186 CPUID_EXT3_LAHF_LM,
2187 .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS,
2188 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
2189 VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL,
2190 .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT |
2191 VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL,
2192 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
2193 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
2194 VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS,
2195 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
2196 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
2197 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
2198 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
2199 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
2200 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
2201 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
2202 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
2203 VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
2204 VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
2205 .features[FEAT_VMX_SECONDARY_CTLS] =
2206 VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
2207 VMX_SECONDARY_EXEC_WBINVD_EXITING,
2208 .xlevel = 0x80000008,
2209 .model_id = "Intel Core 2 Duo P9xxx (Penryn Class Core 2)",
2212 .name = "Nehalem",
2213 .level = 11,
2214 .vendor = CPUID_VENDOR_INTEL,
2215 .family = 6,
2216 .model = 26,
2217 .stepping = 3,
2218 .features[FEAT_1_EDX] =
2219 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
2220 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
2221 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
2222 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
2223 CPUID_DE | CPUID_FP87,
2224 .features[FEAT_1_ECX] =
2225 CPUID_EXT_POPCNT | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
2226 CPUID_EXT_CX16 | CPUID_EXT_SSSE3 | CPUID_EXT_SSE3,
2227 .features[FEAT_8000_0001_EDX] =
2228 CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX,
2229 .features[FEAT_8000_0001_ECX] =
2230 CPUID_EXT3_LAHF_LM,
2231 .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
2232 MSR_VMX_BASIC_TRUE_CTLS,
2233 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
2234 VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
2235 VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
2236 .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
2237 MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
2238 MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
2239 MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
2240 MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
2241 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
2242 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
2243 .features[FEAT_VMX_EXIT_CTLS] =
2244 VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
2245 VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
2246 VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
2247 VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
2248 VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
2249 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
2250 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
2251 VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
2252 VMX_PIN_BASED_VMX_PREEMPTION_TIMER,
2253 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
2254 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
2255 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
2256 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
2257 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
2258 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
2259 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
2260 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
2261 VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
2262 VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
2263 VMX_CPU_BASED_MONITOR_TRAP_FLAG |
2264 VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
2265 .features[FEAT_VMX_SECONDARY_CTLS] =
2266 VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
2267 VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
2268 VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
2269 VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
2270 VMX_SECONDARY_EXEC_ENABLE_VPID,
2271 .xlevel = 0x80000008,
2272 .model_id = "Intel Core i7 9xx (Nehalem Class Core i7)",
2273 .versions = (X86CPUVersionDefinition[]) {
2274 { .version = 1 },
2276 .version = 2,
2277 .alias = "Nehalem-IBRS",
2278 .props = (PropValue[]) {
2279 { "spec-ctrl", "on" },
2280 { "model-id",
2281 "Intel Core i7 9xx (Nehalem Core i7, IBRS update)" },
2282 { /* end of list */ }
2285 { /* end of list */ }
2289 .name = "Westmere",
2290 .level = 11,
2291 .vendor = CPUID_VENDOR_INTEL,
2292 .family = 6,
2293 .model = 44,
2294 .stepping = 1,
2295 .features[FEAT_1_EDX] =
2296 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
2297 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
2298 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
2299 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
2300 CPUID_DE | CPUID_FP87,
2301 .features[FEAT_1_ECX] =
2302 CPUID_EXT_AES | CPUID_EXT_POPCNT | CPUID_EXT_SSE42 |
2303 CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
2304 CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3,
2305 .features[FEAT_8000_0001_EDX] =
2306 CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX,
2307 .features[FEAT_8000_0001_ECX] =
2308 CPUID_EXT3_LAHF_LM,
2309 .features[FEAT_6_EAX] =
2310 CPUID_6_EAX_ARAT,
2311 .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
2312 MSR_VMX_BASIC_TRUE_CTLS,
2313 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
2314 VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
2315 VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
2316 .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
2317 MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
2318 MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
2319 MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
2320 MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
2321 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
2322 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
2323 .features[FEAT_VMX_EXIT_CTLS] =
2324 VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
2325 VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
2326 VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
2327 VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
2328 VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
2329 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
2330 MSR_VMX_MISC_STORE_LMA,
2331 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
2332 VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
2333 VMX_PIN_BASED_VMX_PREEMPTION_TIMER,
2334 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
2335 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
2336 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
2337 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
2338 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
2339 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
2340 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
2341 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
2342 VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
2343 VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
2344 VMX_CPU_BASED_MONITOR_TRAP_FLAG |
2345 VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
2346 .features[FEAT_VMX_SECONDARY_CTLS] =
2347 VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
2348 VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
2349 VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
2350 VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
2351 VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST,
2352 .xlevel = 0x80000008,
2353 .model_id = "Westmere E56xx/L56xx/X56xx (Nehalem-C)",
2354 .versions = (X86CPUVersionDefinition[]) {
2355 { .version = 1 },
2357 .version = 2,
2358 .alias = "Westmere-IBRS",
2359 .props = (PropValue[]) {
2360 { "spec-ctrl", "on" },
2361 { "model-id",
2362 "Westmere E56xx/L56xx/X56xx (IBRS update)" },
2363 { /* end of list */ }
2366 { /* end of list */ }
2370 .name = "SandyBridge",
2371 .level = 0xd,
2372 .vendor = CPUID_VENDOR_INTEL,
2373 .family = 6,
2374 .model = 42,
2375 .stepping = 1,
2376 .features[FEAT_1_EDX] =
2377 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
2378 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
2379 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
2380 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
2381 CPUID_DE | CPUID_FP87,
2382 .features[FEAT_1_ECX] =
2383 CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
2384 CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_POPCNT |
2385 CPUID_EXT_X2APIC | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
2386 CPUID_EXT_CX16 | CPUID_EXT_SSSE3 | CPUID_EXT_PCLMULQDQ |
2387 CPUID_EXT_SSE3,
2388 .features[FEAT_8000_0001_EDX] =
2389 CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_NX |
2390 CPUID_EXT2_SYSCALL,
2391 .features[FEAT_8000_0001_ECX] =
2392 CPUID_EXT3_LAHF_LM,
2393 .features[FEAT_XSAVE] =
2394 CPUID_XSAVE_XSAVEOPT,
2395 .features[FEAT_6_EAX] =
2396 CPUID_6_EAX_ARAT,
2397 .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
2398 MSR_VMX_BASIC_TRUE_CTLS,
2399 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
2400 VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
2401 VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
2402 .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
2403 MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
2404 MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
2405 MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
2406 MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
2407 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
2408 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
2409 .features[FEAT_VMX_EXIT_CTLS] =
2410 VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
2411 VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
2412 VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
2413 VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
2414 VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
2415 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
2416 MSR_VMX_MISC_STORE_LMA,
2417 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
2418 VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
2419 VMX_PIN_BASED_VMX_PREEMPTION_TIMER,
2420 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
2421 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
2422 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
2423 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
2424 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
2425 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
2426 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
2427 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
2428 VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
2429 VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
2430 VMX_CPU_BASED_MONITOR_TRAP_FLAG |
2431 VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
2432 .features[FEAT_VMX_SECONDARY_CTLS] =
2433 VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
2434 VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
2435 VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
2436 VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
2437 VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST,
2438 .xlevel = 0x80000008,
2439 .model_id = "Intel Xeon E312xx (Sandy Bridge)",
2440 .versions = (X86CPUVersionDefinition[]) {
2441 { .version = 1 },
2443 .version = 2,
2444 .alias = "SandyBridge-IBRS",
2445 .props = (PropValue[]) {
2446 { "spec-ctrl", "on" },
2447 { "model-id",
2448 "Intel Xeon E312xx (Sandy Bridge, IBRS update)" },
2449 { /* end of list */ }
2452 { /* end of list */ }
2456 .name = "IvyBridge",
2457 .level = 0xd,
2458 .vendor = CPUID_VENDOR_INTEL,
2459 .family = 6,
2460 .model = 58,
2461 .stepping = 9,
2462 .features[FEAT_1_EDX] =
2463 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
2464 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
2465 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
2466 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
2467 CPUID_DE | CPUID_FP87,
2468 .features[FEAT_1_ECX] =
2469 CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
2470 CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_POPCNT |
2471 CPUID_EXT_X2APIC | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
2472 CPUID_EXT_CX16 | CPUID_EXT_SSSE3 | CPUID_EXT_PCLMULQDQ |
2473 CPUID_EXT_SSE3 | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
2474 .features[FEAT_7_0_EBX] =
2475 CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_SMEP |
2476 CPUID_7_0_EBX_ERMS,
2477 .features[FEAT_8000_0001_EDX] =
2478 CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_NX |
2479 CPUID_EXT2_SYSCALL,
2480 .features[FEAT_8000_0001_ECX] =
2481 CPUID_EXT3_LAHF_LM,
2482 .features[FEAT_XSAVE] =
2483 CPUID_XSAVE_XSAVEOPT,
2484 .features[FEAT_6_EAX] =
2485 CPUID_6_EAX_ARAT,
2486 .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
2487 MSR_VMX_BASIC_TRUE_CTLS,
2488 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
2489 VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
2490 VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
2491 .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
2492 MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
2493 MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
2494 MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
2495 MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
2496 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
2497 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
2498 .features[FEAT_VMX_EXIT_CTLS] =
2499 VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
2500 VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
2501 VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
2502 VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
2503 VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
2504 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
2505 MSR_VMX_MISC_STORE_LMA,
2506 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
2507 VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
2508 VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
2509 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
2510 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
2511 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
2512 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
2513 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
2514 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
2515 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
2516 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
2517 VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
2518 VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
2519 VMX_CPU_BASED_MONITOR_TRAP_FLAG |
2520 VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
2521 .features[FEAT_VMX_SECONDARY_CTLS] =
2522 VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
2523 VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
2524 VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
2525 VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
2526 VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
2527 VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
2528 VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
2529 VMX_SECONDARY_EXEC_RDRAND_EXITING,
2530 .xlevel = 0x80000008,
2531 .model_id = "Intel Xeon E3-12xx v2 (Ivy Bridge)",
2532 .versions = (X86CPUVersionDefinition[]) {
2533 { .version = 1 },
2535 .version = 2,
2536 .alias = "IvyBridge-IBRS",
2537 .props = (PropValue[]) {
2538 { "spec-ctrl", "on" },
2539 { "model-id",
2540 "Intel Xeon E3-12xx v2 (Ivy Bridge, IBRS)" },
2541 { /* end of list */ }
2544 { /* end of list */ }
2548 .name = "Haswell",
2549 .level = 0xd,
2550 .vendor = CPUID_VENDOR_INTEL,
2551 .family = 6,
2552 .model = 60,
2553 .stepping = 4,
2554 .features[FEAT_1_EDX] =
2555 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
2556 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
2557 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
2558 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
2559 CPUID_DE | CPUID_FP87,
2560 .features[FEAT_1_ECX] =
2561 CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
2562 CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
2563 CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
2564 CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
2565 CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
2566 CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
2567 .features[FEAT_8000_0001_EDX] =
2568 CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_NX |
2569 CPUID_EXT2_SYSCALL,
2570 .features[FEAT_8000_0001_ECX] =
2571 CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM,
2572 .features[FEAT_7_0_EBX] =
2573 CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
2574 CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
2575 CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
2576 CPUID_7_0_EBX_RTM,
2577 .features[FEAT_XSAVE] =
2578 CPUID_XSAVE_XSAVEOPT,
2579 .features[FEAT_6_EAX] =
2580 CPUID_6_EAX_ARAT,
2581 .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
2582 MSR_VMX_BASIC_TRUE_CTLS,
2583 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
2584 VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
2585 VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
2586 .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
2587 MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
2588 MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
2589 MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
2590 MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
2591 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
2592 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
2593 .features[FEAT_VMX_EXIT_CTLS] =
2594 VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
2595 VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
2596 VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
2597 VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
2598 VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
2599 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
2600 MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
2601 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
2602 VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
2603 VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
2604 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
2605 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
2606 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
2607 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
2608 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
2609 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
2610 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
2611 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
2612 VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
2613 VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
2614 VMX_CPU_BASED_MONITOR_TRAP_FLAG |
2615 VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
2616 .features[FEAT_VMX_SECONDARY_CTLS] =
2617 VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
2618 VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
2619 VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
2620 VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
2621 VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
2622 VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
2623 VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
2624 VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
2625 VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS,
2626 .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
2627 .xlevel = 0x80000008,
2628 .model_id = "Intel Core Processor (Haswell)",
2629 .versions = (X86CPUVersionDefinition[]) {
2630 { .version = 1 },
2632 .version = 2,
2633 .alias = "Haswell-noTSX",
2634 .props = (PropValue[]) {
2635 { "hle", "off" },
2636 { "rtm", "off" },
2637 { "stepping", "1" },
2638 { "model-id", "Intel Core Processor (Haswell, no TSX)", },
2639 { /* end of list */ }
2643 .version = 3,
2644 .alias = "Haswell-IBRS",
2645 .props = (PropValue[]) {
2646 /* Restore TSX features removed by -v2 above */
2647 { "hle", "on" },
2648 { "rtm", "on" },
2650 * Haswell and Haswell-IBRS had stepping=4 in
2651 * QEMU 4.0 and older
2653 { "stepping", "4" },
2654 { "spec-ctrl", "on" },
2655 { "model-id",
2656 "Intel Core Processor (Haswell, IBRS)" },
2657 { /* end of list */ }
2661 .version = 4,
2662 .alias = "Haswell-noTSX-IBRS",
2663 .props = (PropValue[]) {
2664 { "hle", "off" },
2665 { "rtm", "off" },
2666 /* spec-ctrl was already enabled by -v3 above */
2667 { "stepping", "1" },
2668 { "model-id",
2669 "Intel Core Processor (Haswell, no TSX, IBRS)" },
2670 { /* end of list */ }
2673 { /* end of list */ }
2677 .name = "Broadwell",
2678 .level = 0xd,
2679 .vendor = CPUID_VENDOR_INTEL,
2680 .family = 6,
2681 .model = 61,
2682 .stepping = 2,
2683 .features[FEAT_1_EDX] =
2684 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
2685 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
2686 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
2687 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
2688 CPUID_DE | CPUID_FP87,
2689 .features[FEAT_1_ECX] =
2690 CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
2691 CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
2692 CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
2693 CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
2694 CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
2695 CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
2696 .features[FEAT_8000_0001_EDX] =
2697 CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_NX |
2698 CPUID_EXT2_SYSCALL,
2699 .features[FEAT_8000_0001_ECX] =
2700 CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
2701 .features[FEAT_7_0_EBX] =
2702 CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
2703 CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
2704 CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
2705 CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
2706 CPUID_7_0_EBX_SMAP,
2707 .features[FEAT_XSAVE] =
2708 CPUID_XSAVE_XSAVEOPT,
2709 .features[FEAT_6_EAX] =
2710 CPUID_6_EAX_ARAT,
2711 .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
2712 MSR_VMX_BASIC_TRUE_CTLS,
2713 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
2714 VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
2715 VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
2716 .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
2717 MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
2718 MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
2719 MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
2720 MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
2721 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
2722 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
2723 .features[FEAT_VMX_EXIT_CTLS] =
2724 VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
2725 VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
2726 VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
2727 VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
2728 VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
2729 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
2730 MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
2731 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
2732 VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
2733 VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
2734 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
2735 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
2736 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
2737 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
2738 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
2739 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
2740 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
2741 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
2742 VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
2743 VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
2744 VMX_CPU_BASED_MONITOR_TRAP_FLAG |
2745 VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
2746 .features[FEAT_VMX_SECONDARY_CTLS] =
2747 VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
2748 VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
2749 VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
2750 VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
2751 VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
2752 VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
2753 VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
2754 VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
2755 VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
2756 VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
2757 .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
2758 .xlevel = 0x80000008,
2759 .model_id = "Intel Core Processor (Broadwell)",
2760 .versions = (X86CPUVersionDefinition[]) {
2761 { .version = 1 },
2763 .version = 2,
2764 .alias = "Broadwell-noTSX",
2765 .props = (PropValue[]) {
2766 { "hle", "off" },
2767 { "rtm", "off" },
2768 { "model-id", "Intel Core Processor (Broadwell, no TSX)", },
2769 { /* end of list */ }
2773 .version = 3,
2774 .alias = "Broadwell-IBRS",
2775 .props = (PropValue[]) {
2776 /* Restore TSX features removed by -v2 above */
2777 { "hle", "on" },
2778 { "rtm", "on" },
2779 { "spec-ctrl", "on" },
2780 { "model-id",
2781 "Intel Core Processor (Broadwell, IBRS)" },
2782 { /* end of list */ }
2786 .version = 4,
2787 .alias = "Broadwell-noTSX-IBRS",
2788 .props = (PropValue[]) {
2789 { "hle", "off" },
2790 { "rtm", "off" },
2791 /* spec-ctrl was already enabled by -v3 above */
2792 { "model-id",
2793 "Intel Core Processor (Broadwell, no TSX, IBRS)" },
2794 { /* end of list */ }
2797 { /* end of list */ }
2801 .name = "Skylake-Client",
2802 .level = 0xd,
2803 .vendor = CPUID_VENDOR_INTEL,
2804 .family = 6,
2805 .model = 94,
2806 .stepping = 3,
2807 .features[FEAT_1_EDX] =
2808 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
2809 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
2810 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
2811 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
2812 CPUID_DE | CPUID_FP87,
2813 .features[FEAT_1_ECX] =
2814 CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
2815 CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
2816 CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
2817 CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
2818 CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
2819 CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
2820 .features[FEAT_8000_0001_EDX] =
2821 CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_NX |
2822 CPUID_EXT2_SYSCALL,
2823 .features[FEAT_8000_0001_ECX] =
2824 CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
2825 .features[FEAT_7_0_EBX] =
2826 CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
2827 CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
2828 CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
2829 CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
2830 CPUID_7_0_EBX_SMAP,
2831 /* Missing: XSAVES (not supported by some Linux versions,
2832 * including v4.1 to v4.12).
2833 * KVM doesn't yet expose any XSAVES state save component,
2834 * and the only one defined in Skylake (processor tracing)
2835 * probably will block migration anyway.
2837 .features[FEAT_XSAVE] =
2838 CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
2839 CPUID_XSAVE_XGETBV1,
2840 .features[FEAT_6_EAX] =
2841 CPUID_6_EAX_ARAT,
2842 /* Missing: Mode-based execute control (XS/XU), processor tracing, TSC scaling */
2843 .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
2844 MSR_VMX_BASIC_TRUE_CTLS,
2845 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
2846 VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
2847 VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
2848 .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
2849 MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
2850 MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
2851 MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
2852 MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
2853 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
2854 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
2855 .features[FEAT_VMX_EXIT_CTLS] =
2856 VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
2857 VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
2858 VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
2859 VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
2860 VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
2861 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
2862 MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
2863 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
2864 VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
2865 VMX_PIN_BASED_VMX_PREEMPTION_TIMER,
2866 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
2867 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
2868 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
2869 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
2870 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
2871 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
2872 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
2873 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
2874 VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
2875 VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
2876 VMX_CPU_BASED_MONITOR_TRAP_FLAG |
2877 VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
2878 .features[FEAT_VMX_SECONDARY_CTLS] =
2879 VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
2880 VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
2881 VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
2882 VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
2883 VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
2884 VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
2885 VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
2886 .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
2887 .xlevel = 0x80000008,
2888 .model_id = "Intel Core Processor (Skylake)",
2889 .versions = (X86CPUVersionDefinition[]) {
2890 { .version = 1 },
2892 .version = 2,
2893 .alias = "Skylake-Client-IBRS",
2894 .props = (PropValue[]) {
2895 { "spec-ctrl", "on" },
2896 { "model-id",
2897 "Intel Core Processor (Skylake, IBRS)" },
2898 { /* end of list */ }
2902 .version = 3,
2903 .alias = "Skylake-Client-noTSX-IBRS",
2904 .props = (PropValue[]) {
2905 { "hle", "off" },
2906 { "rtm", "off" },
2907 { "model-id",
2908 "Intel Core Processor (Skylake, IBRS, no TSX)" },
2909 { /* end of list */ }
2912 { /* end of list */ }
2916 .name = "Skylake-Server",
2917 .level = 0xd,
2918 .vendor = CPUID_VENDOR_INTEL,
2919 .family = 6,
2920 .model = 85,
2921 .stepping = 4,
2922 .features[FEAT_1_EDX] =
2923 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
2924 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
2925 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
2926 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
2927 CPUID_DE | CPUID_FP87,
2928 .features[FEAT_1_ECX] =
2929 CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
2930 CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
2931 CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
2932 CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
2933 CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
2934 CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
2935 .features[FEAT_8000_0001_EDX] =
2936 CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
2937 CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
2938 .features[FEAT_8000_0001_ECX] =
2939 CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
2940 .features[FEAT_7_0_EBX] =
2941 CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
2942 CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
2943 CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
2944 CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
2945 CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLWB |
2946 CPUID_7_0_EBX_AVX512F | CPUID_7_0_EBX_AVX512DQ |
2947 CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512CD |
2948 CPUID_7_0_EBX_AVX512VL | CPUID_7_0_EBX_CLFLUSHOPT,
2949 .features[FEAT_7_0_ECX] =
2950 CPUID_7_0_ECX_PKU,
2951 /* Missing: XSAVES (not supported by some Linux versions,
2952 * including v4.1 to v4.12).
2953 * KVM doesn't yet expose any XSAVES state save component,
2954 * and the only one defined in Skylake (processor tracing)
2955 * probably will block migration anyway.
2957 .features[FEAT_XSAVE] =
2958 CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
2959 CPUID_XSAVE_XGETBV1,
2960 .features[FEAT_6_EAX] =
2961 CPUID_6_EAX_ARAT,
2962 /* Missing: Mode-based execute control (XS/XU), processor tracing, TSC scaling */
2963 .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
2964 MSR_VMX_BASIC_TRUE_CTLS,
2965 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
2966 VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
2967 VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
2968 .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
2969 MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
2970 MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
2971 MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
2972 MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
2973 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
2974 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
2975 .features[FEAT_VMX_EXIT_CTLS] =
2976 VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
2977 VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
2978 VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
2979 VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
2980 VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
2981 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
2982 MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
2983 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
2984 VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
2985 VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
2986 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
2987 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
2988 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
2989 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
2990 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
2991 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
2992 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
2993 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
2994 VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
2995 VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
2996 VMX_CPU_BASED_MONITOR_TRAP_FLAG |
2997 VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
2998 .features[FEAT_VMX_SECONDARY_CTLS] =
2999 VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
3000 VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
3001 VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
3002 VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
3003 VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
3004 VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
3005 VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
3006 VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
3007 VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
3008 VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
3009 .xlevel = 0x80000008,
3010 .model_id = "Intel Xeon Processor (Skylake)",
3011 .versions = (X86CPUVersionDefinition[]) {
3012 { .version = 1 },
3014 .version = 2,
3015 .alias = "Skylake-Server-IBRS",
3016 .props = (PropValue[]) {
3017 /* clflushopt was not added to Skylake-Server-IBRS */
3018 /* TODO: add -v3 including clflushopt */
3019 { "clflushopt", "off" },
3020 { "spec-ctrl", "on" },
3021 { "model-id",
3022 "Intel Xeon Processor (Skylake, IBRS)" },
3023 { /* end of list */ }
3027 .version = 3,
3028 .alias = "Skylake-Server-noTSX-IBRS",
3029 .props = (PropValue[]) {
3030 { "hle", "off" },
3031 { "rtm", "off" },
3032 { "model-id",
3033 "Intel Xeon Processor (Skylake, IBRS, no TSX)" },
3034 { /* end of list */ }
3038 .version = 4,
3039 .props = (PropValue[]) {
3040 { "vmx-eptp-switching", "on" },
3041 { /* end of list */ }
3044 { /* end of list */ }
3048 .name = "Cascadelake-Server",
3049 .level = 0xd,
3050 .vendor = CPUID_VENDOR_INTEL,
3051 .family = 6,
3052 .model = 85,
3053 .stepping = 6,
3054 .features[FEAT_1_EDX] =
3055 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
3056 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
3057 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
3058 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
3059 CPUID_DE | CPUID_FP87,
3060 .features[FEAT_1_ECX] =
3061 CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
3062 CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
3063 CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
3064 CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
3065 CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
3066 CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
3067 .features[FEAT_8000_0001_EDX] =
3068 CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
3069 CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
3070 .features[FEAT_8000_0001_ECX] =
3071 CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
3072 .features[FEAT_7_0_EBX] =
3073 CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
3074 CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
3075 CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
3076 CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
3077 CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLWB |
3078 CPUID_7_0_EBX_AVX512F | CPUID_7_0_EBX_AVX512DQ |
3079 CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512CD |
3080 CPUID_7_0_EBX_AVX512VL | CPUID_7_0_EBX_CLFLUSHOPT,
3081 .features[FEAT_7_0_ECX] =
3082 CPUID_7_0_ECX_PKU |
3083 CPUID_7_0_ECX_AVX512VNNI,
3084 .features[FEAT_7_0_EDX] =
3085 CPUID_7_0_EDX_SPEC_CTRL | CPUID_7_0_EDX_SPEC_CTRL_SSBD,
3086 /* Missing: XSAVES (not supported by some Linux versions,
3087 * including v4.1 to v4.12).
3088 * KVM doesn't yet expose any XSAVES state save component,
3089 * and the only one defined in Skylake (processor tracing)
3090 * probably will block migration anyway.
3092 .features[FEAT_XSAVE] =
3093 CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
3094 CPUID_XSAVE_XGETBV1,
3095 .features[FEAT_6_EAX] =
3096 CPUID_6_EAX_ARAT,
3097 /* Missing: Mode-based execute control (XS/XU), processor tracing, TSC scaling */
3098 .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
3099 MSR_VMX_BASIC_TRUE_CTLS,
3100 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
3101 VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
3102 VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
3103 .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
3104 MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
3105 MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
3106 MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
3107 MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
3108 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
3109 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
3110 .features[FEAT_VMX_EXIT_CTLS] =
3111 VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
3112 VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
3113 VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
3114 VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
3115 VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
3116 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
3117 MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
3118 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
3119 VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
3120 VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
3121 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
3122 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
3123 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
3124 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
3125 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
3126 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
3127 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
3128 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
3129 VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
3130 VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
3131 VMX_CPU_BASED_MONITOR_TRAP_FLAG |
3132 VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
3133 .features[FEAT_VMX_SECONDARY_CTLS] =
3134 VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
3135 VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
3136 VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
3137 VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
3138 VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
3139 VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
3140 VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
3141 VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
3142 VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
3143 VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
3144 .xlevel = 0x80000008,
3145 .model_id = "Intel Xeon Processor (Cascadelake)",
3146 .versions = (X86CPUVersionDefinition[]) {
3147 { .version = 1 },
3148 { .version = 2,
3149 .note = "ARCH_CAPABILITIES",
3150 .props = (PropValue[]) {
3151 { "arch-capabilities", "on" },
3152 { "rdctl-no", "on" },
3153 { "ibrs-all", "on" },
3154 { "skip-l1dfl-vmentry", "on" },
3155 { "mds-no", "on" },
3156 { /* end of list */ }
3159 { .version = 3,
3160 .alias = "Cascadelake-Server-noTSX",
3161 .note = "ARCH_CAPABILITIES, no TSX",
3162 .props = (PropValue[]) {
3163 { "hle", "off" },
3164 { "rtm", "off" },
3165 { /* end of list */ }
3168 { .version = 4,
3169 .note = "ARCH_CAPABILITIES, no TSX",
3170 .props = (PropValue[]) {
3171 { "vmx-eptp-switching", "on" },
3172 { /* end of list */ }
3175 { /* end of list */ }
3179 .name = "Cooperlake",
3180 .level = 0xd,
3181 .vendor = CPUID_VENDOR_INTEL,
3182 .family = 6,
3183 .model = 85,
3184 .stepping = 10,
3185 .features[FEAT_1_EDX] =
3186 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
3187 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
3188 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
3189 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
3190 CPUID_DE | CPUID_FP87,
3191 .features[FEAT_1_ECX] =
3192 CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
3193 CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
3194 CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
3195 CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
3196 CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
3197 CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
3198 .features[FEAT_8000_0001_EDX] =
3199 CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
3200 CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
3201 .features[FEAT_8000_0001_ECX] =
3202 CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
3203 .features[FEAT_7_0_EBX] =
3204 CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
3205 CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
3206 CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
3207 CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
3208 CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLWB |
3209 CPUID_7_0_EBX_AVX512F | CPUID_7_0_EBX_AVX512DQ |
3210 CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512CD |
3211 CPUID_7_0_EBX_AVX512VL | CPUID_7_0_EBX_CLFLUSHOPT,
3212 .features[FEAT_7_0_ECX] =
3213 CPUID_7_0_ECX_PKU |
3214 CPUID_7_0_ECX_AVX512VNNI,
3215 .features[FEAT_7_0_EDX] =
3216 CPUID_7_0_EDX_SPEC_CTRL | CPUID_7_0_EDX_STIBP |
3217 CPUID_7_0_EDX_SPEC_CTRL_SSBD | CPUID_7_0_EDX_ARCH_CAPABILITIES,
3218 .features[FEAT_ARCH_CAPABILITIES] =
3219 MSR_ARCH_CAP_RDCL_NO | MSR_ARCH_CAP_IBRS_ALL |
3220 MSR_ARCH_CAP_SKIP_L1DFL_VMENTRY | MSR_ARCH_CAP_MDS_NO |
3221 MSR_ARCH_CAP_PSCHANGE_MC_NO | MSR_ARCH_CAP_TAA_NO,
3222 .features[FEAT_7_1_EAX] =
3223 CPUID_7_1_EAX_AVX512_BF16,
3225 * Missing: XSAVES (not supported by some Linux versions,
3226 * including v4.1 to v4.12).
3227 * KVM doesn't yet expose any XSAVES state save component,
3228 * and the only one defined in Skylake (processor tracing)
3229 * probably will block migration anyway.
3231 .features[FEAT_XSAVE] =
3232 CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
3233 CPUID_XSAVE_XGETBV1,
3234 .features[FEAT_6_EAX] =
3235 CPUID_6_EAX_ARAT,
3236 /* Missing: Mode-based execute control (XS/XU), processor tracing, TSC scaling */
3237 .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
3238 MSR_VMX_BASIC_TRUE_CTLS,
3239 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
3240 VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
3241 VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
3242 .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
3243 MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
3244 MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
3245 MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
3246 MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
3247 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
3248 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
3249 .features[FEAT_VMX_EXIT_CTLS] =
3250 VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
3251 VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
3252 VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
3253 VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
3254 VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
3255 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
3256 MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
3257 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
3258 VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
3259 VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
3260 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
3261 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
3262 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
3263 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
3264 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
3265 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
3266 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
3267 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
3268 VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
3269 VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
3270 VMX_CPU_BASED_MONITOR_TRAP_FLAG |
3271 VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
3272 .features[FEAT_VMX_SECONDARY_CTLS] =
3273 VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
3274 VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
3275 VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
3276 VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
3277 VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
3278 VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
3279 VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
3280 VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
3281 VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
3282 VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
3283 .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
3284 .xlevel = 0x80000008,
3285 .model_id = "Intel Xeon Processor (Cooperlake)",
3288 .name = "Icelake-Client",
3289 .level = 0xd,
3290 .vendor = CPUID_VENDOR_INTEL,
3291 .family = 6,
3292 .model = 126,
3293 .stepping = 0,
3294 .features[FEAT_1_EDX] =
3295 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
3296 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
3297 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
3298 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
3299 CPUID_DE | CPUID_FP87,
3300 .features[FEAT_1_ECX] =
3301 CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
3302 CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
3303 CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
3304 CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
3305 CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
3306 CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
3307 .features[FEAT_8000_0001_EDX] =
3308 CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_NX |
3309 CPUID_EXT2_SYSCALL,
3310 .features[FEAT_8000_0001_ECX] =
3311 CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
3312 .features[FEAT_8000_0008_EBX] =
3313 CPUID_8000_0008_EBX_WBNOINVD,
3314 .features[FEAT_7_0_EBX] =
3315 CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
3316 CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
3317 CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
3318 CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
3319 CPUID_7_0_EBX_SMAP,
3320 .features[FEAT_7_0_ECX] =
3321 CPUID_7_0_ECX_AVX512_VBMI | CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_PKU |
3322 CPUID_7_0_ECX_AVX512_VBMI2 | CPUID_7_0_ECX_GFNI |
3323 CPUID_7_0_ECX_VAES | CPUID_7_0_ECX_VPCLMULQDQ |
3324 CPUID_7_0_ECX_AVX512VNNI | CPUID_7_0_ECX_AVX512BITALG |
3325 CPUID_7_0_ECX_AVX512_VPOPCNTDQ,
3326 .features[FEAT_7_0_EDX] =
3327 CPUID_7_0_EDX_SPEC_CTRL | CPUID_7_0_EDX_SPEC_CTRL_SSBD,
3328 /* Missing: XSAVES (not supported by some Linux versions,
3329 * including v4.1 to v4.12).
3330 * KVM doesn't yet expose any XSAVES state save component,
3331 * and the only one defined in Skylake (processor tracing)
3332 * probably will block migration anyway.
3334 .features[FEAT_XSAVE] =
3335 CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
3336 CPUID_XSAVE_XGETBV1,
3337 .features[FEAT_6_EAX] =
3338 CPUID_6_EAX_ARAT,
3339 /* Missing: Mode-based execute control (XS/XU), processor tracing, TSC scaling */
3340 .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
3341 MSR_VMX_BASIC_TRUE_CTLS,
3342 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
3343 VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
3344 VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
3345 .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
3346 MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
3347 MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
3348 MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
3349 MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
3350 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
3351 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
3352 .features[FEAT_VMX_EXIT_CTLS] =
3353 VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
3354 VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
3355 VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
3356 VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
3357 VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
3358 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
3359 MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
3360 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
3361 VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
3362 VMX_PIN_BASED_VMX_PREEMPTION_TIMER,
3363 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
3364 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
3365 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
3366 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
3367 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
3368 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
3369 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
3370 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
3371 VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
3372 VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
3373 VMX_CPU_BASED_MONITOR_TRAP_FLAG |
3374 VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
3375 .features[FEAT_VMX_SECONDARY_CTLS] =
3376 VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
3377 VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
3378 VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
3379 VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
3380 VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
3381 VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
3382 VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
3383 .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
3384 .xlevel = 0x80000008,
3385 .model_id = "Intel Core Processor (Icelake)",
3386 .versions = (X86CPUVersionDefinition[]) {
3387 { .version = 1 },
3389 .version = 2,
3390 .note = "no TSX",
3391 .alias = "Icelake-Client-noTSX",
3392 .props = (PropValue[]) {
3393 { "hle", "off" },
3394 { "rtm", "off" },
3395 { /* end of list */ }
3398 { /* end of list */ }
3402 .name = "Icelake-Server",
3403 .level = 0xd,
3404 .vendor = CPUID_VENDOR_INTEL,
3405 .family = 6,
3406 .model = 134,
3407 .stepping = 0,
3408 .features[FEAT_1_EDX] =
3409 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
3410 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
3411 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
3412 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
3413 CPUID_DE | CPUID_FP87,
3414 .features[FEAT_1_ECX] =
3415 CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
3416 CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
3417 CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
3418 CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
3419 CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
3420 CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
3421 .features[FEAT_8000_0001_EDX] =
3422 CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
3423 CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
3424 .features[FEAT_8000_0001_ECX] =
3425 CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
3426 .features[FEAT_8000_0008_EBX] =
3427 CPUID_8000_0008_EBX_WBNOINVD,
3428 .features[FEAT_7_0_EBX] =
3429 CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
3430 CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
3431 CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
3432 CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
3433 CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLWB |
3434 CPUID_7_0_EBX_AVX512F | CPUID_7_0_EBX_AVX512DQ |
3435 CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512CD |
3436 CPUID_7_0_EBX_AVX512VL | CPUID_7_0_EBX_CLFLUSHOPT,
3437 .features[FEAT_7_0_ECX] =
3438 CPUID_7_0_ECX_AVX512_VBMI | CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_PKU |
3439 CPUID_7_0_ECX_AVX512_VBMI2 | CPUID_7_0_ECX_GFNI |
3440 CPUID_7_0_ECX_VAES | CPUID_7_0_ECX_VPCLMULQDQ |
3441 CPUID_7_0_ECX_AVX512VNNI | CPUID_7_0_ECX_AVX512BITALG |
3442 CPUID_7_0_ECX_AVX512_VPOPCNTDQ | CPUID_7_0_ECX_LA57,
3443 .features[FEAT_7_0_EDX] =
3444 CPUID_7_0_EDX_SPEC_CTRL | CPUID_7_0_EDX_SPEC_CTRL_SSBD,
3445 /* Missing: XSAVES (not supported by some Linux versions,
3446 * including v4.1 to v4.12).
3447 * KVM doesn't yet expose any XSAVES state save component,
3448 * and the only one defined in Skylake (processor tracing)
3449 * probably will block migration anyway.
3451 .features[FEAT_XSAVE] =
3452 CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
3453 CPUID_XSAVE_XGETBV1,
3454 .features[FEAT_6_EAX] =
3455 CPUID_6_EAX_ARAT,
3456 /* Missing: Mode-based execute control (XS/XU), processor tracing, TSC scaling */
3457 .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
3458 MSR_VMX_BASIC_TRUE_CTLS,
3459 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
3460 VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
3461 VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
3462 .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
3463 MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
3464 MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
3465 MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
3466 MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
3467 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
3468 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
3469 .features[FEAT_VMX_EXIT_CTLS] =
3470 VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
3471 VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
3472 VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
3473 VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
3474 VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
3475 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
3476 MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
3477 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
3478 VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
3479 VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
3480 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
3481 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
3482 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
3483 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
3484 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
3485 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
3486 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
3487 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
3488 VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
3489 VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
3490 VMX_CPU_BASED_MONITOR_TRAP_FLAG |
3491 VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
3492 .features[FEAT_VMX_SECONDARY_CTLS] =
3493 VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
3494 VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
3495 VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
3496 VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
3497 VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
3498 VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
3499 VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
3500 VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
3501 VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS,
3502 .xlevel = 0x80000008,
3503 .model_id = "Intel Xeon Processor (Icelake)",
3504 .versions = (X86CPUVersionDefinition[]) {
3505 { .version = 1 },
3507 .version = 2,
3508 .note = "no TSX",
3509 .alias = "Icelake-Server-noTSX",
3510 .props = (PropValue[]) {
3511 { "hle", "off" },
3512 { "rtm", "off" },
3513 { /* end of list */ }
3517 .version = 3,
3518 .props = (PropValue[]) {
3519 { "arch-capabilities", "on" },
3520 { "rdctl-no", "on" },
3521 { "ibrs-all", "on" },
3522 { "skip-l1dfl-vmentry", "on" },
3523 { "mds-no", "on" },
3524 { "pschange-mc-no", "on" },
3525 { "taa-no", "on" },
3526 { /* end of list */ }
3530 .version = 4,
3531 .props = (PropValue[]) {
3532 { "sha-ni", "on" },
3533 { "avx512ifma", "on" },
3534 { "rdpid", "on" },
3535 { "fsrm", "on" },
3536 { "vmx-rdseed-exit", "on" },
3537 { "vmx-pml", "on" },
3538 { "vmx-eptp-switching", "on" },
3539 { "model", "106" },
3540 { /* end of list */ }
3543 { /* end of list */ }
3547 .name = "Denverton",
3548 .level = 21,
3549 .vendor = CPUID_VENDOR_INTEL,
3550 .family = 6,
3551 .model = 95,
3552 .stepping = 1,
3553 .features[FEAT_1_EDX] =
3554 CPUID_FP87 | CPUID_VME | CPUID_DE | CPUID_PSE | CPUID_TSC |
3555 CPUID_MSR | CPUID_PAE | CPUID_MCE | CPUID_CX8 | CPUID_APIC |
3556 CPUID_SEP | CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV |
3557 CPUID_PAT | CPUID_PSE36 | CPUID_CLFLUSH | CPUID_MMX | CPUID_FXSR |
3558 CPUID_SSE | CPUID_SSE2,
3559 .features[FEAT_1_ECX] =
3560 CPUID_EXT_SSE3 | CPUID_EXT_PCLMULQDQ | CPUID_EXT_MONITOR |
3561 CPUID_EXT_SSSE3 | CPUID_EXT_CX16 | CPUID_EXT_SSE41 |
3562 CPUID_EXT_SSE42 | CPUID_EXT_X2APIC | CPUID_EXT_MOVBE |
3563 CPUID_EXT_POPCNT | CPUID_EXT_TSC_DEADLINE_TIMER |
3564 CPUID_EXT_AES | CPUID_EXT_XSAVE | CPUID_EXT_RDRAND,
3565 .features[FEAT_8000_0001_EDX] =
3566 CPUID_EXT2_SYSCALL | CPUID_EXT2_NX | CPUID_EXT2_PDPE1GB |
3567 CPUID_EXT2_RDTSCP | CPUID_EXT2_LM,
3568 .features[FEAT_8000_0001_ECX] =
3569 CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
3570 .features[FEAT_7_0_EBX] =
3571 CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_ERMS |
3572 CPUID_7_0_EBX_MPX | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_SMAP |
3573 CPUID_7_0_EBX_CLFLUSHOPT | CPUID_7_0_EBX_SHA_NI,
3574 .features[FEAT_7_0_EDX] =
3575 CPUID_7_0_EDX_SPEC_CTRL | CPUID_7_0_EDX_ARCH_CAPABILITIES |
3576 CPUID_7_0_EDX_SPEC_CTRL_SSBD,
3578 * Missing: XSAVES (not supported by some Linux versions,
3579 * including v4.1 to v4.12).
3580 * KVM doesn't yet expose any XSAVES state save component,
3581 * and the only one defined in Skylake (processor tracing)
3582 * probably will block migration anyway.
3584 .features[FEAT_XSAVE] =
3585 CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC | CPUID_XSAVE_XGETBV1,
3586 .features[FEAT_6_EAX] =
3587 CPUID_6_EAX_ARAT,
3588 .features[FEAT_ARCH_CAPABILITIES] =
3589 MSR_ARCH_CAP_RDCL_NO | MSR_ARCH_CAP_SKIP_L1DFL_VMENTRY,
3590 .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
3591 MSR_VMX_BASIC_TRUE_CTLS,
3592 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
3593 VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
3594 VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
3595 .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
3596 MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
3597 MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
3598 MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
3599 MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
3600 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
3601 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
3602 .features[FEAT_VMX_EXIT_CTLS] =
3603 VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
3604 VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
3605 VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
3606 VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
3607 VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
3608 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
3609 MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
3610 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
3611 VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
3612 VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
3613 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
3614 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
3615 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
3616 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
3617 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
3618 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
3619 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
3620 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
3621 VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
3622 VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
3623 VMX_CPU_BASED_MONITOR_TRAP_FLAG |
3624 VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
3625 .features[FEAT_VMX_SECONDARY_CTLS] =
3626 VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
3627 VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
3628 VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
3629 VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
3630 VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
3631 VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
3632 VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
3633 VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
3634 VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
3635 VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
3636 .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
3637 .xlevel = 0x80000008,
3638 .model_id = "Intel Atom Processor (Denverton)",
3639 .versions = (X86CPUVersionDefinition[]) {
3640 { .version = 1 },
3642 .version = 2,
3643 .note = "no MPX, no MONITOR",
3644 .props = (PropValue[]) {
3645 { "monitor", "off" },
3646 { "mpx", "off" },
3647 { /* end of list */ },
3650 { /* end of list */ },
3654 .name = "Snowridge",
3655 .level = 27,
3656 .vendor = CPUID_VENDOR_INTEL,
3657 .family = 6,
3658 .model = 134,
3659 .stepping = 1,
3660 .features[FEAT_1_EDX] =
3661 /* missing: CPUID_PN CPUID_IA64 */
3662 /* missing: CPUID_DTS, CPUID_HT, CPUID_TM, CPUID_PBE */
3663 CPUID_FP87 | CPUID_VME | CPUID_DE | CPUID_PSE |
3664 CPUID_TSC | CPUID_MSR | CPUID_PAE | CPUID_MCE |
3665 CPUID_CX8 | CPUID_APIC | CPUID_SEP |
3666 CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV |
3667 CPUID_PAT | CPUID_PSE36 | CPUID_CLFLUSH |
3668 CPUID_MMX |
3669 CPUID_FXSR | CPUID_SSE | CPUID_SSE2,
3670 .features[FEAT_1_ECX] =
3671 CPUID_EXT_SSE3 | CPUID_EXT_PCLMULQDQ | CPUID_EXT_MONITOR |
3672 CPUID_EXT_SSSE3 |
3673 CPUID_EXT_CX16 |
3674 CPUID_EXT_SSE41 |
3675 CPUID_EXT_SSE42 | CPUID_EXT_X2APIC | CPUID_EXT_MOVBE |
3676 CPUID_EXT_POPCNT |
3677 CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_AES | CPUID_EXT_XSAVE |
3678 CPUID_EXT_RDRAND,
3679 .features[FEAT_8000_0001_EDX] =
3680 CPUID_EXT2_SYSCALL |
3681 CPUID_EXT2_NX |
3682 CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
3683 CPUID_EXT2_LM,
3684 .features[FEAT_8000_0001_ECX] =
3685 CPUID_EXT3_LAHF_LM |
3686 CPUID_EXT3_3DNOWPREFETCH,
3687 .features[FEAT_7_0_EBX] =
3688 CPUID_7_0_EBX_FSGSBASE |
3689 CPUID_7_0_EBX_SMEP |
3690 CPUID_7_0_EBX_ERMS |
3691 CPUID_7_0_EBX_MPX | /* missing bits 13, 15 */
3692 CPUID_7_0_EBX_RDSEED |
3693 CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLFLUSHOPT |
3694 CPUID_7_0_EBX_CLWB |
3695 CPUID_7_0_EBX_SHA_NI,
3696 .features[FEAT_7_0_ECX] =
3697 CPUID_7_0_ECX_UMIP |
3698 /* missing bit 5 */
3699 CPUID_7_0_ECX_GFNI |
3700 CPUID_7_0_ECX_MOVDIRI | CPUID_7_0_ECX_CLDEMOTE |
3701 CPUID_7_0_ECX_MOVDIR64B,
3702 .features[FEAT_7_0_EDX] =
3703 CPUID_7_0_EDX_SPEC_CTRL |
3704 CPUID_7_0_EDX_ARCH_CAPABILITIES | CPUID_7_0_EDX_SPEC_CTRL_SSBD |
3705 CPUID_7_0_EDX_CORE_CAPABILITY,
3706 .features[FEAT_CORE_CAPABILITY] =
3707 MSR_CORE_CAP_SPLIT_LOCK_DETECT,
3709 * Missing: XSAVES (not supported by some Linux versions,
3710 * including v4.1 to v4.12).
3711 * KVM doesn't yet expose any XSAVES state save component,
3712 * and the only one defined in Skylake (processor tracing)
3713 * probably will block migration anyway.
3715 .features[FEAT_XSAVE] =
3716 CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
3717 CPUID_XSAVE_XGETBV1,
3718 .features[FEAT_6_EAX] =
3719 CPUID_6_EAX_ARAT,
3720 .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
3721 MSR_VMX_BASIC_TRUE_CTLS,
3722 .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
3723 VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
3724 VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
3725 .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
3726 MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
3727 MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
3728 MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
3729 MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
3730 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
3731 MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
3732 .features[FEAT_VMX_EXIT_CTLS] =
3733 VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
3734 VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
3735 VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
3736 VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
3737 VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
3738 .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
3739 MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
3740 .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
3741 VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
3742 VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
3743 .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
3744 VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
3745 VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
3746 VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
3747 VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
3748 VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
3749 VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
3750 VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
3751 VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
3752 VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
3753 VMX_CPU_BASED_MONITOR_TRAP_FLAG |
3754 VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
3755 .features[FEAT_VMX_SECONDARY_CTLS] =
3756 VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
3757 VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
3758 VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
3759 VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
3760 VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
3761 VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
3762 VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
3763 VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
3764 VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
3765 VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
3766 .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
3767 .xlevel = 0x80000008,
3768 .model_id = "Intel Atom Processor (SnowRidge)",
3769 .versions = (X86CPUVersionDefinition[]) {
3770 { .version = 1 },
3772 .version = 2,
3773 .props = (PropValue[]) {
3774 { "mpx", "off" },
3775 { "model-id", "Intel Atom Processor (Snowridge, no MPX)" },
3776 { /* end of list */ },
3779 { /* end of list */ },
3783 .name = "KnightsMill",
3784 .level = 0xd,
3785 .vendor = CPUID_VENDOR_INTEL,
3786 .family = 6,
3787 .model = 133,
3788 .stepping = 0,
3789 .features[FEAT_1_EDX] =
3790 CPUID_VME | CPUID_SS | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR |
3791 CPUID_MMX | CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV |
3792 CPUID_MCA | CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC |
3793 CPUID_CX8 | CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC |
3794 CPUID_PSE | CPUID_DE | CPUID_FP87,
3795 .features[FEAT_1_ECX] =
3796 CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
3797 CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
3798 CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
3799 CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
3800 CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
3801 CPUID_EXT_F16C | CPUID_EXT_RDRAND,
3802 .features[FEAT_8000_0001_EDX] =
3803 CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
3804 CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
3805 .features[FEAT_8000_0001_ECX] =
3806 CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
3807 .features[FEAT_7_0_EBX] =
3808 CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
3809 CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS |
3810 CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_AVX512F |
3811 CPUID_7_0_EBX_AVX512CD | CPUID_7_0_EBX_AVX512PF |
3812 CPUID_7_0_EBX_AVX512ER,
3813 .features[FEAT_7_0_ECX] =
3814 CPUID_7_0_ECX_AVX512_VPOPCNTDQ,
3815 .features[FEAT_7_0_EDX] =
3816 CPUID_7_0_EDX_AVX512_4VNNIW | CPUID_7_0_EDX_AVX512_4FMAPS,
3817 .features[FEAT_XSAVE] =
3818 CPUID_XSAVE_XSAVEOPT,
3819 .features[FEAT_6_EAX] =
3820 CPUID_6_EAX_ARAT,
3821 .xlevel = 0x80000008,
3822 .model_id = "Intel Xeon Phi Processor (Knights Mill)",
3825 .name = "Opteron_G1",
3826 .level = 5,
3827 .vendor = CPUID_VENDOR_AMD,
3828 .family = 15,
3829 .model = 6,
3830 .stepping = 1,
3831 .features[FEAT_1_EDX] =
3832 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
3833 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
3834 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
3835 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
3836 CPUID_DE | CPUID_FP87,
3837 .features[FEAT_1_ECX] =
3838 CPUID_EXT_SSE3,
3839 .features[FEAT_8000_0001_EDX] =
3840 CPUID_EXT2_LM | CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
3841 .xlevel = 0x80000008,
3842 .model_id = "AMD Opteron 240 (Gen 1 Class Opteron)",
3845 .name = "Opteron_G2",
3846 .level = 5,
3847 .vendor = CPUID_VENDOR_AMD,
3848 .family = 15,
3849 .model = 6,
3850 .stepping = 1,
3851 .features[FEAT_1_EDX] =
3852 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
3853 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
3854 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
3855 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
3856 CPUID_DE | CPUID_FP87,
3857 .features[FEAT_1_ECX] =
3858 CPUID_EXT_CX16 | CPUID_EXT_SSE3,
3859 .features[FEAT_8000_0001_EDX] =
3860 CPUID_EXT2_LM | CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
3861 .features[FEAT_8000_0001_ECX] =
3862 CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM,
3863 .xlevel = 0x80000008,
3864 .model_id = "AMD Opteron 22xx (Gen 2 Class Opteron)",
3867 .name = "Opteron_G3",
3868 .level = 5,
3869 .vendor = CPUID_VENDOR_AMD,
3870 .family = 16,
3871 .model = 2,
3872 .stepping = 3,
3873 .features[FEAT_1_EDX] =
3874 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
3875 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
3876 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
3877 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
3878 CPUID_DE | CPUID_FP87,
3879 .features[FEAT_1_ECX] =
3880 CPUID_EXT_POPCNT | CPUID_EXT_CX16 | CPUID_EXT_MONITOR |
3881 CPUID_EXT_SSE3,
3882 .features[FEAT_8000_0001_EDX] =
3883 CPUID_EXT2_LM | CPUID_EXT2_NX | CPUID_EXT2_SYSCALL |
3884 CPUID_EXT2_RDTSCP,
3885 .features[FEAT_8000_0001_ECX] =
3886 CPUID_EXT3_MISALIGNSSE | CPUID_EXT3_SSE4A |
3887 CPUID_EXT3_ABM | CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM,
3888 .xlevel = 0x80000008,
3889 .model_id = "AMD Opteron 23xx (Gen 3 Class Opteron)",
3892 .name = "Opteron_G4",
3893 .level = 0xd,
3894 .vendor = CPUID_VENDOR_AMD,
3895 .family = 21,
3896 .model = 1,
3897 .stepping = 2,
3898 .features[FEAT_1_EDX] =
3899 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
3900 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
3901 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
3902 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
3903 CPUID_DE | CPUID_FP87,
3904 .features[FEAT_1_ECX] =
3905 CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
3906 CPUID_EXT_POPCNT | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
3907 CPUID_EXT_CX16 | CPUID_EXT_SSSE3 | CPUID_EXT_PCLMULQDQ |
3908 CPUID_EXT_SSE3,
3909 .features[FEAT_8000_0001_EDX] =
3910 CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_NX |
3911 CPUID_EXT2_SYSCALL | CPUID_EXT2_RDTSCP,
3912 .features[FEAT_8000_0001_ECX] =
3913 CPUID_EXT3_FMA4 | CPUID_EXT3_XOP |
3914 CPUID_EXT3_3DNOWPREFETCH | CPUID_EXT3_MISALIGNSSE |
3915 CPUID_EXT3_SSE4A | CPUID_EXT3_ABM | CPUID_EXT3_SVM |
3916 CPUID_EXT3_LAHF_LM,
3917 .features[FEAT_SVM] =
3918 CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE,
3919 /* no xsaveopt! */
3920 .xlevel = 0x8000001A,
3921 .model_id = "AMD Opteron 62xx class CPU",
3924 .name = "Opteron_G5",
3925 .level = 0xd,
3926 .vendor = CPUID_VENDOR_AMD,
3927 .family = 21,
3928 .model = 2,
3929 .stepping = 0,
3930 .features[FEAT_1_EDX] =
3931 CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
3932 CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
3933 CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
3934 CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
3935 CPUID_DE | CPUID_FP87,
3936 .features[FEAT_1_ECX] =
3937 CPUID_EXT_F16C | CPUID_EXT_AVX | CPUID_EXT_XSAVE |
3938 CPUID_EXT_AES | CPUID_EXT_POPCNT | CPUID_EXT_SSE42 |
3939 CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_FMA |
3940 CPUID_EXT_SSSE3 | CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3,
3941 .features[FEAT_8000_0001_EDX] =
3942 CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_NX |
3943 CPUID_EXT2_SYSCALL | CPUID_EXT2_RDTSCP,
3944 .features[FEAT_8000_0001_ECX] =
3945 CPUID_EXT3_TBM | CPUID_EXT3_FMA4 | CPUID_EXT3_XOP |
3946 CPUID_EXT3_3DNOWPREFETCH | CPUID_EXT3_MISALIGNSSE |
3947 CPUID_EXT3_SSE4A | CPUID_EXT3_ABM | CPUID_EXT3_SVM |
3948 CPUID_EXT3_LAHF_LM,
3949 .features[FEAT_SVM] =
3950 CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE,
3951 /* no xsaveopt! */
3952 .xlevel = 0x8000001A,
3953 .model_id = "AMD Opteron 63xx class CPU",
3956 .name = "EPYC",
3957 .level = 0xd,
3958 .vendor = CPUID_VENDOR_AMD,
3959 .family = 23,
3960 .model = 1,
3961 .stepping = 2,
3962 .features[FEAT_1_EDX] =
3963 CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX | CPUID_CLFLUSH |
3964 CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA | CPUID_PGE |
3965 CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 | CPUID_MCE |
3966 CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE | CPUID_DE |
3967 CPUID_VME | CPUID_FP87,
3968 .features[FEAT_1_ECX] =
3969 CPUID_EXT_RDRAND | CPUID_EXT_F16C | CPUID_EXT_AVX |
3970 CPUID_EXT_XSAVE | CPUID_EXT_AES | CPUID_EXT_POPCNT |
3971 CPUID_EXT_MOVBE | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
3972 CPUID_EXT_CX16 | CPUID_EXT_FMA | CPUID_EXT_SSSE3 |
3973 CPUID_EXT_MONITOR | CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3,
3974 .features[FEAT_8000_0001_EDX] =
3975 CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_PDPE1GB |
3976 CPUID_EXT2_FFXSR | CPUID_EXT2_MMXEXT | CPUID_EXT2_NX |
3977 CPUID_EXT2_SYSCALL,
3978 .features[FEAT_8000_0001_ECX] =
3979 CPUID_EXT3_OSVW | CPUID_EXT3_3DNOWPREFETCH |
3980 CPUID_EXT3_MISALIGNSSE | CPUID_EXT3_SSE4A | CPUID_EXT3_ABM |
3981 CPUID_EXT3_CR8LEG | CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM |
3982 CPUID_EXT3_TOPOEXT,
3983 .features[FEAT_7_0_EBX] =
3984 CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
3985 CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_RDSEED |
3986 CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLFLUSHOPT |
3987 CPUID_7_0_EBX_SHA_NI,
3988 .features[FEAT_XSAVE] =
3989 CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
3990 CPUID_XSAVE_XGETBV1,
3991 .features[FEAT_6_EAX] =
3992 CPUID_6_EAX_ARAT,
3993 .features[FEAT_SVM] =
3994 CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE,
3995 .xlevel = 0x8000001E,
3996 .model_id = "AMD EPYC Processor",
3997 .cache_info = &epyc_cache_info,
3998 .use_epyc_apic_id_encoding = 1,
3999 .versions = (X86CPUVersionDefinition[]) {
4000 { .version = 1 },
4002 .version = 2,
4003 .alias = "EPYC-IBPB",
4004 .props = (PropValue[]) {
4005 { "ibpb", "on" },
4006 { "model-id",
4007 "AMD EPYC Processor (with IBPB)" },
4008 { /* end of list */ }
4012 .version = 3,
4013 .props = (PropValue[]) {
4014 { "ibpb", "on" },
4015 { "perfctr-core", "on" },
4016 { "clzero", "on" },
4017 { "xsaveerptr", "on" },
4018 { "xsaves", "on" },
4019 { "model-id",
4020 "AMD EPYC Processor" },
4021 { /* end of list */ }
4024 { /* end of list */ }
4028 .name = "Dhyana",
4029 .level = 0xd,
4030 .vendor = CPUID_VENDOR_HYGON,
4031 .family = 24,
4032 .model = 0,
4033 .stepping = 1,
4034 .features[FEAT_1_EDX] =
4035 CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX | CPUID_CLFLUSH |
4036 CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA | CPUID_PGE |
4037 CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 | CPUID_MCE |
4038 CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE | CPUID_DE |
4039 CPUID_VME | CPUID_FP87,
4040 .features[FEAT_1_ECX] =
4041 CPUID_EXT_RDRAND | CPUID_EXT_F16C | CPUID_EXT_AVX |
4042 CPUID_EXT_XSAVE | CPUID_EXT_POPCNT |
4043 CPUID_EXT_MOVBE | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
4044 CPUID_EXT_CX16 | CPUID_EXT_FMA | CPUID_EXT_SSSE3 |
4045 CPUID_EXT_MONITOR | CPUID_EXT_SSE3,
4046 .features[FEAT_8000_0001_EDX] =
4047 CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_PDPE1GB |
4048 CPUID_EXT2_FFXSR | CPUID_EXT2_MMXEXT | CPUID_EXT2_NX |
4049 CPUID_EXT2_SYSCALL,
4050 .features[FEAT_8000_0001_ECX] =
4051 CPUID_EXT3_OSVW | CPUID_EXT3_3DNOWPREFETCH |
4052 CPUID_EXT3_MISALIGNSSE | CPUID_EXT3_SSE4A | CPUID_EXT3_ABM |
4053 CPUID_EXT3_CR8LEG | CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM |
4054 CPUID_EXT3_TOPOEXT,
4055 .features[FEAT_8000_0008_EBX] =
4056 CPUID_8000_0008_EBX_IBPB,
4057 .features[FEAT_7_0_EBX] =
4058 CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
4059 CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_RDSEED |
4060 CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLFLUSHOPT,
4062 * Missing: XSAVES (not supported by some Linux versions,
4063 * including v4.1 to v4.12).
4064 * KVM doesn't yet expose any XSAVES state save component.
4066 .features[FEAT_XSAVE] =
4067 CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
4068 CPUID_XSAVE_XGETBV1,
4069 .features[FEAT_6_EAX] =
4070 CPUID_6_EAX_ARAT,
4071 .features[FEAT_SVM] =
4072 CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE,
4073 .xlevel = 0x8000001E,
4074 .model_id = "Hygon Dhyana Processor",
4075 .cache_info = &epyc_cache_info,
4078 .name = "EPYC-Rome",
4079 .level = 0xd,
4080 .vendor = CPUID_VENDOR_AMD,
4081 .family = 23,
4082 .model = 49,
4083 .stepping = 0,
4084 .features[FEAT_1_EDX] =
4085 CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX | CPUID_CLFLUSH |
4086 CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA | CPUID_PGE |
4087 CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 | CPUID_MCE |
4088 CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE | CPUID_DE |
4089 CPUID_VME | CPUID_FP87,
4090 .features[FEAT_1_ECX] =
4091 CPUID_EXT_RDRAND | CPUID_EXT_F16C | CPUID_EXT_AVX |
4092 CPUID_EXT_XSAVE | CPUID_EXT_AES | CPUID_EXT_POPCNT |
4093 CPUID_EXT_MOVBE | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
4094 CPUID_EXT_CX16 | CPUID_EXT_FMA | CPUID_EXT_SSSE3 |
4095 CPUID_EXT_MONITOR | CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3,
4096 .features[FEAT_8000_0001_EDX] =
4097 CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_PDPE1GB |
4098 CPUID_EXT2_FFXSR | CPUID_EXT2_MMXEXT | CPUID_EXT2_NX |
4099 CPUID_EXT2_SYSCALL,
4100 .features[FEAT_8000_0001_ECX] =
4101 CPUID_EXT3_OSVW | CPUID_EXT3_3DNOWPREFETCH |
4102 CPUID_EXT3_MISALIGNSSE | CPUID_EXT3_SSE4A | CPUID_EXT3_ABM |
4103 CPUID_EXT3_CR8LEG | CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM |
4104 CPUID_EXT3_TOPOEXT | CPUID_EXT3_PERFCORE,
4105 .features[FEAT_8000_0008_EBX] =
4106 CPUID_8000_0008_EBX_CLZERO | CPUID_8000_0008_EBX_XSAVEERPTR |
4107 CPUID_8000_0008_EBX_WBNOINVD | CPUID_8000_0008_EBX_IBPB |
4108 CPUID_8000_0008_EBX_STIBP,
4109 .features[FEAT_7_0_EBX] =
4110 CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
4111 CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_RDSEED |
4112 CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLFLUSHOPT |
4113 CPUID_7_0_EBX_SHA_NI | CPUID_7_0_EBX_CLWB,
4114 .features[FEAT_7_0_ECX] =
4115 CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_RDPID,
4116 .features[FEAT_XSAVE] =
4117 CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
4118 CPUID_XSAVE_XGETBV1 | CPUID_XSAVE_XSAVES,
4119 .features[FEAT_6_EAX] =
4120 CPUID_6_EAX_ARAT,
4121 .features[FEAT_SVM] =
4122 CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE,
4123 .xlevel = 0x8000001E,
4124 .model_id = "AMD EPYC-Rome Processor",
4125 .cache_info = &epyc_rome_cache_info,
4126 .use_epyc_apic_id_encoding = 1,
4130 /* KVM-specific features that are automatically added/removed
4131 * from all CPU models when KVM is enabled.
4133 static PropValue kvm_default_props[] = {
4134 { "kvmclock", "on" },
4135 { "kvm-nopiodelay", "on" },
4136 { "kvm-asyncpf", "on" },
4137 { "kvm-steal-time", "on" },
4138 { "kvm-pv-eoi", "on" },
4139 { "kvmclock-stable-bit", "on" },
4140 { "x2apic", "on" },
4141 { "acpi", "off" },
4142 { "monitor", "off" },
4143 { "svm", "off" },
4144 { NULL, NULL },
4147 /* TCG-specific defaults that override all CPU models when using TCG
4149 static PropValue tcg_default_props[] = {
4150 { "vme", "off" },
4151 { NULL, NULL },
4156 * We resolve CPU model aliases using -v1 when using "-machine
4157 * none", but this is just for compatibility while libvirt isn't
4158 * adapted to resolve CPU model versions before creating VMs.
4159 * See "Runnability guarantee of CPU models" at * qemu-deprecated.texi.
4161 X86CPUVersion default_cpu_version = 1;
4163 void x86_cpu_set_default_version(X86CPUVersion version)
4165 /* Translating CPU_VERSION_AUTO to CPU_VERSION_AUTO doesn't make sense */
4166 assert(version != CPU_VERSION_AUTO);
4167 default_cpu_version = version;
4170 static X86CPUVersion x86_cpu_model_last_version(const X86CPUModel *model)
4172 int v = 0;
4173 const X86CPUVersionDefinition *vdef =
4174 x86_cpu_def_get_versions(model->cpudef);
4175 while (vdef->version) {
4176 v = vdef->version;
4177 vdef++;
4179 return v;
4182 /* Return the actual version being used for a specific CPU model */
4183 static X86CPUVersion x86_cpu_model_resolve_version(const X86CPUModel *model)
4185 X86CPUVersion v = model->version;
4186 if (v == CPU_VERSION_AUTO) {
4187 v = default_cpu_version;
4189 if (v == CPU_VERSION_LATEST) {
4190 return x86_cpu_model_last_version(model);
4192 return v;
4195 void x86_cpu_change_kvm_default(const char *prop, const char *value)
4197 PropValue *pv;
4198 for (pv = kvm_default_props; pv->prop; pv++) {
4199 if (!strcmp(pv->prop, prop)) {
4200 pv->value = value;
4201 break;
4205 /* It is valid to call this function only for properties that
4206 * are already present in the kvm_default_props table.
4208 assert(pv->prop);
4211 static uint64_t x86_cpu_get_supported_feature_word(FeatureWord w,
4212 bool migratable_only);
4214 static bool lmce_supported(void)
4216 uint64_t mce_cap = 0;
4218 #ifdef CONFIG_KVM
4219 if (kvm_ioctl(kvm_state, KVM_X86_GET_MCE_CAP_SUPPORTED, &mce_cap) < 0) {
4220 return false;
4222 #endif
4224 return !!(mce_cap & MCG_LMCE_P);
4227 #define CPUID_MODEL_ID_SZ 48
4230 * cpu_x86_fill_model_id:
4231 * Get CPUID model ID string from host CPU.
4233 * @str should have at least CPUID_MODEL_ID_SZ bytes
4235 * The function does NOT add a null terminator to the string
4236 * automatically.
4238 static int cpu_x86_fill_model_id(char *str)
4240 uint32_t eax = 0, ebx = 0, ecx = 0, edx = 0;
4241 int i;
4243 for (i = 0; i < 3; i++) {
4244 host_cpuid(0x80000002 + i, 0, &eax, &ebx, &ecx, &edx);
4245 memcpy(str + i * 16 + 0, &eax, 4);
4246 memcpy(str + i * 16 + 4, &ebx, 4);
4247 memcpy(str + i * 16 + 8, &ecx, 4);
4248 memcpy(str + i * 16 + 12, &edx, 4);
4250 return 0;
4253 static Property max_x86_cpu_properties[] = {
4254 DEFINE_PROP_BOOL("migratable", X86CPU, migratable, true),
4255 DEFINE_PROP_BOOL("host-cache-info", X86CPU, cache_info_passthrough, false),
4256 DEFINE_PROP_END_OF_LIST()
4259 static void max_x86_cpu_class_init(ObjectClass *oc, void *data)
4261 DeviceClass *dc = DEVICE_CLASS(oc);
4262 X86CPUClass *xcc = X86_CPU_CLASS(oc);
4264 xcc->ordering = 9;
4266 xcc->model_description =
4267 "Enables all features supported by the accelerator in the current host";
4269 device_class_set_props(dc, max_x86_cpu_properties);
4272 static void max_x86_cpu_initfn(Object *obj)
4274 X86CPU *cpu = X86_CPU(obj);
4275 CPUX86State *env = &cpu->env;
4276 KVMState *s = kvm_state;
4278 /* We can't fill the features array here because we don't know yet if
4279 * "migratable" is true or false.
4281 cpu->max_features = true;
4283 if (accel_uses_host_cpuid()) {
4284 char vendor[CPUID_VENDOR_SZ + 1] = { 0 };
4285 char model_id[CPUID_MODEL_ID_SZ + 1] = { 0 };
4286 int family, model, stepping;
4288 host_vendor_fms(vendor, &family, &model, &stepping);
4289 cpu_x86_fill_model_id(model_id);
4291 object_property_set_str(OBJECT(cpu), "vendor", vendor, &error_abort);
4292 object_property_set_int(OBJECT(cpu), "family", family, &error_abort);
4293 object_property_set_int(OBJECT(cpu), "model", model, &error_abort);
4294 object_property_set_int(OBJECT(cpu), "stepping", stepping,
4295 &error_abort);
4296 object_property_set_str(OBJECT(cpu), "model-id", model_id,
4297 &error_abort);
4299 if (kvm_enabled()) {
4300 env->cpuid_min_level =
4301 kvm_arch_get_supported_cpuid(s, 0x0, 0, R_EAX);
4302 env->cpuid_min_xlevel =
4303 kvm_arch_get_supported_cpuid(s, 0x80000000, 0, R_EAX);
4304 env->cpuid_min_xlevel2 =
4305 kvm_arch_get_supported_cpuid(s, 0xC0000000, 0, R_EAX);
4306 } else {
4307 env->cpuid_min_level =
4308 hvf_get_supported_cpuid(0x0, 0, R_EAX);
4309 env->cpuid_min_xlevel =
4310 hvf_get_supported_cpuid(0x80000000, 0, R_EAX);
4311 env->cpuid_min_xlevel2 =
4312 hvf_get_supported_cpuid(0xC0000000, 0, R_EAX);
4315 if (lmce_supported()) {
4316 object_property_set_bool(OBJECT(cpu), "lmce", true, &error_abort);
4318 } else {
4319 object_property_set_str(OBJECT(cpu), "vendor", CPUID_VENDOR_AMD,
4320 &error_abort);
4321 object_property_set_int(OBJECT(cpu), "family", 6, &error_abort);
4322 object_property_set_int(OBJECT(cpu), "model", 6, &error_abort);
4323 object_property_set_int(OBJECT(cpu), "stepping", 3, &error_abort);
4324 object_property_set_str(OBJECT(cpu), "model-id",
4325 "QEMU TCG CPU version " QEMU_HW_VERSION,
4326 &error_abort);
4329 object_property_set_bool(OBJECT(cpu), "pmu", true, &error_abort);
4332 static const TypeInfo max_x86_cpu_type_info = {
4333 .name = X86_CPU_TYPE_NAME("max"),
4334 .parent = TYPE_X86_CPU,
4335 .instance_init = max_x86_cpu_initfn,
4336 .class_init = max_x86_cpu_class_init,
4339 #if defined(CONFIG_KVM) || defined(CONFIG_HVF)
4340 static void host_x86_cpu_class_init(ObjectClass *oc, void *data)
4342 X86CPUClass *xcc = X86_CPU_CLASS(oc);
4344 xcc->host_cpuid_required = true;
4345 xcc->ordering = 8;
4347 #if defined(CONFIG_KVM)
4348 xcc->model_description =
4349 "KVM processor with all supported host features ";
4350 #elif defined(CONFIG_HVF)
4351 xcc->model_description =
4352 "HVF processor with all supported host features ";
4353 #endif
4356 static const TypeInfo host_x86_cpu_type_info = {
4357 .name = X86_CPU_TYPE_NAME("host"),
4358 .parent = X86_CPU_TYPE_NAME("max"),
4359 .class_init = host_x86_cpu_class_init,
4362 #endif
4364 static char *feature_word_description(FeatureWordInfo *f, uint32_t bit)
4366 assert(f->type == CPUID_FEATURE_WORD || f->type == MSR_FEATURE_WORD);
4368 switch (f->type) {
4369 case CPUID_FEATURE_WORD:
4371 const char *reg = get_register_name_32(f->cpuid.reg);
4372 assert(reg);
4373 return g_strdup_printf("CPUID.%02XH:%s",
4374 f->cpuid.eax, reg);
4376 case MSR_FEATURE_WORD:
4377 return g_strdup_printf("MSR(%02XH)",
4378 f->msr.index);
4381 return NULL;
4384 static bool x86_cpu_have_filtered_features(X86CPU *cpu)
4386 FeatureWord w;
4388 for (w = 0; w < FEATURE_WORDS; w++) {
4389 if (cpu->filtered_features[w]) {
4390 return true;
4394 return false;
4397 static void mark_unavailable_features(X86CPU *cpu, FeatureWord w, uint64_t mask,
4398 const char *verbose_prefix)
4400 CPUX86State *env = &cpu->env;
4401 FeatureWordInfo *f = &feature_word_info[w];
4402 int i;
4404 if (!cpu->force_features) {
4405 env->features[w] &= ~mask;
4407 cpu->filtered_features[w] |= mask;
4409 if (!verbose_prefix) {
4410 return;
4413 for (i = 0; i < 64; ++i) {
4414 if ((1ULL << i) & mask) {
4415 g_autofree char *feat_word_str = feature_word_description(f, i);
4416 warn_report("%s: %s%s%s [bit %d]",
4417 verbose_prefix,
4418 feat_word_str,
4419 f->feat_names[i] ? "." : "",
4420 f->feat_names[i] ? f->feat_names[i] : "", i);
4425 static void x86_cpuid_version_get_family(Object *obj, Visitor *v,
4426 const char *name, void *opaque,
4427 Error **errp)
4429 X86CPU *cpu = X86_CPU(obj);
4430 CPUX86State *env = &cpu->env;
4431 int64_t value;
4433 value = (env->cpuid_version >> 8) & 0xf;
4434 if (value == 0xf) {
4435 value += (env->cpuid_version >> 20) & 0xff;
4437 visit_type_int(v, name, &value, errp);
4440 static void x86_cpuid_version_set_family(Object *obj, Visitor *v,
4441 const char *name, void *opaque,
4442 Error **errp)
4444 X86CPU *cpu = X86_CPU(obj);
4445 CPUX86State *env = &cpu->env;
4446 const int64_t min = 0;
4447 const int64_t max = 0xff + 0xf;
4448 int64_t value;
4450 if (!visit_type_int(v, name, &value, errp)) {
4451 return;
4453 if (value < min || value > max) {
4454 error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "",
4455 name ? name : "null", value, min, max);
4456 return;
4459 env->cpuid_version &= ~0xff00f00;
4460 if (value > 0x0f) {
4461 env->cpuid_version |= 0xf00 | ((value - 0x0f) << 20);
4462 } else {
4463 env->cpuid_version |= value << 8;
4467 static void x86_cpuid_version_get_model(Object *obj, Visitor *v,
4468 const char *name, void *opaque,
4469 Error **errp)
4471 X86CPU *cpu = X86_CPU(obj);
4472 CPUX86State *env = &cpu->env;
4473 int64_t value;
4475 value = (env->cpuid_version >> 4) & 0xf;
4476 value |= ((env->cpuid_version >> 16) & 0xf) << 4;
4477 visit_type_int(v, name, &value, errp);
4480 static void x86_cpuid_version_set_model(Object *obj, Visitor *v,
4481 const char *name, void *opaque,
4482 Error **errp)
4484 X86CPU *cpu = X86_CPU(obj);
4485 CPUX86State *env = &cpu->env;
4486 const int64_t min = 0;
4487 const int64_t max = 0xff;
4488 int64_t value;
4490 if (!visit_type_int(v, name, &value, errp)) {
4491 return;
4493 if (value < min || value > max) {
4494 error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "",
4495 name ? name : "null", value, min, max);
4496 return;
4499 env->cpuid_version &= ~0xf00f0;
4500 env->cpuid_version |= ((value & 0xf) << 4) | ((value >> 4) << 16);
4503 static void x86_cpuid_version_get_stepping(Object *obj, Visitor *v,
4504 const char *name, void *opaque,
4505 Error **errp)
4507 X86CPU *cpu = X86_CPU(obj);
4508 CPUX86State *env = &cpu->env;
4509 int64_t value;
4511 value = env->cpuid_version & 0xf;
4512 visit_type_int(v, name, &value, errp);
4515 static void x86_cpuid_version_set_stepping(Object *obj, Visitor *v,
4516 const char *name, void *opaque,
4517 Error **errp)
4519 X86CPU *cpu = X86_CPU(obj);
4520 CPUX86State *env = &cpu->env;
4521 const int64_t min = 0;
4522 const int64_t max = 0xf;
4523 int64_t value;
4525 if (!visit_type_int(v, name, &value, errp)) {
4526 return;
4528 if (value < min || value > max) {
4529 error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "",
4530 name ? name : "null", value, min, max);
4531 return;
4534 env->cpuid_version &= ~0xf;
4535 env->cpuid_version |= value & 0xf;
4538 static char *x86_cpuid_get_vendor(Object *obj, Error **errp)
4540 X86CPU *cpu = X86_CPU(obj);
4541 CPUX86State *env = &cpu->env;
4542 char *value;
4544 value = g_malloc(CPUID_VENDOR_SZ + 1);
4545 x86_cpu_vendor_words2str(value, env->cpuid_vendor1, env->cpuid_vendor2,
4546 env->cpuid_vendor3);
4547 return value;
4550 static void x86_cpuid_set_vendor(Object *obj, const char *value,
4551 Error **errp)
4553 X86CPU *cpu = X86_CPU(obj);
4554 CPUX86State *env = &cpu->env;
4555 int i;
4557 if (strlen(value) != CPUID_VENDOR_SZ) {
4558 error_setg(errp, QERR_PROPERTY_VALUE_BAD, "", "vendor", value);
4559 return;
4562 env->cpuid_vendor1 = 0;
4563 env->cpuid_vendor2 = 0;
4564 env->cpuid_vendor3 = 0;
4565 for (i = 0; i < 4; i++) {
4566 env->cpuid_vendor1 |= ((uint8_t)value[i ]) << (8 * i);
4567 env->cpuid_vendor2 |= ((uint8_t)value[i + 4]) << (8 * i);
4568 env->cpuid_vendor3 |= ((uint8_t)value[i + 8]) << (8 * i);
4572 static char *x86_cpuid_get_model_id(Object *obj, Error **errp)
4574 X86CPU *cpu = X86_CPU(obj);
4575 CPUX86State *env = &cpu->env;
4576 char *value;
4577 int i;
4579 value = g_malloc(48 + 1);
4580 for (i = 0; i < 48; i++) {
4581 value[i] = env->cpuid_model[i >> 2] >> (8 * (i & 3));
4583 value[48] = '\0';
4584 return value;
4587 static void x86_cpuid_set_model_id(Object *obj, const char *model_id,
4588 Error **errp)
4590 X86CPU *cpu = X86_CPU(obj);
4591 CPUX86State *env = &cpu->env;
4592 int c, len, i;
4594 if (model_id == NULL) {
4595 model_id = "";
4597 len = strlen(model_id);
4598 memset(env->cpuid_model, 0, 48);
4599 for (i = 0; i < 48; i++) {
4600 if (i >= len) {
4601 c = '\0';
4602 } else {
4603 c = (uint8_t)model_id[i];
4605 env->cpuid_model[i >> 2] |= c << (8 * (i & 3));
4609 static void x86_cpuid_get_tsc_freq(Object *obj, Visitor *v, const char *name,
4610 void *opaque, Error **errp)
4612 X86CPU *cpu = X86_CPU(obj);
4613 int64_t value;
4615 value = cpu->env.tsc_khz * 1000;
4616 visit_type_int(v, name, &value, errp);
4619 static void x86_cpuid_set_tsc_freq(Object *obj, Visitor *v, const char *name,
4620 void *opaque, Error **errp)
4622 X86CPU *cpu = X86_CPU(obj);
4623 const int64_t min = 0;
4624 const int64_t max = INT64_MAX;
4625 int64_t value;
4627 if (!visit_type_int(v, name, &value, errp)) {
4628 return;
4630 if (value < min || value > max) {
4631 error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "",
4632 name ? name : "null", value, min, max);
4633 return;
4636 cpu->env.tsc_khz = cpu->env.user_tsc_khz = value / 1000;
4639 /* Generic getter for "feature-words" and "filtered-features" properties */
4640 static void x86_cpu_get_feature_words(Object *obj, Visitor *v,
4641 const char *name, void *opaque,
4642 Error **errp)
4644 uint64_t *array = (uint64_t *)opaque;
4645 FeatureWord w;
4646 X86CPUFeatureWordInfo word_infos[FEATURE_WORDS] = { };
4647 X86CPUFeatureWordInfoList list_entries[FEATURE_WORDS] = { };
4648 X86CPUFeatureWordInfoList *list = NULL;
4650 for (w = 0; w < FEATURE_WORDS; w++) {
4651 FeatureWordInfo *wi = &feature_word_info[w];
4653 * We didn't have MSR features when "feature-words" was
4654 * introduced. Therefore skipped other type entries.
4656 if (wi->type != CPUID_FEATURE_WORD) {
4657 continue;
4659 X86CPUFeatureWordInfo *qwi = &word_infos[w];
4660 qwi->cpuid_input_eax = wi->cpuid.eax;
4661 qwi->has_cpuid_input_ecx = wi->cpuid.needs_ecx;
4662 qwi->cpuid_input_ecx = wi->cpuid.ecx;
4663 qwi->cpuid_register = x86_reg_info_32[wi->cpuid.reg].qapi_enum;
4664 qwi->features = array[w];
4666 /* List will be in reverse order, but order shouldn't matter */
4667 list_entries[w].next = list;
4668 list_entries[w].value = &word_infos[w];
4669 list = &list_entries[w];
4672 visit_type_X86CPUFeatureWordInfoList(v, "feature-words", &list, errp);
4675 /* Convert all '_' in a feature string option name to '-', to make feature
4676 * name conform to QOM property naming rule, which uses '-' instead of '_'.
4678 static inline void feat2prop(char *s)
4680 while ((s = strchr(s, '_'))) {
4681 *s = '-';
4685 /* Return the feature property name for a feature flag bit */
4686 static const char *x86_cpu_feature_name(FeatureWord w, int bitnr)
4688 const char *name;
4689 /* XSAVE components are automatically enabled by other features,
4690 * so return the original feature name instead
4692 if (w == FEAT_XSAVE_COMP_LO || w == FEAT_XSAVE_COMP_HI) {
4693 int comp = (w == FEAT_XSAVE_COMP_HI) ? bitnr + 32 : bitnr;
4695 if (comp < ARRAY_SIZE(x86_ext_save_areas) &&
4696 x86_ext_save_areas[comp].bits) {
4697 w = x86_ext_save_areas[comp].feature;
4698 bitnr = ctz32(x86_ext_save_areas[comp].bits);
4702 assert(bitnr < 64);
4703 assert(w < FEATURE_WORDS);
4704 name = feature_word_info[w].feat_names[bitnr];
4705 assert(bitnr < 32 || !(name && feature_word_info[w].type == CPUID_FEATURE_WORD));
4706 return name;
4709 /* Compatibily hack to maintain legacy +-feat semantic,
4710 * where +-feat overwrites any feature set by
4711 * feat=on|feat even if the later is parsed after +-feat
4712 * (i.e. "-x2apic,x2apic=on" will result in x2apic disabled)
4714 static GList *plus_features, *minus_features;
4716 static gint compare_string(gconstpointer a, gconstpointer b)
4718 return g_strcmp0(a, b);
4721 /* Parse "+feature,-feature,feature=foo" CPU feature string
4723 static void x86_cpu_parse_featurestr(const char *typename, char *features,
4724 Error **errp)
4726 char *featurestr; /* Single 'key=value" string being parsed */
4727 static bool cpu_globals_initialized;
4728 bool ambiguous = false;
4730 if (cpu_globals_initialized) {
4731 return;
4733 cpu_globals_initialized = true;
4735 if (!features) {
4736 return;
4739 for (featurestr = strtok(features, ",");
4740 featurestr;
4741 featurestr = strtok(NULL, ",")) {
4742 const char *name;
4743 const char *val = NULL;
4744 char *eq = NULL;
4745 char num[32];
4746 GlobalProperty *prop;
4748 /* Compatibility syntax: */
4749 if (featurestr[0] == '+') {
4750 plus_features = g_list_append(plus_features,
4751 g_strdup(featurestr + 1));
4752 continue;
4753 } else if (featurestr[0] == '-') {
4754 minus_features = g_list_append(minus_features,
4755 g_strdup(featurestr + 1));
4756 continue;
4759 eq = strchr(featurestr, '=');
4760 if (eq) {
4761 *eq++ = 0;
4762 val = eq;
4763 } else {
4764 val = "on";
4767 feat2prop(featurestr);
4768 name = featurestr;
4770 if (g_list_find_custom(plus_features, name, compare_string)) {
4771 warn_report("Ambiguous CPU model string. "
4772 "Don't mix both \"+%s\" and \"%s=%s\"",
4773 name, name, val);
4774 ambiguous = true;
4776 if (g_list_find_custom(minus_features, name, compare_string)) {
4777 warn_report("Ambiguous CPU model string. "
4778 "Don't mix both \"-%s\" and \"%s=%s\"",
4779 name, name, val);
4780 ambiguous = true;
4783 /* Special case: */
4784 if (!strcmp(name, "tsc-freq")) {
4785 int ret;
4786 uint64_t tsc_freq;
4788 ret = qemu_strtosz_metric(val, NULL, &tsc_freq);
4789 if (ret < 0 || tsc_freq > INT64_MAX) {
4790 error_setg(errp, "bad numerical value %s", val);
4791 return;
4793 snprintf(num, sizeof(num), "%" PRId64, tsc_freq);
4794 val = num;
4795 name = "tsc-frequency";
4798 prop = g_new0(typeof(*prop), 1);
4799 prop->driver = typename;
4800 prop->property = g_strdup(name);
4801 prop->value = g_strdup(val);
4802 qdev_prop_register_global(prop);
4805 if (ambiguous) {
4806 warn_report("Compatibility of ambiguous CPU model "
4807 "strings won't be kept on future QEMU versions");
4811 static void x86_cpu_expand_features(X86CPU *cpu, Error **errp);
4812 static void x86_cpu_filter_features(X86CPU *cpu, bool verbose);
4814 /* Build a list with the name of all features on a feature word array */
4815 static void x86_cpu_list_feature_names(FeatureWordArray features,
4816 strList **feat_names)
4818 FeatureWord w;
4819 strList **next = feat_names;
4821 for (w = 0; w < FEATURE_WORDS; w++) {
4822 uint64_t filtered = features[w];
4823 int i;
4824 for (i = 0; i < 64; i++) {
4825 if (filtered & (1ULL << i)) {
4826 strList *new = g_new0(strList, 1);
4827 new->value = g_strdup(x86_cpu_feature_name(w, i));
4828 *next = new;
4829 next = &new->next;
4835 static void x86_cpu_get_unavailable_features(Object *obj, Visitor *v,
4836 const char *name, void *opaque,
4837 Error **errp)
4839 X86CPU *xc = X86_CPU(obj);
4840 strList *result = NULL;
4842 x86_cpu_list_feature_names(xc->filtered_features, &result);
4843 visit_type_strList(v, "unavailable-features", &result, errp);
4846 /* Check for missing features that may prevent the CPU class from
4847 * running using the current machine and accelerator.
4849 static void x86_cpu_class_check_missing_features(X86CPUClass *xcc,
4850 strList **missing_feats)
4852 X86CPU *xc;
4853 Error *err = NULL;
4854 strList **next = missing_feats;
4856 if (xcc->host_cpuid_required && !accel_uses_host_cpuid()) {
4857 strList *new = g_new0(strList, 1);
4858 new->value = g_strdup("kvm");
4859 *missing_feats = new;
4860 return;
4863 xc = X86_CPU(object_new_with_class(OBJECT_CLASS(xcc)));
4865 x86_cpu_expand_features(xc, &err);
4866 if (err) {
4867 /* Errors at x86_cpu_expand_features should never happen,
4868 * but in case it does, just report the model as not
4869 * runnable at all using the "type" property.
4871 strList *new = g_new0(strList, 1);
4872 new->value = g_strdup("type");
4873 *next = new;
4874 next = &new->next;
4877 x86_cpu_filter_features(xc, false);
4879 x86_cpu_list_feature_names(xc->filtered_features, next);
4881 object_unref(OBJECT(xc));
4884 /* Print all cpuid feature names in featureset
4886 static void listflags(GList *features)
4888 size_t len = 0;
4889 GList *tmp;
4891 for (tmp = features; tmp; tmp = tmp->next) {
4892 const char *name = tmp->data;
4893 if ((len + strlen(name) + 1) >= 75) {
4894 qemu_printf("\n");
4895 len = 0;
4897 qemu_printf("%s%s", len == 0 ? " " : " ", name);
4898 len += strlen(name) + 1;
4900 qemu_printf("\n");
4903 /* Sort alphabetically by type name, respecting X86CPUClass::ordering. */
4904 static gint x86_cpu_list_compare(gconstpointer a, gconstpointer b)
4906 ObjectClass *class_a = (ObjectClass *)a;
4907 ObjectClass *class_b = (ObjectClass *)b;
4908 X86CPUClass *cc_a = X86_CPU_CLASS(class_a);
4909 X86CPUClass *cc_b = X86_CPU_CLASS(class_b);
4910 int ret;
4912 if (cc_a->ordering != cc_b->ordering) {
4913 ret = cc_a->ordering - cc_b->ordering;
4914 } else {
4915 g_autofree char *name_a = x86_cpu_class_get_model_name(cc_a);
4916 g_autofree char *name_b = x86_cpu_class_get_model_name(cc_b);
4917 ret = strcmp(name_a, name_b);
4919 return ret;
4922 static GSList *get_sorted_cpu_model_list(void)
4924 GSList *list = object_class_get_list(TYPE_X86_CPU, false);
4925 list = g_slist_sort(list, x86_cpu_list_compare);
4926 return list;
4929 static char *x86_cpu_class_get_model_id(X86CPUClass *xc)
4931 Object *obj = object_new_with_class(OBJECT_CLASS(xc));
4932 char *r = object_property_get_str(obj, "model-id", &error_abort);
4933 object_unref(obj);
4934 return r;
4937 static char *x86_cpu_class_get_alias_of(X86CPUClass *cc)
4939 X86CPUVersion version;
4941 if (!cc->model || !cc->model->is_alias) {
4942 return NULL;
4944 version = x86_cpu_model_resolve_version(cc->model);
4945 if (version <= 0) {
4946 return NULL;
4948 return x86_cpu_versioned_model_name(cc->model->cpudef, version);
4951 static void x86_cpu_list_entry(gpointer data, gpointer user_data)
4953 ObjectClass *oc = data;
4954 X86CPUClass *cc = X86_CPU_CLASS(oc);
4955 g_autofree char *name = x86_cpu_class_get_model_name(cc);
4956 g_autofree char *desc = g_strdup(cc->model_description);
4957 g_autofree char *alias_of = x86_cpu_class_get_alias_of(cc);
4958 g_autofree char *model_id = x86_cpu_class_get_model_id(cc);
4960 if (!desc && alias_of) {
4961 if (cc->model && cc->model->version == CPU_VERSION_AUTO) {
4962 desc = g_strdup("(alias configured by machine type)");
4963 } else {
4964 desc = g_strdup_printf("(alias of %s)", alias_of);
4967 if (!desc && cc->model && cc->model->note) {
4968 desc = g_strdup_printf("%s [%s]", model_id, cc->model->note);
4970 if (!desc) {
4971 desc = g_strdup_printf("%s", model_id);
4974 qemu_printf("x86 %-20s %-58s\n", name, desc);
4977 /* list available CPU models and flags */
4978 void x86_cpu_list(void)
4980 int i, j;
4981 GSList *list;
4982 GList *names = NULL;
4984 qemu_printf("Available CPUs:\n");
4985 list = get_sorted_cpu_model_list();
4986 g_slist_foreach(list, x86_cpu_list_entry, NULL);
4987 g_slist_free(list);
4989 names = NULL;
4990 for (i = 0; i < ARRAY_SIZE(feature_word_info); i++) {
4991 FeatureWordInfo *fw = &feature_word_info[i];
4992 for (j = 0; j < 64; j++) {
4993 if (fw->feat_names[j]) {
4994 names = g_list_append(names, (gpointer)fw->feat_names[j]);
4999 names = g_list_sort(names, (GCompareFunc)strcmp);
5001 qemu_printf("\nRecognized CPUID flags:\n");
5002 listflags(names);
5003 qemu_printf("\n");
5004 g_list_free(names);
5007 static void x86_cpu_definition_entry(gpointer data, gpointer user_data)
5009 ObjectClass *oc = data;
5010 X86CPUClass *cc = X86_CPU_CLASS(oc);
5011 CpuDefinitionInfoList **cpu_list = user_data;
5012 CpuDefinitionInfoList *entry;
5013 CpuDefinitionInfo *info;
5015 info = g_malloc0(sizeof(*info));
5016 info->name = x86_cpu_class_get_model_name(cc);
5017 x86_cpu_class_check_missing_features(cc, &info->unavailable_features);
5018 info->has_unavailable_features = true;
5019 info->q_typename = g_strdup(object_class_get_name(oc));
5020 info->migration_safe = cc->migration_safe;
5021 info->has_migration_safe = true;
5022 info->q_static = cc->static_model;
5024 * Old machine types won't report aliases, so that alias translation
5025 * doesn't break compatibility with previous QEMU versions.
5027 if (default_cpu_version != CPU_VERSION_LEGACY) {
5028 info->alias_of = x86_cpu_class_get_alias_of(cc);
5029 info->has_alias_of = !!info->alias_of;
5032 entry = g_malloc0(sizeof(*entry));
5033 entry->value = info;
5034 entry->next = *cpu_list;
5035 *cpu_list = entry;
5038 CpuDefinitionInfoList *qmp_query_cpu_definitions(Error **errp)
5040 CpuDefinitionInfoList *cpu_list = NULL;
5041 GSList *list = get_sorted_cpu_model_list();
5042 g_slist_foreach(list, x86_cpu_definition_entry, &cpu_list);
5043 g_slist_free(list);
5044 return cpu_list;
5047 static uint64_t x86_cpu_get_supported_feature_word(FeatureWord w,
5048 bool migratable_only)
5050 FeatureWordInfo *wi = &feature_word_info[w];
5051 uint64_t r = 0;
5053 if (kvm_enabled()) {
5054 switch (wi->type) {
5055 case CPUID_FEATURE_WORD:
5056 r = kvm_arch_get_supported_cpuid(kvm_state, wi->cpuid.eax,
5057 wi->cpuid.ecx,
5058 wi->cpuid.reg);
5059 break;
5060 case MSR_FEATURE_WORD:
5061 r = kvm_arch_get_supported_msr_feature(kvm_state,
5062 wi->msr.index);
5063 break;
5065 } else if (hvf_enabled()) {
5066 if (wi->type != CPUID_FEATURE_WORD) {
5067 return 0;
5069 r = hvf_get_supported_cpuid(wi->cpuid.eax,
5070 wi->cpuid.ecx,
5071 wi->cpuid.reg);
5072 } else if (tcg_enabled()) {
5073 r = wi->tcg_features;
5074 } else {
5075 return ~0;
5077 if (migratable_only) {
5078 r &= x86_cpu_get_migratable_flags(w);
5080 return r;
5083 static void x86_cpu_apply_props(X86CPU *cpu, PropValue *props)
5085 PropValue *pv;
5086 for (pv = props; pv->prop; pv++) {
5087 if (!pv->value) {
5088 continue;
5090 object_property_parse(OBJECT(cpu), pv->prop, pv->value,
5091 &error_abort);
5095 /* Apply properties for the CPU model version specified in model */
5096 static void x86_cpu_apply_version_props(X86CPU *cpu, X86CPUModel *model)
5098 const X86CPUVersionDefinition *vdef;
5099 X86CPUVersion version = x86_cpu_model_resolve_version(model);
5101 if (version == CPU_VERSION_LEGACY) {
5102 return;
5105 for (vdef = x86_cpu_def_get_versions(model->cpudef); vdef->version; vdef++) {
5106 PropValue *p;
5108 for (p = vdef->props; p && p->prop; p++) {
5109 object_property_parse(OBJECT(cpu), p->prop, p->value,
5110 &error_abort);
5113 if (vdef->version == version) {
5114 break;
5119 * If we reached the end of the list, version number was invalid
5121 assert(vdef->version == version);
5124 /* Load data from X86CPUDefinition into a X86CPU object
5126 static void x86_cpu_load_model(X86CPU *cpu, X86CPUModel *model)
5128 X86CPUDefinition *def = model->cpudef;
5129 CPUX86State *env = &cpu->env;
5130 const char *vendor;
5131 char host_vendor[CPUID_VENDOR_SZ + 1];
5132 FeatureWord w;
5134 /*NOTE: any property set by this function should be returned by
5135 * x86_cpu_static_props(), so static expansion of
5136 * query-cpu-model-expansion is always complete.
5139 /* CPU models only set _minimum_ values for level/xlevel: */
5140 object_property_set_uint(OBJECT(cpu), "min-level", def->level,
5141 &error_abort);
5142 object_property_set_uint(OBJECT(cpu), "min-xlevel", def->xlevel,
5143 &error_abort);
5145 object_property_set_int(OBJECT(cpu), "family", def->family, &error_abort);
5146 object_property_set_int(OBJECT(cpu), "model", def->model, &error_abort);
5147 object_property_set_int(OBJECT(cpu), "stepping", def->stepping,
5148 &error_abort);
5149 object_property_set_str(OBJECT(cpu), "model-id", def->model_id,
5150 &error_abort);
5151 for (w = 0; w < FEATURE_WORDS; w++) {
5152 env->features[w] = def->features[w];
5155 /* legacy-cache defaults to 'off' if CPU model provides cache info */
5156 cpu->legacy_cache = !def->cache_info;
5158 /* Special cases not set in the X86CPUDefinition structs: */
5159 /* TODO: in-kernel irqchip for hvf */
5160 if (kvm_enabled()) {
5161 if (!kvm_irqchip_in_kernel()) {
5162 x86_cpu_change_kvm_default("x2apic", "off");
5165 x86_cpu_apply_props(cpu, kvm_default_props);
5166 } else if (tcg_enabled()) {
5167 x86_cpu_apply_props(cpu, tcg_default_props);
5170 env->features[FEAT_1_ECX] |= CPUID_EXT_HYPERVISOR;
5172 /* sysenter isn't supported in compatibility mode on AMD,
5173 * syscall isn't supported in compatibility mode on Intel.
5174 * Normally we advertise the actual CPU vendor, but you can
5175 * override this using the 'vendor' property if you want to use
5176 * KVM's sysenter/syscall emulation in compatibility mode and
5177 * when doing cross vendor migration
5179 vendor = def->vendor;
5180 if (accel_uses_host_cpuid()) {
5181 uint32_t ebx = 0, ecx = 0, edx = 0;
5182 host_cpuid(0, 0, NULL, &ebx, &ecx, &edx);
5183 x86_cpu_vendor_words2str(host_vendor, ebx, edx, ecx);
5184 vendor = host_vendor;
5187 object_property_set_str(OBJECT(cpu), "vendor", vendor, &error_abort);
5189 x86_cpu_apply_version_props(cpu, model);
5192 * Properties in versioned CPU model are not user specified features.
5193 * We can simply clear env->user_features here since it will be filled later
5194 * in x86_cpu_expand_features() based on plus_features and minus_features.
5196 memset(&env->user_features, 0, sizeof(env->user_features));
5199 #ifndef CONFIG_USER_ONLY
5200 /* Return a QDict containing keys for all properties that can be included
5201 * in static expansion of CPU models. All properties set by x86_cpu_load_model()
5202 * must be included in the dictionary.
5204 static QDict *x86_cpu_static_props(void)
5206 FeatureWord w;
5207 int i;
5208 static const char *props[] = {
5209 "min-level",
5210 "min-xlevel",
5211 "family",
5212 "model",
5213 "stepping",
5214 "model-id",
5215 "vendor",
5216 "lmce",
5217 NULL,
5219 static QDict *d;
5221 if (d) {
5222 return d;
5225 d = qdict_new();
5226 for (i = 0; props[i]; i++) {
5227 qdict_put_null(d, props[i]);
5230 for (w = 0; w < FEATURE_WORDS; w++) {
5231 FeatureWordInfo *fi = &feature_word_info[w];
5232 int bit;
5233 for (bit = 0; bit < 64; bit++) {
5234 if (!fi->feat_names[bit]) {
5235 continue;
5237 qdict_put_null(d, fi->feat_names[bit]);
5241 return d;
5244 /* Add an entry to @props dict, with the value for property. */
5245 static void x86_cpu_expand_prop(X86CPU *cpu, QDict *props, const char *prop)
5247 QObject *value = object_property_get_qobject(OBJECT(cpu), prop,
5248 &error_abort);
5250 qdict_put_obj(props, prop, value);
5253 /* Convert CPU model data from X86CPU object to a property dictionary
5254 * that can recreate exactly the same CPU model.
5256 static void x86_cpu_to_dict(X86CPU *cpu, QDict *props)
5258 QDict *sprops = x86_cpu_static_props();
5259 const QDictEntry *e;
5261 for (e = qdict_first(sprops); e; e = qdict_next(sprops, e)) {
5262 const char *prop = qdict_entry_key(e);
5263 x86_cpu_expand_prop(cpu, props, prop);
5267 /* Convert CPU model data from X86CPU object to a property dictionary
5268 * that can recreate exactly the same CPU model, including every
5269 * writeable QOM property.
5271 static void x86_cpu_to_dict_full(X86CPU *cpu, QDict *props)
5273 ObjectPropertyIterator iter;
5274 ObjectProperty *prop;
5276 object_property_iter_init(&iter, OBJECT(cpu));
5277 while ((prop = object_property_iter_next(&iter))) {
5278 /* skip read-only or write-only properties */
5279 if (!prop->get || !prop->set) {
5280 continue;
5283 /* "hotplugged" is the only property that is configurable
5284 * on the command-line but will be set differently on CPUs
5285 * created using "-cpu ... -smp ..." and by CPUs created
5286 * on the fly by x86_cpu_from_model() for querying. Skip it.
5288 if (!strcmp(prop->name, "hotplugged")) {
5289 continue;
5291 x86_cpu_expand_prop(cpu, props, prop->name);
5295 static void object_apply_props(Object *obj, QDict *props, Error **errp)
5297 const QDictEntry *prop;
5299 for (prop = qdict_first(props); prop; prop = qdict_next(props, prop)) {
5300 if (!object_property_set_qobject(obj, qdict_entry_key(prop),
5301 qdict_entry_value(prop), errp)) {
5302 break;
5307 /* Create X86CPU object according to model+props specification */
5308 static X86CPU *x86_cpu_from_model(const char *model, QDict *props, Error **errp)
5310 X86CPU *xc = NULL;
5311 X86CPUClass *xcc;
5312 Error *err = NULL;
5314 xcc = X86_CPU_CLASS(cpu_class_by_name(TYPE_X86_CPU, model));
5315 if (xcc == NULL) {
5316 error_setg(&err, "CPU model '%s' not found", model);
5317 goto out;
5320 xc = X86_CPU(object_new_with_class(OBJECT_CLASS(xcc)));
5321 if (props) {
5322 object_apply_props(OBJECT(xc), props, &err);
5323 if (err) {
5324 goto out;
5328 x86_cpu_expand_features(xc, &err);
5329 if (err) {
5330 goto out;
5333 out:
5334 if (err) {
5335 error_propagate(errp, err);
5336 object_unref(OBJECT(xc));
5337 xc = NULL;
5339 return xc;
5342 CpuModelExpansionInfo *
5343 qmp_query_cpu_model_expansion(CpuModelExpansionType type,
5344 CpuModelInfo *model,
5345 Error **errp)
5347 X86CPU *xc = NULL;
5348 Error *err = NULL;
5349 CpuModelExpansionInfo *ret = g_new0(CpuModelExpansionInfo, 1);
5350 QDict *props = NULL;
5351 const char *base_name;
5353 xc = x86_cpu_from_model(model->name,
5354 model->has_props ?
5355 qobject_to(QDict, model->props) :
5356 NULL, &err);
5357 if (err) {
5358 goto out;
5361 props = qdict_new();
5362 ret->model = g_new0(CpuModelInfo, 1);
5363 ret->model->props = QOBJECT(props);
5364 ret->model->has_props = true;
5366 switch (type) {
5367 case CPU_MODEL_EXPANSION_TYPE_STATIC:
5368 /* Static expansion will be based on "base" only */
5369 base_name = "base";
5370 x86_cpu_to_dict(xc, props);
5371 break;
5372 case CPU_MODEL_EXPANSION_TYPE_FULL:
5373 /* As we don't return every single property, full expansion needs
5374 * to keep the original model name+props, and add extra
5375 * properties on top of that.
5377 base_name = model->name;
5378 x86_cpu_to_dict_full(xc, props);
5379 break;
5380 default:
5381 error_setg(&err, "Unsupported expansion type");
5382 goto out;
5385 x86_cpu_to_dict(xc, props);
5387 ret->model->name = g_strdup(base_name);
5389 out:
5390 object_unref(OBJECT(xc));
5391 if (err) {
5392 error_propagate(errp, err);
5393 qapi_free_CpuModelExpansionInfo(ret);
5394 ret = NULL;
5396 return ret;
5398 #endif /* !CONFIG_USER_ONLY */
5400 static gchar *x86_gdb_arch_name(CPUState *cs)
5402 #ifdef TARGET_X86_64
5403 return g_strdup("i386:x86-64");
5404 #else
5405 return g_strdup("i386");
5406 #endif
5409 static void x86_cpu_cpudef_class_init(ObjectClass *oc, void *data)
5411 X86CPUModel *model = data;
5412 X86CPUClass *xcc = X86_CPU_CLASS(oc);
5414 xcc->model = model;
5415 xcc->migration_safe = true;
5418 static void x86_register_cpu_model_type(const char *name, X86CPUModel *model)
5420 g_autofree char *typename = x86_cpu_type_name(name);
5421 TypeInfo ti = {
5422 .name = typename,
5423 .parent = TYPE_X86_CPU,
5424 .class_init = x86_cpu_cpudef_class_init,
5425 .class_data = model,
5428 type_register(&ti);
5431 static void x86_register_cpudef_types(X86CPUDefinition *def)
5433 X86CPUModel *m;
5434 const X86CPUVersionDefinition *vdef;
5436 /* AMD aliases are handled at runtime based on CPUID vendor, so
5437 * they shouldn't be set on the CPU model table.
5439 assert(!(def->features[FEAT_8000_0001_EDX] & CPUID_EXT2_AMD_ALIASES));
5440 /* catch mistakes instead of silently truncating model_id when too long */
5441 assert(def->model_id && strlen(def->model_id) <= 48);
5443 /* Unversioned model: */
5444 m = g_new0(X86CPUModel, 1);
5445 m->cpudef = def;
5446 m->version = CPU_VERSION_AUTO;
5447 m->is_alias = true;
5448 x86_register_cpu_model_type(def->name, m);
5450 /* Versioned models: */
5452 for (vdef = x86_cpu_def_get_versions(def); vdef->version; vdef++) {
5453 X86CPUModel *m = g_new0(X86CPUModel, 1);
5454 g_autofree char *name =
5455 x86_cpu_versioned_model_name(def, vdef->version);
5456 m->cpudef = def;
5457 m->version = vdef->version;
5458 m->note = vdef->note;
5459 x86_register_cpu_model_type(name, m);
5461 if (vdef->alias) {
5462 X86CPUModel *am = g_new0(X86CPUModel, 1);
5463 am->cpudef = def;
5464 am->version = vdef->version;
5465 am->is_alias = true;
5466 x86_register_cpu_model_type(vdef->alias, am);
5472 #if !defined(CONFIG_USER_ONLY)
5474 void cpu_clear_apic_feature(CPUX86State *env)
5476 env->features[FEAT_1_EDX] &= ~CPUID_APIC;
5479 #endif /* !CONFIG_USER_ONLY */
5481 void cpu_x86_cpuid(CPUX86State *env, uint32_t index, uint32_t count,
5482 uint32_t *eax, uint32_t *ebx,
5483 uint32_t *ecx, uint32_t *edx)
5485 X86CPU *cpu = env_archcpu(env);
5486 CPUState *cs = env_cpu(env);
5487 uint32_t die_offset;
5488 uint32_t limit;
5489 uint32_t signature[3];
5490 X86CPUTopoInfo topo_info;
5492 topo_info.nodes_per_pkg = env->nr_nodes;
5493 topo_info.dies_per_pkg = env->nr_dies;
5494 topo_info.cores_per_die = cs->nr_cores;
5495 topo_info.threads_per_core = cs->nr_threads;
5497 /* Calculate & apply limits for different index ranges */
5498 if (index >= 0xC0000000) {
5499 limit = env->cpuid_xlevel2;
5500 } else if (index >= 0x80000000) {
5501 limit = env->cpuid_xlevel;
5502 } else if (index >= 0x40000000) {
5503 limit = 0x40000001;
5504 } else {
5505 limit = env->cpuid_level;
5508 if (index > limit) {
5509 /* Intel documentation states that invalid EAX input will
5510 * return the same information as EAX=cpuid_level
5511 * (Intel SDM Vol. 2A - Instruction Set Reference - CPUID)
5513 index = env->cpuid_level;
5516 switch(index) {
5517 case 0:
5518 *eax = env->cpuid_level;
5519 *ebx = env->cpuid_vendor1;
5520 *edx = env->cpuid_vendor2;
5521 *ecx = env->cpuid_vendor3;
5522 break;
5523 case 1:
5524 *eax = env->cpuid_version;
5525 *ebx = (cpu->apic_id << 24) |
5526 8 << 8; /* CLFLUSH size in quad words, Linux wants it. */
5527 *ecx = env->features[FEAT_1_ECX];
5528 if ((*ecx & CPUID_EXT_XSAVE) && (env->cr[4] & CR4_OSXSAVE_MASK)) {
5529 *ecx |= CPUID_EXT_OSXSAVE;
5531 *edx = env->features[FEAT_1_EDX];
5532 if (cs->nr_cores * cs->nr_threads > 1) {
5533 *ebx |= (cs->nr_cores * cs->nr_threads) << 16;
5534 *edx |= CPUID_HT;
5536 if (!cpu->enable_pmu) {
5537 *ecx &= ~CPUID_EXT_PDCM;
5539 break;
5540 case 2:
5541 /* cache info: needed for Pentium Pro compatibility */
5542 if (cpu->cache_info_passthrough) {
5543 host_cpuid(index, 0, eax, ebx, ecx, edx);
5544 break;
5546 *eax = 1; /* Number of CPUID[EAX=2] calls required */
5547 *ebx = 0;
5548 if (!cpu->enable_l3_cache) {
5549 *ecx = 0;
5550 } else {
5551 *ecx = cpuid2_cache_descriptor(env->cache_info_cpuid2.l3_cache);
5553 *edx = (cpuid2_cache_descriptor(env->cache_info_cpuid2.l1d_cache) << 16) |
5554 (cpuid2_cache_descriptor(env->cache_info_cpuid2.l1i_cache) << 8) |
5555 (cpuid2_cache_descriptor(env->cache_info_cpuid2.l2_cache));
5556 break;
5557 case 4:
5558 /* cache info: needed for Core compatibility */
5559 if (cpu->cache_info_passthrough) {
5560 host_cpuid(index, count, eax, ebx, ecx, edx);
5561 /* QEMU gives out its own APIC IDs, never pass down bits 31..26. */
5562 *eax &= ~0xFC000000;
5563 if ((*eax & 31) && cs->nr_cores > 1) {
5564 *eax |= (cs->nr_cores - 1) << 26;
5566 } else {
5567 *eax = 0;
5568 switch (count) {
5569 case 0: /* L1 dcache info */
5570 encode_cache_cpuid4(env->cache_info_cpuid4.l1d_cache,
5571 1, cs->nr_cores,
5572 eax, ebx, ecx, edx);
5573 break;
5574 case 1: /* L1 icache info */
5575 encode_cache_cpuid4(env->cache_info_cpuid4.l1i_cache,
5576 1, cs->nr_cores,
5577 eax, ebx, ecx, edx);
5578 break;
5579 case 2: /* L2 cache info */
5580 encode_cache_cpuid4(env->cache_info_cpuid4.l2_cache,
5581 cs->nr_threads, cs->nr_cores,
5582 eax, ebx, ecx, edx);
5583 break;
5584 case 3: /* L3 cache info */
5585 die_offset = apicid_die_offset(&topo_info);
5586 if (cpu->enable_l3_cache) {
5587 encode_cache_cpuid4(env->cache_info_cpuid4.l3_cache,
5588 (1 << die_offset), cs->nr_cores,
5589 eax, ebx, ecx, edx);
5590 break;
5592 /* fall through */
5593 default: /* end of info */
5594 *eax = *ebx = *ecx = *edx = 0;
5595 break;
5598 break;
5599 case 5:
5600 /* MONITOR/MWAIT Leaf */
5601 *eax = cpu->mwait.eax; /* Smallest monitor-line size in bytes */
5602 *ebx = cpu->mwait.ebx; /* Largest monitor-line size in bytes */
5603 *ecx = cpu->mwait.ecx; /* flags */
5604 *edx = cpu->mwait.edx; /* mwait substates */
5605 break;
5606 case 6:
5607 /* Thermal and Power Leaf */
5608 *eax = env->features[FEAT_6_EAX];
5609 *ebx = 0;
5610 *ecx = 0;
5611 *edx = 0;
5612 break;
5613 case 7:
5614 /* Structured Extended Feature Flags Enumeration Leaf */
5615 if (count == 0) {
5616 /* Maximum ECX value for sub-leaves */
5617 *eax = env->cpuid_level_func7;
5618 *ebx = env->features[FEAT_7_0_EBX]; /* Feature flags */
5619 *ecx = env->features[FEAT_7_0_ECX]; /* Feature flags */
5620 if ((*ecx & CPUID_7_0_ECX_PKU) && env->cr[4] & CR4_PKE_MASK) {
5621 *ecx |= CPUID_7_0_ECX_OSPKE;
5623 *edx = env->features[FEAT_7_0_EDX]; /* Feature flags */
5624 } else if (count == 1) {
5625 *eax = env->features[FEAT_7_1_EAX];
5626 *ebx = 0;
5627 *ecx = 0;
5628 *edx = 0;
5629 } else {
5630 *eax = 0;
5631 *ebx = 0;
5632 *ecx = 0;
5633 *edx = 0;
5635 break;
5636 case 9:
5637 /* Direct Cache Access Information Leaf */
5638 *eax = 0; /* Bits 0-31 in DCA_CAP MSR */
5639 *ebx = 0;
5640 *ecx = 0;
5641 *edx = 0;
5642 break;
5643 case 0xA:
5644 /* Architectural Performance Monitoring Leaf */
5645 if (kvm_enabled() && cpu->enable_pmu) {
5646 KVMState *s = cs->kvm_state;
5648 *eax = kvm_arch_get_supported_cpuid(s, 0xA, count, R_EAX);
5649 *ebx = kvm_arch_get_supported_cpuid(s, 0xA, count, R_EBX);
5650 *ecx = kvm_arch_get_supported_cpuid(s, 0xA, count, R_ECX);
5651 *edx = kvm_arch_get_supported_cpuid(s, 0xA, count, R_EDX);
5652 } else if (hvf_enabled() && cpu->enable_pmu) {
5653 *eax = hvf_get_supported_cpuid(0xA, count, R_EAX);
5654 *ebx = hvf_get_supported_cpuid(0xA, count, R_EBX);
5655 *ecx = hvf_get_supported_cpuid(0xA, count, R_ECX);
5656 *edx = hvf_get_supported_cpuid(0xA, count, R_EDX);
5657 } else {
5658 *eax = 0;
5659 *ebx = 0;
5660 *ecx = 0;
5661 *edx = 0;
5663 break;
5664 case 0xB:
5665 /* Extended Topology Enumeration Leaf */
5666 if (!cpu->enable_cpuid_0xb) {
5667 *eax = *ebx = *ecx = *edx = 0;
5668 break;
5671 *ecx = count & 0xff;
5672 *edx = cpu->apic_id;
5674 switch (count) {
5675 case 0:
5676 *eax = apicid_core_offset(&topo_info);
5677 *ebx = cs->nr_threads;
5678 *ecx |= CPUID_TOPOLOGY_LEVEL_SMT;
5679 break;
5680 case 1:
5681 *eax = env->pkg_offset;
5682 *ebx = cs->nr_cores * cs->nr_threads;
5683 *ecx |= CPUID_TOPOLOGY_LEVEL_CORE;
5684 break;
5685 default:
5686 *eax = 0;
5687 *ebx = 0;
5688 *ecx |= CPUID_TOPOLOGY_LEVEL_INVALID;
5691 assert(!(*eax & ~0x1f));
5692 *ebx &= 0xffff; /* The count doesn't need to be reliable. */
5693 break;
5694 case 0x1F:
5695 /* V2 Extended Topology Enumeration Leaf */
5696 if (env->nr_dies < 2) {
5697 *eax = *ebx = *ecx = *edx = 0;
5698 break;
5701 *ecx = count & 0xff;
5702 *edx = cpu->apic_id;
5703 switch (count) {
5704 case 0:
5705 *eax = apicid_core_offset(&topo_info);
5706 *ebx = cs->nr_threads;
5707 *ecx |= CPUID_TOPOLOGY_LEVEL_SMT;
5708 break;
5709 case 1:
5710 *eax = apicid_die_offset(&topo_info);
5711 *ebx = cs->nr_cores * cs->nr_threads;
5712 *ecx |= CPUID_TOPOLOGY_LEVEL_CORE;
5713 break;
5714 case 2:
5715 *eax = env->pkg_offset;
5716 *ebx = env->nr_dies * cs->nr_cores * cs->nr_threads;
5717 *ecx |= CPUID_TOPOLOGY_LEVEL_DIE;
5718 break;
5719 default:
5720 *eax = 0;
5721 *ebx = 0;
5722 *ecx |= CPUID_TOPOLOGY_LEVEL_INVALID;
5724 assert(!(*eax & ~0x1f));
5725 *ebx &= 0xffff; /* The count doesn't need to be reliable. */
5726 break;
5727 case 0xD: {
5728 /* Processor Extended State */
5729 *eax = 0;
5730 *ebx = 0;
5731 *ecx = 0;
5732 *edx = 0;
5733 if (!(env->features[FEAT_1_ECX] & CPUID_EXT_XSAVE)) {
5734 break;
5737 if (count == 0) {
5738 *ecx = xsave_area_size(x86_cpu_xsave_components(cpu));
5739 *eax = env->features[FEAT_XSAVE_COMP_LO];
5740 *edx = env->features[FEAT_XSAVE_COMP_HI];
5742 * The initial value of xcr0 and ebx == 0, On host without kvm
5743 * commit 412a3c41(e.g., CentOS 6), the ebx's value always == 0
5744 * even through guest update xcr0, this will crash some legacy guest
5745 * (e.g., CentOS 6), So set ebx == ecx to workaroud it.
5747 *ebx = kvm_enabled() ? *ecx : xsave_area_size(env->xcr0);
5748 } else if (count == 1) {
5749 *eax = env->features[FEAT_XSAVE];
5750 } else if (count < ARRAY_SIZE(x86_ext_save_areas)) {
5751 if ((x86_cpu_xsave_components(cpu) >> count) & 1) {
5752 const ExtSaveArea *esa = &x86_ext_save_areas[count];
5753 *eax = esa->size;
5754 *ebx = esa->offset;
5757 break;
5759 case 0x14: {
5760 /* Intel Processor Trace Enumeration */
5761 *eax = 0;
5762 *ebx = 0;
5763 *ecx = 0;
5764 *edx = 0;
5765 if (!(env->features[FEAT_7_0_EBX] & CPUID_7_0_EBX_INTEL_PT) ||
5766 !kvm_enabled()) {
5767 break;
5770 if (count == 0) {
5771 *eax = INTEL_PT_MAX_SUBLEAF;
5772 *ebx = INTEL_PT_MINIMAL_EBX;
5773 *ecx = INTEL_PT_MINIMAL_ECX;
5774 } else if (count == 1) {
5775 *eax = INTEL_PT_MTC_BITMAP | INTEL_PT_ADDR_RANGES_NUM;
5776 *ebx = INTEL_PT_PSB_BITMAP | INTEL_PT_CYCLE_BITMAP;
5778 break;
5780 case 0x40000000:
5782 * CPUID code in kvm_arch_init_vcpu() ignores stuff
5783 * set here, but we restrict to TCG none the less.
5785 if (tcg_enabled() && cpu->expose_tcg) {
5786 memcpy(signature, "TCGTCGTCGTCG", 12);
5787 *eax = 0x40000001;
5788 *ebx = signature[0];
5789 *ecx = signature[1];
5790 *edx = signature[2];
5791 } else {
5792 *eax = 0;
5793 *ebx = 0;
5794 *ecx = 0;
5795 *edx = 0;
5797 break;
5798 case 0x40000001:
5799 *eax = 0;
5800 *ebx = 0;
5801 *ecx = 0;
5802 *edx = 0;
5803 break;
5804 case 0x80000000:
5805 *eax = env->cpuid_xlevel;
5806 *ebx = env->cpuid_vendor1;
5807 *edx = env->cpuid_vendor2;
5808 *ecx = env->cpuid_vendor3;
5809 break;
5810 case 0x80000001:
5811 *eax = env->cpuid_version;
5812 *ebx = 0;
5813 *ecx = env->features[FEAT_8000_0001_ECX];
5814 *edx = env->features[FEAT_8000_0001_EDX];
5816 /* The Linux kernel checks for the CMPLegacy bit and
5817 * discards multiple thread information if it is set.
5818 * So don't set it here for Intel to make Linux guests happy.
5820 if (cs->nr_cores * cs->nr_threads > 1) {
5821 if (env->cpuid_vendor1 != CPUID_VENDOR_INTEL_1 ||
5822 env->cpuid_vendor2 != CPUID_VENDOR_INTEL_2 ||
5823 env->cpuid_vendor3 != CPUID_VENDOR_INTEL_3) {
5824 *ecx |= 1 << 1; /* CmpLegacy bit */
5827 break;
5828 case 0x80000002:
5829 case 0x80000003:
5830 case 0x80000004:
5831 *eax = env->cpuid_model[(index - 0x80000002) * 4 + 0];
5832 *ebx = env->cpuid_model[(index - 0x80000002) * 4 + 1];
5833 *ecx = env->cpuid_model[(index - 0x80000002) * 4 + 2];
5834 *edx = env->cpuid_model[(index - 0x80000002) * 4 + 3];
5835 break;
5836 case 0x80000005:
5837 /* cache info (L1 cache) */
5838 if (cpu->cache_info_passthrough) {
5839 host_cpuid(index, 0, eax, ebx, ecx, edx);
5840 break;
5842 *eax = (L1_DTLB_2M_ASSOC << 24) | (L1_DTLB_2M_ENTRIES << 16) |
5843 (L1_ITLB_2M_ASSOC << 8) | (L1_ITLB_2M_ENTRIES);
5844 *ebx = (L1_DTLB_4K_ASSOC << 24) | (L1_DTLB_4K_ENTRIES << 16) |
5845 (L1_ITLB_4K_ASSOC << 8) | (L1_ITLB_4K_ENTRIES);
5846 *ecx = encode_cache_cpuid80000005(env->cache_info_amd.l1d_cache);
5847 *edx = encode_cache_cpuid80000005(env->cache_info_amd.l1i_cache);
5848 break;
5849 case 0x80000006:
5850 /* cache info (L2 cache) */
5851 if (cpu->cache_info_passthrough) {
5852 host_cpuid(index, 0, eax, ebx, ecx, edx);
5853 break;
5855 *eax = (AMD_ENC_ASSOC(L2_DTLB_2M_ASSOC) << 28) |
5856 (L2_DTLB_2M_ENTRIES << 16) |
5857 (AMD_ENC_ASSOC(L2_ITLB_2M_ASSOC) << 12) |
5858 (L2_ITLB_2M_ENTRIES);
5859 *ebx = (AMD_ENC_ASSOC(L2_DTLB_4K_ASSOC) << 28) |
5860 (L2_DTLB_4K_ENTRIES << 16) |
5861 (AMD_ENC_ASSOC(L2_ITLB_4K_ASSOC) << 12) |
5862 (L2_ITLB_4K_ENTRIES);
5863 encode_cache_cpuid80000006(env->cache_info_amd.l2_cache,
5864 cpu->enable_l3_cache ?
5865 env->cache_info_amd.l3_cache : NULL,
5866 ecx, edx);
5867 break;
5868 case 0x80000007:
5869 *eax = 0;
5870 *ebx = 0;
5871 *ecx = 0;
5872 *edx = env->features[FEAT_8000_0007_EDX];
5873 break;
5874 case 0x80000008:
5875 /* virtual & phys address size in low 2 bytes. */
5876 if (env->features[FEAT_8000_0001_EDX] & CPUID_EXT2_LM) {
5877 /* 64 bit processor */
5878 *eax = cpu->phys_bits; /* configurable physical bits */
5879 if (env->features[FEAT_7_0_ECX] & CPUID_7_0_ECX_LA57) {
5880 *eax |= 0x00003900; /* 57 bits virtual */
5881 } else {
5882 *eax |= 0x00003000; /* 48 bits virtual */
5884 } else {
5885 *eax = cpu->phys_bits;
5887 *ebx = env->features[FEAT_8000_0008_EBX];
5888 if (cs->nr_cores * cs->nr_threads > 1) {
5890 * Bits 15:12 is "The number of bits in the initial
5891 * Core::X86::Apic::ApicId[ApicId] value that indicate
5892 * thread ID within a package". This is already stored at
5893 * CPUX86State::pkg_offset.
5894 * Bits 7:0 is "The number of threads in the package is NC+1"
5896 *ecx = (env->pkg_offset << 12) |
5897 ((cs->nr_cores * cs->nr_threads) - 1);
5898 } else {
5899 *ecx = 0;
5901 *edx = 0;
5902 break;
5903 case 0x8000000A:
5904 if (env->features[FEAT_8000_0001_ECX] & CPUID_EXT3_SVM) {
5905 *eax = 0x00000001; /* SVM Revision */
5906 *ebx = 0x00000010; /* nr of ASIDs */
5907 *ecx = 0;
5908 *edx = env->features[FEAT_SVM]; /* optional features */
5909 } else {
5910 *eax = 0;
5911 *ebx = 0;
5912 *ecx = 0;
5913 *edx = 0;
5915 break;
5916 case 0x8000001D:
5917 *eax = 0;
5918 if (cpu->cache_info_passthrough) {
5919 host_cpuid(index, count, eax, ebx, ecx, edx);
5920 break;
5922 switch (count) {
5923 case 0: /* L1 dcache info */
5924 encode_cache_cpuid8000001d(env->cache_info_amd.l1d_cache,
5925 &topo_info, eax, ebx, ecx, edx);
5926 break;
5927 case 1: /* L1 icache info */
5928 encode_cache_cpuid8000001d(env->cache_info_amd.l1i_cache,
5929 &topo_info, eax, ebx, ecx, edx);
5930 break;
5931 case 2: /* L2 cache info */
5932 encode_cache_cpuid8000001d(env->cache_info_amd.l2_cache,
5933 &topo_info, eax, ebx, ecx, edx);
5934 break;
5935 case 3: /* L3 cache info */
5936 encode_cache_cpuid8000001d(env->cache_info_amd.l3_cache,
5937 &topo_info, eax, ebx, ecx, edx);
5938 break;
5939 default: /* end of info */
5940 *eax = *ebx = *ecx = *edx = 0;
5941 break;
5943 break;
5944 case 0x8000001E:
5945 assert(cpu->core_id <= 255);
5946 encode_topo_cpuid8000001e(&topo_info, cpu, eax, ebx, ecx, edx);
5947 break;
5948 case 0xC0000000:
5949 *eax = env->cpuid_xlevel2;
5950 *ebx = 0;
5951 *ecx = 0;
5952 *edx = 0;
5953 break;
5954 case 0xC0000001:
5955 /* Support for VIA CPU's CPUID instruction */
5956 *eax = env->cpuid_version;
5957 *ebx = 0;
5958 *ecx = 0;
5959 *edx = env->features[FEAT_C000_0001_EDX];
5960 break;
5961 case 0xC0000002:
5962 case 0xC0000003:
5963 case 0xC0000004:
5964 /* Reserved for the future, and now filled with zero */
5965 *eax = 0;
5966 *ebx = 0;
5967 *ecx = 0;
5968 *edx = 0;
5969 break;
5970 case 0x8000001F:
5971 *eax = sev_enabled() ? 0x2 : 0;
5972 *ebx = sev_get_cbit_position();
5973 *ebx |= sev_get_reduced_phys_bits() << 6;
5974 *ecx = 0;
5975 *edx = 0;
5976 break;
5977 default:
5978 /* reserved values: zero */
5979 *eax = 0;
5980 *ebx = 0;
5981 *ecx = 0;
5982 *edx = 0;
5983 break;
5987 static void x86_cpu_reset(DeviceState *dev)
5989 CPUState *s = CPU(dev);
5990 X86CPU *cpu = X86_CPU(s);
5991 X86CPUClass *xcc = X86_CPU_GET_CLASS(cpu);
5992 CPUX86State *env = &cpu->env;
5993 target_ulong cr4;
5994 uint64_t xcr0;
5995 int i;
5997 xcc->parent_reset(dev);
5999 memset(env, 0, offsetof(CPUX86State, end_reset_fields));
6001 env->old_exception = -1;
6003 /* init to reset state */
6005 env->hflags2 |= HF2_GIF_MASK;
6006 env->hflags &= ~HF_GUEST_MASK;
6008 cpu_x86_update_cr0(env, 0x60000010);
6009 env->a20_mask = ~0x0;
6010 env->smbase = 0x30000;
6011 env->msr_smi_count = 0;
6013 env->idt.limit = 0xffff;
6014 env->gdt.limit = 0xffff;
6015 env->ldt.limit = 0xffff;
6016 env->ldt.flags = DESC_P_MASK | (2 << DESC_TYPE_SHIFT);
6017 env->tr.limit = 0xffff;
6018 env->tr.flags = DESC_P_MASK | (11 << DESC_TYPE_SHIFT);
6020 cpu_x86_load_seg_cache(env, R_CS, 0xf000, 0xffff0000, 0xffff,
6021 DESC_P_MASK | DESC_S_MASK | DESC_CS_MASK |
6022 DESC_R_MASK | DESC_A_MASK);
6023 cpu_x86_load_seg_cache(env, R_DS, 0, 0, 0xffff,
6024 DESC_P_MASK | DESC_S_MASK | DESC_W_MASK |
6025 DESC_A_MASK);
6026 cpu_x86_load_seg_cache(env, R_ES, 0, 0, 0xffff,
6027 DESC_P_MASK | DESC_S_MASK | DESC_W_MASK |
6028 DESC_A_MASK);
6029 cpu_x86_load_seg_cache(env, R_SS, 0, 0, 0xffff,
6030 DESC_P_MASK | DESC_S_MASK | DESC_W_MASK |
6031 DESC_A_MASK);
6032 cpu_x86_load_seg_cache(env, R_FS, 0, 0, 0xffff,
6033 DESC_P_MASK | DESC_S_MASK | DESC_W_MASK |
6034 DESC_A_MASK);
6035 cpu_x86_load_seg_cache(env, R_GS, 0, 0, 0xffff,
6036 DESC_P_MASK | DESC_S_MASK | DESC_W_MASK |
6037 DESC_A_MASK);
6039 env->eip = 0xfff0;
6040 env->regs[R_EDX] = env->cpuid_version;
6042 env->eflags = 0x2;
6044 /* FPU init */
6045 for (i = 0; i < 8; i++) {
6046 env->fptags[i] = 1;
6048 cpu_set_fpuc(env, 0x37f);
6050 env->mxcsr = 0x1f80;
6051 /* All units are in INIT state. */
6052 env->xstate_bv = 0;
6054 env->pat = 0x0007040600070406ULL;
6055 env->msr_ia32_misc_enable = MSR_IA32_MISC_ENABLE_DEFAULT;
6056 if (env->features[FEAT_1_ECX] & CPUID_EXT_MONITOR) {
6057 env->msr_ia32_misc_enable |= MSR_IA32_MISC_ENABLE_MWAIT;
6060 memset(env->dr, 0, sizeof(env->dr));
6061 env->dr[6] = DR6_FIXED_1;
6062 env->dr[7] = DR7_FIXED_1;
6063 cpu_breakpoint_remove_all(s, BP_CPU);
6064 cpu_watchpoint_remove_all(s, BP_CPU);
6066 cr4 = 0;
6067 xcr0 = XSTATE_FP_MASK;
6069 #ifdef CONFIG_USER_ONLY
6070 /* Enable all the features for user-mode. */
6071 if (env->features[FEAT_1_EDX] & CPUID_SSE) {
6072 xcr0 |= XSTATE_SSE_MASK;
6074 for (i = 2; i < ARRAY_SIZE(x86_ext_save_areas); i++) {
6075 const ExtSaveArea *esa = &x86_ext_save_areas[i];
6076 if (env->features[esa->feature] & esa->bits) {
6077 xcr0 |= 1ull << i;
6081 if (env->features[FEAT_1_ECX] & CPUID_EXT_XSAVE) {
6082 cr4 |= CR4_OSFXSR_MASK | CR4_OSXSAVE_MASK;
6084 if (env->features[FEAT_7_0_EBX] & CPUID_7_0_EBX_FSGSBASE) {
6085 cr4 |= CR4_FSGSBASE_MASK;
6087 #endif
6089 env->xcr0 = xcr0;
6090 cpu_x86_update_cr4(env, cr4);
6093 * SDM 11.11.5 requires:
6094 * - IA32_MTRR_DEF_TYPE MSR.E = 0
6095 * - IA32_MTRR_PHYSMASKn.V = 0
6096 * All other bits are undefined. For simplification, zero it all.
6098 env->mtrr_deftype = 0;
6099 memset(env->mtrr_var, 0, sizeof(env->mtrr_var));
6100 memset(env->mtrr_fixed, 0, sizeof(env->mtrr_fixed));
6102 env->interrupt_injected = -1;
6103 env->exception_nr = -1;
6104 env->exception_pending = 0;
6105 env->exception_injected = 0;
6106 env->exception_has_payload = false;
6107 env->exception_payload = 0;
6108 env->nmi_injected = false;
6109 #if !defined(CONFIG_USER_ONLY)
6110 /* We hard-wire the BSP to the first CPU. */
6111 apic_designate_bsp(cpu->apic_state, s->cpu_index == 0);
6113 s->halted = !cpu_is_bsp(cpu);
6115 if (kvm_enabled()) {
6116 kvm_arch_reset_vcpu(cpu);
6118 #endif
6121 #ifndef CONFIG_USER_ONLY
6122 bool cpu_is_bsp(X86CPU *cpu)
6124 return cpu_get_apic_base(cpu->apic_state) & MSR_IA32_APICBASE_BSP;
6127 /* TODO: remove me, when reset over QOM tree is implemented */
6128 static void x86_cpu_machine_reset_cb(void *opaque)
6130 X86CPU *cpu = opaque;
6131 cpu_reset(CPU(cpu));
6133 #endif
6135 static void mce_init(X86CPU *cpu)
6137 CPUX86State *cenv = &cpu->env;
6138 unsigned int bank;
6140 if (((cenv->cpuid_version >> 8) & 0xf) >= 6
6141 && (cenv->features[FEAT_1_EDX] & (CPUID_MCE | CPUID_MCA)) ==
6142 (CPUID_MCE | CPUID_MCA)) {
6143 cenv->mcg_cap = MCE_CAP_DEF | MCE_BANKS_DEF |
6144 (cpu->enable_lmce ? MCG_LMCE_P : 0);
6145 cenv->mcg_ctl = ~(uint64_t)0;
6146 for (bank = 0; bank < MCE_BANKS_DEF; bank++) {
6147 cenv->mce_banks[bank * 4] = ~(uint64_t)0;
6152 #ifndef CONFIG_USER_ONLY
6153 APICCommonClass *apic_get_class(void)
6155 const char *apic_type = "apic";
6157 /* TODO: in-kernel irqchip for hvf */
6158 if (kvm_apic_in_kernel()) {
6159 apic_type = "kvm-apic";
6160 } else if (xen_enabled()) {
6161 apic_type = "xen-apic";
6164 return APIC_COMMON_CLASS(object_class_by_name(apic_type));
6167 static void x86_cpu_apic_create(X86CPU *cpu, Error **errp)
6169 APICCommonState *apic;
6170 ObjectClass *apic_class = OBJECT_CLASS(apic_get_class());
6172 cpu->apic_state = DEVICE(object_new_with_class(apic_class));
6174 object_property_add_child(OBJECT(cpu), "lapic",
6175 OBJECT(cpu->apic_state));
6176 object_unref(OBJECT(cpu->apic_state));
6178 qdev_prop_set_uint32(cpu->apic_state, "id", cpu->apic_id);
6179 /* TODO: convert to link<> */
6180 apic = APIC_COMMON(cpu->apic_state);
6181 apic->cpu = cpu;
6182 apic->apicbase = APIC_DEFAULT_ADDRESS | MSR_IA32_APICBASE_ENABLE;
6185 static void x86_cpu_apic_realize(X86CPU *cpu, Error **errp)
6187 APICCommonState *apic;
6188 static bool apic_mmio_map_once;
6190 if (cpu->apic_state == NULL) {
6191 return;
6193 qdev_realize(DEVICE(cpu->apic_state), NULL, errp);
6195 /* Map APIC MMIO area */
6196 apic = APIC_COMMON(cpu->apic_state);
6197 if (!apic_mmio_map_once) {
6198 memory_region_add_subregion_overlap(get_system_memory(),
6199 apic->apicbase &
6200 MSR_IA32_APICBASE_BASE,
6201 &apic->io_memory,
6202 0x1000);
6203 apic_mmio_map_once = true;
6207 static void x86_cpu_machine_done(Notifier *n, void *unused)
6209 X86CPU *cpu = container_of(n, X86CPU, machine_done);
6210 MemoryRegion *smram =
6211 (MemoryRegion *) object_resolve_path("/machine/smram", NULL);
6213 if (smram) {
6214 cpu->smram = g_new(MemoryRegion, 1);
6215 memory_region_init_alias(cpu->smram, OBJECT(cpu), "smram",
6216 smram, 0, 4 * GiB);
6217 memory_region_set_enabled(cpu->smram, true);
6218 memory_region_add_subregion_overlap(cpu->cpu_as_root, 0, cpu->smram, 1);
6221 #else
6222 static void x86_cpu_apic_realize(X86CPU *cpu, Error **errp)
6225 #endif
6227 /* Note: Only safe for use on x86(-64) hosts */
6228 static uint32_t x86_host_phys_bits(void)
6230 uint32_t eax;
6231 uint32_t host_phys_bits;
6233 host_cpuid(0x80000000, 0, &eax, NULL, NULL, NULL);
6234 if (eax >= 0x80000008) {
6235 host_cpuid(0x80000008, 0, &eax, NULL, NULL, NULL);
6236 /* Note: According to AMD doc 25481 rev 2.34 they have a field
6237 * at 23:16 that can specify a maximum physical address bits for
6238 * the guest that can override this value; but I've not seen
6239 * anything with that set.
6241 host_phys_bits = eax & 0xff;
6242 } else {
6243 /* It's an odd 64 bit machine that doesn't have the leaf for
6244 * physical address bits; fall back to 36 that's most older
6245 * Intel.
6247 host_phys_bits = 36;
6250 return host_phys_bits;
6253 static void x86_cpu_adjust_level(X86CPU *cpu, uint32_t *min, uint32_t value)
6255 if (*min < value) {
6256 *min = value;
6260 /* Increase cpuid_min_{level,xlevel,xlevel2} automatically, if appropriate */
6261 static void x86_cpu_adjust_feat_level(X86CPU *cpu, FeatureWord w)
6263 CPUX86State *env = &cpu->env;
6264 FeatureWordInfo *fi = &feature_word_info[w];
6265 uint32_t eax = fi->cpuid.eax;
6266 uint32_t region = eax & 0xF0000000;
6268 assert(feature_word_info[w].type == CPUID_FEATURE_WORD);
6269 if (!env->features[w]) {
6270 return;
6273 switch (region) {
6274 case 0x00000000:
6275 x86_cpu_adjust_level(cpu, &env->cpuid_min_level, eax);
6276 break;
6277 case 0x80000000:
6278 x86_cpu_adjust_level(cpu, &env->cpuid_min_xlevel, eax);
6279 break;
6280 case 0xC0000000:
6281 x86_cpu_adjust_level(cpu, &env->cpuid_min_xlevel2, eax);
6282 break;
6285 if (eax == 7) {
6286 x86_cpu_adjust_level(cpu, &env->cpuid_min_level_func7,
6287 fi->cpuid.ecx);
6291 /* Calculate XSAVE components based on the configured CPU feature flags */
6292 static void x86_cpu_enable_xsave_components(X86CPU *cpu)
6294 CPUX86State *env = &cpu->env;
6295 int i;
6296 uint64_t mask;
6298 if (!(env->features[FEAT_1_ECX] & CPUID_EXT_XSAVE)) {
6299 return;
6302 mask = 0;
6303 for (i = 0; i < ARRAY_SIZE(x86_ext_save_areas); i++) {
6304 const ExtSaveArea *esa = &x86_ext_save_areas[i];
6305 if (env->features[esa->feature] & esa->bits) {
6306 mask |= (1ULL << i);
6310 env->features[FEAT_XSAVE_COMP_LO] = mask;
6311 env->features[FEAT_XSAVE_COMP_HI] = mask >> 32;
6314 /***** Steps involved on loading and filtering CPUID data
6316 * When initializing and realizing a CPU object, the steps
6317 * involved in setting up CPUID data are:
6319 * 1) Loading CPU model definition (X86CPUDefinition). This is
6320 * implemented by x86_cpu_load_model() and should be completely
6321 * transparent, as it is done automatically by instance_init.
6322 * No code should need to look at X86CPUDefinition structs
6323 * outside instance_init.
6325 * 2) CPU expansion. This is done by realize before CPUID
6326 * filtering, and will make sure host/accelerator data is
6327 * loaded for CPU models that depend on host capabilities
6328 * (e.g. "host"). Done by x86_cpu_expand_features().
6330 * 3) CPUID filtering. This initializes extra data related to
6331 * CPUID, and checks if the host supports all capabilities
6332 * required by the CPU. Runnability of a CPU model is
6333 * determined at this step. Done by x86_cpu_filter_features().
6335 * Some operations don't require all steps to be performed.
6336 * More precisely:
6338 * - CPU instance creation (instance_init) will run only CPU
6339 * model loading. CPU expansion can't run at instance_init-time
6340 * because host/accelerator data may be not available yet.
6341 * - CPU realization will perform both CPU model expansion and CPUID
6342 * filtering, and return an error in case one of them fails.
6343 * - query-cpu-definitions needs to run all 3 steps. It needs
6344 * to run CPUID filtering, as the 'unavailable-features'
6345 * field is set based on the filtering results.
6346 * - The query-cpu-model-expansion QMP command only needs to run
6347 * CPU model loading and CPU expansion. It should not filter
6348 * any CPUID data based on host capabilities.
6351 /* Expand CPU configuration data, based on configured features
6352 * and host/accelerator capabilities when appropriate.
6354 static void x86_cpu_expand_features(X86CPU *cpu, Error **errp)
6356 CPUX86State *env = &cpu->env;
6357 FeatureWord w;
6358 int i;
6359 GList *l;
6361 for (l = plus_features; l; l = l->next) {
6362 const char *prop = l->data;
6363 if (!object_property_set_bool(OBJECT(cpu), prop, true, errp)) {
6364 return;
6368 for (l = minus_features; l; l = l->next) {
6369 const char *prop = l->data;
6370 if (!object_property_set_bool(OBJECT(cpu), prop, false, errp)) {
6371 return;
6375 /*TODO: Now cpu->max_features doesn't overwrite features
6376 * set using QOM properties, and we can convert
6377 * plus_features & minus_features to global properties
6378 * inside x86_cpu_parse_featurestr() too.
6380 if (cpu->max_features) {
6381 for (w = 0; w < FEATURE_WORDS; w++) {
6382 /* Override only features that weren't set explicitly
6383 * by the user.
6385 env->features[w] |=
6386 x86_cpu_get_supported_feature_word(w, cpu->migratable) &
6387 ~env->user_features[w] &
6388 ~feature_word_info[w].no_autoenable_flags;
6392 for (i = 0; i < ARRAY_SIZE(feature_dependencies); i++) {
6393 FeatureDep *d = &feature_dependencies[i];
6394 if (!(env->features[d->from.index] & d->from.mask)) {
6395 uint64_t unavailable_features = env->features[d->to.index] & d->to.mask;
6397 /* Not an error unless the dependent feature was added explicitly. */
6398 mark_unavailable_features(cpu, d->to.index,
6399 unavailable_features & env->user_features[d->to.index],
6400 "This feature depends on other features that were not requested");
6402 env->features[d->to.index] &= ~unavailable_features;
6406 if (!kvm_enabled() || !cpu->expose_kvm) {
6407 env->features[FEAT_KVM] = 0;
6410 x86_cpu_enable_xsave_components(cpu);
6412 /* CPUID[EAX=7,ECX=0].EBX always increased level automatically: */
6413 x86_cpu_adjust_feat_level(cpu, FEAT_7_0_EBX);
6414 if (cpu->full_cpuid_auto_level) {
6415 x86_cpu_adjust_feat_level(cpu, FEAT_1_EDX);
6416 x86_cpu_adjust_feat_level(cpu, FEAT_1_ECX);
6417 x86_cpu_adjust_feat_level(cpu, FEAT_6_EAX);
6418 x86_cpu_adjust_feat_level(cpu, FEAT_7_0_ECX);
6419 x86_cpu_adjust_feat_level(cpu, FEAT_7_1_EAX);
6420 x86_cpu_adjust_feat_level(cpu, FEAT_8000_0001_EDX);
6421 x86_cpu_adjust_feat_level(cpu, FEAT_8000_0001_ECX);
6422 x86_cpu_adjust_feat_level(cpu, FEAT_8000_0007_EDX);
6423 x86_cpu_adjust_feat_level(cpu, FEAT_8000_0008_EBX);
6424 x86_cpu_adjust_feat_level(cpu, FEAT_C000_0001_EDX);
6425 x86_cpu_adjust_feat_level(cpu, FEAT_SVM);
6426 x86_cpu_adjust_feat_level(cpu, FEAT_XSAVE);
6428 /* Intel Processor Trace requires CPUID[0x14] */
6429 if ((env->features[FEAT_7_0_EBX] & CPUID_7_0_EBX_INTEL_PT)) {
6430 if (cpu->intel_pt_auto_level) {
6431 x86_cpu_adjust_level(cpu, &cpu->env.cpuid_min_level, 0x14);
6432 } else if (cpu->env.cpuid_min_level < 0x14) {
6433 mark_unavailable_features(cpu, FEAT_7_0_EBX,
6434 CPUID_7_0_EBX_INTEL_PT,
6435 "Intel PT need CPUID leaf 0x14, please set by \"-cpu ...,+intel-pt,min-level=0x14\"");
6439 /* CPU topology with multi-dies support requires CPUID[0x1F] */
6440 if (env->nr_dies > 1) {
6441 x86_cpu_adjust_level(cpu, &env->cpuid_min_level, 0x1F);
6444 /* SVM requires CPUID[0x8000000A] */
6445 if (env->features[FEAT_8000_0001_ECX] & CPUID_EXT3_SVM) {
6446 x86_cpu_adjust_level(cpu, &env->cpuid_min_xlevel, 0x8000000A);
6449 /* SEV requires CPUID[0x8000001F] */
6450 if (sev_enabled()) {
6451 x86_cpu_adjust_level(cpu, &env->cpuid_min_xlevel, 0x8000001F);
6455 /* Set cpuid_*level* based on cpuid_min_*level, if not explicitly set */
6456 if (env->cpuid_level_func7 == UINT32_MAX) {
6457 env->cpuid_level_func7 = env->cpuid_min_level_func7;
6459 if (env->cpuid_level == UINT32_MAX) {
6460 env->cpuid_level = env->cpuid_min_level;
6462 if (env->cpuid_xlevel == UINT32_MAX) {
6463 env->cpuid_xlevel = env->cpuid_min_xlevel;
6465 if (env->cpuid_xlevel2 == UINT32_MAX) {
6466 env->cpuid_xlevel2 = env->cpuid_min_xlevel2;
6471 * Finishes initialization of CPUID data, filters CPU feature
6472 * words based on host availability of each feature.
6474 * Returns: 0 if all flags are supported by the host, non-zero otherwise.
6476 static void x86_cpu_filter_features(X86CPU *cpu, bool verbose)
6478 CPUX86State *env = &cpu->env;
6479 FeatureWord w;
6480 const char *prefix = NULL;
6482 if (verbose) {
6483 prefix = accel_uses_host_cpuid()
6484 ? "host doesn't support requested feature"
6485 : "TCG doesn't support requested feature";
6488 for (w = 0; w < FEATURE_WORDS; w++) {
6489 uint64_t host_feat =
6490 x86_cpu_get_supported_feature_word(w, false);
6491 uint64_t requested_features = env->features[w];
6492 uint64_t unavailable_features = requested_features & ~host_feat;
6493 mark_unavailable_features(cpu, w, unavailable_features, prefix);
6496 if ((env->features[FEAT_7_0_EBX] & CPUID_7_0_EBX_INTEL_PT) &&
6497 kvm_enabled()) {
6498 KVMState *s = CPU(cpu)->kvm_state;
6499 uint32_t eax_0 = kvm_arch_get_supported_cpuid(s, 0x14, 0, R_EAX);
6500 uint32_t ebx_0 = kvm_arch_get_supported_cpuid(s, 0x14, 0, R_EBX);
6501 uint32_t ecx_0 = kvm_arch_get_supported_cpuid(s, 0x14, 0, R_ECX);
6502 uint32_t eax_1 = kvm_arch_get_supported_cpuid(s, 0x14, 1, R_EAX);
6503 uint32_t ebx_1 = kvm_arch_get_supported_cpuid(s, 0x14, 1, R_EBX);
6505 if (!eax_0 ||
6506 ((ebx_0 & INTEL_PT_MINIMAL_EBX) != INTEL_PT_MINIMAL_EBX) ||
6507 ((ecx_0 & INTEL_PT_MINIMAL_ECX) != INTEL_PT_MINIMAL_ECX) ||
6508 ((eax_1 & INTEL_PT_MTC_BITMAP) != INTEL_PT_MTC_BITMAP) ||
6509 ((eax_1 & INTEL_PT_ADDR_RANGES_NUM_MASK) <
6510 INTEL_PT_ADDR_RANGES_NUM) ||
6511 ((ebx_1 & (INTEL_PT_PSB_BITMAP | INTEL_PT_CYCLE_BITMAP)) !=
6512 (INTEL_PT_PSB_BITMAP | INTEL_PT_CYCLE_BITMAP)) ||
6513 (ecx_0 & INTEL_PT_IP_LIP)) {
6515 * Processor Trace capabilities aren't configurable, so if the
6516 * host can't emulate the capabilities we report on
6517 * cpu_x86_cpuid(), intel-pt can't be enabled on the current host.
6519 mark_unavailable_features(cpu, FEAT_7_0_EBX, CPUID_7_0_EBX_INTEL_PT, prefix);
6524 static void x86_cpu_realizefn(DeviceState *dev, Error **errp)
6526 CPUState *cs = CPU(dev);
6527 X86CPU *cpu = X86_CPU(dev);
6528 X86CPUClass *xcc = X86_CPU_GET_CLASS(dev);
6529 CPUX86State *env = &cpu->env;
6530 Error *local_err = NULL;
6531 static bool ht_warned;
6533 if (xcc->host_cpuid_required) {
6534 if (!accel_uses_host_cpuid()) {
6535 g_autofree char *name = x86_cpu_class_get_model_name(xcc);
6536 error_setg(&local_err, "CPU model '%s' requires KVM", name);
6537 goto out;
6541 if (cpu->max_features && accel_uses_host_cpuid()) {
6542 if (enable_cpu_pm) {
6543 host_cpuid(5, 0, &cpu->mwait.eax, &cpu->mwait.ebx,
6544 &cpu->mwait.ecx, &cpu->mwait.edx);
6545 env->features[FEAT_1_ECX] |= CPUID_EXT_MONITOR;
6546 if (kvm_enabled() && kvm_has_waitpkg()) {
6547 env->features[FEAT_7_0_ECX] |= CPUID_7_0_ECX_WAITPKG;
6550 if (kvm_enabled() && cpu->ucode_rev == 0) {
6551 cpu->ucode_rev = kvm_arch_get_supported_msr_feature(kvm_state,
6552 MSR_IA32_UCODE_REV);
6556 if (cpu->ucode_rev == 0) {
6557 /* The default is the same as KVM's. */
6558 if (IS_AMD_CPU(env)) {
6559 cpu->ucode_rev = 0x01000065;
6560 } else {
6561 cpu->ucode_rev = 0x100000000ULL;
6565 /* mwait extended info: needed for Core compatibility */
6566 /* We always wake on interrupt even if host does not have the capability */
6567 cpu->mwait.ecx |= CPUID_MWAIT_EMX | CPUID_MWAIT_IBE;
6569 if (cpu->apic_id == UNASSIGNED_APIC_ID) {
6570 error_setg(errp, "apic-id property was not initialized properly");
6571 return;
6574 x86_cpu_expand_features(cpu, &local_err);
6575 if (local_err) {
6576 goto out;
6579 x86_cpu_filter_features(cpu, cpu->check_cpuid || cpu->enforce_cpuid);
6581 if (cpu->enforce_cpuid && x86_cpu_have_filtered_features(cpu)) {
6582 error_setg(&local_err,
6583 accel_uses_host_cpuid() ?
6584 "Host doesn't support requested features" :
6585 "TCG doesn't support requested features");
6586 goto out;
6589 /* On AMD CPUs, some CPUID[8000_0001].EDX bits must match the bits on
6590 * CPUID[1].EDX.
6592 if (IS_AMD_CPU(env)) {
6593 env->features[FEAT_8000_0001_EDX] &= ~CPUID_EXT2_AMD_ALIASES;
6594 env->features[FEAT_8000_0001_EDX] |= (env->features[FEAT_1_EDX]
6595 & CPUID_EXT2_AMD_ALIASES);
6598 /* For 64bit systems think about the number of physical bits to present.
6599 * ideally this should be the same as the host; anything other than matching
6600 * the host can cause incorrect guest behaviour.
6601 * QEMU used to pick the magic value of 40 bits that corresponds to
6602 * consumer AMD devices but nothing else.
6604 if (env->features[FEAT_8000_0001_EDX] & CPUID_EXT2_LM) {
6605 if (accel_uses_host_cpuid()) {
6606 uint32_t host_phys_bits = x86_host_phys_bits();
6607 static bool warned;
6609 /* Print a warning if the user set it to a value that's not the
6610 * host value.
6612 if (cpu->phys_bits != host_phys_bits && cpu->phys_bits != 0 &&
6613 !warned) {
6614 warn_report("Host physical bits (%u)"
6615 " does not match phys-bits property (%u)",
6616 host_phys_bits, cpu->phys_bits);
6617 warned = true;
6620 if (cpu->host_phys_bits) {
6621 /* The user asked for us to use the host physical bits */
6622 cpu->phys_bits = host_phys_bits;
6623 if (cpu->host_phys_bits_limit &&
6624 cpu->phys_bits > cpu->host_phys_bits_limit) {
6625 cpu->phys_bits = cpu->host_phys_bits_limit;
6629 if (cpu->phys_bits &&
6630 (cpu->phys_bits > TARGET_PHYS_ADDR_SPACE_BITS ||
6631 cpu->phys_bits < 32)) {
6632 error_setg(errp, "phys-bits should be between 32 and %u "
6633 " (but is %u)",
6634 TARGET_PHYS_ADDR_SPACE_BITS, cpu->phys_bits);
6635 return;
6637 } else {
6638 if (cpu->phys_bits && cpu->phys_bits != TCG_PHYS_ADDR_BITS) {
6639 error_setg(errp, "TCG only supports phys-bits=%u",
6640 TCG_PHYS_ADDR_BITS);
6641 return;
6644 /* 0 means it was not explicitly set by the user (or by machine
6645 * compat_props or by the host code above). In this case, the default
6646 * is the value used by TCG (40).
6648 if (cpu->phys_bits == 0) {
6649 cpu->phys_bits = TCG_PHYS_ADDR_BITS;
6651 } else {
6652 /* For 32 bit systems don't use the user set value, but keep
6653 * phys_bits consistent with what we tell the guest.
6655 if (cpu->phys_bits != 0) {
6656 error_setg(errp, "phys-bits is not user-configurable in 32 bit");
6657 return;
6660 if (env->features[FEAT_1_EDX] & CPUID_PSE36) {
6661 cpu->phys_bits = 36;
6662 } else {
6663 cpu->phys_bits = 32;
6667 /* Cache information initialization */
6668 if (!cpu->legacy_cache) {
6669 if (!xcc->model || !xcc->model->cpudef->cache_info) {
6670 g_autofree char *name = x86_cpu_class_get_model_name(xcc);
6671 error_setg(errp,
6672 "CPU model '%s' doesn't support legacy-cache=off", name);
6673 return;
6675 env->cache_info_cpuid2 = env->cache_info_cpuid4 = env->cache_info_amd =
6676 *xcc->model->cpudef->cache_info;
6677 } else {
6678 /* Build legacy cache information */
6679 env->cache_info_cpuid2.l1d_cache = &legacy_l1d_cache;
6680 env->cache_info_cpuid2.l1i_cache = &legacy_l1i_cache;
6681 env->cache_info_cpuid2.l2_cache = &legacy_l2_cache_cpuid2;
6682 env->cache_info_cpuid2.l3_cache = &legacy_l3_cache;
6684 env->cache_info_cpuid4.l1d_cache = &legacy_l1d_cache;
6685 env->cache_info_cpuid4.l1i_cache = &legacy_l1i_cache;
6686 env->cache_info_cpuid4.l2_cache = &legacy_l2_cache;
6687 env->cache_info_cpuid4.l3_cache = &legacy_l3_cache;
6689 env->cache_info_amd.l1d_cache = &legacy_l1d_cache_amd;
6690 env->cache_info_amd.l1i_cache = &legacy_l1i_cache_amd;
6691 env->cache_info_amd.l2_cache = &legacy_l2_cache_amd;
6692 env->cache_info_amd.l3_cache = &legacy_l3_cache;
6696 cpu_exec_realizefn(cs, &local_err);
6697 if (local_err != NULL) {
6698 error_propagate(errp, local_err);
6699 return;
6702 #ifndef CONFIG_USER_ONLY
6703 MachineState *ms = MACHINE(qdev_get_machine());
6704 qemu_register_reset(x86_cpu_machine_reset_cb, cpu);
6706 if (cpu->env.features[FEAT_1_EDX] & CPUID_APIC || ms->smp.cpus > 1) {
6707 x86_cpu_apic_create(cpu, &local_err);
6708 if (local_err != NULL) {
6709 goto out;
6712 #endif
6714 mce_init(cpu);
6716 #ifndef CONFIG_USER_ONLY
6717 if (tcg_enabled()) {
6718 cpu->cpu_as_mem = g_new(MemoryRegion, 1);
6719 cpu->cpu_as_root = g_new(MemoryRegion, 1);
6721 /* Outer container... */
6722 memory_region_init(cpu->cpu_as_root, OBJECT(cpu), "memory", ~0ull);
6723 memory_region_set_enabled(cpu->cpu_as_root, true);
6725 /* ... with two regions inside: normal system memory with low
6726 * priority, and...
6728 memory_region_init_alias(cpu->cpu_as_mem, OBJECT(cpu), "memory",
6729 get_system_memory(), 0, ~0ull);
6730 memory_region_add_subregion_overlap(cpu->cpu_as_root, 0, cpu->cpu_as_mem, 0);
6731 memory_region_set_enabled(cpu->cpu_as_mem, true);
6733 cs->num_ases = 2;
6734 cpu_address_space_init(cs, 0, "cpu-memory", cs->memory);
6735 cpu_address_space_init(cs, 1, "cpu-smm", cpu->cpu_as_root);
6737 /* ... SMRAM with higher priority, linked from /machine/smram. */
6738 cpu->machine_done.notify = x86_cpu_machine_done;
6739 qemu_add_machine_init_done_notifier(&cpu->machine_done);
6741 #endif
6743 qemu_init_vcpu(cs);
6746 * Most Intel and certain AMD CPUs support hyperthreading. Even though QEMU
6747 * fixes this issue by adjusting CPUID_0000_0001_EBX and CPUID_8000_0008_ECX
6748 * based on inputs (sockets,cores,threads), it is still better to give
6749 * users a warning.
6751 * NOTE: the following code has to follow qemu_init_vcpu(). Otherwise
6752 * cs->nr_threads hasn't be populated yet and the checking is incorrect.
6754 if (IS_AMD_CPU(env) &&
6755 !(env->features[FEAT_8000_0001_ECX] & CPUID_EXT3_TOPOEXT) &&
6756 cs->nr_threads > 1 && !ht_warned) {
6757 warn_report("This family of AMD CPU doesn't support "
6758 "hyperthreading(%d)",
6759 cs->nr_threads);
6760 error_printf("Please configure -smp options properly"
6761 " or try enabling topoext feature.\n");
6762 ht_warned = true;
6765 x86_cpu_apic_realize(cpu, &local_err);
6766 if (local_err != NULL) {
6767 goto out;
6769 cpu_reset(cs);
6771 xcc->parent_realize(dev, &local_err);
6773 out:
6774 if (local_err != NULL) {
6775 error_propagate(errp, local_err);
6776 return;
6780 static void x86_cpu_unrealizefn(DeviceState *dev)
6782 X86CPU *cpu = X86_CPU(dev);
6783 X86CPUClass *xcc = X86_CPU_GET_CLASS(dev);
6785 #ifndef CONFIG_USER_ONLY
6786 cpu_remove_sync(CPU(dev));
6787 qemu_unregister_reset(x86_cpu_machine_reset_cb, dev);
6788 #endif
6790 if (cpu->apic_state) {
6791 object_unparent(OBJECT(cpu->apic_state));
6792 cpu->apic_state = NULL;
6795 xcc->parent_unrealize(dev);
6798 typedef struct BitProperty {
6799 FeatureWord w;
6800 uint64_t mask;
6801 } BitProperty;
6803 static void x86_cpu_get_bit_prop(Object *obj, Visitor *v, const char *name,
6804 void *opaque, Error **errp)
6806 X86CPU *cpu = X86_CPU(obj);
6807 BitProperty *fp = opaque;
6808 uint64_t f = cpu->env.features[fp->w];
6809 bool value = (f & fp->mask) == fp->mask;
6810 visit_type_bool(v, name, &value, errp);
6813 static void x86_cpu_set_bit_prop(Object *obj, Visitor *v, const char *name,
6814 void *opaque, Error **errp)
6816 DeviceState *dev = DEVICE(obj);
6817 X86CPU *cpu = X86_CPU(obj);
6818 BitProperty *fp = opaque;
6819 bool value;
6821 if (dev->realized) {
6822 qdev_prop_set_after_realize(dev, name, errp);
6823 return;
6826 if (!visit_type_bool(v, name, &value, errp)) {
6827 return;
6830 if (value) {
6831 cpu->env.features[fp->w] |= fp->mask;
6832 } else {
6833 cpu->env.features[fp->w] &= ~fp->mask;
6835 cpu->env.user_features[fp->w] |= fp->mask;
6838 static void x86_cpu_release_bit_prop(Object *obj, const char *name,
6839 void *opaque)
6841 BitProperty *prop = opaque;
6842 g_free(prop);
6845 /* Register a boolean property to get/set a single bit in a uint32_t field.
6847 * The same property name can be registered multiple times to make it affect
6848 * multiple bits in the same FeatureWord. In that case, the getter will return
6849 * true only if all bits are set.
6851 static void x86_cpu_register_bit_prop(X86CPU *cpu,
6852 const char *prop_name,
6853 FeatureWord w,
6854 int bitnr)
6856 BitProperty *fp;
6857 ObjectProperty *op;
6858 uint64_t mask = (1ULL << bitnr);
6860 op = object_property_find(OBJECT(cpu), prop_name, NULL);
6861 if (op) {
6862 fp = op->opaque;
6863 assert(fp->w == w);
6864 fp->mask |= mask;
6865 } else {
6866 fp = g_new0(BitProperty, 1);
6867 fp->w = w;
6868 fp->mask = mask;
6869 object_property_add(OBJECT(cpu), prop_name, "bool",
6870 x86_cpu_get_bit_prop,
6871 x86_cpu_set_bit_prop,
6872 x86_cpu_release_bit_prop, fp);
6876 static void x86_cpu_register_feature_bit_props(X86CPU *cpu,
6877 FeatureWord w,
6878 int bitnr)
6880 FeatureWordInfo *fi = &feature_word_info[w];
6881 const char *name = fi->feat_names[bitnr];
6883 if (!name) {
6884 return;
6887 /* Property names should use "-" instead of "_".
6888 * Old names containing underscores are registered as aliases
6889 * using object_property_add_alias()
6891 assert(!strchr(name, '_'));
6892 /* aliases don't use "|" delimiters anymore, they are registered
6893 * manually using object_property_add_alias() */
6894 assert(!strchr(name, '|'));
6895 x86_cpu_register_bit_prop(cpu, name, w, bitnr);
6898 #if !defined(CONFIG_USER_ONLY)
6899 static GuestPanicInformation *x86_cpu_get_crash_info(CPUState *cs)
6901 X86CPU *cpu = X86_CPU(cs);
6902 CPUX86State *env = &cpu->env;
6903 GuestPanicInformation *panic_info = NULL;
6905 if (env->features[FEAT_HYPERV_EDX] & HV_GUEST_CRASH_MSR_AVAILABLE) {
6906 panic_info = g_malloc0(sizeof(GuestPanicInformation));
6908 panic_info->type = GUEST_PANIC_INFORMATION_TYPE_HYPER_V;
6910 assert(HV_CRASH_PARAMS >= 5);
6911 panic_info->u.hyper_v.arg1 = env->msr_hv_crash_params[0];
6912 panic_info->u.hyper_v.arg2 = env->msr_hv_crash_params[1];
6913 panic_info->u.hyper_v.arg3 = env->msr_hv_crash_params[2];
6914 panic_info->u.hyper_v.arg4 = env->msr_hv_crash_params[3];
6915 panic_info->u.hyper_v.arg5 = env->msr_hv_crash_params[4];
6918 return panic_info;
6920 static void x86_cpu_get_crash_info_qom(Object *obj, Visitor *v,
6921 const char *name, void *opaque,
6922 Error **errp)
6924 CPUState *cs = CPU(obj);
6925 GuestPanicInformation *panic_info;
6927 if (!cs->crash_occurred) {
6928 error_setg(errp, "No crash occured");
6929 return;
6932 panic_info = x86_cpu_get_crash_info(cs);
6933 if (panic_info == NULL) {
6934 error_setg(errp, "No crash information");
6935 return;
6938 visit_type_GuestPanicInformation(v, "crash-information", &panic_info,
6939 errp);
6940 qapi_free_GuestPanicInformation(panic_info);
6942 #endif /* !CONFIG_USER_ONLY */
6944 static void x86_cpu_initfn(Object *obj)
6946 X86CPU *cpu = X86_CPU(obj);
6947 X86CPUClass *xcc = X86_CPU_GET_CLASS(obj);
6948 CPUX86State *env = &cpu->env;
6949 FeatureWord w;
6951 env->nr_dies = 1;
6952 env->nr_nodes = 1;
6953 cpu_set_cpustate_pointers(cpu);
6955 object_property_add(obj, "family", "int",
6956 x86_cpuid_version_get_family,
6957 x86_cpuid_version_set_family, NULL, NULL);
6958 object_property_add(obj, "model", "int",
6959 x86_cpuid_version_get_model,
6960 x86_cpuid_version_set_model, NULL, NULL);
6961 object_property_add(obj, "stepping", "int",
6962 x86_cpuid_version_get_stepping,
6963 x86_cpuid_version_set_stepping, NULL, NULL);
6964 object_property_add_str(obj, "vendor",
6965 x86_cpuid_get_vendor,
6966 x86_cpuid_set_vendor);
6967 object_property_add_str(obj, "model-id",
6968 x86_cpuid_get_model_id,
6969 x86_cpuid_set_model_id);
6970 object_property_add(obj, "tsc-frequency", "int",
6971 x86_cpuid_get_tsc_freq,
6972 x86_cpuid_set_tsc_freq, NULL, NULL);
6973 object_property_add(obj, "feature-words", "X86CPUFeatureWordInfo",
6974 x86_cpu_get_feature_words,
6975 NULL, NULL, (void *)env->features);
6976 object_property_add(obj, "filtered-features", "X86CPUFeatureWordInfo",
6977 x86_cpu_get_feature_words,
6978 NULL, NULL, (void *)cpu->filtered_features);
6980 * The "unavailable-features" property has the same semantics as
6981 * CpuDefinitionInfo.unavailable-features on the "query-cpu-definitions"
6982 * QMP command: they list the features that would have prevented the
6983 * CPU from running if the "enforce" flag was set.
6985 object_property_add(obj, "unavailable-features", "strList",
6986 x86_cpu_get_unavailable_features,
6987 NULL, NULL, NULL);
6989 #if !defined(CONFIG_USER_ONLY)
6990 object_property_add(obj, "crash-information", "GuestPanicInformation",
6991 x86_cpu_get_crash_info_qom, NULL, NULL, NULL);
6992 #endif
6994 for (w = 0; w < FEATURE_WORDS; w++) {
6995 int bitnr;
6997 for (bitnr = 0; bitnr < 64; bitnr++) {
6998 x86_cpu_register_feature_bit_props(cpu, w, bitnr);
7002 object_property_add_alias(obj, "sse3", obj, "pni");
7003 object_property_add_alias(obj, "pclmuldq", obj, "pclmulqdq");
7004 object_property_add_alias(obj, "sse4-1", obj, "sse4.1");
7005 object_property_add_alias(obj, "sse4-2", obj, "sse4.2");
7006 object_property_add_alias(obj, "xd", obj, "nx");
7007 object_property_add_alias(obj, "ffxsr", obj, "fxsr-opt");
7008 object_property_add_alias(obj, "i64", obj, "lm");
7010 object_property_add_alias(obj, "ds_cpl", obj, "ds-cpl");
7011 object_property_add_alias(obj, "tsc_adjust", obj, "tsc-adjust");
7012 object_property_add_alias(obj, "fxsr_opt", obj, "fxsr-opt");
7013 object_property_add_alias(obj, "lahf_lm", obj, "lahf-lm");
7014 object_property_add_alias(obj, "cmp_legacy", obj, "cmp-legacy");
7015 object_property_add_alias(obj, "nodeid_msr", obj, "nodeid-msr");
7016 object_property_add_alias(obj, "perfctr_core", obj, "perfctr-core");
7017 object_property_add_alias(obj, "perfctr_nb", obj, "perfctr-nb");
7018 object_property_add_alias(obj, "kvm_nopiodelay", obj, "kvm-nopiodelay");
7019 object_property_add_alias(obj, "kvm_mmu", obj, "kvm-mmu");
7020 object_property_add_alias(obj, "kvm_asyncpf", obj, "kvm-asyncpf");
7021 object_property_add_alias(obj, "kvm_steal_time", obj, "kvm-steal-time");
7022 object_property_add_alias(obj, "kvm_pv_eoi", obj, "kvm-pv-eoi");
7023 object_property_add_alias(obj, "kvm_pv_unhalt", obj, "kvm-pv-unhalt");
7024 object_property_add_alias(obj, "kvm_poll_control", obj, "kvm-poll-control");
7025 object_property_add_alias(obj, "svm_lock", obj, "svm-lock");
7026 object_property_add_alias(obj, "nrip_save", obj, "nrip-save");
7027 object_property_add_alias(obj, "tsc_scale", obj, "tsc-scale");
7028 object_property_add_alias(obj, "vmcb_clean", obj, "vmcb-clean");
7029 object_property_add_alias(obj, "pause_filter", obj, "pause-filter");
7030 object_property_add_alias(obj, "sse4_1", obj, "sse4.1");
7031 object_property_add_alias(obj, "sse4_2", obj, "sse4.2");
7033 if (xcc->model) {
7034 x86_cpu_load_model(cpu, xcc->model);
7038 static int64_t x86_cpu_get_arch_id(CPUState *cs)
7040 X86CPU *cpu = X86_CPU(cs);
7042 return cpu->apic_id;
7045 static bool x86_cpu_get_paging_enabled(const CPUState *cs)
7047 X86CPU *cpu = X86_CPU(cs);
7049 return cpu->env.cr[0] & CR0_PG_MASK;
7052 static void x86_cpu_set_pc(CPUState *cs, vaddr value)
7054 X86CPU *cpu = X86_CPU(cs);
7056 cpu->env.eip = value;
7059 static void x86_cpu_synchronize_from_tb(CPUState *cs, TranslationBlock *tb)
7061 X86CPU *cpu = X86_CPU(cs);
7063 cpu->env.eip = tb->pc - tb->cs_base;
7066 int x86_cpu_pending_interrupt(CPUState *cs, int interrupt_request)
7068 X86CPU *cpu = X86_CPU(cs);
7069 CPUX86State *env = &cpu->env;
7071 #if !defined(CONFIG_USER_ONLY)
7072 if (interrupt_request & CPU_INTERRUPT_POLL) {
7073 return CPU_INTERRUPT_POLL;
7075 #endif
7076 if (interrupt_request & CPU_INTERRUPT_SIPI) {
7077 return CPU_INTERRUPT_SIPI;
7080 if (env->hflags2 & HF2_GIF_MASK) {
7081 if ((interrupt_request & CPU_INTERRUPT_SMI) &&
7082 !(env->hflags & HF_SMM_MASK)) {
7083 return CPU_INTERRUPT_SMI;
7084 } else if ((interrupt_request & CPU_INTERRUPT_NMI) &&
7085 !(env->hflags2 & HF2_NMI_MASK)) {
7086 return CPU_INTERRUPT_NMI;
7087 } else if (interrupt_request & CPU_INTERRUPT_MCE) {
7088 return CPU_INTERRUPT_MCE;
7089 } else if ((interrupt_request & CPU_INTERRUPT_HARD) &&
7090 (((env->hflags2 & HF2_VINTR_MASK) &&
7091 (env->hflags2 & HF2_HIF_MASK)) ||
7092 (!(env->hflags2 & HF2_VINTR_MASK) &&
7093 (env->eflags & IF_MASK &&
7094 !(env->hflags & HF_INHIBIT_IRQ_MASK))))) {
7095 return CPU_INTERRUPT_HARD;
7096 #if !defined(CONFIG_USER_ONLY)
7097 } else if ((interrupt_request & CPU_INTERRUPT_VIRQ) &&
7098 (env->eflags & IF_MASK) &&
7099 !(env->hflags & HF_INHIBIT_IRQ_MASK)) {
7100 return CPU_INTERRUPT_VIRQ;
7101 #endif
7105 return 0;
7108 static bool x86_cpu_has_work(CPUState *cs)
7110 return x86_cpu_pending_interrupt(cs, cs->interrupt_request) != 0;
7113 static void x86_disas_set_info(CPUState *cs, disassemble_info *info)
7115 X86CPU *cpu = X86_CPU(cs);
7116 CPUX86State *env = &cpu->env;
7118 info->mach = (env->hflags & HF_CS64_MASK ? bfd_mach_x86_64
7119 : env->hflags & HF_CS32_MASK ? bfd_mach_i386_i386
7120 : bfd_mach_i386_i8086);
7121 info->print_insn = print_insn_i386;
7123 info->cap_arch = CS_ARCH_X86;
7124 info->cap_mode = (env->hflags & HF_CS64_MASK ? CS_MODE_64
7125 : env->hflags & HF_CS32_MASK ? CS_MODE_32
7126 : CS_MODE_16);
7127 info->cap_insn_unit = 1;
7128 info->cap_insn_split = 8;
7131 void x86_update_hflags(CPUX86State *env)
7133 uint32_t hflags;
7134 #define HFLAG_COPY_MASK \
7135 ~( HF_CPL_MASK | HF_PE_MASK | HF_MP_MASK | HF_EM_MASK | \
7136 HF_TS_MASK | HF_TF_MASK | HF_VM_MASK | HF_IOPL_MASK | \
7137 HF_OSFXSR_MASK | HF_LMA_MASK | HF_CS32_MASK | \
7138 HF_SS32_MASK | HF_CS64_MASK | HF_ADDSEG_MASK)
7140 hflags = env->hflags & HFLAG_COPY_MASK;
7141 hflags |= (env->segs[R_SS].flags >> DESC_DPL_SHIFT) & HF_CPL_MASK;
7142 hflags |= (env->cr[0] & CR0_PE_MASK) << (HF_PE_SHIFT - CR0_PE_SHIFT);
7143 hflags |= (env->cr[0] << (HF_MP_SHIFT - CR0_MP_SHIFT)) &
7144 (HF_MP_MASK | HF_EM_MASK | HF_TS_MASK);
7145 hflags |= (env->eflags & (HF_TF_MASK | HF_VM_MASK | HF_IOPL_MASK));
7147 if (env->cr[4] & CR4_OSFXSR_MASK) {
7148 hflags |= HF_OSFXSR_MASK;
7151 if (env->efer & MSR_EFER_LMA) {
7152 hflags |= HF_LMA_MASK;
7155 if ((hflags & HF_LMA_MASK) && (env->segs[R_CS].flags & DESC_L_MASK)) {
7156 hflags |= HF_CS32_MASK | HF_SS32_MASK | HF_CS64_MASK;
7157 } else {
7158 hflags |= (env->segs[R_CS].flags & DESC_B_MASK) >>
7159 (DESC_B_SHIFT - HF_CS32_SHIFT);
7160 hflags |= (env->segs[R_SS].flags & DESC_B_MASK) >>
7161 (DESC_B_SHIFT - HF_SS32_SHIFT);
7162 if (!(env->cr[0] & CR0_PE_MASK) || (env->eflags & VM_MASK) ||
7163 !(hflags & HF_CS32_MASK)) {
7164 hflags |= HF_ADDSEG_MASK;
7165 } else {
7166 hflags |= ((env->segs[R_DS].base | env->segs[R_ES].base |
7167 env->segs[R_SS].base) != 0) << HF_ADDSEG_SHIFT;
7170 env->hflags = hflags;
7173 static Property x86_cpu_properties[] = {
7174 #ifdef CONFIG_USER_ONLY
7175 /* apic_id = 0 by default for *-user, see commit 9886e834 */
7176 DEFINE_PROP_UINT32("apic-id", X86CPU, apic_id, 0),
7177 DEFINE_PROP_INT32("thread-id", X86CPU, thread_id, 0),
7178 DEFINE_PROP_INT32("core-id", X86CPU, core_id, 0),
7179 DEFINE_PROP_INT32("die-id", X86CPU, die_id, 0),
7180 DEFINE_PROP_INT32("socket-id", X86CPU, socket_id, 0),
7181 #else
7182 DEFINE_PROP_UINT32("apic-id", X86CPU, apic_id, UNASSIGNED_APIC_ID),
7183 DEFINE_PROP_INT32("thread-id", X86CPU, thread_id, -1),
7184 DEFINE_PROP_INT32("core-id", X86CPU, core_id, -1),
7185 DEFINE_PROP_INT32("die-id", X86CPU, die_id, -1),
7186 DEFINE_PROP_INT32("socket-id", X86CPU, socket_id, -1),
7187 #endif
7188 DEFINE_PROP_INT32("node-id", X86CPU, node_id, CPU_UNSET_NUMA_NODE_ID),
7189 DEFINE_PROP_BOOL("pmu", X86CPU, enable_pmu, false),
7191 DEFINE_PROP_UINT32("hv-spinlocks", X86CPU, hyperv_spinlock_attempts,
7192 HYPERV_SPINLOCK_NEVER_RETRY),
7193 DEFINE_PROP_BIT64("hv-relaxed", X86CPU, hyperv_features,
7194 HYPERV_FEAT_RELAXED, 0),
7195 DEFINE_PROP_BIT64("hv-vapic", X86CPU, hyperv_features,
7196 HYPERV_FEAT_VAPIC, 0),
7197 DEFINE_PROP_BIT64("hv-time", X86CPU, hyperv_features,
7198 HYPERV_FEAT_TIME, 0),
7199 DEFINE_PROP_BIT64("hv-crash", X86CPU, hyperv_features,
7200 HYPERV_FEAT_CRASH, 0),
7201 DEFINE_PROP_BIT64("hv-reset", X86CPU, hyperv_features,
7202 HYPERV_FEAT_RESET, 0),
7203 DEFINE_PROP_BIT64("hv-vpindex", X86CPU, hyperv_features,
7204 HYPERV_FEAT_VPINDEX, 0),
7205 DEFINE_PROP_BIT64("hv-runtime", X86CPU, hyperv_features,
7206 HYPERV_FEAT_RUNTIME, 0),
7207 DEFINE_PROP_BIT64("hv-synic", X86CPU, hyperv_features,
7208 HYPERV_FEAT_SYNIC, 0),
7209 DEFINE_PROP_BIT64("hv-stimer", X86CPU, hyperv_features,
7210 HYPERV_FEAT_STIMER, 0),
7211 DEFINE_PROP_BIT64("hv-frequencies", X86CPU, hyperv_features,
7212 HYPERV_FEAT_FREQUENCIES, 0),
7213 DEFINE_PROP_BIT64("hv-reenlightenment", X86CPU, hyperv_features,
7214 HYPERV_FEAT_REENLIGHTENMENT, 0),
7215 DEFINE_PROP_BIT64("hv-tlbflush", X86CPU, hyperv_features,
7216 HYPERV_FEAT_TLBFLUSH, 0),
7217 DEFINE_PROP_BIT64("hv-evmcs", X86CPU, hyperv_features,
7218 HYPERV_FEAT_EVMCS, 0),
7219 DEFINE_PROP_BIT64("hv-ipi", X86CPU, hyperv_features,
7220 HYPERV_FEAT_IPI, 0),
7221 DEFINE_PROP_BIT64("hv-stimer-direct", X86CPU, hyperv_features,
7222 HYPERV_FEAT_STIMER_DIRECT, 0),
7223 DEFINE_PROP_ON_OFF_AUTO("hv-no-nonarch-coresharing", X86CPU,
7224 hyperv_no_nonarch_cs, ON_OFF_AUTO_OFF),
7225 DEFINE_PROP_BOOL("hv-passthrough", X86CPU, hyperv_passthrough, false),
7227 DEFINE_PROP_BOOL("check", X86CPU, check_cpuid, true),
7228 DEFINE_PROP_BOOL("enforce", X86CPU, enforce_cpuid, false),
7229 DEFINE_PROP_BOOL("x-force-features", X86CPU, force_features, false),
7230 DEFINE_PROP_BOOL("kvm", X86CPU, expose_kvm, true),
7231 DEFINE_PROP_UINT32("phys-bits", X86CPU, phys_bits, 0),
7232 DEFINE_PROP_BOOL("host-phys-bits", X86CPU, host_phys_bits, false),
7233 DEFINE_PROP_UINT8("host-phys-bits-limit", X86CPU, host_phys_bits_limit, 0),
7234 DEFINE_PROP_BOOL("fill-mtrr-mask", X86CPU, fill_mtrr_mask, true),
7235 DEFINE_PROP_UINT32("level-func7", X86CPU, env.cpuid_level_func7,
7236 UINT32_MAX),
7237 DEFINE_PROP_UINT32("level", X86CPU, env.cpuid_level, UINT32_MAX),
7238 DEFINE_PROP_UINT32("xlevel", X86CPU, env.cpuid_xlevel, UINT32_MAX),
7239 DEFINE_PROP_UINT32("xlevel2", X86CPU, env.cpuid_xlevel2, UINT32_MAX),
7240 DEFINE_PROP_UINT32("min-level", X86CPU, env.cpuid_min_level, 0),
7241 DEFINE_PROP_UINT32("min-xlevel", X86CPU, env.cpuid_min_xlevel, 0),
7242 DEFINE_PROP_UINT32("min-xlevel2", X86CPU, env.cpuid_min_xlevel2, 0),
7243 DEFINE_PROP_UINT64("ucode-rev", X86CPU, ucode_rev, 0),
7244 DEFINE_PROP_BOOL("full-cpuid-auto-level", X86CPU, full_cpuid_auto_level, true),
7245 DEFINE_PROP_STRING("hv-vendor-id", X86CPU, hyperv_vendor_id),
7246 DEFINE_PROP_BOOL("cpuid-0xb", X86CPU, enable_cpuid_0xb, true),
7247 DEFINE_PROP_BOOL("lmce", X86CPU, enable_lmce, false),
7248 DEFINE_PROP_BOOL("l3-cache", X86CPU, enable_l3_cache, true),
7249 DEFINE_PROP_BOOL("kvm-no-smi-migration", X86CPU, kvm_no_smi_migration,
7250 false),
7251 DEFINE_PROP_BOOL("vmware-cpuid-freq", X86CPU, vmware_cpuid_freq, true),
7252 DEFINE_PROP_BOOL("tcg-cpuid", X86CPU, expose_tcg, true),
7253 DEFINE_PROP_BOOL("x-migrate-smi-count", X86CPU, migrate_smi_count,
7254 true),
7256 * lecacy_cache defaults to true unless the CPU model provides its
7257 * own cache information (see x86_cpu_load_def()).
7259 DEFINE_PROP_BOOL("legacy-cache", X86CPU, legacy_cache, true),
7262 * From "Requirements for Implementing the Microsoft
7263 * Hypervisor Interface":
7264 * https://docs.microsoft.com/en-us/virtualization/hyper-v-on-windows/reference/tlfs
7266 * "Starting with Windows Server 2012 and Windows 8, if
7267 * CPUID.40000005.EAX contains a value of -1, Windows assumes that
7268 * the hypervisor imposes no specific limit to the number of VPs.
7269 * In this case, Windows Server 2012 guest VMs may use more than
7270 * 64 VPs, up to the maximum supported number of processors applicable
7271 * to the specific Windows version being used."
7273 DEFINE_PROP_INT32("x-hv-max-vps", X86CPU, hv_max_vps, -1),
7274 DEFINE_PROP_BOOL("x-hv-synic-kvm-only", X86CPU, hyperv_synic_kvm_only,
7275 false),
7276 DEFINE_PROP_BOOL("x-intel-pt-auto-level", X86CPU, intel_pt_auto_level,
7277 true),
7278 DEFINE_PROP_END_OF_LIST()
7281 static void x86_cpu_common_class_init(ObjectClass *oc, void *data)
7283 X86CPUClass *xcc = X86_CPU_CLASS(oc);
7284 CPUClass *cc = CPU_CLASS(oc);
7285 DeviceClass *dc = DEVICE_CLASS(oc);
7287 device_class_set_parent_realize(dc, x86_cpu_realizefn,
7288 &xcc->parent_realize);
7289 device_class_set_parent_unrealize(dc, x86_cpu_unrealizefn,
7290 &xcc->parent_unrealize);
7291 device_class_set_props(dc, x86_cpu_properties);
7293 device_class_set_parent_reset(dc, x86_cpu_reset, &xcc->parent_reset);
7294 cc->reset_dump_flags = CPU_DUMP_FPU | CPU_DUMP_CCOP;
7296 cc->class_by_name = x86_cpu_class_by_name;
7297 cc->parse_features = x86_cpu_parse_featurestr;
7298 cc->has_work = x86_cpu_has_work;
7299 #ifdef CONFIG_TCG
7300 cc->do_interrupt = x86_cpu_do_interrupt;
7301 cc->cpu_exec_interrupt = x86_cpu_exec_interrupt;
7302 #endif
7303 cc->dump_state = x86_cpu_dump_state;
7304 cc->set_pc = x86_cpu_set_pc;
7305 cc->synchronize_from_tb = x86_cpu_synchronize_from_tb;
7306 cc->gdb_read_register = x86_cpu_gdb_read_register;
7307 cc->gdb_write_register = x86_cpu_gdb_write_register;
7308 cc->get_arch_id = x86_cpu_get_arch_id;
7309 cc->get_paging_enabled = x86_cpu_get_paging_enabled;
7310 #ifndef CONFIG_USER_ONLY
7311 cc->asidx_from_attrs = x86_asidx_from_attrs;
7312 cc->get_memory_mapping = x86_cpu_get_memory_mapping;
7313 cc->get_phys_page_attrs_debug = x86_cpu_get_phys_page_attrs_debug;
7314 cc->get_crash_info = x86_cpu_get_crash_info;
7315 cc->write_elf64_note = x86_cpu_write_elf64_note;
7316 cc->write_elf64_qemunote = x86_cpu_write_elf64_qemunote;
7317 cc->write_elf32_note = x86_cpu_write_elf32_note;
7318 cc->write_elf32_qemunote = x86_cpu_write_elf32_qemunote;
7319 cc->vmsd = &vmstate_x86_cpu;
7320 #endif
7321 cc->gdb_arch_name = x86_gdb_arch_name;
7322 #ifdef TARGET_X86_64
7323 cc->gdb_core_xml_file = "i386-64bit.xml";
7324 cc->gdb_num_core_regs = 66;
7325 #else
7326 cc->gdb_core_xml_file = "i386-32bit.xml";
7327 cc->gdb_num_core_regs = 50;
7328 #endif
7329 #if defined(CONFIG_TCG) && !defined(CONFIG_USER_ONLY)
7330 cc->debug_excp_handler = breakpoint_handler;
7331 #endif
7332 cc->cpu_exec_enter = x86_cpu_exec_enter;
7333 cc->cpu_exec_exit = x86_cpu_exec_exit;
7334 #ifdef CONFIG_TCG
7335 cc->tcg_initialize = tcg_x86_init;
7336 cc->tlb_fill = x86_cpu_tlb_fill;
7337 #endif
7338 cc->disas_set_info = x86_disas_set_info;
7340 dc->user_creatable = true;
7343 static const TypeInfo x86_cpu_type_info = {
7344 .name = TYPE_X86_CPU,
7345 .parent = TYPE_CPU,
7346 .instance_size = sizeof(X86CPU),
7347 .instance_init = x86_cpu_initfn,
7348 .abstract = true,
7349 .class_size = sizeof(X86CPUClass),
7350 .class_init = x86_cpu_common_class_init,
7354 /* "base" CPU model, used by query-cpu-model-expansion */
7355 static void x86_cpu_base_class_init(ObjectClass *oc, void *data)
7357 X86CPUClass *xcc = X86_CPU_CLASS(oc);
7359 xcc->static_model = true;
7360 xcc->migration_safe = true;
7361 xcc->model_description = "base CPU model type with no features enabled";
7362 xcc->ordering = 8;
7365 static const TypeInfo x86_base_cpu_type_info = {
7366 .name = X86_CPU_TYPE_NAME("base"),
7367 .parent = TYPE_X86_CPU,
7368 .class_init = x86_cpu_base_class_init,
7371 static void x86_cpu_register_types(void)
7373 int i;
7375 type_register_static(&x86_cpu_type_info);
7376 for (i = 0; i < ARRAY_SIZE(builtin_x86_defs); i++) {
7377 x86_register_cpudef_types(&builtin_x86_defs[i]);
7379 type_register_static(&max_x86_cpu_type_info);
7380 type_register_static(&x86_base_cpu_type_info);
7381 #if defined(CONFIG_KVM) || defined(CONFIG_HVF)
7382 type_register_static(&host_x86_cpu_type_info);
7383 #endif
7386 type_init(x86_cpu_register_types)