target-i386: add feature flags for CPUID[EAX=0xd,ECX=1]

These represent xsave-related capabilities of the processor, and KVM may
or may not support them.

Add feature bits so that they are considered by "-cpu ...,enforce", and use
the new feature work instead of calling kvm_arch_get_supported_cpuid.

Bit 3 (XSAVES) is not migratables because it requires saving MSR_IA32_XSS.
Neither KVM nor any commonly available hardware supports it anyway.

Backports commit 0bb0b2d2fe7f645ddaf1f0ff40ac669c9feb4aa1 from qemu

also backports 18cd2c17b5370369a886155c001da0a7f54bbcca
This commit is contained in:
Paolo Bonzini 2018-02-14 15:46:12 -05:00 committed by Lioncash
parent a439a8c701
commit 5e9ea14b7e
No known key found for this signature in database
GPG key ID: 4E3C3CC1031BA9C7
2 changed files with 66 additions and 0 deletions

View file

@ -241,6 +241,18 @@ static const char *cpuid_apm_edx_feature_name[] = {
NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
}; };
static const char *cpuid_xsave_feature_name[] = {
"xsaveopt", "xsavec", "xgetbv1", "xsaves",
NULL, NULL, NULL, NULL,
NULL, NULL, NULL, NULL,
NULL, NULL, NULL, NULL,
NULL, NULL, NULL, NULL,
NULL, NULL, NULL, NULL,
NULL, NULL, NULL, NULL,
NULL, NULL, NULL, NULL,
};
#define I486_FEATURES (CPUID_FP87 | CPUID_VME | CPUID_PSE) #define I486_FEATURES (CPUID_FP87 | CPUID_VME | CPUID_PSE)
#define PENTIUM_FEATURES (I486_FEATURES | CPUID_DE | CPUID_TSC | \ #define PENTIUM_FEATURES (I486_FEATURES | CPUID_DE | CPUID_TSC | \
CPUID_MSR | CPUID_MCE | CPUID_CX8 | CPUID_MMX | CPUID_APIC) CPUID_MSR | CPUID_MCE | CPUID_CX8 | CPUID_MMX | CPUID_APIC)
@ -371,6 +383,15 @@ static FeatureWordInfo feature_word_info[FEATURE_WORDS] = {
{0}, {0},
// FEAT_SVM // FEAT_SVM
{0}, {0},
// FEAT_XSAVE
{
cpuid_xsave_feature_name,
0xd,
true,1,
R_EAX,
0,
0,
},
#else #else
[FEAT_1_EDX] = { [FEAT_1_EDX] = {
.feat_names = feature_name, .feat_names = feature_name,
@ -411,6 +432,13 @@ static FeatureWordInfo feature_word_info[FEATURE_WORDS] = {
.tcg_features = TCG_APM_FEATURES, .tcg_features = TCG_APM_FEATURES,
.unmigratable_flags = CPUID_APM_INVTSC, .unmigratable_flags = CPUID_APM_INVTSC,
}, },
[FEAT_XSAVE] = {
.feat_names = cpuid_xsave_feature_name,
.cpuid_eax = 0xd,
.cpuid_needs_ecx = true, .cpuid_ecx = 1,
.cpuid_reg = R_EAX,
.tcg_features = 0,
},
#endif #endif
}; };
@ -985,6 +1013,16 @@ static X86CPUDefinition builtin_x86_defs[] = {
CPUID_EXT2_SYSCALL, CPUID_EXT2_SYSCALL,
// FEAT_8000_0001_ECX // FEAT_8000_0001_ECX
CPUID_EXT3_LAHF_LM, CPUID_EXT3_LAHF_LM,
// FEAT_8000_0007_EDX
0,
// FEAT_C000_0001_EDX
0,
// FEAT_KVM
0,
// FEAT_SVM
0,
// FEAT_XSAVE
CPUID_XSAVE_XSAVEOPT,
}, },
"Intel Xeon E312xx (Sandy Bridge)", "Intel Xeon E312xx (Sandy Bridge)",
}, },
@ -1017,6 +1055,16 @@ static X86CPUDefinition builtin_x86_defs[] = {
CPUID_EXT2_SYSCALL, CPUID_EXT2_SYSCALL,
// FEAT_8000_0001_ECX // FEAT_8000_0001_ECX
CPUID_EXT3_LAHF_LM, CPUID_EXT3_LAHF_LM,
// FEAT_8000_0007_EDX
0,
// FEAT_C000_0001_EDX
0,
// FEAT_KVM
0,
// FEAT_SVM
0,
// FEAT_XSAVE
CPUID_XSAVE_XSAVEOPT,
}, },
"Intel Core Processor (Haswell)", "Intel Core Processor (Haswell)",
}, },
@ -1050,6 +1098,16 @@ static X86CPUDefinition builtin_x86_defs[] = {
CPUID_EXT2_SYSCALL, CPUID_EXT2_SYSCALL,
// FEAT_8000_0001_ECX // FEAT_8000_0001_ECX
CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH, CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
// FEAT_8000_0007_EDX
0,
// FEAT_C000_0001_EDX
0,
// FEAT_KVM
0,
// FEAT_SVM
0,
// FEAT_XSAVE
CPUID_XSAVE_XSAVEOPT,
}, },
"Intel Core Processor (Broadwell)", "Intel Core Processor (Broadwell)",
}, },

