aboutsummaryrefslogtreecommitdiff
path: root/target
diff options
context:
space:
mode:
authorYang Zhong <yang.zhong@linux.intel.com>2023-04-06 02:40:41 -0400
committerPaolo Bonzini <pbonzini@redhat.com>2023-04-20 11:17:35 +0200
commit72497cff896fecf74306ed33626c30e43633cdd6 (patch)
treef76744f9d2f90a4e909947dd21732fca35a6b6b7 /target
parenta50c99bcc09f5f85495e365a37f8ef459405fc51 (diff)
downloadqemu-72497cff896fecf74306ed33626c30e43633cdd6.zip
qemu-72497cff896fecf74306ed33626c30e43633cdd6.tar.gz
qemu-72497cff896fecf74306ed33626c30e43633cdd6.tar.bz2
target/i386: Change wrong XFRM value in SGX CPUID leaf
The previous patch wrongly replaced FEAT_XSAVE_XCR0_{LO|HI} with FEAT_XSAVE_XSS_{LO|HI} in CPUID(EAX=12,ECX=1):{ECX,EDX}. As a result, SGX enclaves only supported SSE and x87 feature (xfrm=0x3). Fixes: 301e90675c3f ("target/i386: Enable support for XSAVES based features") Signed-off-by: Yang Zhong <yang.zhong@linux.intel.com> Reviewed-by: Yang Weijiang <weijiang.yang@intel.com> Reviewed-by: Kai Huang <kai.huang@intel.com> Message-Id: <20230406064041.420039-1-yang.zhong@linux.intel.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'target')
-rw-r--r--target/i386/cpu.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/target/i386/cpu.c b/target/i386/cpu.c
index 6576287..f083ff4 100644
--- a/target/i386/cpu.c
+++ b/target/i386/cpu.c
@@ -5718,8 +5718,8 @@ void cpu_x86_cpuid(CPUX86State *env, uint32_t index, uint32_t count,
} else {
*eax &= env->features[FEAT_SGX_12_1_EAX];
*ebx &= 0; /* ebx reserve */
- *ecx &= env->features[FEAT_XSAVE_XSS_LO];
- *edx &= env->features[FEAT_XSAVE_XSS_HI];
+ *ecx &= env->features[FEAT_XSAVE_XCR0_LO];
+ *edx &= env->features[FEAT_XSAVE_XCR0_HI];
/* FP and SSE are always allowed regardless of XSAVE/XCR0. */
*ecx |= XSTATE_FP_MASK | XSTATE_SSE_MASK;