changeset 3605:6702a154df1f libavcodec

MUL* for ARM code based on a patch by Siarhei Siamashka untested
author michael
date Tue, 22 Aug 2006 13:25:09 +0000
parents dad0296d4522
children e28285ddde8d
files mpegaudiodec.c
diffstat 1 files changed, 11 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- a/mpegaudiodec.c	Tue Aug 22 12:07:02 2006 +0000
+++ b/mpegaudiodec.c	Tue Aug 22 13:25:09 2006 +0000
@@ -55,6 +55,17 @@
         ({ int64_t rt; asm ("imull %2\n\t" : "=A"(rt) : "a" (ra), "g" (rb)); rt; })
 #   define MULH(ra, rb) \
         ({ int rt, dummy; asm ("imull %3\n\t" : "=d"(rt), "=a"(dummy): "a" (ra), "rm" (rb)); rt; })
+#elif defined(ARCH_ARMV4L)
+#   define MULL(a, b) \
+        ({  int lo, hi;\
+            asm("smull %0, %1, %2, %3     \n\t"\
+                "mov   %0, %0,     lsr #%4\n\t"\
+                "add   %1, %0, %1, lsl #%5\n\t"\
+            : "=r"(lo), "=r"(hi)\
+            : "r"(b), "r"(a), "i"(FRAC_BITS), "i"(32-FRAC_BITS));\
+         hi; })
+#   define MUL64(a,b) ((int64_t)(a) * (int64_t)(b))
+#   define MULH(a, b) ({ int lo, hi; asm ("smull %0, %1, %2, %3" : "=r"(lo), "=r"(hi) : "r"(b),"r"(a)); hi; })
 #else
 #   define MULL(a,b) (((int64_t)(a) * (int64_t)(b)) >> FRAC_BITS)
 #   define MUL64(a,b) ((int64_t)(a) * (int64_t)(b))