From: aurel32 Date: Thu, 13 Mar 2008 19:20:33 +0000 (+0000) Subject: Slowdown SDL while minimized X-Git-Tag: xen-3.3.0-rc1~310 X-Git-Url: http://xenbits.xensource.com/gitweb?a=commitdiff_plain;h=f442e08b418785e13b1161edfa9e0c72cc324c41;p=qemu-xen-3.3-testing.git Slowdown SDL while minimized When SDL is invisible/minimized, there is no need to keep calling the VGA refresh 33 times per second. This patch reduces in that case the rate to 2 times per second, which should be responsive enough for the un-minimizing event. (Samuel Thibault) git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@4050 c046a42c-6fe2-441c-8c8c-71466251a162 --- diff --git a/console.h b/console.h index b8a5c6d2..1e69ffd0 100644 --- a/console.h +++ b/console.h @@ -71,6 +71,7 @@ struct DisplayState { int height; void *opaque; struct QEMUTimer *gui_timer; + uint64_t gui_timer_interval; void (*dpy_update)(struct DisplayState *s, int x, int y, int w, int h); void (*dpy_resize)(struct DisplayState *s, int w, int h); diff --git a/sdl.c b/sdl.c index 05a394c7..431e5271 100644 --- a/sdl.c +++ b/sdl.c @@ -510,6 +510,15 @@ static void sdl_refresh(DisplayState *ds) !ev->active.gain && !gui_fullscreen_initial_grab) { sdl_grab_end(); } + if (ev->active.state & SDL_APPACTIVE) { + if (ev->active.gain) { + /* Back to default interval */ + ds->gui_timer_interval = 0; + } else { + /* Sleeping interval */ + ds->gui_timer_interval = 500; + } + } break; default: break; diff --git a/vl.c b/vl.c index 5b9e4ce7..2019f9f0 100644 --- a/vl.c +++ b/vl.c @@ -7208,7 +7208,11 @@ static void gui_update(void *opaque) { DisplayState *ds = opaque; ds->dpy_refresh(ds); - qemu_mod_timer(ds->gui_timer, GUI_REFRESH_INTERVAL + qemu_get_clock(rt_clock)); + qemu_mod_timer(ds->gui_timer, + (ds->gui_timer_interval ? + ds->gui_timer_interval : + GUI_REFRESH_INTERVAL) + + qemu_get_clock(rt_clock)); } struct vm_change_state_entry {