x86: PABSW: port to cpuflags

pull/6/merge
Diego Biurrun 13 years ago
parent 6c104826bd
commit dbb37e7711
  1. 3
      libavcodec/x86/vc1dsp.asm
  2. 22
      libavutil/x86/x86util.asm

@ -268,7 +268,6 @@ cglobal vc1_h_loop_filter8, 3,5,0
%endmacro
INIT_MMX mmxext
%define PABSW PABSW_MMXEXT
VC1_LF
INIT_XMM sse2
@ -284,8 +283,6 @@ cglobal vc1_h_loop_filter8, 3,6,8
VC1_H_LOOP_FILTER 8, r5
RET
%define PABSW PABSW_SSSE3
INIT_MMX ssse3
; void ff_vc1_v_loop_filter4_ssse3(uint8_t *src, int stride, int pq)
cglobal vc1_v_loop_filter4, 3,5,0

@ -145,13 +145,21 @@
%endif
%endmacro
; PABSW macros assume %1 != %2, while ABS1/2 macros work in-place
%macro PABSW_MMX 2
; PABSW macro assumes %1 != %2, while ABS1/2 macros work in-place
%macro PABSW 2
%if cpuflag(ssse3)
pabsw %1, %2
%elif cpuflag(mmxext)
pxor %1, %1
psubw %1, %2
pmaxsw %1, %2
%else
pxor %1, %1
pcmpgtw %1, %2
pxor %2, %1
psubw %2, %1
SWAP %1, %2
%endif
%endmacro
%macro PSIGNW_MMX 2
@ -159,16 +167,6 @@
psubw %1, %2
%endmacro
%macro PABSW_MMXEXT 2
pxor %1, %1
psubw %1, %2
pmaxsw %1, %2
%endmacro
%macro PABSW_SSSE3 2
pabsw %1, %2
%endmacro
%macro PSIGNW_SSSE3 2
psignw %1, %2
%endmacro

Loading…
Cancel
Save