From mboxrd@z Thu Jan 1 00:00:00 1970 From: Radim =?utf-8?B?S3LEjW3DocWZ?= Subject: Re: [PATCH v3 1/2] KVM: X86: Processor States following Reset or INIT Date: Tue, 10 Oct 2017 20:55:12 +0200 Message-ID: <20171010185512.GA28763@flask> References: <1507589513-125748-1-git-send-email-wanpeng.li@hotmail.com> Mime-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit Cc: linux-kernel@vger.kernel.org, kvm@vger.kernel.org, Paolo Bonzini , Wanpeng Li , Jim Mattson To: Wanpeng Li Return-path: Content-Disposition: inline In-Reply-To: <1507589513-125748-1-git-send-email-wanpeng.li@hotmail.com> Sender: linux-kernel-owner@vger.kernel.org List-Id: kvm.vger.kernel.org 2017-10-09 15:51-0700, Wanpeng Li: > From: Wanpeng Li > > - XCR0 is reset to 1 by RESET but not INIT > - XSS is zeroed by both RESET and INIT > - BNDCFGU, BND0-BND3, BNDCFGS are zeroed by both RESET and INIT > > This patch does this according to SDM. > > Cc: Paolo Bonzini > Cc: Radim Krčmář > Cc: Jim Mattson > Signed-off-by: Wanpeng Li > --- > v2 -> v3: > * fix null pointer deference > * fix patch description > v1 -> v2: > * XCR0 is not zeroed by INIT > * XSS, BNDCFGU, BND0-BND3, BNDCFGS are zeroed by both RESET and INIT > > arch/x86/kvm/vmx.c | 2 ++ > arch/x86/kvm/x86.c | 15 +++++++++++++++ > 2 files changed, 17 insertions(+) > > diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c > @@ -7804,18 +7804,33 @@ void kvm_vcpu_reset(struct kvm_vcpu *vcpu, bool init_event) > kvm_async_pf_hash_reset(vcpu); > vcpu->arch.apf.halted = false; > > + if (kvm_mpx_supported()) { > + void *mpx_state_buffer; > + > + mpx_state_buffer = get_xsave_addr(&vcpu->arch.guest_fpu.state.xsave, XFEATURE_MASK_BNDREGS); > + if (mpx_state_buffer) > + memset(mpx_state_buffer, 0, sizeof(struct mpx_bndreg_state)); I think we should call kvm_put_guest_fpu() before doing this. The register might be loaded in CPU and XSAVE instruction from vcpu_put() would overwrite any changes we did. > + mpx_state_buffer = get_xsave_addr(&vcpu->arch.guest_fpu.state.xsave, XFEATURE_MASK_BNDCSR); > + if (mpx_state_buffer) > + memset(mpx_state_buffer, 0, sizeof(u64)); XFEATURE_MASK_BNDCSR is actually struct mpx_bndcsr { u64 bndcfgu; u64 bndstatus; } __packed; So clearing two u64 would be correct, thanks.