From d063bf17e5d315a52e5c52ab43eac6f37827e219 Mon Sep 17 00:00:00 2001 From: Joerg Roedel Date: Wed, 16 Apr 2008 16:51:17 +0200 Subject: [PATCH] --- yaml --- r: 93907 b: refs/heads/master c: d7bf8221a3037d0d0760a1ccf1833bda03213abf h: refs/heads/master i: 93905: 97980cf46d0e6a40d342250d47e685fd46d0809c 93903: f1a74bae146856f072f55788a0b8abf47dcb815d v: v3 --- [refs] | 2 +- trunk/arch/x86/kvm/svm.c | 12 ++++++++++++ 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index e8d4055a7257..3b87cb8dec5b 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: ec7cf6903ffced20098e2bcc27a184172836dfb9 +refs/heads/master: d7bf8221a3037d0d0760a1ccf1833bda03213abf diff --git a/trunk/arch/x86/kvm/svm.c b/trunk/arch/x86/kvm/svm.c index f8ce36e6690c..ee2ee83f3c48 100644 --- a/trunk/arch/x86/kvm/svm.c +++ b/trunk/arch/x86/kvm/svm.c @@ -1620,6 +1620,16 @@ static void svm_prepare_guest_switch(struct kvm_vcpu *vcpu) { } +static inline void sync_cr8_to_lapic(struct kvm_vcpu *vcpu) +{ + struct vcpu_svm *svm = to_svm(vcpu); + + if (!(svm->vmcb->control.intercept_cr_write & INTERCEPT_CR8_MASK)) { + int cr8 = svm->vmcb->control.int_ctl & V_TPR_MASK; + kvm_lapic_set_tpr(vcpu, cr8); + } +} + static inline void sync_lapic_to_cr8(struct kvm_vcpu *vcpu) { struct vcpu_svm *svm = to_svm(vcpu); @@ -1791,6 +1801,8 @@ static void svm_vcpu_run(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run) stgi(); + sync_cr8_to_lapic(vcpu); + svm->next_rip = 0; }