[Mplayer-cvslog] CVS: main/libvo osd.c,1.9,1.10
Nick Kurshev
nick at mplayer.dev.hu
Sun Nov 11 16:35:14 CET 2001
Update of /cvsroot/mplayer/main/libvo
In directory mplayer:/var/tmp.root/cvs-serv17930/main/libvo
Modified Files:
osd.c
Log Message:
Minor speedup for K6-2, K7, P3
Index: osd.c
===================================================================
RCS file: /cvsroot/mplayer/main/libvo/osd.c,v
retrieving revision 1.9
retrieving revision 1.10
diff -u -r1.9 -r1.10
--- osd.c 11 Nov 2001 14:42:10 -0000 1.9
+++ osd.c 11 Nov 2001 15:35:11 -0000 1.10
@@ -85,40 +85,41 @@
register int x;
#ifdef ARCH_X86
#ifdef HAVE_MMX
+ asm volatile(
+ PREFETCHW" %0\n\t"
+ PREFETCH" %1\n\t"
+ PREFETCH" %2\n\t"
+ "pxor %%mm7, %%mm7\n\t"
+ "pcmpeqb %%mm6, %%mm6\n\t" // F..F
+ ::"m"(dstbase),"m"(srca),"m"(src):"memory");
+ for(x=0;x<w;x+=2){
asm volatile(
- "pxor %%mm7, %%mm7 \n\t"
- "xorl %%eax, %%eax \n\t"
- "pcmpeqb %%mm6, %%mm6 \n\t" // F..F
- ".balign 16\n\t"
- "1: \n\t"
- "movq (%0, %%eax, 4), %%mm0 \n\t" // dstbase
- "movq %%mm0, %%mm1 \n\t"
- "punpcklbw %%mm7, %%mm0 \n\t"
- "punpckhbw %%mm7, %%mm1 \n\t"
- "movd (%1, %%eax), %%mm2 \n\t" // srca ABCD0000
- "paddb %%mm6, %%mm2 \n\t"
- "punpcklbw %%mm2, %%mm2 \n\t" // srca AABBCCDD
- "punpcklbw %%mm2, %%mm2 \n\t" // srca AAAABBBB
- "movq %%mm2, %%mm3 \n\t"
- "punpcklbw %%mm7, %%mm2 \n\t" // srca 0A0A0A0A
- "punpckhbw %%mm7, %%mm3 \n\t" // srca 0B0B0B0B
- "pmullw %%mm2, %%mm0 \n\t"
- "pmullw %%mm3, %%mm1 \n\t"
- "psrlw $8, %%mm0 \n\t"
- "psrlw $8, %%mm1 \n\t"
- "packuswb %%mm1, %%mm0 \n\t"
- "movd (%2, %%eax), %%mm2 \n\t" // src ABCD0000
- "punpcklbw %%mm2, %%mm2 \n\t" // src AABBCCDD
- "punpcklbw %%mm2, %%mm2 \n\t" // src AAAABBBB
- "paddb %%mm2, %%mm0 \n\t"
- "movq %%mm0, (%0, %%eax, 4) \n\t"
- "addl $2, %%eax \n\t"
- "cmpl %3, %%eax \n\t"
- " jb 1b \n\t"
-
- :: "r" (dstbase), "r" (srca), "r" (src), "r" (w)
- : "%eax"
- );
+ PREFETCHW" 32%0\n\t"
+ PREFETCH" 32%1\n\t"
+ PREFETCH" 32%2\n\t"
+ "movq %0, %%mm0\n\t" // dstbase
+ "movq %%mm0, %%mm1\n\t"
+ "punpcklbw %%mm7, %%mm0\n\t"
+ "punpckhbw %%mm7, %%mm1\n\t"
+ "movd %1, %%mm2\n\t" // srca ABCD0000
+ "paddb %%mm6, %%mm2\n\t"
+ "punpcklbw %%mm2, %%mm2\n\t" // srca AABBCCDD
+ "punpcklbw %%mm2, %%mm2\n\t" // srca AAAABBBB
+ "movq %%mm2, %%mm3\n\t"
+ "punpcklbw %%mm7, %%mm2\n\t" // srca 0A0A0A0A
+ "punpckhbw %%mm7, %%mm3\n\t" // srca 0B0B0B0B
+ "pmullw %%mm2, %%mm0\n\t"
+ "pmullw %%mm3, %%mm1\n\t"
+ "psrlw $8, %%mm0\n\t"
+ "psrlw $8, %%mm1\n\t"
+ "packuswb %%mm1, %%mm0\n\t"
+ "movd %2, %%mm2 \n\t" // src ABCD0000
+ "punpcklbw %%mm2, %%mm2\n\t" // src AABBCCDD
+ "punpcklbw %%mm2, %%mm2\n\t" // src AAAABBBB
+ "paddb %%mm2, %%mm0\n\t"
+ "movq %%mm0, %0\n\t"
+ :: "m" (dstbase[4*x]), "m" (srca[x]), "m" (src[x]));
+ }
#else /* 0 HAVE_MMX2*/
for(x=0;x<w;x++){
if(srca[x]){
More information about the MPlayer-cvslog
mailing list