aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNicholas Piggin <npiggin@gmail.com>2023-06-27 16:14:06 +1000
committerPaolo Bonzini <pbonzini@redhat.com>2023-06-27 09:00:13 +0200
commit67f85346ca9305d9fb3254ceff735ceaadeb0911 (patch)
tree463b967b5cce984a1ff6097e37f91628736c35d2
parent4329d049d5b8d4af71c6b399d64a6d1b98856318 (diff)
downloadqemu-67f85346ca9305d9fb3254ceff735ceaadeb0911.zip
qemu-67f85346ca9305d9fb3254ceff735ceaadeb0911.tar.gz
qemu-67f85346ca9305d9fb3254ceff735ceaadeb0911.tar.bz2
icount: don't adjust virtual time backwards after warp
The icount-based QEMU_CLOCK_VIRTUAL runs ahead of the RT clock at times. When warping, it is possible it is still ahead at the end of the warp, which causes icount adaptive mode to adjust it backward. This can result in the machine observing time going backwards. Prevent this by clamping adaptive adjustment to 0 at minimum. Signed-off-by: Nicholas Piggin <npiggin@gmail.com> Message-ID: <20230627061406.241847-1-npiggin@gmail.com> Cc: qemu-stable@nongnu.org Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
-rw-r--r--softmmu/icount.c9
1 files changed, 7 insertions, 2 deletions
diff --git a/softmmu/icount.c b/softmmu/icount.c
index 4504433..a5cef9c 100644
--- a/softmmu/icount.c
+++ b/softmmu/icount.c
@@ -259,11 +259,16 @@ static void icount_warp_rt(void)
warp_delta = clock - timers_state.vm_clock_warp_start;
if (icount_enabled() == 2) {
/*
- * In adaptive mode, do not let QEMU_CLOCK_VIRTUAL run too
- * far ahead of real time.
+ * In adaptive mode, do not let QEMU_CLOCK_VIRTUAL run too far
+ * ahead of real time (it might already be ahead so careful not
+ * to go backwards).
*/
int64_t cur_icount = icount_get_locked();
int64_t delta = clock - cur_icount;
+
+ if (delta < 0) {
+ delta = 0;
+ }
warp_delta = MIN(warp_delta, delta);
}
qatomic_set_i64(&timers_state.qemu_icount_bias,