qemu-xen: use dynticks instead of a static 10ms timeout
Use dynticks instead of polling the timers every 10ms.
This allows a qemu running in dom0 to wake up only when the next timer
goes off (that is every 100ms, because of the buffer_io_timer) instead
of every 10ms.
For the moment stubdoms still run with the old 10ms timeout because
minios doesn't support the posix timer_create interface yet.
Also disable the nographic_timer when CONFIG_DM because it is only
useful with tcg.
Signed-off-by: Stefano Stabellini <stefano.stabellini@xxxxxxxxxxxxx>
---
diff --git a/i386-dm/helper2.c b/i386-dm/helper2.c
index ce73421..94237b6 100644
--- a/i386-dm/helper2.c
+++ b/i386-dm/helper2.c
@@ -572,8 +572,13 @@ int main_loop(void)
while (1) {
while (!(vm_running && xen_pause_requested))
+#ifdef CONFIG_STUBDOM
/* Wait up to 10 msec. */
main_loop_wait(10);
+#else
+ /* Wait up to 10s. */
+ main_loop_wait(10000);
+#endif
fprintf(logfile, "device model saving state\n");
diff --git a/vl.c b/vl.c
index d465a09..9c08fcb 100644
--- a/vl.c
+++ b/vl.c
@@ -942,7 +942,7 @@ static void win32_rearm_timer(struct qemu_alarm_timer *t);
static int unix_start_timer(struct qemu_alarm_timer *t);
static void unix_stop_timer(struct qemu_alarm_timer *t);
-#if defined(__linux__) && !defined(CONFIG_DM)
+#if defined(__linux__)
static int dynticks_start_timer(struct qemu_alarm_timer *t);
static void dynticks_stop_timer(struct qemu_alarm_timer *t);
@@ -1025,7 +1025,7 @@ static void init_icount_adjust(void)
static struct qemu_alarm_timer alarm_timers[] = {
#ifndef _WIN32
-#if defined(__linux__) && !defined(CONFIG_DM)
+#if defined(__linux__)
{"dynticks", ALARM_FLAG_DYNTICKS, dynticks_start_timer,
dynticks_stop_timer, dynticks_rearm_timer, NULL},
/* HPET - if available - is preferred */
@@ -1327,7 +1327,6 @@ static int timer_load(QEMUFile *f, void *opaque, int
version_id)
return 0;
}
-#ifndef CONFIG_DM /* ends just before fcntl_setfl */
#ifdef _WIN32
void CALLBACK host_alarm_handler(UINT uTimerID, UINT uMsg,
DWORD_PTR dwUser, DWORD_PTR dw1, DWORD_PTR
dw2)
@@ -1436,7 +1435,6 @@ static uint64_t qemu_next_deadline_dyntick(void)
return delta;
}
#endif
-#endif
#ifndef _WIN32
@@ -1455,7 +1453,6 @@ static int fcntl_setfl(int fd, int flag)
return 0;
}
-#ifndef CONFIG_DM /* ends after end of win32_rearm_timer */
#if defined(__linux__)
#define RTC_FREQ 1024
@@ -1632,6 +1629,7 @@ static void dynticks_rearm_timer(struct qemu_alarm_timer
*t)
#endif /* defined(__linux__) */
+#ifndef CONFIG_STUBDOM
static int unix_start_timer(struct qemu_alarm_timer *t)
{
struct sigaction act;
@@ -1665,8 +1663,11 @@ static void unix_stop_timer(struct qemu_alarm_timer *t)
memset(&itv, 0, sizeof(itv));
setitimer(ITIMER_REAL, &itv, NULL);
}
+#else
+static int unix_start_timer(struct qemu_alarm_timer *t) { return 0; }
+static void unix_stop_timer(struct qemu_alarm_timer *t) { }
+#endif
-#endif /* !defined(_WIN32) */
static void try_to_rearm_timer(void *opaque)
{
@@ -6017,10 +6018,12 @@ int main(int argc, char **argv, char **envp)
dcl = dcl->next;
}
+#ifndef CONFIG_DM
if (nographic || (vnc_display && !sdl)) {
nographic_timer = qemu_new_timer(rt_clock, nographic_update, NULL);
qemu_mod_timer(nographic_timer, qemu_get_clock(rt_clock));
}
+#endif
text_consoles_set_display(display_state);
qemu_chr_initial_reset();
@@ -6155,6 +6158,3 @@ int main(int argc, char **argv, char **envp)
return 0;
}
-
-static int unix_start_timer(struct qemu_alarm_timer *t) { return 0; }
-static void unix_stop_timer(struct qemu_alarm_timer *t) { }
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-devel
|