Commit 45c3af97 authored by Paolo Bonzini's avatar Paolo Bonzini

KVM: x86: Trace changes to active TSC offset regardless if vCPU in guest-mode

For some reason, kvm_x86_ops->write_l1_tsc_offset() skipped trace
of change to active TSC offset in case vCPU is in guest-mode.
This patch changes write_l1_tsc_offset() behavior to trace any change
to active TSC offset to aid debugging.  The VMX code is changed to
look more similar to SVM, which is in my opinion nicer.

Based on a patch by Liran Alon.
Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
parent fd65d314
...@@ -1456,10 +1456,11 @@ static u64 svm_write_l1_tsc_offset(struct kvm_vcpu *vcpu, u64 offset) ...@@ -1456,10 +1456,11 @@ static u64 svm_write_l1_tsc_offset(struct kvm_vcpu *vcpu, u64 offset)
g_tsc_offset = svm->vmcb->control.tsc_offset - g_tsc_offset = svm->vmcb->control.tsc_offset -
svm->nested.hsave->control.tsc_offset; svm->nested.hsave->control.tsc_offset;
svm->nested.hsave->control.tsc_offset = offset; svm->nested.hsave->control.tsc_offset = offset;
} else }
trace_kvm_write_tsc_offset(vcpu->vcpu_id,
svm->vmcb->control.tsc_offset, trace_kvm_write_tsc_offset(vcpu->vcpu_id,
offset); svm->vmcb->control.tsc_offset - g_tsc_offset,
offset);
svm->vmcb->control.tsc_offset = offset + g_tsc_offset; svm->vmcb->control.tsc_offset = offset + g_tsc_offset;
......
...@@ -3466,24 +3466,24 @@ static u64 vmx_read_l1_tsc_offset(struct kvm_vcpu *vcpu) ...@@ -3466,24 +3466,24 @@ static u64 vmx_read_l1_tsc_offset(struct kvm_vcpu *vcpu)
static u64 vmx_write_l1_tsc_offset(struct kvm_vcpu *vcpu, u64 offset) static u64 vmx_write_l1_tsc_offset(struct kvm_vcpu *vcpu, u64 offset)
{ {
u64 active_offset = offset; struct vmcs12 *vmcs12 = get_vmcs12(vcpu);
if (is_guest_mode(vcpu)) { u64 g_tsc_offset = 0;
/*
* We're here if L1 chose not to trap WRMSR to TSC. According /*
* to the spec, this should set L1's TSC; The offset that L1 * We're here if L1 chose not to trap WRMSR to TSC. According
* set for L2 remains unchanged, and still needs to be added * to the spec, this should set L1's TSC; The offset that L1
* to the newly set TSC to get L2's TSC. * set for L2 remains unchanged, and still needs to be added
*/ * to the newly set TSC to get L2's TSC.
struct vmcs12 *vmcs12 = get_vmcs12(vcpu); */
if (nested_cpu_has(vmcs12, CPU_BASED_USE_TSC_OFFSETING)) if (is_guest_mode(vcpu) &&
active_offset += vmcs12->tsc_offset; (vmcs12->cpu_based_vm_exec_control & CPU_BASED_USE_TSC_OFFSETING))
} else { g_tsc_offset = vmcs12->tsc_offset;
trace_kvm_write_tsc_offset(vcpu->vcpu_id,
vmcs_read64(TSC_OFFSET), offset);
}
vmcs_write64(TSC_OFFSET, active_offset); trace_kvm_write_tsc_offset(vcpu->vcpu_id,
return active_offset; vcpu->arch.tsc_offset - g_tsc_offset,
offset);
vmcs_write64(TSC_OFFSET, offset + g_tsc_offset);
return offset + g_tsc_offset;
} }
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment