[FFmpeg-cvslog] swscale: make yuv2yuv1 use named registers.
Ronald S. Bultje
git at videolan.org
Wed Feb 8 06:04:56 CET 2012
ffmpeg | branch: master | Ronald S. Bultje <rsbultje at gmail.com> | Sat Feb 4 10:00:27 2012 +0100| [ef1c785f11c168384e42d147648c8fdf5317739b] | committer: Ronald S. Bultje
swscale: make yuv2yuv1 use named registers.
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=ef1c785f11c168384e42d147648c8fdf5317739b
---
libswscale/x86/output.asm | 50 ++++++++++++++++++++++----------------------
1 files changed, 25 insertions(+), 25 deletions(-)
diff --git a/libswscale/x86/output.asm b/libswscale/x86/output.asm
index a288f08..8a72d55 100644
--- a/libswscale/x86/output.asm
+++ b/libswscale/x86/output.asm
@@ -273,17 +273,17 @@ yuv2planeX_fn 10, 7, 5
%macro yuv2plane1_mainloop 2
.loop_%2:
%if %1 == 8
- paddsw m0, m2, [r0+r2*2+mmsize*0]
- paddsw m1, m3, [r0+r2*2+mmsize*1]
+ paddsw m0, m2, [srcq+dstwq*2+mmsize*0]
+ paddsw m1, m3, [srcq+dstwq*2+mmsize*1]
psraw m0, 7
psraw m1, 7
packuswb m0, m1
mov%2 [r1+r2], m0
%elif %1 == 16
- paddd m0, m4, [r0+r2*4+mmsize*0]
- paddd m1, m4, [r0+r2*4+mmsize*1]
- paddd m2, m4, [r0+r2*4+mmsize*2]
- paddd m3, m4, [r0+r2*4+mmsize*3]
+ paddd m0, m4, [srcq+dstwq*4+mmsize*0]
+ paddd m1, m4, [srcq+dstwq*4+mmsize*1]
+ paddd m2, m4, [srcq+dstwq*4+mmsize*2]
+ paddd m3, m4, [srcq+dstwq*4+mmsize*3]
psrad m0, 3
psrad m1, 3
psrad m2, 3
@@ -297,46 +297,46 @@ yuv2planeX_fn 10, 7, 5
paddw m0, m5
paddw m2, m5
%endif ; mmx/sse2/sse4/avx
- mov%2 [r1+r2*2], m0
- mov%2 [r1+r2*2+mmsize], m2
-%else
- paddsw m0, m2, [r0+r2*2+mmsize*0]
- paddsw m1, m2, [r0+r2*2+mmsize*1]
+ mov%2 [dstq+dstwq*2+mmsize*0], m0
+ mov%2 [dstq+dstwq*2+mmsize*1], m2
+%else ; %1 == 9/10
+ paddsw m0, m2, [srcq+dstwq*2+mmsize*0]
+ paddsw m1, m2, [srcq+dstwq*2+mmsize*1]
psraw m0, 15 - %1
psraw m1, 15 - %1
pmaxsw m0, m4
pmaxsw m1, m4
pminsw m0, m3
pminsw m1, m3
- mov%2 [r1+r2*2], m0
- mov%2 [r1+r2*2+mmsize], m1
+ mov%2 [dstq+dstwq*2+mmsize*0], m0
+ mov%2 [dstq+dstwq*2+mmsize*1], m1
%endif
- add r2, mmsize
+ add dstwq, mmsize
jl .loop_%2
%endmacro
%macro yuv2plane1_fn 3
-cglobal yuv2plane1_%1, %3, %3, %2
- add r2, mmsize - 1
- and r2, ~(mmsize - 1)
+cglobal yuv2plane1_%1, %3, %3, %2, src, dst, dstw, dither, offset
+ add dstwq, mmsize - 1
+ and dstwq, ~(mmsize - 1)
%if %1 == 8
- add r1, r2
+ add dstq, dstwq
%else ; %1 != 8
- lea r1, [r1+r2*2]
+ lea dstq, [dstq+dstwq*2]
%endif ; %1 == 8
%if %1 == 16
- lea r0, [r0+r2*4]
+ lea srcq, [srcq+dstwq*4]
%else ; %1 != 16
- lea r0, [r0+r2*2]
+ lea srcq, [srcq+dstwq*2]
%endif ; %1 == 16
- neg r2
+ neg dstwq
%if %1 == 8
pxor m4, m4 ; zero
; create registers holding dither
- movq m3, [r3] ; dither
- test r4d, r4d
+ movq m3, [ditherq] ; dither
+ test offsetd, offsetd
jz .no_rot
%if mmsize == 16
punpcklqdq m3, m3
@@ -372,7 +372,7 @@ cglobal yuv2plane1_%1, %3, %3, %2
%if mmsize == 8
yuv2plane1_mainloop %1, a
%else ; mmsize == 16
- test r1, 15
+ test dstq, 15
jnz .unaligned
yuv2plane1_mainloop %1, a
REP_RET
More information about the ffmpeg-cvslog
mailing list