Commit bbefd4fc authored by Paolo Bonzini's avatar Paolo Bonzini

KVM: x86: move kvm_inject_gp up from kvm_set_xcr to callers

Push the injection of #GP up to the callers, so that they can just use
kvm_complete_insn_gp.
Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
parent fd238002
...@@ -2357,11 +2357,8 @@ static int xsetbv_interception(struct vcpu_svm *svm) ...@@ -2357,11 +2357,8 @@ static int xsetbv_interception(struct vcpu_svm *svm)
u64 new_bv = kvm_read_edx_eax(&svm->vcpu); u64 new_bv = kvm_read_edx_eax(&svm->vcpu);
u32 index = kvm_rcx_read(&svm->vcpu); u32 index = kvm_rcx_read(&svm->vcpu);
if (kvm_set_xcr(&svm->vcpu, index, new_bv) == 0) { int err = kvm_set_xcr(&svm->vcpu, index, new_bv);
return kvm_skip_emulated_instruction(&svm->vcpu); return kvm_complete_insn_gp(&svm->vcpu, err);
}
return 1;
} }
static int rdpru_interception(struct vcpu_svm *svm) static int rdpru_interception(struct vcpu_svm *svm)
......
...@@ -5223,9 +5223,8 @@ static int handle_xsetbv(struct kvm_vcpu *vcpu) ...@@ -5223,9 +5223,8 @@ static int handle_xsetbv(struct kvm_vcpu *vcpu)
u64 new_bv = kvm_read_edx_eax(vcpu); u64 new_bv = kvm_read_edx_eax(vcpu);
u32 index = kvm_rcx_read(vcpu); u32 index = kvm_rcx_read(vcpu);
if (kvm_set_xcr(vcpu, index, new_bv) == 0) int err = kvm_set_xcr(vcpu, index, new_bv);
return kvm_skip_emulated_instruction(vcpu); return kvm_complete_insn_gp(vcpu, err);
return 1;
} }
static int handle_apic_access(struct kvm_vcpu *vcpu) static int handle_apic_access(struct kvm_vcpu *vcpu)
......
...@@ -986,12 +986,10 @@ static int __kvm_set_xcr(struct kvm_vcpu *vcpu, u32 index, u64 xcr) ...@@ -986,12 +986,10 @@ static 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 (static_call(kvm_x86_get_cpl)(vcpu) != 0 || if (static_call(kvm_x86_get_cpl)(vcpu) == 0)
__kvm_set_xcr(vcpu, index, xcr)) { return __kvm_set_xcr(vcpu, index, xcr);
kvm_inject_gp(vcpu, 0);
return 1; return 1;
}
return 0;
} }
EXPORT_SYMBOL_GPL(kvm_set_xcr); EXPORT_SYMBOL_GPL(kvm_set_xcr);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment