diff bswap.h @ 582:57da90f7c680 libavutil

split bswap.h into per-arch files
author mru
date Tue, 21 Oct 2008 22:29:57 +0000
parents 2ec148d26d9f
children b27f233a4b3c
line wrap: on
line diff
--- a/bswap.h	Tue Oct 21 21:40:24 2008 +0000
+++ b/bswap.h	Tue Oct 21 22:29:57 2008 +0000
@@ -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 @@
     return r.ll;
 #endif
 }
+#endif
 
 // be2me ... BigEndian to MachineEndian
 // le2me ... LittleEndian to MachineEndian