qxl-render: add sanity check
Verify dirty rectangle is completely within the primary surface, just ignore it in case it isn't. Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
This commit is contained in:
parent
5643fc012c
commit
788fbf042f
@ -138,6 +138,12 @@ static void qxl_render_update_area_unlocked(PCIQXLDevice *qxl)
|
|||||||
if (qemu_spice_rect_is_empty(qxl->dirty+i)) {
|
if (qemu_spice_rect_is_empty(qxl->dirty+i)) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
if (qxl->dirty[i].left > qxl->dirty[i].right ||
|
||||||
|
qxl->dirty[i].top > qxl->dirty[i].bottom ||
|
||||||
|
qxl->dirty[i].right > qxl->guest_primary.surface.width ||
|
||||||
|
qxl->dirty[i].bottom > qxl->guest_primary.surface.height) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
qxl_blit(qxl, qxl->dirty+i);
|
qxl_blit(qxl, qxl->dirty+i);
|
||||||
dpy_gfx_update(vga->con,
|
dpy_gfx_update(vga->con,
|
||||||
qxl->dirty[i].left, qxl->dirty[i].top,
|
qxl->dirty[i].left, qxl->dirty[i].top,
|
||||||
|
Loading…
Reference in New Issue
Block a user