mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
KVM: x86: remove vcpu's CPL check in host-invoked XCR set
commit 764bcbc5a6
upstream.
__kvm_set_xcr function does the CPL check when set xcr. __kvm_set_xcr is
called in two flows, one is invoked by guest, call stack shown as below,
handle_xsetbv(or xsetbv_interception)
kvm_set_xcr
__kvm_set_xcr
the other one is invoked by host, for example during system reset:
kvm_arch_vcpu_ioctl
kvm_vcpu_ioctl_x86_set_xcrs
__kvm_set_xcr
The former does need the CPL check, but the latter does not.
Signed-off-by: Zhang Haoyu <haoyu.zhang@huawei.com>
[Tweaks to commit message. - Paolo]
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
68447fe9bd
commit
e6e045d591
1 changed files with 2 additions and 3 deletions
|
@ -555,8 +555,6 @@ int __kvm_set_xcr(struct kvm_vcpu *vcpu, u32 index, u64 xcr)
|
||||||
if (index != XCR_XFEATURE_ENABLED_MASK)
|
if (index != XCR_XFEATURE_ENABLED_MASK)
|
||||||
return 1;
|
return 1;
|
||||||
xcr0 = xcr;
|
xcr0 = xcr;
|
||||||
if (kvm_x86_ops->get_cpl(vcpu) != 0)
|
|
||||||
return 1;
|
|
||||||
if (!(xcr0 & XSTATE_FP))
|
if (!(xcr0 & XSTATE_FP))
|
||||||
return 1;
|
return 1;
|
||||||
if ((xcr0 & XSTATE_YMM) && !(xcr0 & XSTATE_SSE))
|
if ((xcr0 & XSTATE_YMM) && !(xcr0 & XSTATE_SSE))
|
||||||
|
@ -570,7 +568,8 @@ int __kvm_set_xcr(struct kvm_vcpu *vcpu, u32 index, u64 xcr)
|
||||||
|
|
||||||
int kvm_set_xcr(struct kvm_vcpu *vcpu, u32 index, u64 xcr)
|
int kvm_set_xcr(struct kvm_vcpu *vcpu, u32 index, u64 xcr)
|
||||||
{
|
{
|
||||||
if (__kvm_set_xcr(vcpu, index, xcr)) {
|
if (kvm_x86_ops->get_cpl(vcpu) != 0 ||
|
||||||
|
__kvm_set_xcr(vcpu, index, xcr)) {
|
||||||
kvm_inject_gp(vcpu, 0);
|
kvm_inject_gp(vcpu, 0);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue