[Mplayer-cvslog] CVS: main/libvo mga_common.c,1.25,1.26

Arpi of Ize arpi at mplayer.dev.hu
Sat Mar 30 18:40:38 CET 2002


Update of /cvsroot/mplayer/main/libvo
In directory mplayer:/var/tmp.root/cvs-serv28545

Modified Files:
	mga_common.c 
Log Message:
using interleaveBytes() for G200 draw_slice

Index: mga_common.c
===================================================================
RCS file: /cvsroot/mplayer/main/libvo/mga_common.c,v
retrieving revision 1.25
retrieving revision 1.26
diff -u -r1.25 -r1.26
--- mga_common.c	29 Mar 2002 05:03:25 -0000	1.25
+++ mga_common.c	30 Mar 2002 17:40:22 -0000	1.26
@@ -2,6 +2,7 @@
 #include "fastmemcpy.h"
 #include "../mmx_defs.h"
 #include "../mp_image.h"
+#include "../postproc/rgb2rgb.h"
 
 // mga_vid drawing functions
 
@@ -85,60 +86,10 @@
         width/=2;height/=2;x/=2;y/=2;
 
 	dest = vid_data + bespitch*mga_vid_config.src_height + bespitch*y + 2*x;
-	src = image[1];
-	src2 = image[2];
-	
-	for(h=0; h < height; h++)
-	{
-#ifdef HAVE_MMX
-		asm(
-			"xorl %%eax, %%eax		\n\t"
-			"1:				\n\t"
-			PREFETCH" 64(%1, %%eax)		\n\t"
-			PREFETCH" 64(%2, %%eax)		\n\t"
-			"movq (%1, %%eax), %%mm0	\n\t"
-			"movq 8(%1, %%eax), %%mm2	\n\t"
-			"movq %%mm0, %%mm1		\n\t"
-			"movq %%mm2, %%mm3		\n\t"
-			"movq (%2, %%eax), %%mm4	\n\t"
-			"movq 8(%2, %%eax), %%mm5	\n\t"
-			"punpcklbw %%mm4, %%mm0		\n\t"
-			"punpckhbw %%mm4, %%mm1		\n\t"
-			"punpcklbw %%mm5, %%mm2		\n\t"
-			"punpckhbw %%mm5, %%mm3		\n\t"
-			MOVNTQ" %%mm0, (%0, %%eax, 2)	\n\t"
-			MOVNTQ" %%mm1, 8(%0, %%eax, 2)	\n\t"
-			MOVNTQ" %%mm2, 16(%0, %%eax, 2)	\n\t"
-			MOVNTQ" %%mm3, 24(%0, %%eax, 2)	\n\t"
-			"addl $16, %%eax			\n\t"
-			"cmpl %3, %%eax			\n\t"
-			" jb 1b				\n\t"
-			::"r"(dest), "r"(src), "r"(src2), "r" (width-15)
-			: "memory", "%eax"
-		);
-		for(w= (width&(~15)); w < width; w++)
-		{
-			dest[2*w+0] = src[w];
-			dest[2*w+1] = src2[w];
-		}
-#else
-		for(w=0; w < width; w++)
-		{
-			dest[2*w+0] = src[w];
-			dest[2*w+1] = src2[w];
-		}
-#endif
-		dest += bespitch;
-                src += stride[1];
-                src2+= stride[2];
-	}
-#ifdef HAVE_MMX
-	asm(
-		EMMS" \n\t"
-		SFENCE" \n\t"
-		::: "memory"
-		);
-#endif
+
+	interleaveBytes(image[1],image[2],dest,
+		mga_vid_config.src_width, height,
+		stride[1], stride[2], bespitch);
 }
 
 static void




More information about the MPlayer-cvslog mailing list