Module Name:    src
Committed By:   rin
Date:           Wed Aug  7 11:03:14 UTC 2019

Modified Files:
        src/sys/dev/rasops: rasops.c

Log Message:
Fix a critical bug for rasops_copyrows() introduced in rev. 1.90:
http://cvsweb.netbsd.org/bsdweb.cgi/src/sys/dev/rasops/rasops.c#rev1.90

When src < dst, we have to copy backward.


To generate a diff of this commit:
cvs rdiff -u -r1.112 -r1.113 src/sys/dev/rasops/rasops.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/dev/rasops/rasops.c
diff -u src/sys/dev/rasops/rasops.c:1.112 src/sys/dev/rasops/rasops.c:1.113
--- src/sys/dev/rasops/rasops.c:1.112	Wed Aug  7 10:59:51 2019
+++ src/sys/dev/rasops/rasops.c	Wed Aug  7 11:03:14 2019
@@ -1,4 +1,4 @@
-/*	 $NetBSD: rasops.c,v 1.112 2019/08/07 10:59:51 rin Exp $	*/
+/*	 $NetBSD: rasops.c,v 1.113 2019/08/07 11:03:14 rin Exp $	*/
 
 /*-
  * Copyright (c) 1999 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: rasops.c,v 1.112 2019/08/07 10:59:51 rin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rasops.c,v 1.113 2019/08/07 11:03:14 rin Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_rasops.h"
@@ -726,19 +726,29 @@ rasops_copyrows(void *cookie, int src, i
 	n = ri->ri_emustride;
 	stride = ri->ri_stride;
 
-	sp = ri->ri_bits + src * ri->ri_yscale;
-	dp = ri->ri_bits + dst * ri->ri_yscale;
+	src *= ri->ri_yscale;
+	dst *= ri->ri_yscale;
+
+	if (src < dst) {
+		/* backward copy */
+		src += (num - 1) * stride;
+		dst += (num - 1) * stride;
+		stride *= -1;
+	}
+
+	sp = ri->ri_bits + src;
+	dp = ri->ri_bits + dst;
 	if (ri->ri_hwbits)
-		hp = ri->ri_hwbits + dst * ri->ri_yscale;
+		hp = ri->ri_hwbits + dst;
 
 	while (num--) {
 		memcpy(dp, sp, n);
-		dp += stride;
+		sp += stride;
 		if (ri->ri_hwbits) {
-			memcpy(hp, sp, n);
+			memcpy(hp, dp, n);
 			hp += stride;
 		}
-		sp += stride;
+		dp += stride;
 	}
 }
 

Reply via email to