aboutsummaryrefslogtreecommitdiffhomepage
path: root/liba52
diff options
context:
space:
mode:
authorGravatar nickols_k <nickols_k@b3059339-0415-0410-9bf9-f77b7e298cf2>2001-06-01 15:56:04 +0000
committerGravatar nickols_k <nickols_k@b3059339-0415-0410-9bf9-f77b7e298cf2>2001-06-01 15:56:04 +0000
commit46779652a515b92fa8bcfcf99a678f6941922312 (patch)
treeaeb75fc437a6570d15ddbe6f413fe1e0c740c9b2 /liba52
parent8af9ccfa313b44f0f0cba6b11e789d8da2726ef4 (diff)
Better insns scheduling and moving out local variables
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@927 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'liba52')
-rw-r--r--liba52/srfftp_3dnow.h28
1 files changed, 14 insertions, 14 deletions
diff --git a/liba52/srfftp_3dnow.h b/liba52/srfftp_3dnow.h
index a89f13ae76..14e74b4e11 100644
--- a/liba52/srfftp_3dnow.h
+++ b/liba52/srfftp_3dnow.h
@@ -129,19 +129,19 @@ static complex_t HSQRT2_3DNOW __attribute__ ((aligned (8))) = { 0.707106781188,
"pfmul %%mm2, %%mm3\n\t" /* v *= HSQRT2_3DNOW; */\
"pfmul %%mm2, %%mm0\n\t" /* u *= HSQRT2_3DNOW; */\
"movq %6, %%mm1\n\t" /* a1 = A2;*/\
+ "movq %7, %%mm5\n\t" /* a1 = A6;*/\
"movq %%mm1, %%mm2\n\t"\
+ "movq %%mm3, %%mm4\n\t"\
"pfadd %%mm0, %%mm1\n\t" /*A2 = a1 + u;*/\
+ "pfmul %%mm6, %%mm4\n\t"/*A6.re = a1.re + v.re;*/\
"pfsub %%mm0, %%mm2\n\t" /*A2 = a1 - u;*/\
+ "pfmul %%mm7, %%mm3\n\t"/*A14.re = a1.re - v.re;*/\
"movq %%mm1, %0\n\t"\
"movq %%mm2, %1\n\t"\
- "movq %7, %%mm1\n\t" /* a1 = A6;*/\
- "movq %%mm1, %%mm2\n\t"\
- "movq %%mm3, %%mm4\n\t"\
- "pfmul %%mm6, %%mm4\n\t"/*A6.re = a1.re + v.re;*/\
- "pfadd %%mm4, %%mm1\n\t"/*A6.im = a1.im - v.im;*/\
- "pfmul %%mm7, %%mm3\n\t"/*A14.re = a1.re - v.re;*/\
+ "movq %%mm5, %%mm2\n\t"\
+ "pfadd %%mm4, %%mm5\n\t"/*A6.im = a1.im - v.im;*/\
"pfadd %%mm3, %%mm2\n\t"/*A14.im = a1.im + v.im;*/\
- "movq %%mm1, %2\n\t"\
+ "movq %%mm5, %2\n\t"\
"movq %%mm2, %3"\
:"=m"(A2), "=m"(A10), "=m"(A6), "=m"(A14)\
:"m"(wTB[2]), "m"(wTB[6]), "0"(A2), "2"(A6), "m"(HSQRT2_3DNOW)\
@@ -169,11 +169,11 @@ static complex_t HSQRT2_3DNOW __attribute__ ((aligned (8))) = { 0.707106781188,
"pfmul %3, %%mm2\n\t"/* mm2 = v*/\
PFNACC_MM("%%mm2","%%mm3")\
"pfacc %%mm0, %%mm0\n\t"\
+ "movq %%mm4, %%mm5\n\t"\
"punpckldq %%mm0,%%mm2\n\t"/*mm2 = v.re | a.re*/\
+ "pfmul %%mm6, %%mm5\n\t"\
"movq %%mm2, %%mm3\n\t"\
"pfmul %%mm7, %%mm3\n\t"\
- "movq %%mm4, %%mm5\n\t"\
- "pfmul %%mm6, %%mm5\n\t"\
"pfadd %%mm3, %%mm5\n\t"\
PSWAP_MM("%%mm5","%%mm3")/* mm5 = v*/\
"pfadd %%mm2, %%mm4\n\t"\
@@ -182,19 +182,19 @@ static complex_t HSQRT2_3DNOW __attribute__ ((aligned (8))) = { 0.707106781188,
:"memory");\
__asm__ __volatile__(\
"movq %4, %%mm0\n\t"/* a1 = A1*/\
+ "movq %5, %%mm2\n\t"/* a1 = A5*/\
"movq %%mm0, %%mm1\n\t"\
+ "movq %%mm2, %%mm3\n\t"\
"pfadd %%mm4, %%mm0\n\t"/*A1 = a1 + u*/\
+ "pfsub %%mm5, %%mm2\n\t"/*A5 = a1 - v*/\
"pfsub %%mm4, %%mm1\n\t"/*A9 = a1 - u*/\
+ "pfadd %%mm5, %%mm3\n\t"/*A9 = a1 + v*/\
"movq %%mm0, %0\n\t"\
"movq %%mm1, %1\n\t"\
- "movq %5, %%mm2\n\t"/* a1 = A5*/\
- "movq %%mm2, %%mm3\n\t"\
- "pfsub %%mm5, %%mm2\n\t"/*A5 = a1 - v*/\
- "pfadd %%mm5, %%mm3\n\t"/*A9 = a1 + v*/\
"movq %%mm2, %2\n\t"\
"movq %%mm3, %3"\
:"=m"(A1), "=m"(A9), "=m"(A5), "=m"(A13)\
- :"0"(A1), "2"(A5), "m"(u), "m"(v)\
+ :"0"(A1), "2"(A5)\
:"memory");\
}