X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Fsrc%2Fpalacios%2Fsvm.c;h=ee7ff6d9e7b9fd8da417ee879a6522074bad2c62;hb=624a05de781c51ed5d34a6db2583f884918a9594;hp=296559f59568eb3344db3ced7a6e65e1af915308;hpb=570ad6257ed18fbbc840c17a600f12f2dc44b010;p=palacios.git diff --git a/palacios/src/palacios/svm.c b/palacios/src/palacios/svm.c index 296559f..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; @@ -383,9 +392,12 @@ void Init_VMCB_BIOS(vmcb_t * vmcb, struct guest_info vm_info) { ctrl_area->instrs.IOIO_PROT = 1; } - //ctrl_area->instrs.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) { PrintDebug("Creating initial shadow page table\n"); @@ -430,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); @@ -593,7 +606,7 @@ void Init_VMCB_pe(vmcb_t *vmcb, struct guest_info vm_info) { - +#endif