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);
PrintDebug(info->vm_info, info, "Starting VMX core %u\n", info->vcpu_id);
-#if V3_CONFIG_HVM
- if (v3_setup_hvm_vm_for_boot(vm)) {
- PrintError(vm, VCORE_NONE, "HVM setup for boot failed\n");
+#ifdef V3_CONFIG_MULTIBOOT
+ if (v3_setup_multiboot_core_for_boot(info)) {
+ PrintError(info->vm_info, info, "Failed to setup Multiboot core...\n");
+ return -1;
+ }
+#endif
+
+#ifdef V3_CONFIG_HVM
+ if (v3_setup_hvm_hrt_core_for_boot(info)) {
+ PrintError(info->vm_info, info, "Failed to setup HRT core...\n");
return -1;
}
#endif
}
+#ifdef V3_CONFIG_HVM
+ if (v3_handle_hvm_reset(info) > 0) {
+ continue;
+ }
+#endif
+
+#ifdef V3_CONFIG_MULTIBOOT
+ if (v3_handle_multiboot_reset(info) > 0) {
+ continue;
+ }
+#endif
+
#ifdef V3_CONFIG_PMU_TELEMETRY
v3_pmu_telemetry_start(info);
#endif
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);