From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([208.118.235.92]:58628) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1TUxRY-00078j-MO for qemu-devel@nongnu.org; Sun, 04 Nov 2012 05:28:41 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1TUxRX-0001XC-LD for qemu-devel@nongnu.org; Sun, 04 Nov 2012 05:28:40 -0500 Received: from chello084112167138.7.11.vie.surfer.at ([84.112.167.138]:35771 helo=wiesinger.com) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1TUxRX-0001X8-AR for qemu-devel@nongnu.org; Sun, 04 Nov 2012 05:28:39 -0500 Received: from [192.168.32.238] (bgld-ip-238.intern [192.168.32.238]) by wiesinger.com (8.14.4/8.14.4) with ESMTP id qA4ASX70019346 for ; Sun, 4 Nov 2012 11:28:33 +0100 Message-ID: <50964350.5070701@wiesinger.com> Date: Sun, 04 Nov 2012 11:28:32 +0100 From: Gerhard Wiesinger MIME-Version: 1.0 References: In-Reply-To: Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Subject: Re: [Qemu-devel] [PATCH] ui/vnc.c: Fix crash with VNC List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Ping? On 01.11.2012 21:06, Gerhard Wiesinger wrote: > Fix crash with VNC under NT 4.0 and VMWare VGA and window which is > outside of the visible area. > > Backtrace: > #0 set_bit (addr=, nr=-3) at ./bitops.h:122 > #1 vnc_dpy_update (ds=, x=-48, y=145, w=57, h=161) at > ui/vnc.c:452 > #2 0x00007f1ce057e2ec in dpy_update (s=0x7f1ce1c8c880, h=16, w=66, > y=145, x=-57) at ./console.h:242 > #3 vmsvga_update_rect (h=16, w=66, y=145, x=-57, s=0x7f1ce1cb3dd0) at > hw/vmware_vga.c:324 > #4 vmsvga_update_rect_flush (s=0x7f1ce1cb3dd0) at hw/vmware_vga.c:357 > #5 vmsvga_update_display (opaque=0x7f1ce1cb3dd0) at hw/vmware_vga.c:960 > #6 0x00007f1ce05f0b37 in vnc_refresh (opaque=0x7f1cd8526010) at > ui/vnc.c:2590 > #7 0x00007f1ce05c002b in qemu_run_timers (clock=0x7f1ce1c4f910) at > qemu-timer.c:392 > #8 qemu_run_timers (clock=0x7f1ce1c4f910) at qemu-timer.c:373 > #9 0x00007f1ce05c028d in qemu_run_all_timers () at qemu-timer.c:449 > #10 0x00007f1ce058f2ee in main_loop_wait (nonblocking=) > at main-loop.c:502 > #11 0x00007f1ce047acb3 in main_loop () at vl.c:1655 > #12 main (argc=, argv=, envp= out>) at vl.c:3826 > > Signed-off-by: Gerhard Wiesinger > --- > ui/vnc.c | 5 +++++ > 1 file changed, 5 insertions(+) > > diff --git a/ui/vnc.c b/ui/vnc.c > index 7c120e6..ae6d819 100644 > --- a/ui/vnc.c > +++ b/ui/vnc.c > @@ -453,6 +453,11 @@ static void vnc_dpy_update(DisplayState *ds, int > x, int y, int w, int h) > w = MIN(x + w, width) - x; > h = MIN(h, height); > > + x = MAX(x, 0); > + y = MAX(y, 0); > + w = MAX(w, 0); > + h = MAX(h, 0); > + > for (; y < h; y++) > for (i = 0; i < w; i += 16) > set_bit((x + i) / 16, s->dirty[y]);