From 05bb536fbebb4e856bbcf15e3bc5f8df6d7fb48f Mon Sep 17 00:00:00 2001 From: lloyd Date: Sat, 8 Mar 2008 23:14:03 +0000 Subject: Put reverse_bytes into bit_ops.h so they can be inlined. Rewrite the version for 64-bit to not use 64-bit constants - that way GCC won't complain everwhere. Plan is for a module to replace all of these with asm (bswap, xchg on x86), at least for x86-64 --- include/bit_ops.h | 21 +++++++++++++++++---- src/bit_ops.cpp | 29 ----------------------------- 2 files changed, 17 insertions(+), 33 deletions(-) diff --git a/include/bit_ops.h b/include/bit_ops.h index 3576f8ce1..d0fb03d1f 100644 --- a/include/bit_ops.h +++ b/include/bit_ops.h @@ -24,11 +24,24 @@ template inline T rotate_right(T input, u32bit rot) } /************************************************* -* Byteswap * +* Byte Swapping Functions * *************************************************/ -u16bit reverse_bytes(u16bit); -u32bit reverse_bytes(u32bit); -u64bit reverse_bytes(u64bit); +inline u16bit reverse_bytes(u16bit input) + { + return rotate_left(input, 8); + } + +inline u32bit reverse_bytes(u32bit input) + { + input = ((input & 0xFF00FF00) >> 8) | ((input & 0x00FF00FF) << 8); + return rotate_left(input, 16); + } + +inline u64bit reverse_bytes(u64bit input) + { + return rotate_left(static_cast(input ), 16) | + rotate_left(static_cast(input >> 32), 16); + } /************************************************* * Array XOR * diff --git a/src/bit_ops.cpp b/src/bit_ops.cpp index dad2b0fb9..2db947d01 100644 --- a/src/bit_ops.cpp +++ b/src/bit_ops.cpp @@ -42,35 +42,6 @@ void xor_buf(byte out[], const byte in[], const byte mask[], u32bit length) out[j] = in[j] ^ mask[j]; } -/************************************************* -* Reverse bytes * -*************************************************/ -u16bit reverse_bytes(u16bit input) - { - return rotate_left(input, 8); - } - -/************************************************* -* Reverse bytes * -*************************************************/ -u32bit reverse_bytes(u32bit input) - { - input = ((input & 0xFF00FF00) >> 8) | ((input & 0x00FF00FF) << 8); - return rotate_left(input, 16); - } - -/************************************************* -* Reverse bytes * -*************************************************/ -u64bit reverse_bytes(u64bit input) - { - input = ((input & 0xFF00FF00FF00FF00) >> 8) | - ((input & 0x00FF00FF00FF00FF) << 8); - input = ((input & 0xFFFF0000FFFF0000) >> 16) | - ((input & 0x0000FFFF0000FFFF) << 16); - return rotate_left(input, 32); - } - /************************************************* * Return true iff arg is 2**n for some n > 0 * *************************************************/ -- cgit v1.2.3