|
@@ -3806,11 +3806,6 @@ static void emulator_set_segment_selector(u16 sel, int seg,
|
|
kvm_set_segment(vcpu, &kvm_seg, seg);
|
|
kvm_set_segment(vcpu, &kvm_seg, seg);
|
|
}
|
|
}
|
|
|
|
|
|
-static void emulator_set_rflags(struct kvm_vcpu *vcpu, unsigned long rflags)
|
|
|
|
-{
|
|
|
|
- kvm_x86_ops->set_rflags(vcpu, rflags);
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
static struct x86_emulate_ops emulate_ops = {
|
|
static struct x86_emulate_ops emulate_ops = {
|
|
.read_std = kvm_read_guest_virt_system,
|
|
.read_std = kvm_read_guest_virt_system,
|
|
.write_std = kvm_write_guest_virt_system,
|
|
.write_std = kvm_write_guest_virt_system,
|
|
@@ -3829,7 +3824,6 @@ static struct x86_emulate_ops emulate_ops = {
|
|
.get_cr = emulator_get_cr,
|
|
.get_cr = emulator_get_cr,
|
|
.set_cr = emulator_set_cr,
|
|
.set_cr = emulator_set_cr,
|
|
.cpl = emulator_get_cpl,
|
|
.cpl = emulator_get_cpl,
|
|
- .set_rflags = emulator_set_rflags,
|
|
|
|
.get_dr = emulator_get_dr,
|
|
.get_dr = emulator_get_dr,
|
|
.set_dr = emulator_set_dr,
|
|
.set_dr = emulator_set_dr,
|
|
.set_msr = kvm_set_msr,
|
|
.set_msr = kvm_set_msr,
|
|
@@ -3941,6 +3935,7 @@ restart:
|
|
|
|
|
|
shadow_mask = vcpu->arch.emulate_ctxt.interruptibility;
|
|
shadow_mask = vcpu->arch.emulate_ctxt.interruptibility;
|
|
kvm_x86_ops->set_interrupt_shadow(vcpu, shadow_mask);
|
|
kvm_x86_ops->set_interrupt_shadow(vcpu, shadow_mask);
|
|
|
|
+ kvm_x86_ops->set_rflags(vcpu, vcpu->arch.emulate_ctxt.eflags);
|
|
kvm_rip_write(vcpu, vcpu->arch.emulate_ctxt.eip);
|
|
kvm_rip_write(vcpu, vcpu->arch.emulate_ctxt.eip);
|
|
|
|
|
|
if (vcpu->arch.pio.count) {
|
|
if (vcpu->arch.pio.count) {
|