[Qemu-devel] [PATCH v3 2/5] Add CET SHSTK and IBT CPUID feature-word definitions.
XSS[bit 11] and XSS[bit 12] correspond to CET user mode area and supervisor mode area respectively. Signed-off-by: Zhang Yi Signed-off-by: Yang Weijiang --- target/i386/cpu.c | 37 +++-- 1 file changed, 35 insertions(+), 2 deletions(-) diff --git a/target/i386/cpu.c b/target/i386/cpu.c index f81d35e1f9..f6c7bdf6fe 100644 --- a/target/i386/cpu.c +++ b/target/i386/cpu.c @@ -1018,7 +1018,7 @@ static FeatureWordInfo feature_word_info[FEATURE_WORDS] = { .type = CPUID_FEATURE_WORD, .feat_names = { NULL, "avx512vbmi", "umip", "pku", -NULL /* ospke */, NULL, "avx512vbmi2", NULL, +NULL /* ospke */, NULL, "avx512vbmi2", "shstk", "gfni", "vaes", "vpclmulqdq", "avx512vnni", "avx512bitalg", NULL, "avx512-vpopcntdq", NULL, "la57", NULL, NULL, NULL, @@ -1041,7 +1041,7 @@ static FeatureWordInfo feature_word_info[FEATURE_WORDS] = { NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, "pconfig", NULL, -NULL, NULL, NULL, NULL, +"ibt", NULL, NULL, NULL, NULL, NULL, "spec-ctrl", NULL, NULL, "arch-capabilities", NULL, "ssbd", }, @@ -1162,6 +1162,25 @@ static FeatureWordInfo feature_word_info[FEATURE_WORDS] = { } }, }, +/* Below are CET supervisor xsave features */ +[FEAT_XSAVE_SV_LO] = { +.type = CPUID_FEATURE_WORD, +.cpuid = { +.eax = 0xD, +.needs_ecx = true, +.ecx = 1, +.reg = R_ECX, +}, +}, +[FEAT_XSAVE_SV_HI] = { +.type = CPUID_FEATURE_WORD, +.cpuid = { +.eax = 0xD, +.needs_ecx = true, +.ecx = 1, +.reg = R_EDX +}, +} }; typedef struct X86RegisterInfo32 { @@ -1233,6 +1252,14 @@ static const ExtSaveArea x86_ext_save_areas[] = { { .feature = FEAT_7_0_ECX, .bits = CPUID_7_0_ECX_PKU, .offset = offsetof(X86XSaveArea, pkru_state), .size = sizeof(XSavePKRU) }, +[XSTATE_CET_U_BIT] = { +.feature = FEAT_7_0_ECX, .bits = CPUID_7_0_ECX_CET_SHSTK, +.offset = 0 /*supervisor mode component, offset = 0 */, +.size = sizeof(XSaveCETU) }, +[XSTATE_CET_S_BIT] = { +.feature = FEAT_7_0_ECX, .bits = CPUID_7_0_ECX_CET_SHSTK, +.offset = 0 /*supervisor mode component, offset = 0 */, +.size = sizeof(XSaveCETS) }, }; static uint32_t xsave_area_size(uint64_t mask) @@ -1243,6 +1270,9 @@ static uint32_t xsave_area_size(uint64_t mask) for (i = 0; i < ARRAY_SIZE(x86_ext_save_areas); i++) { const ExtSaveArea *esa = _ext_save_areas[i]; if ((mask >> i) & 1) { +if (i >= 2 && !esa->offset) { +continue; +} ret = MAX(ret, esa->offset + esa->size); } } @@ -4657,6 +4687,9 @@ static void x86_cpu_reset(CPUState *s) } for (i = 2; i < ARRAY_SIZE(x86_ext_save_areas); i++) { const ExtSaveArea *esa = _ext_save_areas[i]; +if (!esa->offset) { +continue; +} if (env->features[esa->feature] & esa->bits) { xcr0 |= 1ull << i; } -- 2.17.1
[Qemu-devel] [PATCH v3 2/5] Add CET SHSTK and IBT CPUID feature-word definitions.
XSS[bit 11] and XSS[bit 12] correspond to CET user mode area and supervisor mode area respectively. Signed-off-by: Zhang Yi Signed-off-by: Yang Weijiang --- target/i386/cpu.c | 37 +++-- 1 file changed, 35 insertions(+), 2 deletions(-) diff --git a/target/i386/cpu.c b/target/i386/cpu.c index f81d35e1f9..f6c7bdf6fe 100644 --- a/target/i386/cpu.c +++ b/target/i386/cpu.c @@ -1018,7 +1018,7 @@ static FeatureWordInfo feature_word_info[FEATURE_WORDS] = { .type = CPUID_FEATURE_WORD, .feat_names = { NULL, "avx512vbmi", "umip", "pku", -NULL /* ospke */, NULL, "avx512vbmi2", NULL, +NULL /* ospke */, NULL, "avx512vbmi2", "shstk", "gfni", "vaes", "vpclmulqdq", "avx512vnni", "avx512bitalg", NULL, "avx512-vpopcntdq", NULL, "la57", NULL, NULL, NULL, @@ -1041,7 +1041,7 @@ static FeatureWordInfo feature_word_info[FEATURE_WORDS] = { NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, "pconfig", NULL, -NULL, NULL, NULL, NULL, +"ibt", NULL, NULL, NULL, NULL, NULL, "spec-ctrl", NULL, NULL, "arch-capabilities", NULL, "ssbd", }, @@ -1162,6 +1162,25 @@ static FeatureWordInfo feature_word_info[FEATURE_WORDS] = { } }, }, +/* Below are CET supervisor xsave features */ +[FEAT_XSAVE_SV_LO] = { +.type = CPUID_FEATURE_WORD, +.cpuid = { +.eax = 0xD, +.needs_ecx = true, +.ecx = 1, +.reg = R_ECX, +}, +}, +[FEAT_XSAVE_SV_HI] = { +.type = CPUID_FEATURE_WORD, +.cpuid = { +.eax = 0xD, +.needs_ecx = true, +.ecx = 1, +.reg = R_EDX +}, +} }; typedef struct X86RegisterInfo32 { @@ -1233,6 +1252,14 @@ static const ExtSaveArea x86_ext_save_areas[] = { { .feature = FEAT_7_0_ECX, .bits = CPUID_7_0_ECX_PKU, .offset = offsetof(X86XSaveArea, pkru_state), .size = sizeof(XSavePKRU) }, +[XSTATE_CET_U_BIT] = { +.feature = FEAT_7_0_ECX, .bits = CPUID_7_0_ECX_CET_SHSTK, +.offset = 0 /*supervisor mode component, offset = 0 */, +.size = sizeof(XSaveCETU) }, +[XSTATE_CET_S_BIT] = { +.feature = FEAT_7_0_ECX, .bits = CPUID_7_0_ECX_CET_SHSTK, +.offset = 0 /*supervisor mode component, offset = 0 */, +.size = sizeof(XSaveCETS) }, }; static uint32_t xsave_area_size(uint64_t mask) @@ -1243,6 +1270,9 @@ static uint32_t xsave_area_size(uint64_t mask) for (i = 0; i < ARRAY_SIZE(x86_ext_save_areas); i++) { const ExtSaveArea *esa = _ext_save_areas[i]; if ((mask >> i) & 1) { +if (i >= 2 && !esa->offset) { +continue; +} ret = MAX(ret, esa->offset + esa->size); } } @@ -4657,6 +4687,9 @@ static void x86_cpu_reset(CPUState *s) } for (i = 2; i < ARRAY_SIZE(x86_ext_save_areas); i++) { const ExtSaveArea *esa = _ext_save_areas[i]; +if (!esa->offset) { +continue; +} if (env->features[esa->feature] & esa->bits) { xcr0 |= 1ull << i; } -- 2.17.1