summaryrefslogtreecommitdiff
path: root/libavutil/bswap.h
diff options
context:
space:
mode:
authorMåns Rullgård <mans@mansr.com>2008-10-21 22:29:57 +0000
committerMåns Rullgård <mans@mansr.com>2008-10-21 22:29:57 +0000
commit3a90480ac463ffdddfd3718d272a6206eab70bfc (patch)
treef1df94c4bbc5fc8f7f5e377c9be56f7741595d04 /libavutil/bswap.h
parent37d3e0667abd01124d783f3ca10a4aef05746a2a (diff)
split bswap.h into per-arch files
Originally committed as revision 15663 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavutil/bswap.h')
-rw-r--r--libavutil/bswap.h59
1 files changed, 16 insertions, 43 deletions
diff --git a/libavutil/bswap.h b/libavutil/bswap.h
index 3d0a2a7c8d..c14676e6ab 100644
--- a/libavutil/bswap.h
+++ b/libavutil/bswap.h
@@ -30,68 +30,40 @@
#include "config.h"
#include "common.h"
+#if defined(ARCH_ARMV4L)
+# include "arm/bswap.h"
+#elif defined(ARCH_BFIN)
+# include "bfin/bswap.h"
+#elif defined(ARCH_SH4)
+# include "sh4/bswap.h"
+#elif defined(ARCH_X86)
+# include "x86/bswap.h"
+#endif
+
+#ifndef bswap_16
static av_always_inline av_const uint16_t bswap_16(uint16_t x)
{
-#if defined(ARCH_X86)
- __asm__("rorw $8, %0" : "+r"(x));
-#elif defined(ARCH_SH4)
- __asm__("swap.b %0,%0" : "=r"(x) : "0"(x));
-#elif defined(HAVE_ARMV6)
- __asm__("rev16 %0, %0" : "+r"(x));
-#else
x= (x>>8) | (x<<8);
-#endif
return x;
}
+#endif
+#ifndef bswap_32
static av_always_inline av_const uint32_t bswap_32(uint32_t x)
{
-#if defined(ARCH_X86)
-#ifdef HAVE_BSWAP
- __asm__("bswap %0" : "+r" (x));
-#else
- __asm__("rorw $8, %w0 \n\t"
- "rorl $16, %0 \n\t"
- "rorw $8, %w0"
- : "+r"(x));
-#endif
-#elif defined(ARCH_SH4)
- __asm__("swap.b %0,%0\n"
- "swap.w %0,%0\n"
- "swap.b %0,%0\n"
- : "=r"(x) : "0"(x));
-#elif defined(HAVE_ARMV6)
- __asm__("rev %0, %0" : "+r"(x));
-#elif defined(ARCH_ARMV4L)
- uint32_t t;
- __asm__ ("eor %1, %0, %0, ror #16 \n\t"
- "bic %1, %1, #0xFF0000 \n\t"
- "mov %0, %0, ror #8 \n\t"
- "eor %0, %0, %1, lsr #8 \n\t"
- : "+r"(x), "=&r"(t));
-#elif defined(ARCH_BFIN)
- unsigned tmp;
- __asm__("%1 = %0 >> 8 (V); \n\t"
- "%0 = %0 << 8 (V); \n\t"
- "%0 = %0 | %1; \n\t"
- "%0 = PACK(%0.L, %0.H); \n\t"
- : "+d"(x), "=&d"(tmp));
-#else
x= ((x<<8)&0xFF00FF00) | ((x>>8)&0x00FF00FF);
x= (x>>16) | (x<<16);
-#endif
return x;
}
+#endif
+#ifndef bswap_64
static inline uint64_t av_const bswap_64(uint64_t x)
{
#if 0
x= ((x<< 8)&0xFF00FF00FF00FF00ULL) | ((x>> 8)&0x00FF00FF00FF00FFULL);
x= ((x<<16)&0xFFFF0000FFFF0000ULL) | ((x>>16)&0x0000FFFF0000FFFFULL);
return (x>>32) | (x<<32);
-#elif defined(ARCH_X86_64)
- __asm__("bswap %0": "=r" (x) : "0" (x));
- return x;
#else
union {
uint64_t ll;
@@ -103,6 +75,7 @@ static inline uint64_t av_const bswap_64(uint64_t x)
return r.ll;
#endif
}
+#endif
// be2me ... BigEndian to MachineEndian
// le2me ... LittleEndian to MachineEndian