After handling a rdmsr or wrmsr, refactor the success and failure code paths into separate functions. This will allow us to also complete or fail MSR accesses on the entry path from userspace into kvm. Signed-off-by: Peter Hornyack <peterhornyack@xxxxxxxxxx> --- arch/x86/kvm/vmx.c | 44 +++++++++++++++++++++++++++++++++----------- 1 file changed, 33 insertions(+), 11 deletions(-) diff --git a/arch/x86/kvm/vmx.c b/arch/x86/kvm/vmx.c index 37eae551857c..acc38e27d221 100644 --- a/arch/x86/kvm/vmx.c +++ b/arch/x86/kvm/vmx.c @@ -5463,6 +5463,34 @@ static int handle_cpuid(struct kvm_vcpu *vcpu) return 1; } +static void complete_rdmsr(struct kvm_vcpu *vcpu, const struct msr_data *msr) +{ + trace_kvm_msr_read(msr->index, msr->data); + + /* FIXME: handling of bits 32:63 of rax, rdx */ + vcpu->arch.regs[VCPU_REGS_RAX] = msr->data & -1u; + vcpu->arch.regs[VCPU_REGS_RDX] = (msr->data >> 32) & -1u; + skip_emulated_instruction(vcpu); +} + +static void fail_rdmsr(struct kvm_vcpu *vcpu, const struct msr_data *msr) +{ + trace_kvm_msr_read_ex(msr->index); + kvm_inject_gp(vcpu, 0); +} + +static void complete_wrmsr(struct kvm_vcpu *vcpu, const struct msr_data *msr) +{ + trace_kvm_msr_write(msr->index, msr->data); + skip_emulated_instruction(vcpu); +} + +static void fail_wrmsr(struct kvm_vcpu *vcpu, const struct msr_data *msr) +{ + trace_kvm_msr_write_ex(msr->index, msr->data); + kvm_inject_gp(vcpu, 0); +} + static int handle_rdmsr(struct kvm_vcpu *vcpu) { u32 ecx = vcpu->arch.regs[VCPU_REGS_RCX]; @@ -5471,17 +5499,12 @@ static int handle_rdmsr(struct kvm_vcpu *vcpu) msr_info.index = ecx; msr_info.host_initiated = false; if (vmx_get_msr(vcpu, &msr_info)) { - trace_kvm_msr_read_ex(ecx); - kvm_inject_gp(vcpu, 0); + fail_rdmsr(vcpu, &msr_info); return 1; } - trace_kvm_msr_read(ecx, msr_info.data); + complete_rdmsr(vcpu, &msr_info); - /* FIXME: handling of bits 32:63 of rax, rdx */ - vcpu->arch.regs[VCPU_REGS_RAX] = msr_info.data & -1u; - vcpu->arch.regs[VCPU_REGS_RDX] = (msr_info.data >> 32) & -1u; - skip_emulated_instruction(vcpu); return 1; } @@ -5496,13 +5519,12 @@ static int handle_wrmsr(struct kvm_vcpu *vcpu) msr.index = ecx; msr.host_initiated = false; if (kvm_set_msr(vcpu, &msr) != 0) { - trace_kvm_msr_write_ex(ecx, data); - kvm_inject_gp(vcpu, 0); + fail_wrmsr(vcpu, &msr); return 1; } - trace_kvm_msr_write(ecx, data); - skip_emulated_instruction(vcpu); + complete_wrmsr(vcpu, &msr); + return 1; } -- 2.5.0.276.gf5e568e -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html