diff options
author | Måns Rullgård <mans@mansr.com> | 2008-10-21 22:29:57 +0000 |
---|---|---|
committer | Måns Rullgård <mans@mansr.com> | 2008-10-21 22:29:57 +0000 |
commit | 3a90480ac463ffdddfd3718d272a6206eab70bfc (patch) | |
tree | f1df94c4bbc5fc8f7f5e377c9be56f7741595d04 /libavutil/bswap.h | |
parent | 37d3e0667abd01124d783f3ca10a4aef05746a2a (diff) | |
download | ffmpeg-3a90480ac463ffdddfd3718d272a6206eab70bfc.tar.gz |
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.h | 59 |
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 |