1
0
mirror of https://github.com/FFmpeg/FFmpeg.git synced 2025-01-13 21:28:01 +02:00

Fix asm constraints in apply_window()

Originally committed as revision 23752 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
Vitor Sessak 2010-06-24 08:46:47 +00:00
parent 986f143a38
commit 57dbd12b6d

View File

@ -51,11 +51,11 @@ static void apply_window(const float *buf, const float *win1,
#define MULT(a, b) \
"movaps " #a "(%0,%5), %%xmm1 \n\t" \
"movaps " #a "(%2,%5), %%xmm2 \n\t" \
"movaps " #a "(%1,%0), %%xmm1 \n\t" \
"movaps " #a "(%3,%0), %%xmm2 \n\t" \
"mulps %%xmm2, %%xmm1 \n\t" \
"subps %%xmm1, %%xmm0 \n\t" \
"mulps " #b "(%1,%5), %%xmm2 \n\t" \
"mulps " #b "(%2,%0), %%xmm2 \n\t" \
"subps %%xmm2, %%xmm4 \n\t" \
__asm__ volatile(
@ -72,11 +72,12 @@ static void apply_window(const float *buf, const float *win1,
MULT(1536, 384)
MULT(1792, 448)
"movaps %%xmm0, (%3,%5) \n\t"
"movaps %%xmm4, (%4,%5) \n\t"
"addl $16, %5 \n\t"
"movaps %%xmm0, (%4,%0) \n\t"
"movaps %%xmm4, (%5,%0) \n\t"
"addl $16, %0 \n\t"
"jl 1b \n\t"
:"+&r"(win1a), "+&r"(win2a), "+&r"(bufa), "+&r"(sum1a), "+&r"(sum2a), "+&r"(count)
:"+&r"(count)
:"r"(win1a), "r"(win2a), "r"(bufa), "r"(sum1a), "r"(sum2a)
);
#undef MULT