[libav-devel] [PATCH 1/3] x86: videodsp: Properly mark sse2 instructions in emulated_edge_mc as such.

2014-01-30 Thread Janne Grunau
From: Ronald S. Bultje rsbul...@gmail.com

Should fix crashes or corrupt output on pre-SSE2 CPUs when they were
using SSE2-code (e.g. AMD Athlon XP 2400+ or Intel Pentium III) in
hfix or hvar single-edge (left/right) extension functions.

Signed-off-by: Janne Grunau janne-li...@jannau.net
---
 libavcodec/x86/videodsp.asm| 72 +-
 libavcodec/x86/videodsp_init.c | 37 --
 2 files changed, 70 insertions(+), 39 deletions(-)

diff --git a/libavcodec/x86/videodsp.asm b/libavcodec/x86/videodsp.asm
index 59f1937..aceb77a 100644
--- a/libavcodec/x86/videodsp.asm
+++ b/libavcodec/x86/videodsp.asm
@@ -102,8 +102,8 @@ cglobal emu_edge_hvar, 5, 6, 1, dst, dst_stride, start_x, 
n_words, h, w
 imul wd, 0x01010101 ;   w *= 0x01010101
 movd m0, wd
 mov  wq, n_wordsq   ;   initialize w
-%if cpuflag(sse)
-shufps   m0, m0, q  ;   splat
+%if cpuflag(sse2)
+pshufd   m0, m0, q  ;   splat
 %else ; mmx
 punpckldqm0, m0 ;   splat
 %endif ; mmx/sse
@@ -124,7 +124,7 @@ INIT_MMX mmx
 hvar_fn
 %endif
 
-INIT_XMM sse
+INIT_XMM sse2
 hvar_fn
 
 ; macro to read/write a horizontal number of pixels (%2) to/from registers
@@ -137,42 +137,49 @@ hvar_fn
 ; - if (%2  3)  fills 1, 2 or 4 bytes in eax
 ; writing data out is in the same way
 %macro READ_NUM_BYTES 2
-%assign %%off 0 ; offset in source buffer
-%assign %%idx 0 ; mmx/xmm register index
+%assign %%off 0 ; offset in source buffer
+%assign %%mmx_idx 0 ; mmx register index
+%assign %%xmm_idx 0 ; xmm register index
 
 %rep %2/mmsize
-movu m %+ %%idx, [srcq+%%off]
+%if mmsize == 16
+movu   xmm %+ %%xmm_idx, [srcq+%%off]
+%assign %%xmm_idx %%xmm_idx+1
+%else ; mmx
+movumm %+ %%mmx_idx, [srcq+%%off]
+%assign %%mmx_idx %%mmx_idx+1
+%endif
 %assign %%off %%off+mmsize
-%assign %%idx %%idx+1
 %endrep ; %2/mmsize
 
 %if mmsize == 16
 %if (%2-%%off) = 8
 %if %2  16  (%2-%%off)  8
-movu m %+ %%idx, [srcq+%2-16]
+movu   xmm %+ %%xmm_idx, [srcq+%2-16]
+%assign %%xmm_idx %%xmm_idx+1
 %assign %%off %2
 %else
-movq m %+ %%idx, [srcq+%%off]
+movqmm %+ %%mmx_idx, [srcq+%%off]
+%assign %%mmx_idx %%mmx_idx+1
 %assign %%off %%off+8
 %endif
-%assign %%idx %%idx+1
 %endif ; (%2-%%off) = 8
 %endif
 
 %if (%2-%%off) = 4
 %if %2  8  (%2-%%off)  4
-movq m %+ %%idx, [srcq+%2-8]
+movqmm %+ %%mmx_idx, [srcq+%2-8]
 %assign %%off %2
 %else
-movd m %+ %%idx, [srcq+%%off]
+movdmm %+ %%mmx_idx, [srcq+%%off]
 %assign %%off %%off+4
 %endif
-%assign %%idx %%idx+1
+%assign %%mmx_idx %%mmx_idx+1
 %endif ; (%2-%%off) = 4
 
 %if (%2-%%off) = 1
 %if %2 = 4
-movd m %+ %%idx, [srcq+%2-4]
+movd mm %+ %%mmx_idx, [srcq+%2-4]
 %elif (%2-%%off) == 1
 movvalb, [srcq+%2-1]
 %elif (%2-%%off) == 2
@@ -180,48 +187,55 @@ hvar_fn
 %elifidn %1, body
 movvald, [srcq+%2-3]
 %else
-movd m %+ %%idx, [srcq+%2-3]
+movd mm %+ %%mmx_idx, [srcq+%2-3]
 %endif
 %endif ; (%2-%%off) = 1
 %endmacro ; READ_NUM_BYTES
 
 %macro WRITE_NUM_BYTES 2
-%assign %%off 0 ; offset in destination buffer
-%assign %%idx 0 ; mmx/xmm register index
+%assign %%off 0 ; offset in destination buffer
+%assign %%mmx_idx 0 ; mmx register index
+%assign %%xmm_idx 0 ; xmm register index
 
 %rep %2/mmsize
-movu   [dstq+%%off], m %+ %%idx
+%if mmsize == 16
+movu   [dstq+%%off], xmm %+ %%xmm_idx
+%assign %%xmm_idx %%xmm_idx+1
+%else ; mmx
+movu   [dstq+%%off], mm %+ %%mmx_idx
+%assign %%mmx_idx %%mmx_idx+1
+%endif
 %assign %%off %%off+mmsize
-%assign %%idx %%idx+1
 %endrep ; %2/mmsize
 
 %if mmsize == 16
 %if (%2-%%off) = 8
 %if %2  16  (%2-%%off)  8
-movu   [dstq+%2-16], m %+ %%idx
+movu   [dstq+%2-16], xmm %+ %%xmm_idx
+%assign %%xmm_idx %%xmm_idx+1
 %assign %%off %2
 %else
-movq   [dstq+%%off], m %+ %%idx
+movq   [dstq+%%off], mm %+ %%mmx_idx
+%assign %%mmx_idx %%mmx_idx+1
 %assign %%off %%off+8
 %endif
-%assign %%idx %%idx+1
 %endif ; (%2-%%off) = 8
 %endif
 
 %if (%2-%%off) = 4
 %if %2  8  (%2-%%off)  4
-movq[dstq+%2-8], m %+ %%idx
+movq[dstq+%2-8], mm %+ %%mmx_idx
 %assign %%off %2
 %else
-movd   [dstq+%%off], m %+ %%idx
+movd   [dstq+%%off], mm %+ %%mmx_idx
 %assign %%off %%off+4
 %endif
-%assign %%idx %%idx+1
+%assign %%mmx_idx %%mmx_idx+1
 %endif ; (%2-%%off) = 4
 
 %if (%2-%%off) = 1
 %if %2 = 4
-movd[dstq+%2-4], m %+ %%idx
+movd[dstq+%2-4], mm %+ %%mmx_idx
 %elif (%2-%%off) == 1
 mov [dstq+%2-1], valb
 %elif (%2-%%off) == 2
@@ -231,7 +245,7 @@ hvar_fn
 shrvald, 16
 mov [dstq+%2-1], valb
 %else
-movd   vald, m %+ %%idx
+movd   vald, mm %+ %%mmx_idx
 mov [dstq+%2-3], valw
 shrvald, 16
 mov [dstq+%2-1], valb
@@ -339,7 +353,7 @@ VERTICAL_EXTEND 16, 22
 %if %1 = 

Re: [libav-devel] [PATCH 1/3] x86: videodsp: Properly mark sse2 instructions in emulated_edge_mc as such.

2014-01-30 Thread Diego Biurrun
On Thu, Jan 30, 2014 at 03:43:30PM +0100, Janne Grunau wrote:
 From: Ronald S. Bultje rsbul...@gmail.com
 
 Should fix crashes or corrupt output on pre-SSE2 CPUs when they were
 using SSE2-code (e.g. AMD Athlon XP 2400+ or Intel Pentium III) in
 hfix or hvar single-edge (left/right) extension functions.
 
 Signed-off-by: Janne Grunau janne-li...@jannau.net
 ---
  libavcodec/x86/videodsp.asm| 72 
 +-
  libavcodec/x86/videodsp_init.c | 37 --
  2 files changed, 70 insertions(+), 39 deletions(-)

probably OK

Diego
___
libav-devel mailing list
libav-devel@libav.org
https://lists.libav.org/mailman/listinfo/libav-devel