# HG changeset patch # User michael # Date 1156253109 0 # Node ID 6702a154df1f79f69c7828c78bc5a5543fbb12dc # Parent dad0296d4522364f2be3d77f23c72586be10e14a MUL* for ARM code based on a patch by Siarhei Siamashka untested diff -r dad0296d4522 -r 6702a154df1f mpegaudiodec.c --- 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))