[Ffmpeg-cvslog] r8632 - trunk/libavcodec/armv4l/dsputil_iwmmxt.c

diego subversion
Fri Apr 6 11:59:55 CEST 2007


Author: diego
Date: Fri Apr  6 11:59:55 2007
New Revision: 8632

Modified:
   trunk/libavcodec/armv4l/dsputil_iwmmxt.c

Log:
IWMMXT-specific dsputils clear_blocks function.
patch by David Bateman, adb014 gmail com


Modified: trunk/libavcodec/armv4l/dsputil_iwmmxt.c
==============================================================================
--- trunk/libavcodec/armv4l/dsputil_iwmmxt.c	(original)
+++ trunk/libavcodec/armv4l/dsputil_iwmmxt.c	Fri Apr  6 11:59:55 2007
@@ -123,6 +123,25 @@ void add_pixels_clamped_iwmmxt(const DCT
         : "cc", "memory", "r12");
 }
 
+static void clear_blocks_iwmmxt(DCTELEM *blocks)
+{
+    __asm __volatile(
+                "wzero wr0                      \n\t"
+                "mov r1, #(128 * 6 / 32)        \n\t"
+                "1:                             \n\t"
+                "wstrd wr0, [%0]                \n\t"
+                "wstrd wr0, [%0, #8]            \n\t"
+                "wstrd wr0, [%0, #16]           \n\t"
+                "wstrd wr0, [%0, #24]           \n\t"
+                "subs r1, r1, #1                \n\t"
+                "add %0, %0, #32                \n\t"
+                "bne 1b                         \n\t"
+                : "+r"(blocks)
+                :
+                : "r1"
+        );
+}
+
 static void nop(uint8_t *block, const uint8_t *pixels, int line_size, int h)
 {
     return;
@@ -146,6 +165,8 @@ void dsputil_init_iwmmxt(DSPContext* c, 
 
     c->add_pixels_clamped = add_pixels_clamped_iwmmxt;
 
+    c->clear_blocks = clear_blocks_iwmmxt;
+
     c->put_pixels_tab[0][0] = put_pixels16_iwmmxt;
     c->put_pixels_tab[0][1] = put_pixels16_x2_iwmmxt;
     c->put_pixels_tab[0][2] = put_pixels16_y2_iwmmxt;




More information about the ffmpeg-cvslog mailing list