OSDN Git Service

x86: huffyuv: Use EXTERNAL_SSSE3_FAST convenience macro where appropriate
authorDiego Biurrun <diego@biurrun.de>
Mon, 18 Jan 2016 09:52:21 +0000 (10:52 +0100)
committerDiego Biurrun <diego@biurrun.de>
Wed, 20 Jul 2016 16:43:28 +0000 (18:43 +0200)
libavcodec/x86/huffyuvdsp.asm
libavcodec/x86/huffyuvdsp_init.c

index e7536da..692162b 100644 (file)
@@ -146,8 +146,8 @@ cglobal add_hfyu_left_pred, 3,3,7, dst, src, w, left
     psllq   m0, 56
     ADD_HFYU_LEFT_LOOP 1, 1
 
-INIT_XMM sse4
-cglobal add_hfyu_left_pred, 3,3,7, dst, src, w, left
+INIT_XMM ssse3
+cglobal add_hfyu_left_pred_unaligned, 3,3,7, dst, src, w, left
     mova    m5, [pb_f]
     mova    m6, [pb_zzzzzzzz77777777]
     mova    m4, [pb_zzzz3333zzzzbbbb]
index 75537d7..80e6cfb 100644 (file)
@@ -31,8 +31,8 @@ void ff_add_hfyu_median_pred_mmxext(uint8_t *dst, const uint8_t *top,
 
 int  ff_add_hfyu_left_pred_ssse3(uint8_t *dst, const uint8_t *src,
                                  int w, int left);
-int  ff_add_hfyu_left_pred_sse4(uint8_t *dst, const uint8_t *src,
-                                int w, int left);
+int  ff_add_hfyu_left_pred_unaligned_ssse3(uint8_t *dst, const uint8_t *src,
+                                           int w, int left);
 
 #if HAVE_INLINE_ASM
 
@@ -124,7 +124,9 @@ av_cold void ff_huffyuvdsp_init_x86(HuffYUVDSPContext *c)
 
     if (EXTERNAL_SSSE3(cpu_flags)) {
         c->add_hfyu_left_pred = ff_add_hfyu_left_pred_ssse3;
-        if (cpu_flags & AV_CPU_FLAG_SSE4) // not really SSE4, just slow on Conroe
-            c->add_hfyu_left_pred = ff_add_hfyu_left_pred_sse4;
+    }
+
+    if (EXTERNAL_SSSE3_FAST(cpu_flags)) {
+        c->add_hfyu_left_pred = ff_add_hfyu_left_pred_unaligned_ssse3;
     }
 }