Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 091c82c0 authored by Roel Kluin's avatar Roel Kluin Committed by Linus Torvalds
Browse files

amifb: test virtual screen range before subtraction on unsigned



dx and dy are u32's, so the test should occur before the subtraction

Signed-off-by: default avatarRoel Kluin <12o3l@tiscali.nl>
Cc: Antonino Daplas <adaplas@pol.net>
Cc: Krzysztof Helt <krzysztof.h1@wp.pl>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 816664f8
Loading
Loading
Loading
Loading
+5 −2
Original line number Diff line number Diff line
@@ -2048,13 +2048,16 @@ static void amifb_copyarea(struct fb_info *info,
	width = x2 - dx;
	height = y2 - dy;

	if (area->sx + dx < area->dx || area->sy + dy < area->dy)
		return;

	/* update sx,sy */
	sx = area->sx + (dx - area->dx);
	sy = area->sy + (dy - area->dy);

	/* the source must be completely inside the virtual screen */
	if (sx < 0 || sy < 0 || (sx + width) > info->var.xres_virtual ||
	    (sy + height) > info->var.yres_virtual)
	if (sx + width > info->var.xres_virtual ||
			sy + height > info->var.yres_virtual)
		return;

	if (dy > sy || (dy == sy && dx > sx)) {