View file

@ -390,6 +390,7 @@
#define MSR_VM_HSAVE_PA 0xc0010117 #define MSR_VM_HSAVE_PA 0xc0010117
#define MSR_IA32_BNDCFGS 0x00000d90 #define MSR_IA32_BNDCFGS 0x00000d90
#define MSR_IA32_XSS 0x00000da0
#define XSTATE_FP (1ULL << 0) #define XSTATE_FP (1ULL << 0)
#define XSTATE_SSE (1ULL << 1) #define XSTATE_SSE (1ULL << 1)
@ -412,6 +413,7 @@ typedef enum FeatureWord {
FEAT_C000_0001_EDX, /* CPUID[C000_0001].EDX */ FEAT_C000_0001_EDX, /* CPUID[C000_0001].EDX */
FEAT_KVM, /* CPUID[4000_0001].EAX (KVM_CPUID_FEATURES) */ FEAT_KVM, /* CPUID[4000_0001].EAX (KVM_CPUID_FEATURES) */
FEAT_SVM, /* CPUID[8000_000A].EDX */ FEAT_SVM, /* CPUID[8000_000A].EDX */
FEAT_XSAVE, /* CPUID[EAX=0xd,ECX=1].EAX */
FEATURE_WORDS, FEATURE_WORDS,
} FeatureWord; } FeatureWord;
@ -572,6 +574,11 @@ typedef uint32_t FeatureWordArray[FEATURE_WORDS];
#define CPUID_7_0_EBX_AVX512ER (1U << 27) /* AVX-512 Exponential and Reciprocal */ #define CPUID_7_0_EBX_AVX512ER (1U << 27) /* AVX-512 Exponential and Reciprocal */
#define CPUID_7_0_EBX_AVX512CD (1U << 28) /* AVX-512 Conflict Detection */ #define CPUID_7_0_EBX_AVX512CD (1U << 28) /* AVX-512 Conflict Detection */
#define CPUID_XSAVE_XSAVEOPT (1U << 0)
#define CPUID_XSAVE_XSAVEC (1U << 1)
#define CPUID_XSAVE_XGETBV1 (1U << 2)
#define CPUID_XSAVE_XSAVES (1U << 3)
/* CPUID[0x80000007].EDX flags: */ /* CPUID[0x80000007].EDX flags: */
#define CPUID_APM_INVTSC (1U << 8) #define CPUID_APM_INVTSC (1U << 8)
@ -970,6 +977,7 @@ typedef struct CPUX86State {
uint64_t xstate_bv; uint64_t xstate_bv;
uint64_t xcr0; uint64_t xcr0;
uint64_t xss;
TPRAccess tpr_access_type; TPRAccess tpr_access_type;