for ( i = 0; i < ARRAY_SIZE(v->arch.debugreg); ++i )
v->arch.debugreg[i] = c(debugreg[i]);
- v->arch.user_regs.eflags |= 2;
-
if ( has_hvm_container_vcpu(v) )
{
/*
v->arch.user_regs.edi = ctxt.rdi;
v->arch.user_regs.esp = ctxt.rsp;
v->arch.user_regs.eip = ctxt.rip;
- v->arch.user_regs.eflags = ctxt.rflags | 2;
+ v->arch.user_regs.eflags = ctxt.rflags | X86_EFLAGS_MBS;
v->arch.user_regs.r8 = ctxt.r8;
v->arch.user_regs.r9 = ctxt.r9;
v->arch.user_regs.r10 = ctxt.r10;
(void(*)(unsigned long))hvm_assert_evtchn_irq,
(unsigned long)v);
- v->arch.user_regs.eflags = 2;
-
v->arch.hvm_vcpu.inject_trap.vector = -1;
if ( is_pvh_vcpu(v) )
v->arch.vgc_flags = VGCF_online;
memset(&v->arch.user_regs, 0, sizeof(v->arch.user_regs));
- v->arch.user_regs.eflags = 2;
+ v->arch.user_regs.eflags = X86_EFLAGS_MBS;
v->arch.user_regs.edx = 0x00000f00;
v->arch.user_regs.eip = ip;
memset(&v->arch.debugreg, 0, sizeof(v->arch.debugreg));
mov UREGS_rsp(%rsp),%rax
mov %rax,VMCB_rsp(%rcx)
mov UREGS_eflags(%rsp),%rax
+ or $X86_EFLAGS_MBS,%rax
mov %rax,VMCB_rflags(%rcx)
pop %r15
__vmwrite(GUEST_RIP, regs->rip);
__vmwrite(GUEST_RSP, regs->rsp);
- __vmwrite(GUEST_RFLAGS, regs->rflags);
+ __vmwrite(GUEST_RFLAGS, regs->rflags | X86_EFLAGS_MBS);
}
/*
* EFLAGS bits
*/
#define X86_EFLAGS_CF 0x00000001 /* Carry Flag */
+#define X86_EFLAGS_MBS 0x00000002 /* Resvd bit */
#define X86_EFLAGS_PF 0x00000004 /* Parity Flag */
#define X86_EFLAGS_AF 0x00000010 /* Auxillary carry Flag */
#define X86_EFLAGS_ZF 0x00000040 /* Zero Flag */