X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Fsrc%2Fpalacios%2Fsvm.c;h=ee7ff6d9e7b9fd8da417ee879a6522074bad2c62;hb=624a05de781c51ed5d34a6db2583f884918a9594;hp=077e95cefd888e804cb14533d511cc77272229b3;hpb=ace8f0532fa5650c6642a3a7174f3aa19b09095a;p=palacios.git diff --git a/palacios/src/palacios/svm.c b/palacios/src/palacios/svm.c index 077e95c..ee7ff6d 100644 --- a/palacios/src/palacios/svm.c +++ b/palacios/src/palacios/svm.c @@ -145,10 +145,13 @@ int start_svm_guest(struct guest_info *info) { //PrintDebug("Launching to RIP: %x\n", info->rip); safe_svm_launch((vmcb_t*)(info->vmm_data), &(info->vm_regs)); //launch_svm((vmcb_t*)(info->vmm_data)); - // PrintDebug("SVM Returned\n"); + //PrintDebug("SVM Returned\n"); - STGI(); + + STGI(); + + if (handle_svm_exit(info) != 0) { PrintDebug("SVM ERROR!!\n"); break; @@ -309,6 +312,7 @@ void Init_VMCB_BIOS(vmcb_t * vmcb, struct guest_info vm_info) { guest_state->efer |= EFER_MSR_svm_enable; guest_state->rflags = 0x00000002; // The reserved bit is always 1 ctrl_area->svm_instrs.VMRUN = 1; + ctrl_area->instrs.HLT = 1; // guest_state->cr0 = 0x00000001; // PE ctrl_area->guest_ASID = 1;