From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from [140.186.70.92] (port=49133 helo=eggs.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1PrRN5-0004f9-I8 for qemu-devel@nongnu.org; Mon, 21 Feb 2011 03:43:56 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1PrRN2-0000Iw-OO for qemu-devel@nongnu.org; Mon, 21 Feb 2011 03:43:55 -0500 Received: from mail-ww0-f53.google.com ([74.125.82.53]:49307) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1PrRN2-0000IY-Jl for qemu-devel@nongnu.org; Mon, 21 Feb 2011 03:43:52 -0500 Received: by wwi18 with SMTP id 18so5370402wwi.10 for ; Mon, 21 Feb 2011 00:43:51 -0800 (PST) Sender: Paolo Bonzini From: Paolo Bonzini Date: Mon, 21 Feb 2011 09:43:21 +0100 Message-Id: <1298277820-8817-3-git-send-email-pbonzini@redhat.com> In-Reply-To: <1298277820-8817-1-git-send-email-pbonzini@redhat.com> References: <1298277820-8817-1-git-send-email-pbonzini@redhat.com> Subject: [Qemu-devel] [PATCH 02/21] implement win32 dynticks timer List-Id: qemu-devel.nongnu.org List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Signed-off-by: Paolo Bonzini --- qemu-timer.c | 7 ++++++- 1 files changed, 6 insertions(+), 1 deletions(-) diff --git a/qemu-timer.c b/qemu-timer.c index b0db780..e6b926b 100644 --- a/qemu-timer.c +++ b/qemu-timer.c @@ -1006,6 +1006,7 @@ static void win32_stop_timer(struct qemu_alarm_timer *t) static void win32_rearm_timer(struct qemu_alarm_timer *t) { struct qemu_alarm_win32 *data = t->priv; + int nearest_delta_ms; assert(alarm_has_dynticks(t)); if (!active_timers[QEMU_CLOCK_REALTIME] && @@ -1015,7 +1016,11 @@ static void win32_rearm_timer(struct qemu_alarm_timer *t) timeKillEvent(data->timerId); - data->timerId = timeSetEvent(1, + nearest_delta_ms = (qemu_next_alarm_deadline() + 999999) / 1000000; + if (nearest_delta_ms < 1) { + nearest_delta_ms = 1; + } + data->timerId = timeSetEvent(nearest_delta_ms, data->period, host_alarm_handler, (DWORD)t, -- 1.7.3.5