[SCM] libav/experimental: untested generic bswap64

siretart at users.alioth.debian.org siretart at users.alioth.debian.org
Sun Jun 30 15:32:08 UTC 2013


The following commit has been merged in the experimental branch:
commit bbdadbda05a2ade237b70c66db74c41d5a700cb3
Author: Nick Kurshev <nickols_k at mail.ru>
Date:   Sun May 26 09:45:45 2002 +0000

    untested generic bswap64
    
    Originally committed as revision 603 to svn://svn.ffmpeg.org/ffmpeg/trunk

diff --git a/libavcodec/bswap.h b/libavcodec/bswap.h
index af80e50..767848e 100644
--- a/libavcodec/bswap.h
+++ b/libavcodec/bswap.h
@@ -5,6 +5,7 @@
 #include <byteswap.h>
 #else
 
+#include <inttypes.h> /* for __WORDSIZE */
 #ifdef ARCH_X86
 inline static unsigned short ByteSwap16(unsigned short x)
 {
@@ -52,6 +53,17 @@ inline static unsigned long long int ByteSwap64(unsigned long long int x)
      ((((x) & 0xff000000) >> 24) | (((x) & 0x00ff0000) >>  8) | \
       (((x) & 0x0000ff00) <<  8) | (((x) & 0x000000ff) << 24))
 
+#if __WORDSIZE >= 64
+# define bswap_64(x) \
+     ((((x) & 0xff00000000000000ull) >> 56)				      \
+      | (((x) & 0x00ff000000000000ull) >> 40)				      \
+      | (((x) & 0x0000ff0000000000ull) >> 24)				      \
+      | (((x) & 0x000000ff00000000ull) >> 8)				      \
+      | (((x) & 0x00000000ff000000ull) << 8)				      \
+      | (((x) & 0x0000000000ff0000ull) << 24)				      \
+      | (((x) & 0x000000000000ff00ull) << 40)				      \
+      | (((x) & 0x00000000000000ffull) << 56))
+#else
 #define bswap_64(x) \
      (__extension__						\
       ({ union { __extension__ unsigned long long int __ll;	\
@@ -60,6 +72,7 @@ inline static unsigned long long int ByteSwap64(unsigned long long int x)
          __r.__l[0] = bswap_32 (__w.__l[1]);			\
          __r.__l[1] = bswap_32 (__w.__l[0]);			\
          __r.__ll; }))
+#endif
 #endif	/* !ARCH_X86 */
 
 #endif	/* !HAVE_BYTESWAP_H */

-- 
Libav/FFmpeg packaging



More information about the pkg-multimedia-commits mailing list