Commit 8e6ed96c authored by Li RongQing's avatar Li RongQing Committed by Sean Christopherson

KVM: x86: fire timer when it is migrated and expired, and in oneshot mode

when the vCPU was migrated, if its timer is expired, KVM _should_ fire
the timer ASAP, zeroing the deadline here will cause the timer to
immediately fire on the destination

Cc: Sean Christopherson <seanjc@google.com>
Cc: Peter Shier <pshier@google.com>
Cc: Jim Mattson <jmattson@google.com>
Cc: Wanpeng Li <wanpengli@tencent.com>
Cc: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: default avatarLi RongQing <lirongqing@baidu.com>
Link: https://lore.kernel.org/r/20230106040625.8404-1-lirongqing@baidu.comSigned-off-by: default avatarSean Christopherson <seanjc@google.com>
parent 02efd818
...@@ -1968,8 +1968,12 @@ static bool set_target_expiration(struct kvm_lapic *apic, u32 count_reg) ...@@ -1968,8 +1968,12 @@ static bool set_target_expiration(struct kvm_lapic *apic, u32 count_reg)
if (unlikely(count_reg != APIC_TMICT)) { if (unlikely(count_reg != APIC_TMICT)) {
deadline = tmict_to_ns(apic, deadline = tmict_to_ns(apic,
kvm_lapic_get_reg(apic, count_reg)); kvm_lapic_get_reg(apic, count_reg));
if (unlikely(deadline <= 0)) if (unlikely(deadline <= 0)) {
deadline = apic->lapic_timer.period; if (apic_lvtt_period(apic))
deadline = apic->lapic_timer.period;
else
deadline = 0;
}
else if (unlikely(deadline > apic->lapic_timer.period)) { else if (unlikely(deadline > apic->lapic_timer.period)) {
pr_info_ratelimited( pr_info_ratelimited(
"vcpu %i: requested lapic timer restore with " "vcpu %i: requested lapic timer restore with "
......
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