#include <palacios/vmm_ctrl_regs.h>
#include <palacios/svm_io.h>
#include <palacios/svm_halt.h>
+#include <palacios/svm_pause.h>
#include <palacios/vmm_intr.h>
if (handle_svm_halt(info) == -1) {
return -1;
}
+ } else if (exit_code == VMEXIT_PAUSE) {
+ PrintDebug("Guest paused\n");
+ if (handle_svm_pause(info) == -1) {
+ return -1;
+ }
} else {
addr_t rip_addr;
char buf[15];
PrintTraceMemDump(buf, 15);
- while(1);
+ return -1;
}
guest_ctrl->EVENTINJ.type = SVM_INJECTION_EXCEPTION;
- if (info->intr_state.excp_error_code) {
+ if (info->intr_state.excp_error_code_valid) { //PAD
guest_ctrl->EVENTINJ.error_code = info->intr_state.excp_error_code;
guest_ctrl->EVENTINJ.ev = 1;
PrintDebug("Injecting error code %x\n", guest_ctrl->EVENTINJ.error_code);
info->ctrl_regs.cr2 = fault_addr;
raise_exception_with_error(info, PF_EXCEPTION, *(uint_t *)&error_code);
- PrintDebug("Access error injecting pf to guest (guest access error=%d) (pf error code=%d)\n", guest_pte_access, error_code);
+ PrintDebug("Access error injecting pf to guest (guest access error=%d) (pf error code=%d)\n", guest_pte_access, *(uint_t*)&error_code);
return 0;
}