summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorLadislav Zezula <zezula@volny.cz>2021-04-01 18:01:16 +0200
committerGitHub <noreply@github.com>2021-04-01 18:01:16 +0200
commit302ace05a120d64cc678d2863843ae093bb09b52 (patch)
tree553603aee550f7260a3b8b7d4769ce679687af72 /src
parent0a9057a09f083eb4791a55eb3d9538cea9822e37 (diff)
parent172ed20dece801612c5863f65bbffccfa8200959 (diff)
Merge pull request #213 from glebm/fix-byte-swapping
Fix big endian on non-Mac
Diffstat (limited to 'src')
-rw-r--r--src/SBaseCommon.cpp39
1 files changed, 20 insertions, 19 deletions
diff --git a/src/SBaseCommon.cpp b/src/SBaseCommon.cpp
index 700c4a7..2f30a71 100644
--- a/src/SBaseCommon.cpp
+++ b/src/SBaseCommon.cpp
@@ -1756,45 +1756,46 @@ void CalculateDataBlockHash(void * pvDataBlock, DWORD cbDataBlock, LPBYTE md5_ha
#ifndef STORMLIB_LITTLE_ENDIAN
-//
-// Note that those functions are implemented for Mac operating system,
-// as this is the only supported platform that uses big endian.
-//
-
// Swaps a signed 16-bit integer
-int16_t SwapInt16(uint16_t data)
+int16_t SwapInt16(uint16_t val)
{
- return (int16_t)CFSwapInt16(data);
+ return (val << 8) | ((val >> 8) & 0xFF);
}
// Swaps an unsigned 16-bit integer
-uint16_t SwapUInt16(uint16_t data)
+uint16_t SwapUInt16(uint16_t val)
{
- return CFSwapInt16(data);
+ return (val << 8) | (val >> 8 );
}
-// Swaps signed 32-bit integer
-int32_t SwapInt32(uint32_t data)
+// Swaps a signed 32-bit integer
+int32_t SwapInt32(uint32_t val)
{
- return (int32_t)CFSwapInt32(data);
+ val = ((val << 8) & 0xFF00FF00) | ((val >> 8) & 0xFF00FF );
+ return (val << 16) | ((val >> 16) & 0xFFFF);
}
// Swaps an unsigned 32-bit integer
-uint32_t SwapUInt32(uint32_t data)
+uint32_t SwapUInt32(uint32_t val)
{
- return CFSwapInt32(data);
+ val = ((val << 8) & 0xFF00FF00 ) | ((val >> 8) & 0xFF00FF );
+ return (val << 16) | (val >> 16);
}
-// Swaps signed 64-bit integer
-int64_t SwapInt64(int64_t data)
+// Swaps a signed 64-bit integer
+int64_t SwapInt64(uint64_t val)
{
- return (int64_t)CFSwapInt64(data);
+ val = ((val << 8) & 0xFF00FF00FF00FF00ULL ) | ((val >> 8) & 0x00FF00FF00FF00FFULL );
+ val = ((val << 16) & 0xFFFF0000FFFF0000ULL ) | ((val >> 16) & 0x0000FFFF0000FFFFULL );
+ return (val << 32) | ((val >> 32) & 0xFFFFFFFFULL);
}
// Swaps an unsigned 64-bit integer
-uint64_t SwapUInt64(uint64_t data)
+uint64_t SwapUInt64(uint64_t val)
{
- return CFSwapInt64(data);
+ val = ((val << 8) & 0xFF00FF00FF00FF00ULL ) | ((val >> 8) & 0x00FF00FF00FF00FFULL );
+ val = ((val << 16) & 0xFFFF0000FFFF0000ULL ) | ((val >> 16) & 0x0000FFFF0000FFFFULL );
+ return (val << 32) | (val >> 32);
}
// Swaps array of unsigned 16-bit integers