KVM: VMX: Adjust rflags if in real mode emulation
authorAvi Kivity <avi@redhat.com>
Wed, 12 Aug 2009 12:29:37 +0000 (15:29 +0300)
committerAvi Kivity <avi@redhat.com>
Thu, 10 Sep 2009 07:46:43 +0000 (10:46 +0300)
We set rflags.vm86 when virtualizing real mode to do through vm8086 mode;
so we need to take it out again when reading rflags.

Signed-off-by: Avi Kivity <avi@redhat.com>
arch/x86/kvm/vmx.c

index 31c3a8740c4204bfd6852d34525872e9d3570761..2b7e7bd190fd5a072ad9500c707726294d128a76 100644 (file)
@@ -781,7 +781,12 @@ static void vmx_fpu_deactivate(struct kvm_vcpu *vcpu)
 
 static unsigned long vmx_get_rflags(struct kvm_vcpu *vcpu)
 {
-       return vmcs_readl(GUEST_RFLAGS);
+       unsigned long rflags;
+
+       rflags = vmcs_readl(GUEST_RFLAGS);
+       if (to_vmx(vcpu)->rmode.vm86_active)
+               rflags &= ~(unsigned long)(X86_EFLAGS_IOPL | X86_EFLAGS_VM);
+       return rflags;
 }
 
 static void vmx_set_rflags(struct kvm_vcpu *vcpu, unsigned long rflags)