提交 8e388e90 编写于 作者: G Gerd Hoffmann

spice/gl: add unblock timer

Pure debug aid, print a warning in case unblocking
doesn't happen within one second.
Signed-off-by: NGerd Hoffmann <kraxel@redhat.com>
Reviewed-by: NMarc-André Lureau <marcandre.lureau@redhat.com>
上级 474114b7
...@@ -117,6 +117,7 @@ struct SimpleSpiceDisplay { ...@@ -117,6 +117,7 @@ struct SimpleSpiceDisplay {
#ifdef HAVE_SPICE_GL #ifdef HAVE_SPICE_GL
/* opengl rendering */ /* opengl rendering */
QEMUBH *gl_unblock_bh; QEMUBH *gl_unblock_bh;
QEMUTimer *gl_unblock_timer;
int dmabuf_fd; int dmabuf_fd;
#endif #endif
}; };
......
...@@ -797,6 +797,15 @@ static const DisplayChangeListenerOps display_listener_ops = { ...@@ -797,6 +797,15 @@ static const DisplayChangeListenerOps display_listener_ops = {
static void qemu_spice_gl_block(SimpleSpiceDisplay *ssd, bool block) static void qemu_spice_gl_block(SimpleSpiceDisplay *ssd, bool block)
{ {
uint64_t timeout;
if (block) {
timeout = qemu_clock_get_ms(QEMU_CLOCK_REALTIME);
timeout += 1000; /* one sec */
timer_mod(ssd->gl_unblock_timer, timeout);
} else {
timer_del(ssd->gl_unblock_timer);
}
graphic_hw_gl_block(ssd->dcl.con, block); graphic_hw_gl_block(ssd->dcl.con, block);
} }
...@@ -807,6 +816,11 @@ static void qemu_spice_gl_unblock_bh(void *opaque) ...@@ -807,6 +816,11 @@ static void qemu_spice_gl_unblock_bh(void *opaque)
qemu_spice_gl_block(ssd, false); qemu_spice_gl_block(ssd, false);
} }
static void qemu_spice_gl_block_timer(void *opaque)
{
fprintf(stderr, "WARNING: spice: no gl-draw-done within one second\n");
}
static QEMUGLContext qemu_spice_gl_create_context(DisplayChangeListener *dcl, static QEMUGLContext qemu_spice_gl_create_context(DisplayChangeListener *dcl,
QEMUGLParams *params) QEMUGLParams *params)
{ {
...@@ -888,6 +902,8 @@ static void qemu_spice_display_init_one(QemuConsole *con) ...@@ -888,6 +902,8 @@ static void qemu_spice_display_init_one(QemuConsole *con)
ssd->dcl.ops = &display_listener_gl_ops; ssd->dcl.ops = &display_listener_gl_ops;
ssd->dmabuf_fd = -1; ssd->dmabuf_fd = -1;
ssd->gl_unblock_bh = qemu_bh_new(qemu_spice_gl_unblock_bh, ssd); ssd->gl_unblock_bh = qemu_bh_new(qemu_spice_gl_unblock_bh, ssd);
ssd->gl_unblock_timer = timer_new_ms(QEMU_CLOCK_REALTIME,
qemu_spice_gl_block_timer, ssd);
} }
#endif #endif
ssd->dcl.con = con; ssd->dcl.con = con;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册