[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