diff options
author | Joerg Roedel <joerg.roedel@amd.com> | 2008-04-30 11:56:00 -0400 |
---|---|---|
committer | Avi Kivity <avi@qumranet.com> | 2008-07-20 05:40:47 -0400 |
commit | c47f098d69ed2bd7343e54095ff4aa2533253bee (patch) | |
tree | e296ddf631b111bad32255581bf3f192e7efb0ba /arch/x86/kvm/svm.c | |
parent | c7bf23babc959b186335d2640959a1b8633588de (diff) |
KVM: SVM: implement dedicated NMI exit handler
With an exit handler for NMI intercepts its possible to account them using
kvmtrace.
Signed-off-by: Joerg Roedel <joerg.roedel@amd.com>
Signed-off-by: Avi Kivity <avi@qumranet.com>
Diffstat (limited to 'arch/x86/kvm/svm.c')
-rw-r--r-- | arch/x86/kvm/svm.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/arch/x86/kvm/svm.c b/arch/x86/kvm/svm.c index 6b0d5fa5bab3..8a2118b09fd2 100644 --- a/arch/x86/kvm/svm.c +++ b/arch/x86/kvm/svm.c | |||
@@ -1081,6 +1081,11 @@ static int io_interception(struct vcpu_svm *svm, struct kvm_run *kvm_run) | |||
1081 | return kvm_emulate_pio(&svm->vcpu, kvm_run, in, size, port); | 1081 | return kvm_emulate_pio(&svm->vcpu, kvm_run, in, size, port); |
1082 | } | 1082 | } |
1083 | 1083 | ||
1084 | static int nmi_interception(struct vcpu_svm *svm, struct kvm_run *kvm_run) | ||
1085 | { | ||
1086 | return 1; | ||
1087 | } | ||
1088 | |||
1084 | static int nop_on_interception(struct vcpu_svm *svm, struct kvm_run *kvm_run) | 1089 | static int nop_on_interception(struct vcpu_svm *svm, struct kvm_run *kvm_run) |
1085 | { | 1090 | { |
1086 | return 1; | 1091 | return 1; |
@@ -1365,7 +1370,7 @@ static int (*svm_exit_handlers[])(struct vcpu_svm *svm, | |||
1365 | [SVM_EXIT_EXCP_BASE + NM_VECTOR] = nm_interception, | 1370 | [SVM_EXIT_EXCP_BASE + NM_VECTOR] = nm_interception, |
1366 | [SVM_EXIT_EXCP_BASE + MC_VECTOR] = mc_interception, | 1371 | [SVM_EXIT_EXCP_BASE + MC_VECTOR] = mc_interception, |
1367 | [SVM_EXIT_INTR] = nop_on_interception, | 1372 | [SVM_EXIT_INTR] = nop_on_interception, |
1368 | [SVM_EXIT_NMI] = nop_on_interception, | 1373 | [SVM_EXIT_NMI] = nmi_interception, |
1369 | [SVM_EXIT_SMI] = nop_on_interception, | 1374 | [SVM_EXIT_SMI] = nop_on_interception, |
1370 | [SVM_EXIT_INIT] = nop_on_interception, | 1375 | [SVM_EXIT_INIT] = nop_on_interception, |
1371 | [SVM_EXIT_VINTR] = interrupt_window_interception, | 1376 | [SVM_EXIT_VINTR] = interrupt_window_interception, |