Index: third_party/lzma_sdk/7zCrc.c |
diff --git a/third_party/lzma_sdk/7zCrc.c b/third_party/lzma_sdk/7zCrc.c |
index a920849611cce5407d4c4f26e2b12da5c2b04359..dc6d6abdc0a54b8f9a092964dd493c982906e2b2 100644 |
--- a/third_party/lzma_sdk/7zCrc.c |
+++ b/third_party/lzma_sdk/7zCrc.c |
@@ -1,5 +1,7 @@ |
-/* 7zCrc.c -- CRC32 calculation |
-2009-11-23 : Igor Pavlov : Public domain */ |
+/* 7zCrc.c -- CRC32 init |
+2015-03-10 : Igor Pavlov : Public domain */ |
+ |
+#include "Precomp.h" |
#include "7zCrc.h" |
#include "CpuArch.h" |
@@ -7,34 +9,28 @@ |
#define kCrcPoly 0xEDB88320 |
#ifdef MY_CPU_LE |
-#define CRC_NUM_TABLES 8 |
+ #define CRC_NUM_TABLES 8 |
#else |
-#define CRC_NUM_TABLES 1 |
-#endif |
- |
-typedef UInt32 (MY_FAST_CALL *CRC_FUNC)(UInt32 v, const void *data, size_t size, const UInt32 *table); |
- |
-static CRC_FUNC g_CrcUpdate; |
-UInt32 g_CrcTable[256 * CRC_NUM_TABLES]; |
+ #define CRC_NUM_TABLES 9 |
-#if CRC_NUM_TABLES == 1 |
+ #define CRC_UINT32_SWAP(v) ((v >> 24) | ((v >> 8) & 0xFF00) | ((v << 8) & 0xFF0000) | (v << 24)) |
-#define CRC_UPDATE_BYTE_2(crc, b) (table[((crc) ^ (b)) & 0xFF] ^ ((crc) >> 8)) |
+ UInt32 MY_FAST_CALL CrcUpdateT1_BeT4(UInt32 v, const void *data, size_t size, const UInt32 *table); |
+ UInt32 MY_FAST_CALL CrcUpdateT1_BeT8(UInt32 v, const void *data, size_t size, const UInt32 *table); |
+#endif |
-static UInt32 MY_FAST_CALL CrcUpdateT1(UInt32 v, const void *data, size_t size, const UInt32 *table) |
-{ |
- const Byte *p = (const Byte *)data; |
- for (; size > 0; size--, p++) |
- v = CRC_UPDATE_BYTE_2(v, *p); |
- return v; |
-} |
+#ifndef MY_CPU_BE |
+ UInt32 MY_FAST_CALL CrcUpdateT4(UInt32 v, const void *data, size_t size, const UInt32 *table); |
+ UInt32 MY_FAST_CALL CrcUpdateT8(UInt32 v, const void *data, size_t size, const UInt32 *table); |
+#endif |
-#else |
+typedef UInt32 (MY_FAST_CALL *CRC_FUNC)(UInt32 v, const void *data, size_t size, const UInt32 *table); |
-UInt32 MY_FAST_CALL CrcUpdateT4(UInt32 v, const void *data, size_t size, const UInt32 *table); |
-UInt32 MY_FAST_CALL CrcUpdateT8(UInt32 v, const void *data, size_t size, const UInt32 *table); |
+CRC_FUNC g_CrcUpdateT4; |
+CRC_FUNC g_CrcUpdateT8; |
+CRC_FUNC g_CrcUpdate; |
-#endif |
+UInt32 g_CrcTable[256 * CRC_NUM_TABLES]; |
UInt32 MY_FAST_CALL CrcUpdate(UInt32 v, const void *data, size_t size) |
{ |
@@ -46,6 +42,17 @@ UInt32 MY_FAST_CALL CrcCalc(const void *data, size_t size) |
return g_CrcUpdate(CRC_INIT_VAL, data, size, g_CrcTable) ^ CRC_INIT_VAL; |
} |
+#define CRC_UPDATE_BYTE_2(crc, b) (table[((crc) ^ (b)) & 0xFF] ^ ((crc) >> 8)) |
+ |
+UInt32 MY_FAST_CALL CrcUpdateT1(UInt32 v, const void *data, size_t size, const UInt32 *table) |
+{ |
+ const Byte *p = (const Byte *)data; |
+ const Byte *pEnd = p + size; |
+ for (; p != pEnd; p++) |
+ v = CRC_UPDATE_BYTE_2(v, *p); |
+ return v; |
+} |
+ |
void MY_FAST_CALL CrcGenerateTable() |
{ |
UInt32 i; |
@@ -57,18 +64,65 @@ void MY_FAST_CALL CrcGenerateTable() |
r = (r >> 1) ^ (kCrcPoly & ~((r & 1) - 1)); |
g_CrcTable[i] = r; |
} |
- #if CRC_NUM_TABLES == 1 |
- g_CrcUpdate = CrcUpdateT1; |
- #else |
for (; i < 256 * CRC_NUM_TABLES; i++) |
{ |
UInt32 r = g_CrcTable[i - 256]; |
g_CrcTable[i] = g_CrcTable[r & 0xFF] ^ (r >> 8); |
} |
- g_CrcUpdate = CrcUpdateT4; |
- #ifdef MY_CPU_X86_OR_AMD64 |
- if (!CPU_Is_InOrder()) |
- g_CrcUpdate = CrcUpdateT8; |
+ |
+ #if CRC_NUM_TABLES < 4 |
+ |
+ g_CrcUpdate = CrcUpdateT1; |
+ |
+ #else |
+ |
+ #ifdef MY_CPU_LE |
+ |
+ g_CrcUpdateT4 = CrcUpdateT4; |
+ g_CrcUpdate = CrcUpdateT4; |
+ |
+ #if CRC_NUM_TABLES >= 8 |
+ g_CrcUpdateT8 = CrcUpdateT8; |
+ |
+ #ifdef MY_CPU_X86_OR_AMD64 |
+ if (!CPU_Is_InOrder()) |
+ g_CrcUpdate = CrcUpdateT8; |
+ #endif |
+ #endif |
+ |
+ #else |
+ { |
+ #ifndef MY_CPU_BE |
+ UInt32 k = 0x01020304; |
+ const Byte *p = (const Byte *)&k; |
+ if (p[0] == 4 && p[1] == 3) |
+ { |
+ g_CrcUpdateT4 = CrcUpdateT4; |
+ g_CrcUpdate = CrcUpdateT4; |
+ #if CRC_NUM_TABLES >= 8 |
+ g_CrcUpdateT8 = CrcUpdateT8; |
+ // g_CrcUpdate = CrcUpdateT8; |
+ #endif |
+ } |
+ else if (p[0] != 1 || p[1] != 2) |
+ g_CrcUpdate = CrcUpdateT1; |
+ else |
+ #endif |
+ { |
+ for (i = 256 * CRC_NUM_TABLES - 1; i >= 256; i--) |
+ { |
+ UInt32 x = g_CrcTable[i - 256]; |
+ g_CrcTable[i] = CRC_UINT32_SWAP(x); |
+ } |
+ g_CrcUpdateT4 = CrcUpdateT1_BeT4; |
+ g_CrcUpdate = CrcUpdateT1_BeT4; |
+ #if CRC_NUM_TABLES >= 8 |
+ g_CrcUpdateT8 = CrcUpdateT1_BeT8; |
+ // g_CrcUpdate = CrcUpdateT1_BeT8; |
+ #endif |
+ } |
+ } |
#endif |
+ |
#endif |
} |