From b0367ef00afe74f4fae1ff930ea53e88c46c3d52 Mon Sep 17 00:00:00 2001 From: =?utf8?q?M=C3=A5ns=20Rullg=C3=A5rd?= Date: Tue, 15 Jul 2008 19:06:32 +0000 Subject: [PATCH] ARM: optimised MAC64 and MLS64 Originally committed as revision 14245 to svn://svn.ffmpeg.org/ffmpeg/trunk --- libavcodec/armv4l/mathops.h | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/libavcodec/armv4l/mathops.h b/libavcodec/armv4l/mathops.h index e42cefb..ff12aef 100644 --- a/libavcodec/armv4l/mathops.h +++ b/libavcodec/armv4l/mathops.h @@ -57,6 +57,16 @@ static inline av_const int64_t MUL64(int a, int b) } #define MUL64 MUL64 +static inline av_const int64_t MAC64(int64_t d, int a, int b) +{ + union { uint64_t x; unsigned hl[2]; } x = { d }; + asm ("smlal %0, %1, %2, %3" + : "+r"(x.hl[0]), "+r"(x.hl[1]) : "r"(a), "r"(b)); + return x.x; +} +#define MAC64(d, a, b) ((d) = MAC64(d, a, b)) +#define MLS64(d, a, b) MAC64(d, -(a), b) + #if defined(HAVE_ARMV5TE) /* signed 16x16 -> 32 multiply add accumulate */ -- 2.7.4