KVM: nVMX: Add tracepoints for nested_vmexit and nested_vmexit_inject
authorJan Kiszka <jan.kiszka@siemens.com>
Sat, 4 Jan 2014 17:47:21 +0000 (18:47 +0100)
committerPaolo Bonzini <pbonzini@redhat.com>
Fri, 17 Jan 2014 09:22:15 +0000 (10:22 +0100)
Already used by nested SVM for tracing nested vmexit: kvm_nested_vmexit
marks exits from L2 to L0 while kvm_nested_vmexit_inject marks vmexits
that are reflected to L1.

Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
arch/x86/kvm/vmx.c

index e3578b301d81bef77789867e86115d1d2aa24661..e539c45eb66921dcfc67480269b4955702175803 100644 (file)
@@ -6697,6 +6697,13 @@ static bool nested_vmx_exit_handled(struct kvm_vcpu *vcpu)
        struct vmcs12 *vmcs12 = get_vmcs12(vcpu);
        u32 exit_reason = vmx->exit_reason;
 
+       trace_kvm_nested_vmexit(kvm_rip_read(vcpu), exit_reason,
+                               vmcs_readl(EXIT_QUALIFICATION),
+                               vmx->idt_vectoring_info,
+                               intr_info,
+                               vmcs_read32(VM_EXIT_INTR_ERROR_CODE),
+                               KVM_ISA_VMX);
+
        if (vmx->nested.nested_run_pending)
                return 0;
 
@@ -8469,6 +8476,13 @@ static void nested_vmx_vmexit(struct kvm_vcpu *vcpu, u32 exit_reason,
        prepare_vmcs12(vcpu, vmcs12, exit_reason, exit_intr_info,
                       exit_qualification);
 
+       trace_kvm_nested_vmexit_inject(vmcs12->vm_exit_reason,
+                                      vmcs12->exit_qualification,
+                                      vmcs12->idt_vectoring_info_field,
+                                      vmcs12->vm_exit_intr_info,
+                                      vmcs12->vm_exit_intr_error_code,
+                                      KVM_ISA_VMX);
+
        cpu = get_cpu();
        vmx->loaded_vmcs = &vmx->vmcs01;
        vmx_vcpu_put(vcpu);