shithub: qk1

Download patch

ref: 60dafa3dfb733d569305e406d10d4b7d43e9cf00
parent: bcd7bbc429073a5683d89abcec6613bc1d6f6f1d
author: Sigrid Solveig Haflínudóttir <[email protected]>
date: Sun Oct 13 23:38:43 EDT 2024

Draw*: stop with the unroll loops

--- a/draw.c
+++ b/draw.c
@@ -213,37 +213,12 @@
 
 	source = pic->pixels;
 	dest = vid.buffer + y * vid.width + x;
-	if(pic->width & 7){	// general
-		for(v=0; v<pic->height; v++){
-			for(u=0; u<pic->width; u++)
-				if(opaque(tpix = source[u]))
-					dest[u] = tpix;
-			dest += vid.width;
-			source += pic->width;
-		}
-	}else{	// unwound
-		for(v=0; v<pic->height; v++){
-			for(u=0; u<pic->width; u+=8){
-				if(opaque(tpix = source[u]))
-					dest[u] = tpix;
-				if(opaque(tpix = source[u+1]))
-					dest[u+1] = tpix;
-				if(opaque(tpix = source[u+2]))
-					dest[u+2] = tpix;
-				if(opaque(tpix = source[u+3]))
-					dest[u+3] = tpix;
-				if(opaque(tpix = source[u+4]))
-					dest[u+4] = tpix;
-				if(opaque(tpix = source[u+5]))
-					dest[u+5] = tpix;
-				if(opaque(tpix = source[u+6]))
-					dest[u+6] = tpix;
-				if(opaque(tpix = source[u+7]))
-					dest[u+7] = tpix;
-			}
-			dest += vid.width;
-			source += pic->width;
-		}
+	for(v=0; v<pic->height; v++){
+		for(u=0; u<pic->width; u++)
+			if(opaque(tpix = source[u]))
+				dest[u] = tpix;
+		dest += vid.width;
+		source += pic->width;
 	}
 }
 
@@ -263,37 +238,12 @@
 
 	source = pic->pixels;
 	dest = vid.buffer + y * vid.width + x;
-	if (pic->width & 7){	// general
-		for(v=0; v<pic->height; v++){
-			for(u=0; u<pic->width; u++)
-				if(opaque(tpix = source[u]))
-					dest[u] = tpix;
-			dest += vid.width;
-			source += pic->width;
-		}
-	}else{	// unwound
-		for(v=0; v<pic->height; v++){
-			for(u=0; u<pic->width; u+=8){
-				if(opaque(tpix = source[u]))
-					dest[u] = tpix;
-				if(opaque(tpix = source[u+1]))
-					dest[u+1] = tpix;
-				if(opaque(tpix = source[u+2]))
-					dest[u+2] = tpix;
-				if(opaque(tpix = source[u+3]))
-					dest[u+3] = tpix;
-				if(opaque(tpix = source[u+4]))
-					dest[u+4] = tpix;
-				if(opaque(tpix = source[u+5]))
-					dest[u+5] = tpix;
-				if(opaque(tpix = source[u+6]))
-					dest[u+6] = tpix;
-				if(opaque(tpix = source[u+7]))
-					dest[u+7] = tpix;
-			}
-			dest += vid.width;
-			source += pic->width;
-		}
+	for(v=0; v<pic->height; v++){
+		for(u=0; u<pic->width; u++)
+			if(opaque(tpix = source[u]))
+				dest[u] = tpix;
+		dest += vid.width;
+		source += pic->width;
 	}
 }