diff options
author | Chris J Arges <chris.j.arges@canonical.com> | 2014-11-12 21:00:39 -0600 |
---|---|---|
committer | Paolo Bonzini <pbonzini@redhat.com> | 2014-11-13 11:56:11 +0100 |
commit | d913b904355721e0aabb28dc8be2a3121de2e794 (patch) | |
tree | 35312a4baa8932ed0522725c5d7a980fcc60b64f /arch/x86/kvm/svm.c | |
parent | 54b98bff8ef4ccfc6f638c5ed868d2d51cdde585 (diff) | |
download | lwn-d913b904355721e0aabb28dc8be2a3121de2e794.tar.gz lwn-d913b904355721e0aabb28dc8be2a3121de2e794.zip |
kvm: svm: move WARN_ON in svm_adjust_tsc_offset
When running the tsc_adjust kvm-unit-test on an AMD processor with the
IA32_TSC_ADJUST feature enabled, the WARN_ON in svm_adjust_tsc_offset can be
triggered. This WARN_ON checks for a negative adjustment in case __scale_tsc
is called; however it may trigger unnecessary warnings.
This patch moves the WARN_ON to trigger only if __scale_tsc will actually be
called from svm_adjust_tsc_offset. In addition make adj in kvm_set_msr_common
s64 since this can have signed values.
Signed-off-by: Chris J Arges <chris.j.arges@canonical.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'arch/x86/kvm/svm.c')
-rw-r--r-- | arch/x86/kvm/svm.c | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/arch/x86/kvm/svm.c b/arch/x86/kvm/svm.c index d4f3aaa2df7c..6b411add23b8 100644 --- a/arch/x86/kvm/svm.c +++ b/arch/x86/kvm/svm.c @@ -1056,9 +1056,11 @@ static void svm_adjust_tsc_offset(struct kvm_vcpu *vcpu, s64 adjustment, bool ho { struct vcpu_svm *svm = to_svm(vcpu); - WARN_ON(adjustment < 0); - if (host) - adjustment = svm_scale_tsc(vcpu, adjustment); + if (host) { + if (svm->tsc_ratio != TSC_RATIO_DEFAULT) + WARN_ON(adjustment < 0); + adjustment = svm_scale_tsc(vcpu, (u64)adjustment); + } svm->vmcb->control.tsc_offset += adjustment; if (is_guest_mode(vcpu)) |