v3_mem_track_entry(info);
#endif
+#ifdef V3_CONFIG_HVM
+ v3_handle_hvm_entry(info);
+#endif
+
// Update timer devices after being in the VM before doing
// IRQ updates, so that any interrupts they raise get seen
// immediately.
v3_handle_timeouts(info, guest_cycles);
}
+#ifdef V3_CONFIG_HVM
+ v3_handle_hvm_exit(info);
+#endif
+
#ifdef V3_CONFIG_MEM_TRACK
v3_mem_track_exit(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");
+ break;
+ }
} 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");
+ break;
+ }
}
V3_Print(info->vm_info, info, "SVM core %u: Host Address of rip = 0x%p\n", info->vcpu_id, (void *)host_addr);