Mercurial > libavcodec.hg
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))