mirror of
https://gitee.com/openharmony/third_party_ffmpeg
synced 2024-11-23 19:30:05 +00:00
x86: h264_intrapred: use newly introduced SPLAT* and PSHUFLW macros
This commit is contained in:
parent
4d4752366f
commit
878e669029
@ -103,15 +103,8 @@ cglobal pred16x16_horizontal, 2,3
|
||||
%else
|
||||
punpcklbw m0, m0
|
||||
punpcklbw m1, m1
|
||||
%if cpuflag(mmx2)
|
||||
pshufw m0, m0, 0xff
|
||||
pshufw m1, m1, 0xff
|
||||
%else
|
||||
punpckhwd m0, m0
|
||||
punpckhwd m1, m1
|
||||
punpckhdq m0, m0
|
||||
punpckhdq m1, m1
|
||||
%endif
|
||||
SPLATW m0, m0, 3
|
||||
SPLATW m1, m1, 3
|
||||
mova [r0+r1*0+8], m0
|
||||
mova [r0+r1*1+8], m1
|
||||
%endif
|
||||
@ -162,18 +155,8 @@ cglobal pred16x16_dc, 2,7
|
||||
shr r2d, 5
|
||||
%if cpuflag(ssse3)
|
||||
pxor m1, m1
|
||||
movd m0, r2d
|
||||
pshufb m0, m1
|
||||
%elif cpuflag(sse2)
|
||||
movd m0, r2d
|
||||
punpcklbw m0, m0
|
||||
pshuflw m0, m0, 0
|
||||
punpcklqdq m0, m0
|
||||
%elif cpuflag(mmx2)
|
||||
movd m0, r2d
|
||||
punpcklbw m0, m0
|
||||
pshufw m0, m0, 0
|
||||
%endif
|
||||
SPLATB_REG m0, r2d, m1
|
||||
|
||||
%if mmsize==8
|
||||
mov r3d, 8
|
||||
@ -227,12 +210,7 @@ cglobal pred16x16_tm_vp8, 2,5
|
||||
movzx r2d, byte [r0+r1-1]
|
||||
sub r2d, r3d
|
||||
movd mm4, r2d
|
||||
%if cpuflag(mmx2)
|
||||
pshufw mm4, mm4, 0
|
||||
%else
|
||||
punpcklwd mm4, mm4
|
||||
punpckldq mm4, mm4
|
||||
%endif
|
||||
SPLATW mm4, mm4, 0
|
||||
movq mm5, mm4
|
||||
movq mm6, mm4
|
||||
movq mm7, mm4
|
||||
@ -332,19 +310,15 @@ cglobal pred16x16_plane_%1, 2,9,7
|
||||
movhlps m1, m0
|
||||
%endif
|
||||
paddw m0, m1
|
||||
%if cpuflag(sse2)
|
||||
pshuflw m1, m0, 0xE
|
||||
%elif cpuflag(mmx2)
|
||||
pshufw m1, m0, 0xE
|
||||
%if cpuflag(mmx2)
|
||||
PSHUFLW m1, m0, 0xE
|
||||
%elif cpuflag(mmx)
|
||||
mova m1, m0
|
||||
psrlq m1, 32
|
||||
%endif
|
||||
paddw m0, m1
|
||||
%if cpuflag(sse2)
|
||||
pshuflw m1, m0, 0x1
|
||||
%elif cpuflag(mmx2)
|
||||
pshufw m1, m0, 0x1
|
||||
%if cpuflag(mmx2)
|
||||
PSHUFLW m1, m0, 0x1
|
||||
%elif cpuflag(mmx)
|
||||
mova m1, m0
|
||||
psrlq m1, 16
|
||||
@ -483,25 +457,9 @@ cglobal pred16x16_plane_%1, 2,9,7
|
||||
|
||||
movd m1, r5d
|
||||
movd m3, r3d
|
||||
%if cpuflag(sse2)
|
||||
pshuflw m0, m0, 0x0
|
||||
pshuflw m1, m1, 0x0
|
||||
pshuflw m3, m3, 0x0
|
||||
punpcklqdq m0, m0 ; splat H (words)
|
||||
punpcklqdq m1, m1 ; splat V (words)
|
||||
punpcklqdq m3, m3 ; splat a (words)
|
||||
%elif cpuflag(mmx2)
|
||||
pshufw m0, m0, 0x0
|
||||
pshufw m1, m1, 0x0
|
||||
pshufw m3, m3, 0x0
|
||||
%elif cpuflag(mmx)
|
||||
punpcklwd m0, m0
|
||||
punpcklwd m1, m1
|
||||
punpcklwd m3, m3
|
||||
punpckldq m0, m0
|
||||
punpckldq m1, m1
|
||||
punpckldq m3, m3
|
||||
%endif
|
||||
SPLATW m0, m0, 0 ; H
|
||||
SPLATW m1, m1, 0 ; V
|
||||
SPLATW m3, m3, 0 ; a
|
||||
%ifidn %1, svq3
|
||||
SWAP 0, 1
|
||||
%endif
|
||||
@ -626,10 +584,8 @@ cglobal pred8x8_plane, 2,9,7
|
||||
paddw m0, m1
|
||||
|
||||
%if notcpuflag(ssse3)
|
||||
%if cpuflag(sse2) ; mmsize == 16
|
||||
pshuflw m1, m0, 0xE
|
||||
%elif cpuflag(mmx2)
|
||||
pshufw m1, m0, 0xE
|
||||
%if cpuflag(mmx2)
|
||||
PSHUFLW m1, m0, 0xE
|
||||
%elif cpuflag(mmx)
|
||||
mova m1, m0
|
||||
psrlq m1, 32
|
||||
@ -637,10 +593,8 @@ cglobal pred8x8_plane, 2,9,7
|
||||
paddw m0, m1
|
||||
%endif ; !ssse3
|
||||
|
||||
%if cpuflag(sse2)
|
||||
pshuflw m1, m0, 0x1
|
||||
%elif cpuflag(mmx2)
|
||||
pshufw m1, m0, 0x1
|
||||
%if cpuflag(mmx2)
|
||||
PSHUFLW m1, m0, 0x1
|
||||
%elif cpuflag(mmx)
|
||||
mova m1, m0
|
||||
psrlq m1, 16
|
||||
@ -711,25 +665,9 @@ cglobal pred8x8_plane, 2,9,7
|
||||
|
||||
movd m1, r5d
|
||||
movd m3, r3d
|
||||
%if cpuflag(sse2)
|
||||
pshuflw m0, m0, 0x0
|
||||
pshuflw m1, m1, 0x0
|
||||
pshuflw m3, m3, 0x0
|
||||
punpcklqdq m0, m0 ; splat H (words)
|
||||
punpcklqdq m1, m1 ; splat V (words)
|
||||
punpcklqdq m3, m3 ; splat a (words)
|
||||
%elif cpuflag(mmx2)
|
||||
pshufw m0, m0, 0x0
|
||||
pshufw m1, m1, 0x0
|
||||
pshufw m3, m3, 0x0
|
||||
%elif cpuflag(mmx)
|
||||
punpcklwd m0, m0
|
||||
punpcklwd m1, m1
|
||||
punpcklwd m3, m3
|
||||
punpckldq m0, m0
|
||||
punpckldq m1, m1
|
||||
punpckldq m3, m3
|
||||
%endif
|
||||
SPLATW m0, m0, 0 ; H
|
||||
SPLATW m1, m1, 0 ; V
|
||||
SPLATW m3, m3, 0 ; a
|
||||
%if mmsize == 8
|
||||
mova m2, m0
|
||||
%endif
|
||||
@ -815,24 +753,8 @@ cglobal pred8x8_horizontal, 2,3
|
||||
mova m2, [pb_3]
|
||||
%endif
|
||||
.loop:
|
||||
movd m0, [r0+r1*0-4]
|
||||
movd m1, [r0+r1*1-4]
|
||||
%if cpuflag(ssse3)
|
||||
pshufb m0, m2
|
||||
pshufb m1, m2
|
||||
%else
|
||||
punpcklbw m0, m0
|
||||
punpcklbw m1, m1
|
||||
%if cpuflag(mmx2)
|
||||
pshufw m0, m0, 0xff
|
||||
pshufw m1, m1, 0xff
|
||||
%else
|
||||
punpckhwd m0, m0
|
||||
punpckhwd m1, m1
|
||||
punpckhdq m0, m0
|
||||
punpckhdq m1, m1
|
||||
%endif
|
||||
%endif
|
||||
SPLATB_LOAD m0, r0+r1*0-1, m2
|
||||
SPLATB_LOAD m1, r0+r1*1-1, m2
|
||||
mova [r0+r1*0], m0
|
||||
mova [r0+r1*1], m1
|
||||
lea r0, [r0+r1*2]
|
||||
@ -1000,15 +922,8 @@ cglobal pred8x8_tm_vp8, 2,6
|
||||
sub r3d, r4d
|
||||
movd mm2, r2d
|
||||
movd mm4, r3d
|
||||
%if cpuflag(mmx2)
|
||||
pshufw mm2, mm2, 0
|
||||
pshufw mm4, mm4, 0
|
||||
%else
|
||||
punpcklwd mm2, mm2
|
||||
punpcklwd mm4, mm4
|
||||
punpckldq mm2, mm2
|
||||
punpckldq mm4, mm4
|
||||
%endif
|
||||
SPLATW mm2, mm2, 0
|
||||
SPLATW mm4, mm4, 0
|
||||
movq mm3, mm2
|
||||
movq mm5, mm4
|
||||
paddw mm2, mm0
|
||||
|
Loading…
Reference in New Issue
Block a user