Commit 5bd4597a authored by mru's avatar mru

ARM: ARMv6 optimised bswap_16/32

git-svn-id: file:///var/local/repositories/ffmpeg/trunk@14239 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent af8dd66e
...@@ -40,6 +40,8 @@ static av_always_inline av_const uint16_t bswap_16(uint16_t x) ...@@ -40,6 +40,8 @@ static av_always_inline av_const uint16_t bswap_16(uint16_t x)
asm("rorw $8, %0" : "+r"(x)); asm("rorw $8, %0" : "+r"(x));
#elif defined(ARCH_SH4) #elif defined(ARCH_SH4)
asm("swap.b %0,%0" : "=r"(x) : "0"(x)); asm("swap.b %0,%0" : "=r"(x) : "0"(x));
#elif defined(HAVE_ARMV6)
asm("rev16 %0, %0" : "+r"(x));
#else #else
x= (x>>8) | (x<<8); x= (x>>8) | (x<<8);
#endif #endif
...@@ -62,6 +64,8 @@ static av_always_inline av_const uint32_t bswap_32(uint32_t x) ...@@ -62,6 +64,8 @@ static av_always_inline av_const uint32_t bswap_32(uint32_t x)
"swap.w %0,%0\n" "swap.w %0,%0\n"
"swap.b %0,%0\n" "swap.b %0,%0\n"
: "=r"(x) : "0"(x)); : "=r"(x) : "0"(x));
#elif defined(HAVE_ARMV6)
asm("rev %0, %0" : "+r"(x));
#elif defined(ARCH_ARM) #elif defined(ARCH_ARM)
uint32_t t; uint32_t t;
asm ("eor %1, %0, %0, ror #16 \n\t" asm ("eor %1, %0, %0, ror #16 \n\t"
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment