X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Finclude%2Fpalacios%2Fsvm_handler.h;h=abe3b79db57e789f3c391f96bf30eb3c6d997e02;hb=f9bb3db89469169bb5775dc031d89e570c6fed70;hp=8fee2b14a078f21f398e0fb19bb38baa89581064;hpb=a32563c70ad5a49b3b7fb23f07b13d2c6710c03f;p=palacios.git diff --git a/palacios/include/palacios/svm_handler.h b/palacios/include/palacios/svm_handler.h index 8fee2b1..abe3b79 100644 --- a/palacios/include/palacios/svm_handler.h +++ b/palacios/include/palacios/svm_handler.h @@ -1,3 +1,6 @@ +/* Northwestern University */ +/* (c) 2008, Jack Lange */ + #ifndef __SVM_HANDLER_H #define __SVM_HANDLER_H @@ -9,8 +12,6 @@ - - /******************************************/ /* SVM Intercept Exit Codes */ /* AMD Arch Vol 3, Appendix C, pg 477-478 */ @@ -177,6 +178,155 @@ +static const uchar_t VMEXIT_CR0_READ_STR[] = "VMEXIT_CR0_READ"; +static const uchar_t VMEXIT_CR1_READ_STR[] = "VMEXIT_CR1_READ"; +static const uchar_t VMEXIT_CR2_READ_STR[] = "VMEXIT_CR2_READ"; +static const uchar_t VMEXIT_CR3_READ_STR[] = "VMEXIT_CR3_READ"; +static const uchar_t VMEXIT_CR4_READ_STR[] = "VMEXIT_CR4_READ"; +static const uchar_t VMEXIT_CR5_READ_STR[] = "VMEXIT_CR5_READ"; +static const uchar_t VMEXIT_CR6_READ_STR[] = "VMEXIT_CR6_READ"; +static const uchar_t VMEXIT_CR7_READ_STR[] = "VMEXIT_CR7_READ"; +static const uchar_t VMEXIT_CR8_READ_STR[] = "VMEXIT_CR8_READ"; +static const uchar_t VMEXIT_CR9_READ_STR[] = "VMEXIT_CR9_READ"; +static const uchar_t VMEXIT_CR10_READ_STR[] = "VMEXIT_CR10_READ"; +static const uchar_t VMEXIT_CR11_READ_STR[] = "VMEXIT_CR11_READ"; +static const uchar_t VMEXIT_CR12_READ_STR[] = "VMEXIT_CR12_READ"; +static const uchar_t VMEXIT_CR13_READ_STR[] = "VMEXIT_CR13_READ"; +static const uchar_t VMEXIT_CR14_READ_STR[] = "VMEXIT_CR14_READ"; +static const uchar_t VMEXIT_CR15_READ_STR[] = "VMEXIT_CR15_READ"; +static const uchar_t VMEXIT_CR0_WRITE_STR[] = "VMEXIT_CR0_WRITE"; +static const uchar_t VMEXIT_CR1_WRITE_STR[] = "VMEXIT_CR1_WRITE"; +static const uchar_t VMEXIT_CR2_WRITE_STR[] = "VMEXIT_CR2_WRITE"; +static const uchar_t VMEXIT_CR3_WRITE_STR[] = "VMEXIT_CR3_WRITE"; +static const uchar_t VMEXIT_CR4_WRITE_STR[] = "VMEXIT_CR4_WRITE"; +static const uchar_t VMEXIT_CR5_WRITE_STR[] = "VMEXIT_CR5_WRITE"; +static const uchar_t VMEXIT_CR6_WRITE_STR[] = "VMEXIT_CR6_WRITE"; +static const uchar_t VMEXIT_CR7_WRITE_STR[] = "VMEXIT_CR7_WRITE"; +static const uchar_t VMEXIT_CR8_WRITE_STR[] = "VMEXIT_CR8_WRITE"; +static const uchar_t VMEXIT_CR9_WRITE_STR[] = "VMEXIT_CR9_WRITE"; +static const uchar_t VMEXIT_CR10_WRITE_STR[] = "VMEXIT_CR10_WRITE"; +static const uchar_t VMEXIT_CR11_WRITE_STR[] = "VMEXIT_CR11_WRITE"; +static const uchar_t VMEXIT_CR12_WRITE_STR[] = "VMEXIT_CR12_WRITE"; +static const uchar_t VMEXIT_CR13_WRITE_STR[] = "VMEXIT_CR13_WRITE"; +static const uchar_t VMEXIT_CR14_WRITE_STR[] = "VMEXIT_CR14_WRITE"; +static const uchar_t VMEXIT_CR15_WRITE_STR[] = "VMEXIT_CR15_WRITE"; +static const uchar_t VMEXIT_DR0_READ_STR[] = "VMEXIT_DR0_READ"; +static const uchar_t VMEXIT_DR1_READ_STR[] = "VMEXIT_DR1_READ"; +static const uchar_t VMEXIT_DR2_READ_STR[] = "VMEXIT_DR2_READ"; +static const uchar_t VMEXIT_DR3_READ_STR[] = "VMEXIT_DR3_READ"; +static const uchar_t VMEXIT_DR4_READ_STR[] = "VMEXIT_DR4_READ"; +static const uchar_t VMEXIT_DR5_READ_STR[] = "VMEXIT_DR5_READ"; +static const uchar_t VMEXIT_DR6_READ_STR[] = "VMEXIT_DR6_READ"; +static const uchar_t VMEXIT_DR7_READ_STR[] = "VMEXIT_DR7_READ"; +static const uchar_t VMEXIT_DR8_READ_STR[] = "VMEXIT_DR8_READ"; +static const uchar_t VMEXIT_DR9_READ_STR[] = "VMEXIT_DR9_READ"; +static const uchar_t VMEXIT_DR10_READ_STR[] = "VMEXIT_DR10_READ"; +static const uchar_t VMEXIT_DR11_READ_STR[] = "VMEXIT_DR11_READ"; +static const uchar_t VMEXIT_DR12_READ_STR[] = "VMEXIT_DR12_READ"; +static const uchar_t VMEXIT_DR13_READ_STR[] = "VMEXIT_DR13_READ"; +static const uchar_t VMEXIT_DR14_READ_STR[] = "VMEXIT_DR14_READ"; +static const uchar_t VMEXIT_DR15_READ_STR[] = "VMEXIT_DR15_READ"; +static const uchar_t VMEXIT_DR0_WRITE_STR[] = "VMEXIT_DR0_WRITE"; +static const uchar_t VMEXIT_DR1_WRITE_STR[] = "VMEXIT_DR1_WRITE"; +static const uchar_t VMEXIT_DR2_WRITE_STR[] = "VMEXIT_DR2_WRITE"; +static const uchar_t VMEXIT_DR3_WRITE_STR[] = "VMEXIT_DR3_WRITE"; +static const uchar_t VMEXIT_DR4_WRITE_STR[] = "VMEXIT_DR4_WRITE"; +static const uchar_t VMEXIT_DR5_WRITE_STR[] = "VMEXIT_DR5_WRITE"; +static const uchar_t VMEXIT_DR6_WRITE_STR[] = "VMEXIT_DR6_WRITE"; +static const uchar_t VMEXIT_DR7_WRITE_STR[] = "VMEXIT_DR7_WRITE"; +static const uchar_t VMEXIT_DR8_WRITE_STR[] = "VMEXIT_DR8_WRITE"; +static const uchar_t VMEXIT_DR9_WRITE_STR[] = "VMEXIT_DR9_WRITE"; +static const uchar_t VMEXIT_DR10_WRITE_STR[] = "VMEXIT_DR10_WRITE"; +static const uchar_t VMEXIT_DR11_WRITE_STR[] = "VMEXIT_DR11_WRITE"; +static const uchar_t VMEXIT_DR12_WRITE_STR[] = "VMEXIT_DR12_WRITE"; +static const uchar_t VMEXIT_DR13_WRITE_STR[] = "VMEXIT_DR13_WRITE"; +static const uchar_t VMEXIT_DR14_WRITE_STR[] = "VMEXIT_DR14_WRITE"; +static const uchar_t VMEXIT_DR15_WRITE_STR[] = "VMEXIT_DR15_WRITE"; +static const uchar_t VMEXIT_EXCP0_STR[] = "VMEXIT_EXCP0"; +static const uchar_t VMEXIT_EXCP1_STR[] = "VMEXIT_EXCP1"; +static const uchar_t VMEXIT_EXCP2_STR[] = "VMEXIT_EXCP2"; +static const uchar_t VMEXIT_EXCP3_STR[] = "VMEXIT_EXCP3"; +static const uchar_t VMEXIT_EXCP4_STR[] = "VMEXIT_EXCP4"; +static const uchar_t VMEXIT_EXCP5_STR[] = "VMEXIT_EXCP5"; +static const uchar_t VMEXIT_EXCP6_STR[] = "VMEXIT_EXCP6"; +static const uchar_t VMEXIT_EXCP7_STR[] = "VMEXIT_EXCP7"; +static const uchar_t VMEXIT_EXCP8_STR[] = "VMEXIT_EXCP8"; +static const uchar_t VMEXIT_EXCP9_STR[] = "VMEXIT_EXCP9"; +static const uchar_t VMEXIT_EXCP10_STR[] = "VMEXIT_EXCP10"; +static const uchar_t VMEXIT_EXCP11_STR[] = "VMEXIT_EXCP11"; +static const uchar_t VMEXIT_EXCP12_STR[] = "VMEXIT_EXCP12"; +static const uchar_t VMEXIT_EXCP13_STR[] = "VMEXIT_EXCP13"; +static const uchar_t VMEXIT_EXCP14_STR[] = "VMEXIT_EXCP14"; +static const uchar_t VMEXIT_EXCP15_STR[] = "VMEXIT_EXCP15"; +static const uchar_t VMEXIT_EXCP16_STR[] = "VMEXIT_EXCP16"; +static const uchar_t VMEXIT_EXCP17_STR[] = "VMEXIT_EXCP17"; +static const uchar_t VMEXIT_EXCP18_STR[] = "VMEXIT_EXCP18"; +static const uchar_t VMEXIT_EXCP19_STR[] = "VMEXIT_EXCP19"; +static const uchar_t VMEXIT_EXCP20_STR[] = "VMEXIT_EXCP20"; +static const uchar_t VMEXIT_EXCP21_STR[] = "VMEXIT_EXCP21"; +static const uchar_t VMEXIT_EXCP22_STR[] = "VMEXIT_EXCP22"; +static const uchar_t VMEXIT_EXCP23_STR[] = "VMEXIT_EXCP23"; +static const uchar_t VMEXIT_EXCP24_STR[] = "VMEXIT_EXCP24"; +static const uchar_t VMEXIT_EXCP25_STR[] = "VMEXIT_EXCP25"; +static const uchar_t VMEXIT_EXCP26_STR[] = "VMEXIT_EXCP26"; +static const uchar_t VMEXIT_EXCP27_STR[] = "VMEXIT_EXCP27"; +static const uchar_t VMEXIT_EXCP28_STR[] = "VMEXIT_EXCP28"; +static const uchar_t VMEXIT_EXCP29_STR[] = "VMEXIT_EXCP29"; +static const uchar_t VMEXIT_EXCP30_STR[] = "VMEXIT_EXCP30"; +static const uchar_t VMEXIT_EXCP31_STR[] = "VMEXIT_EXCP31"; +static const uchar_t VMEXIT_INTR_STR[] = "VMEXIT_INTR"; +static const uchar_t VMEXIT_NMI_STR[] = "VMEXIT_NMI"; +static const uchar_t VMEXIT_SMI_STR[] = "VMEXIT_SMI"; +static const uchar_t VMEXIT_INIT_STR[] = "VMEXIT_INIT"; +static const uchar_t VMEXIT_VINITR_STR[] = "VMEXIT_VINITR"; +static const uchar_t VMEXIT_CR0_SEL_WRITE_STR[] = "VMEXIT_CR0_SEL_WRITE"; +static const uchar_t VMEXIT_IDTR_READ_STR[] = "VMEXIT_IDTR_READ"; +static const uchar_t VMEXIT_GDTR_READ_STR[] = "VMEXIT_GDTR_READ"; +static const uchar_t VMEXIT_LDTR_READ_STR[] = "VMEXIT_LDTR_READ"; +static const uchar_t VMEXIT_TR_READ_STR[] = "VMEXIT_TR_READ"; +static const uchar_t VMEXIT_IDTR_WRITE_STR[] = "VMEXIT_IDTR_WRITE"; +static const uchar_t VMEXIT_GDTR_WRITE_STR[] = "VMEXIT_GDTR_WRITE"; +static const uchar_t VMEXIT_LDTR_WRITE_STR[] = "VMEXIT_LDTR_WRITE"; +static const uchar_t VMEXIT_TR_WRITE_STR[] = "VMEXIT_TR_WRITE"; +static const uchar_t VMEXIT_RDTSC_STR[] = "VMEXIT_RDTSC"; +static const uchar_t VMEXIT_RDPMC_STR[] = "VMEXIT_RDPMC"; +static const uchar_t VMEXIT_PUSHF_STR[] = "VMEXIT_PUSHF"; +static const uchar_t VMEXIT_POPF_STR[] = "VMEXIT_POPF"; +static const uchar_t VMEXIT_CPUID_STR[] = "VMEXIT_CPUID"; +static const uchar_t VMEXIT_RSM_STR[] = "VMEXIT_RSM"; +static const uchar_t VMEXIT_IRET_STR[] = "VMEXIT_IRET"; +static const uchar_t VMEXIT_SWINT_STR[] = "VMEXIT_SWINT"; +static const uchar_t VMEXIT_INVD_STR[] = "VMEXIT_INVD"; +static const uchar_t VMEXIT_PAUSE_STR[] = "VMEXIT_PAUSE"; +static const uchar_t VMEXIT_HLT_STR[] = "VMEXIT_HLT"; +static const uchar_t VMEXIT_INVLPG_STR[] = "VMEXIT_INVLPG"; +static const uchar_t VMEXIT_INVLPGA_STR[] = "VMEXIT_INVLPGA"; +static const uchar_t VMEXIT_IOIO_STR[] = "VMEXIT_IOIO"; +static const uchar_t VMEXIT_MSR_STR[] = "VMEXIT_MSR"; +static const uchar_t VMEXIT_TASK_SWITCH_STR[] = "VMEXIT_TASK_SWITCH"; +static const uchar_t VMEXIT_FERR_FREEZE_STR[] = "VMEXIT_FERR_FREEZE"; +static const uchar_t VMEXIT_SHUTDOWN_STR[] = "VMEXIT_SHUTDOWN"; +static const uchar_t VMEXIT_VMRUN_STR[] = "VMEXIT_VMRUN"; +static const uchar_t VMEXIT_VMMCALL_STR[] = "VMEXIT_VMMCALL"; +static const uchar_t VMEXIT_VMLOAD_STR[] = "VMEXIT_VMLOAD"; +static const uchar_t VMEXIT_VMSAVE_STR[] = "VMEXIT_VMSAVE"; +static const uchar_t VMEXIT_STGI_STR[] = "VMEXIT_STGI"; +static const uchar_t VMEXIT_CLGI_STR[] = "VMEXIT_CLGI"; +static const uchar_t VMEXIT_SKINIT_STR[] = "VMEXIT_SKINIT"; +static const uchar_t VMEXIT_RDTSCP_STR[] = "VMEXIT_RDTSCP"; +static const uchar_t VMEXIT_ICEBP_STR[] = "VMEXIT_ICEBP"; +static const uchar_t VMEXIT_WBINVD_STR[] = "VMEXIT_WBINVD"; +static const uchar_t VMEXIT_MONITOR_STR[] = "VMEXIT_MONITOR"; +static const uchar_t VMEXIT_MWAIT_STR[] = "VMEXIT_MWAIT"; +static const uchar_t VMEXIT_MWAIT_CONDITIONAL_STR[] = "VMEXIT_MWAIT_CONDITIONAL"; +static const uchar_t VMEXIT_NPF_STR[] = "VMEXIT_NPF"; +static const uchar_t VMEXIT_INVALID_VMCB_STR[] = "VMEXIT_INVALID_VMCB"; + + +const uchar_t * vmexit_code_to_str(uint_t exit_code); + + + int handle_shadow_paging(struct guest_info * info); int handle_svm_intr(struct guest_info * info);