The commit is pushed to "branch-rh7-3.10.0-327.4.5.vz7.11.x-ovz" and will 
appear at https://src.openvz.org/scm/ovz/vzkernel.git
after rh7-3.10.0-327.4.5.vz7.11.2
------>
commit c812f91bf6b7bf2f8b9b0d22bec528e5ccc17ab5
Author: Andrey Smetanin <[email protected]>
Date:   Tue Feb 16 13:50:26 2016 +0400

    ms/kvm/x86: Reorg stimer_expiration() to better control timer restart
    
    Split stimer_expiration() into two parts - timer expiration message
    sending and timer restart/cleanup based on timer state(config).
    
    This also fixes a bug where a one-shot timer message whose delivery
    failed once would get lost for good.
    
    ms commit - 0cdeabb1186fc3a6c7854f05cec7c99e32935ebc.
    
    Signed-off-by: Andrey Smetanin <[email protected]>
    
    Reviewed-by: Roman Kagan <[email protected]>
    CC: Gleb Natapov <[email protected]>
    CC: Paolo Bonzini <[email protected]>
    CC: Roman Kagan <[email protected]>
    CC: Denis V. Lunev <[email protected]>
    CC: [email protected]
    Signed-off-by: Paolo Bonzini <[email protected]>
---
 arch/x86/kvm/hyperv.c | 26 ++++++++++++++------------
 1 file changed, 14 insertions(+), 12 deletions(-)

diff --git a/arch/x86/kvm/hyperv.c b/arch/x86/kvm/hyperv.c
index 67cace3..b121fca 100644
--- a/arch/x86/kvm/hyperv.c
+++ b/arch/x86/kvm/hyperv.c
@@ -554,30 +554,27 @@ static int synic_deliver_msg(struct kvm_vcpu_hv_synic 
*synic, u32 sint,
        return r;
 }
 
-static void stimer_send_msg(struct kvm_vcpu_hv_stimer *stimer)
+static int stimer_send_msg(struct kvm_vcpu_hv_stimer *stimer)
 {
        struct kvm_vcpu *vcpu = stimer_to_vcpu(stimer);
        struct hv_message *msg = &stimer->msg;
        struct hv_timer_message_payload *payload =
                        (struct hv_timer_message_payload *)&msg->u.payload;
-       int r;
 
-       stimer->msg_pending = true;
        payload->expiration_time = stimer->exp_time;
        payload->delivery_time = get_time_ref_counter(vcpu->kvm);
-       r = synic_deliver_msg(vcpu_to_synic(vcpu),
-                             HV_STIMER_SINT(stimer->config), msg);
-       if (!r)
-               stimer->msg_pending = false;
+       return synic_deliver_msg(vcpu_to_synic(vcpu),
+                                HV_STIMER_SINT(stimer->config), msg);
 }
 
 static void stimer_expiration(struct kvm_vcpu_hv_stimer *stimer)
 {
-       stimer_send_msg(stimer);
-       if (!(stimer->config & HV_STIMER_PERIODIC))
-               stimer->config &= ~HV_STIMER_ENABLE;
-       else
-               stimer_start(stimer);
+       stimer->msg_pending = true;
+       if (!stimer_send_msg(stimer)) {
+               stimer->msg_pending = false;
+               if (!(stimer->config & HV_STIMER_PERIODIC))
+                       stimer->config &= ~HV_STIMER_ENABLE;
+       }
 }
 
 void kvm_hv_process_stimers(struct kvm_vcpu *vcpu)
@@ -594,6 +591,11 @@ void kvm_hv_process_stimers(struct kvm_vcpu *vcpu)
                                time_now = get_time_ref_counter(vcpu->kvm);
                                if (time_now >= stimer->exp_time)
                                        stimer_expiration(stimer);
+
+                               if (stimer->config & HV_STIMER_ENABLE)
+                                       stimer_start(stimer);
+                               else
+                                       stimer_cleanup(stimer);
                        }
                }
 }
_______________________________________________
Devel mailing list
[email protected]
https://lists.openvz.org/mailman/listinfo/devel

Reply via email to