X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Fsrc%2Fpalacios%2Fsvm.c;h=ee7ff6d9e7b9fd8da417ee879a6522074bad2c62;hb=624a05de781c51ed5d34a6db2583f884918a9594;hp=4a16070db234bf914fe56f4dbdc979d49da3b2b5;hpb=df58bd3c484a52b1e166dc28e7b9b6fd94e5a023;p=palacios.git diff --git a/palacios/src/palacios/svm.c b/palacios/src/palacios/svm.c index 4a16070..ee7ff6d 100644 --- a/palacios/src/palacios/svm.c +++ b/palacios/src/palacios/svm.c @@ -20,10 +20,11 @@ extern void Set_MSR(uint_t MSR, uint_t high_byte, uint_t low_byte); extern uint_t launch_svm(vmcb_t * vmcb_addr); extern void safe_svm_launch(vmcb_t * vmcb_addr, struct guest_gprs * gprs); +extern void STGI(); +extern void CLGI(); + extern uint_t Get_CR3(); -extern void GetGDTR(void * gdt); -extern void GetIDTR(void * idt); extern void DisableInts(); @@ -138,14 +139,21 @@ int start_svm_guest(struct guest_info *info) { while (1) { + CLGI(); + //PrintDebug("SVM Launch Args (vmcb=%x), (info=%x), (vm_regs=%x)\n", info->vmm_data, &(info->vm_regs)); //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"); + + + STGI(); + + if (handle_svm_exit(info) != 0) { - // handle exit code.... + PrintDebug("SVM ERROR!!\n"); break; } } @@ -304,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; @@ -384,11 +393,10 @@ void Init_VMCB_BIOS(vmcb_t * vmcb, struct guest_info vm_info) { } - if (vm_info.irq_map.num_hooks > 0) { - PrintDebug("Exiting on interrupts\n"); - ctrl_area->guest_ctrl.V_INTR_MASKING = 1; - ctrl_area->instrs.INTR = 1; - } + + PrintDebug("Exiting on interrupts\n"); + ctrl_area->guest_ctrl.V_INTR_MASKING = 1; + ctrl_area->instrs.INTR = 1; if (vm_info.page_mode == SHADOW_PAGING) { @@ -434,6 +442,7 @@ void Init_VMCB_BIOS(vmcb_t * vmcb, struct guest_info vm_info) { } +#if 0 void Init_VMCB_pe(vmcb_t *vmcb, struct guest_info vm_info) { vmcb_ctrl_t * ctrl_area = GET_VMCB_CTRL_AREA(vmcb); vmcb_saved_state_t * guest_state = GET_VMCB_SAVE_STATE_AREA(vmcb); @@ -597,7 +606,7 @@ void Init_VMCB_pe(vmcb_t *vmcb, struct guest_info vm_info) { - +#endif