diff options
Diffstat (limited to 'arch/x86/kvm')
-rw-r--r-- | arch/x86/kvm/svm.c | 26 |
1 files changed, 25 insertions, 1 deletions
diff --git a/arch/x86/kvm/svm.c b/arch/x86/kvm/svm.c index 0eac1a5060a6..8953292acfd9 100644 --- a/arch/x86/kvm/svm.c +++ b/arch/x86/kvm/svm.c | |||
@@ -949,7 +949,9 @@ static void new_asid(struct vcpu_svm *svm, struct svm_cpu_data *svm_data) | |||
949 | 949 | ||
950 | static unsigned long svm_get_dr(struct kvm_vcpu *vcpu, int dr) | 950 | static unsigned long svm_get_dr(struct kvm_vcpu *vcpu, int dr) |
951 | { | 951 | { |
952 | return to_svm(vcpu)->db_regs[dr]; | 952 | unsigned long val = to_svm(vcpu)->db_regs[dr]; |
953 | KVMTRACE_2D(DR_READ, vcpu, (u32)dr, (u32)val, handler); | ||
954 | return val; | ||
953 | } | 955 | } |
954 | 956 | ||
955 | static void svm_set_dr(struct kvm_vcpu *vcpu, int dr, unsigned long value, | 957 | static void svm_set_dr(struct kvm_vcpu *vcpu, int dr, unsigned long value, |
@@ -1004,6 +1006,12 @@ static int pf_interception(struct vcpu_svm *svm, struct kvm_run *kvm_run) | |||
1004 | 1006 | ||
1005 | fault_address = svm->vmcb->control.exit_info_2; | 1007 | fault_address = svm->vmcb->control.exit_info_2; |
1006 | error_code = svm->vmcb->control.exit_info_1; | 1008 | error_code = svm->vmcb->control.exit_info_1; |
1009 | |||
1010 | if (!npt_enabled) | ||
1011 | KVMTRACE_3D(PAGE_FAULT, &svm->vcpu, error_code, | ||
1012 | (u32)fault_address, (u32)(fault_address >> 32), | ||
1013 | handler); | ||
1014 | |||
1007 | return kvm_mmu_page_fault(&svm->vcpu, fault_address, error_code); | 1015 | return kvm_mmu_page_fault(&svm->vcpu, fault_address, error_code); |
1008 | } | 1016 | } |
1009 | 1017 | ||
@@ -1083,12 +1091,14 @@ static int io_interception(struct vcpu_svm *svm, struct kvm_run *kvm_run) | |||
1083 | 1091 | ||
1084 | static int nmi_interception(struct vcpu_svm *svm, struct kvm_run *kvm_run) | 1092 | static int nmi_interception(struct vcpu_svm *svm, struct kvm_run *kvm_run) |
1085 | { | 1093 | { |
1094 | KVMTRACE_0D(NMI, &svm->vcpu, handler); | ||
1086 | return 1; | 1095 | return 1; |
1087 | } | 1096 | } |
1088 | 1097 | ||
1089 | static int intr_interception(struct vcpu_svm *svm, struct kvm_run *kvm_run) | 1098 | static int intr_interception(struct vcpu_svm *svm, struct kvm_run *kvm_run) |
1090 | { | 1099 | { |
1091 | ++svm->vcpu.stat.irq_exits; | 1100 | ++svm->vcpu.stat.irq_exits; |
1101 | KVMTRACE_0D(INTR, &svm->vcpu, handler); | ||
1092 | return 1; | 1102 | return 1; |
1093 | } | 1103 | } |
1094 | 1104 | ||
@@ -1230,6 +1240,9 @@ static int rdmsr_interception(struct vcpu_svm *svm, struct kvm_run *kvm_run) | |||
1230 | if (svm_get_msr(&svm->vcpu, ecx, &data)) | 1240 | if (svm_get_msr(&svm->vcpu, ecx, &data)) |
1231 | kvm_inject_gp(&svm->vcpu, 0); | 1241 | kvm_inject_gp(&svm->vcpu, 0); |
1232 | else { | 1242 | else { |
1243 | KVMTRACE_3D(MSR_READ, &svm->vcpu, ecx, (u32)data, | ||
1244 | (u32)(data >> 32), handler); | ||
1245 | |||
1233 | svm->vmcb->save.rax = data & 0xffffffff; | 1246 | svm->vmcb->save.rax = data & 0xffffffff; |
1234 | svm->vcpu.arch.regs[VCPU_REGS_RDX] = data >> 32; | 1247 | svm->vcpu.arch.regs[VCPU_REGS_RDX] = data >> 32; |
1235 | svm->next_rip = svm->vmcb->save.rip + 2; | 1248 | svm->next_rip = svm->vmcb->save.rip + 2; |
@@ -1315,6 +1328,10 @@ static int wrmsr_interception(struct vcpu_svm *svm, struct kvm_run *kvm_run) | |||
1315 | u32 ecx = svm->vcpu.arch.regs[VCPU_REGS_RCX]; | 1328 | u32 ecx = svm->vcpu.arch.regs[VCPU_REGS_RCX]; |
1316 | u64 data = (svm->vmcb->save.rax & -1u) | 1329 | u64 data = (svm->vmcb->save.rax & -1u) |
1317 | | ((u64)(svm->vcpu.arch.regs[VCPU_REGS_RDX] & -1u) << 32); | 1330 | | ((u64)(svm->vcpu.arch.regs[VCPU_REGS_RDX] & -1u) << 32); |
1331 | |||
1332 | KVMTRACE_3D(MSR_WRITE, &svm->vcpu, ecx, (u32)data, (u32)(data >> 32), | ||
1333 | handler); | ||
1334 | |||
1318 | svm->next_rip = svm->vmcb->save.rip + 2; | 1335 | svm->next_rip = svm->vmcb->save.rip + 2; |
1319 | if (svm_set_msr(&svm->vcpu, ecx, data)) | 1336 | if (svm_set_msr(&svm->vcpu, ecx, data)) |
1320 | kvm_inject_gp(&svm->vcpu, 0); | 1337 | kvm_inject_gp(&svm->vcpu, 0); |
@@ -1334,6 +1351,8 @@ static int msr_interception(struct vcpu_svm *svm, struct kvm_run *kvm_run) | |||
1334 | static int interrupt_window_interception(struct vcpu_svm *svm, | 1351 | static int interrupt_window_interception(struct vcpu_svm *svm, |
1335 | struct kvm_run *kvm_run) | 1352 | struct kvm_run *kvm_run) |
1336 | { | 1353 | { |
1354 | KVMTRACE_0D(PEND_INTR, &svm->vcpu, handler); | ||
1355 | |||
1337 | svm->vmcb->control.intercept &= ~(1ULL << INTERCEPT_VINTR); | 1356 | svm->vmcb->control.intercept &= ~(1ULL << INTERCEPT_VINTR); |
1338 | svm->vmcb->control.int_ctl &= ~V_IRQ_MASK; | 1357 | svm->vmcb->control.int_ctl &= ~V_IRQ_MASK; |
1339 | /* | 1358 | /* |
@@ -1408,6 +1427,9 @@ static int handle_exit(struct kvm_run *kvm_run, struct kvm_vcpu *vcpu) | |||
1408 | struct vcpu_svm *svm = to_svm(vcpu); | 1427 | struct vcpu_svm *svm = to_svm(vcpu); |
1409 | u32 exit_code = svm->vmcb->control.exit_code; | 1428 | u32 exit_code = svm->vmcb->control.exit_code; |
1410 | 1429 | ||
1430 | KVMTRACE_3D(VMEXIT, vcpu, exit_code, (u32)svm->vmcb->save.rip, | ||
1431 | (u32)((u64)svm->vmcb->save.rip >> 32), entryexit); | ||
1432 | |||
1411 | if (npt_enabled) { | 1433 | if (npt_enabled) { |
1412 | int mmu_reload = 0; | 1434 | int mmu_reload = 0; |
1413 | if ((vcpu->arch.cr0 ^ svm->vmcb->save.cr0) & X86_CR0_PG) { | 1435 | if ((vcpu->arch.cr0 ^ svm->vmcb->save.cr0) & X86_CR0_PG) { |
@@ -1481,6 +1503,8 @@ static inline void svm_inject_irq(struct vcpu_svm *svm, int irq) | |||
1481 | { | 1503 | { |
1482 | struct vmcb_control_area *control; | 1504 | struct vmcb_control_area *control; |
1483 | 1505 | ||
1506 | KVMTRACE_1D(INJ_VIRQ, &svm->vcpu, (u32)irq, handler); | ||
1507 | |||
1484 | control = &svm->vmcb->control; | 1508 | control = &svm->vmcb->control; |
1485 | control->int_vector = irq; | 1509 | control->int_vector = irq; |
1486 | control->int_ctl &= ~V_INTR_PRIO_MASK; | 1510 | control->int_ctl &= ~V_INTR_PRIO_MASK; |