diff options
author | Joerg Roedel <joerg.roedel@amd.com> | 2009-10-09 10:08:32 -0400 |
---|---|---|
committer | Avi Kivity <avi@redhat.com> | 2009-12-03 02:32:16 -0500 |
commit | 532a46b98963f110e9425a251e127d6537915dde (patch) | |
tree | 54b41094e6f1fef54db79fbcad3e4b36128542a5 /arch/x86/kvm/trace.h | |
parent | ec1ff79084fccdae0dca9b04b89dcdf3235bbfa1 (diff) |
KVM: SVM: Add tracepoint for skinit instruction
This patch adds a tracepoint for the event that the guest
executed the SKINIT instruction. This information is
important because SKINIT is an SVM extenstion not yet
implemented by nested SVM and we may need this information
for debugging hypervisors that do not yet run on nested SVM.
Signed-off-by: Joerg Roedel <joerg.roedel@amd.com>
Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
Diffstat (limited to 'arch/x86/kvm/trace.h')
-rw-r--r-- | arch/x86/kvm/trace.h | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/arch/x86/kvm/trace.h b/arch/x86/kvm/trace.h index 7e1f08e959bc..816e0449db0b 100644 --- a/arch/x86/kvm/trace.h +++ b/arch/x86/kvm/trace.h | |||
@@ -492,6 +492,28 @@ TRACE_EVENT(kvm_invlpga, | |||
492 | TP_printk("rip: 0x%016llx asid: %d address: 0x%016llx\n", | 492 | TP_printk("rip: 0x%016llx asid: %d address: 0x%016llx\n", |
493 | __entry->rip, __entry->asid, __entry->address) | 493 | __entry->rip, __entry->asid, __entry->address) |
494 | ); | 494 | ); |
495 | |||
496 | /* | ||
497 | * Tracepoint for nested #vmexit because of interrupt pending | ||
498 | */ | ||
499 | TRACE_EVENT(kvm_skinit, | ||
500 | TP_PROTO(__u64 rip, __u32 slb), | ||
501 | TP_ARGS(rip, slb), | ||
502 | |||
503 | TP_STRUCT__entry( | ||
504 | __field( __u64, rip ) | ||
505 | __field( __u32, slb ) | ||
506 | ), | ||
507 | |||
508 | TP_fast_assign( | ||
509 | __entry->rip = rip; | ||
510 | __entry->slb = slb; | ||
511 | ), | ||
512 | |||
513 | TP_printk("rip: 0x%016llx slb: 0x%08x\n", | ||
514 | __entry->rip, __entry->slb) | ||
515 | ); | ||
516 | |||
495 | #endif /* _TRACE_KVM_H */ | 517 | #endif /* _TRACE_KVM_H */ |
496 | 518 | ||
497 | /* This part must be outside protection */ | 519 | /* This part must be outside protection */ |