hvm vlapic: Fix tmcct read logic when in periodic mode.
authorKeir Fraser <keir@xen.org>
Fri, 10 Dec 2010 16:49:05 +0000 (16:49 +0000)
committerKeir Fraser <keir@xen.org>
Fri, 10 Dec 2010 16:49:05 +0000 (16:49 +0000)
Signed-off-by: Keir Fraser <keir@xen.org>
xen/arch/x86/hvm/vlapic.c

index cf0ee2108148296c4d0ecc38caba5c45aa8c8bc0..84dd4d24a5d53a51dedb238cad62c281d54e07b3 100644 (file)
@@ -435,12 +435,19 @@ int vlapic_ipi(
 static uint32_t vlapic_get_tmcct(struct vlapic *vlapic)
 {
     struct vcpu *v = current;
-    uint32_t tmcct, tmict = vlapic_get_reg(vlapic, APIC_TMICT);
+    uint32_t tmcct = 0, tmict = vlapic_get_reg(vlapic, APIC_TMICT);
     uint64_t counter_passed;
 
     counter_passed = ((hvm_get_guest_time(v) - vlapic->timer_last_update)
-                      / APIC_BUS_CYCLE_NS / vlapic->hw.timer_divisor);
-    tmcct = (counter_passed < tmict) ? tmict - counter_passed : 0;
+                      / (APIC_BUS_CYCLE_NS * vlapic->hw.timer_divisor));
+
+    if ( tmict != 0 )
+    {
+        if ( vlapic_lvtt_period(vlapic) )
+            counter_passed %= tmict;
+        if ( counter_passed < tmict )
+            tmcct = tmict - counter_passed;
+    }
 
     HVM_DBG_LOG(DBG_LEVEL_VLAPIC_TIMER,
                 "timer initial count %d, timer current count %d, "