vmx_ret |= check_vmcs_write(VMCS_LINK_PTR_HIGH, (addr_t)0xffffffffUL);
#endif
-
+ if (vmx_ret != VMX_SUCCESS) {
+ PrintError(core->vm_info, core, "Error configuring VMX\n");
+ return -1;
+ }
PrintDebug(core->vm_info, core, "Serializing VMCS: %p\n", (void *)vmx_state->vmcs_ptr_phys);
vmx_ret = vmcs_clear(vmx_state->vmcs_ptr_phys);
+ if (vmx_ret != VMX_SUCCESS) {
+ PrintError(core->vm_info,core,"VMCS Clear failed\n");
+ return;
+ }
+
core->core_run_state = CORE_STOPPED;
return;
}
if (info->shdw_pg_mode == NESTED_PAGING) {
check_vmcs_read(VMCS_GUEST_PHYS_ADDR, &(exit_info.ept_fault_addr));
+ } else {
+ exit_info.ept_fault_addr = 0;
}
//PrintDebug(info->vm_info, info, "VMX Exit taken, id-qual: %u-%lu\n", exit_info.exit_reason, exit_info.exit_qual);
linear_addr = get_addr_linear(info, info->rip, &(info->segments.cs));
if (info->mem_mode == PHYSICAL_MEM) {
- v3_gpa_to_hva(info, linear_addr, &host_addr);
+ if (v3_gpa_to_hva(info, linear_addr, &host_addr)) {
+ PrintError(info->vm_info, info, "Cannot translate address\n");
+ return -1;
+ }
} else if (info->mem_mode == VIRTUAL_MEM) {
- v3_gva_to_hva(info, linear_addr, &host_addr);
+ if (v3_gva_to_hva(info, linear_addr, &host_addr)) {
+ PrintError(info->vm_info, info, "Cannot translate address\n");
+ return -1;
+ }
}
V3_Print(info->vm_info, info, "VMX core %u: Host Address of rip = 0x%p\n", info->vcpu_id, (void *)host_addr);