X-Git-Url: https://git.lttng.org/?a=blobdiff_plain;f=ltt-statedump.c;h=43cc2edd4a2fad759ea0f936954107a7fb921abb;hb=refs%2Fheads%2Fv0.19-stable;hp=06ade69a8374f08b2db6852b7c18fb9dfd6e3d9a;hpb=1c8284ebdbd119314b8f01e442e64cf5fd4b9fe6;p=lttng-modules.git diff --git a/ltt-statedump.c b/ltt-statedump.c index 06ade69a..43cc2edd 100644 --- a/ltt-statedump.c +++ b/ltt-statedump.c @@ -39,6 +39,10 @@ #include #endif +#ifdef CONFIG_HAVE_KVM +#include +#endif + #define NB_PROC_CHUNK 20 /* @@ -85,6 +89,65 @@ enum lttng_process_status { LTTNG_DEAD = 7, }; +struct trace_enum_map { + long id; + const char *symbol; +}; + +#ifdef CONFIG_HAVE_KVM +static const struct trace_enum_map vmx_kvm_exit_enum[] = { + { EXIT_REASON_EXCEPTION_NMI, "exception" }, + { EXIT_REASON_EXTERNAL_INTERRUPT, "ext_irq" }, + { EXIT_REASON_TRIPLE_FAULT, "triple_fault" }, + { EXIT_REASON_PENDING_INTERRUPT, "interrupt_window" }, + { EXIT_REASON_NMI_WINDOW, "nmi_window" }, + { EXIT_REASON_TASK_SWITCH, "task_switch" }, + { EXIT_REASON_CPUID, "cpuid" }, + { EXIT_REASON_HLT, "halt" }, + { EXIT_REASON_INVLPG, "invlpg" }, + { EXIT_REASON_RDPMC, "rdpmc" }, + { EXIT_REASON_RDTSC, "rdtsc" }, + { EXIT_REASON_VMCALL, "hypercall" }, + { EXIT_REASON_VMCLEAR, "vmclear" }, + { EXIT_REASON_VMLAUNCH, "vmlaunch" }, + { EXIT_REASON_VMPTRLD, "vmprtld" }, + { EXIT_REASON_VMPTRST, "vmptrst" }, + { EXIT_REASON_VMREAD, "vmread" }, + { EXIT_REASON_VMRESUME, "vmresume" }, + { EXIT_REASON_VMWRITE, "vmwrite" }, + { EXIT_REASON_VMOFF, "vmoff" }, + { EXIT_REASON_VMON, "vmon" }, + { EXIT_REASON_CR_ACCESS, "cr_access" }, + { EXIT_REASON_DR_ACCESS, "dr_access" }, + { EXIT_REASON_IO_INSTRUCTION, "io_instruction" }, + { EXIT_REASON_MSR_READ, "rdmsr" }, + { EXIT_REASON_MSR_WRITE, "wrmsr" }, + { EXIT_REASON_MWAIT_INSTRUCTION, "mwait_instruction" }, + { EXIT_REASON_MONITOR_INSTRUCTION, "monitor_instruction" }, + { EXIT_REASON_PAUSE_INSTRUCTION, "pause_instruction" }, + { EXIT_REASON_MCE_DURING_VMENTRY, "mce_during_vmentry" }, + { EXIT_REASON_TPR_BELOW_THRESHOLD, "tpr_below_thres" }, + { EXIT_REASON_APIC_ACCESS, "apic_access" }, + { EXIT_REASON_EPT_VIOLATION, "ept_violation" }, + { EXIT_REASON_EPT_MISCONFIG, "epg_misconfig" }, + { EXIT_REASON_WBINVD, "wbinvd" }, + { -1, NULL } +}; +#endif /* CONFIG_HAVE_KVM */ + +static void ltt_dump_enum_tables(struct ltt_probe_private_data *call_data) +{ +#ifdef CONFIG_HAVE_KVM + int i; + /* KVM exit reasons for VMX */ + for(i = 0; vmx_kvm_exit_enum[i].symbol; i++) { + __trace_mark(0, enum_tables, vmx_kvm_exit, call_data, + "id %ld symbol %s", vmx_kvm_exit_enum[i].id, + vmx_kvm_exit_enum[i].symbol); + } +#endif /* CONFIG_HAVE_KVM */ +} + #ifdef CONFIG_INET static void ltt_enumerate_device(struct ltt_probe_private_data *call_data, struct net_device *dev) @@ -374,6 +437,7 @@ static int do_ltt_statedump(struct ltt_probe_private_data *call_data) ltt_dump_sys_call_table(call_data); ltt_dump_softirq_vec(call_data); ltt_dump_idt_table(call_data); + ltt_dump_enum_tables(call_data); mutex_lock(&statedump_cb_mutex);