1 /*
2 	DS_CRC32.h is part of DualSenseWindows
3 	https://github.com/Ohjurot/DualSense-Windows
4 
5 	Contributors of this file:
6 	11.2020 Ludwig Füchsl
7 
8 	Licensed under the MIT License (To be found in repository root directory)
9 */
10 module ds5w.dscrc32;
11 
12 class CRC32
13 {
14 private:
15     /// <summary>
16     /// Fast lookup precalculated byte crc hashes
17     /// </summary>
18     const static uint[256] hashTable =
19         [
20             0xd202ef8d, 0xa505df1b, 0x3c0c8ea1, 0x4b0bbe37, 0xd56f2b94, 0xa2681b02,
21             0x3b614ab8, 0x4c667a2e,
22             0xdcd967bf, 0xabde5729, 0x32d70693, 0x45d03605, 0xdbb4a3a6, 0xacb39330,
23             0x35bac28a, 0x42bdf21c,
24             0xcfb5ffe9, 0xb8b2cf7f, 0x21bb9ec5, 0x56bcae53, 0xc8d83bf0, 0xbfdf0b66,
25             0x26d65adc, 0x51d16a4a,
26             0xc16e77db, 0xb669474d, 0x2f6016f7, 0x58672661, 0xc603b3c2, 0xb1048354,
27             0x280dd2ee, 0x5f0ae278,
28             0xe96ccf45, 0x9e6bffd3, 0x762ae69, 0x70659eff, 0xee010b5c, 0x99063bca,
29             0xf6a70, 0x77085ae6,
30             0xe7b74777, 0x90b077e1, 0x9b9265b, 0x7ebe16cd, 0xe0da836e, 0x97ddb3f8,
31             0xed4e242, 0x79d3d2d4,
32             0xf4dbdf21, 0x83dcefb7, 0x1ad5be0d, 0x6dd28e9b, 0xf3b61b38, 0x84b12bae,
33             0x1db87a14, 0x6abf4a82,
34             0xfa005713, 0x8d076785, 0x140e363f, 0x630906a9, 0xfd6d930a, 0x8a6aa39c,
35             0x1363f226, 0x6464c2b0,
36             0xa4deae1d, 0xd3d99e8b, 0x4ad0cf31, 0x3dd7ffa7, 0xa3b36a04, 0xd4b45a92,
37             0x4dbd0b28, 0x3aba3bbe,
38             0xaa05262f, 0xdd0216b9, 0x440b4703, 0x330c7795, 0xad68e236, 0xda6fd2a0,
39             0x4366831a, 0x3461b38c,
40             0xb969be79, 0xce6e8eef, 0x5767df55, 0x2060efc3, 0xbe047a60, 0xc9034af6,
41             0x500a1b4c, 0x270d2bda,
42             0xb7b2364b, 0xc0b506dd, 0x59bc5767, 0x2ebb67f1, 0xb0dff252, 0xc7d8c2c4,
43             0x5ed1937e, 0x29d6a3e8,
44             0x9fb08ed5, 0xe8b7be43, 0x71beeff9, 0x6b9df6f, 0x98dd4acc, 0xefda7a5a,
45             0x76d32be0, 0x1d41b76,
46             0x916b06e7, 0xe66c3671, 0x7f6567cb, 0x862575d, 0x9606c2fe, 0xe101f268,
47             0x7808a3d2, 0xf0f9344,
48             0x82079eb1, 0xf500ae27, 0x6c09ff9d, 0x1b0ecf0b, 0x856a5aa8, 0xf26d6a3e,
49             0x6b643b84, 0x1c630b12,
50             0x8cdc1683, 0xfbdb2615, 0x62d277af, 0x15d54739, 0x8bb1d29a, 0xfcb6e20c,
51             0x65bfb3b6, 0x12b88320,
52             0x3fba6cad, 0x48bd5c3b, 0xd1b40d81, 0xa6b33d17, 0x38d7a8b4, 0x4fd09822,
53             0xd6d9c998, 0xa1def90e,
54             0x3161e49f, 0x4666d409, 0xdf6f85b3, 0xa868b525, 0x360c2086, 0x410b1010,
55             0xd80241aa, 0xaf05713c,
56             0x220d7cc9, 0x550a4c5f, 0xcc031de5, 0xbb042d73, 0x2560b8d0, 0x52678846,
57             0xcb6ed9fc, 0xbc69e96a,
58             0x2cd6f4fb, 0x5bd1c46d, 0xc2d895d7, 0xb5dfa541, 0x2bbb30e2, 0x5cbc0074,
59             0xc5b551ce, 0xb2b26158,
60             0x4d44c65, 0x73d37cf3, 0xeada2d49, 0x9ddd1ddf, 0x3b9887c, 0x74beb8ea,
61             0xedb7e950, 0x9ab0d9c6,
62             0xa0fc457, 0x7d08f4c1, 0xe401a57b, 0x930695ed, 0xd62004e, 0x7a6530d8,
63             0xe36c6162, 0x946b51f4,
64             0x19635c01, 0x6e646c97, 0xf76d3d2d, 0x806a0dbb, 0x1e0e9818, 0x6909a88e,
65             0xf000f934, 0x8707c9a2,
66             0x17b8d433, 0x60bfe4a5, 0xf9b6b51f, 0x8eb18589, 0x10d5102a, 0x67d220bc,
67             0xfedb7106, 0x89dc4190,
68             0x49662d3d, 0x3e611dab, 0xa7684c11, 0xd06f7c87, 0x4e0be924, 0x390cd9b2,
69             0xa0058808, 0xd702b89e,
70             0x47bda50f, 0x30ba9599, 0xa9b3c423, 0xdeb4f4b5, 0x40d06116, 0x37d75180,
71             0xaede003a, 0xd9d930ac,
72             0x54d13d59, 0x23d60dcf, 0xbadf5c75, 0xcdd86ce3, 0x53bcf940, 0x24bbc9d6,
73             0xbdb2986c, 0xcab5a8fa,
74             0x5a0ab56b, 0x2d0d85fd, 0xb404d447, 0xc303e4d1, 0x5d677172, 0x2a6041e4,
75             0xb369105e, 0xc46e20c8,
76             0x72080df5, 0x50f3d63, 0x9c066cd9, 0xeb015c4f, 0x7565c9ec, 0x262f97a,
77             0x9b6ba8c0, 0xec6c9856,
78             0x7cd385c7, 0xbd4b551, 0x92dde4eb, 0xe5dad47d, 0x7bbe41de, 0xcb97148,
79             0x95b020f2, 0xe2b71064,
80             0x6fbf1d91, 0x18b82d07, 0x81b17cbd, 0xf6b64c2b, 0x68d2d988, 0x1fd5e91e,
81             0x86dcb8a4, 0xf1db8832,
82             0x616495a3, 0x1663a535, 0x8f6af48f, 0xf86dc419, 0x660951ba, 0x110e612c,
83             0x88073096, 0xff000000
84         ];
85 
86     /// <summary>
87     /// Start seed for crc hash
88     /// </summary>
89     const static uint crcSeed = 0xeada2d49;
90 
91 public:
92     /// <summary>
93     /// Compute the CRC32 Hash
94     /// </summary>
95     /// <param name="buffer">Input buffer</param>
96     /// <param name="len">Length of buffer</param>
97     /// <returns>Computed crc value</returns>
98     static uint compute(ubyte* buffer, int len)
99     {
100         // Start point
101         uint result = crcSeed;
102 
103         // Foreach element in arrray
104         foreach (i; 0 .. len)
105         {
106             // Compute crc
107             result = hashTable[(cast(ubyte) result) ^ (cast(ubyte) buffer[i])] ^ (result >> 8);
108         }
109 
110         // Return result
111         return result;
112     }
113 }