From 6e22a6dfa5e28fdbba035a7517a6e5b8f759ba31 Mon Sep 17 00:00:00 2001 From: Jeroen van Rijn Date: Tue, 21 Sep 2021 16:28:35 +0200 Subject: [PATCH] hash: Smaller CRC-64 ISO 3306 table. --- core/hash/crc.odin | 132 ++++++++++++++-------------- tests/core/hash/test_core_hash.odin | 8 +- 2 files changed, 70 insertions(+), 70 deletions(-) diff --git a/core/hash/crc.odin b/core/hash/crc.odin index 54bd9c2de..b504e92fb 100644 --- a/core/hash/crc.odin +++ b/core/hash/crc.odin @@ -65,7 +65,7 @@ crc64_iso_3306 :: proc(data: []byte, seed := u64(0)) -> u64 #no_bounds_check { tmp_1l := (low >> 8) | shr index := (low ~ u64(b)) & 0xFF - result = (tmp_1h << 32 | tmp_1l) ~ _crc64_table_iso_3306[index] + result = (tmp_1h << 32 | tmp_1l) ~ (u64(_crc64_table_iso_3306[index]) << 48) } return result } @@ -673,69 +673,69 @@ crc64_iso_3306_inverse :: proc(data: []byte, seed := u64(0)) -> u64 { }, } -@private _crc64_table_iso_3306 := [256]u64{ - 0x0000000000000000, 0x01b0000000000000, 0x0360000000000000, 0x02d0000000000000, - 0x06c0000000000000, 0x0770000000000000, 0x05a0000000000000, 0x0410000000000000, - 0x0d80000000000000, 0x0c30000000000000, 0x0ee0000000000000, 0x0f50000000000000, - 0x0b40000000000000, 0x0af0000000000000, 0x0820000000000000, 0x0990000000000000, - 0x1b00000000000000, 0x1ab0000000000000, 0x1860000000000000, 0x19d0000000000000, - 0x1dc0000000000000, 0x1c70000000000000, 0x1ea0000000000000, 0x1f10000000000000, - 0x1680000000000000, 0x1730000000000000, 0x15e0000000000000, 0x1450000000000000, - 0x1040000000000000, 0x11f0000000000000, 0x1320000000000000, 0x1290000000000000, - 0x3600000000000000, 0x37b0000000000000, 0x3560000000000000, 0x34d0000000000000, - 0x30c0000000000000, 0x3170000000000000, 0x33a0000000000000, 0x3210000000000000, - 0x3b80000000000000, 0x3a30000000000000, 0x38e0000000000000, 0x3950000000000000, - 0x3d40000000000000, 0x3cf0000000000000, 0x3e20000000000000, 0x3f90000000000000, - 0x2d00000000000000, 0x2cb0000000000000, 0x2e60000000000000, 0x2fd0000000000000, - 0x2bc0000000000000, 0x2a70000000000000, 0x28a0000000000000, 0x2910000000000000, - 0x2080000000000000, 0x2130000000000000, 0x23e0000000000000, 0x2250000000000000, - 0x2640000000000000, 0x27f0000000000000, 0x2520000000000000, 0x2490000000000000, - 0x6c00000000000000, 0x6db0000000000000, 0x6f60000000000000, 0x6ed0000000000000, - 0x6ac0000000000000, 0x6b70000000000000, 0x69a0000000000000, 0x6810000000000000, - 0x6180000000000000, 0x6030000000000000, 0x62e0000000000000, 0x6350000000000000, - 0x6740000000000000, 0x66f0000000000000, 0x6420000000000000, 0x6590000000000000, - 0x7700000000000000, 0x76b0000000000000, 0x7460000000000000, 0x75d0000000000000, - 0x71c0000000000000, 0x7070000000000000, 0x72a0000000000000, 0x7310000000000000, - 0x7a80000000000000, 0x7b30000000000000, 0x79e0000000000000, 0x7850000000000000, - 0x7c40000000000000, 0x7df0000000000000, 0x7f20000000000000, 0x7e90000000000000, - 0x5a00000000000000, 0x5bb0000000000000, 0x5960000000000000, 0x58d0000000000000, - 0x5cc0000000000000, 0x5d70000000000000, 0x5fa0000000000000, 0x5e10000000000000, - 0x5780000000000000, 0x5630000000000000, 0x54e0000000000000, 0x5550000000000000, - 0x5140000000000000, 0x50f0000000000000, 0x5220000000000000, 0x5390000000000000, - 0x4100000000000000, 0x40b0000000000000, 0x4260000000000000, 0x43d0000000000000, - 0x47c0000000000000, 0x4670000000000000, 0x44a0000000000000, 0x4510000000000000, - 0x4c80000000000000, 0x4d30000000000000, 0x4fe0000000000000, 0x4e50000000000000, - 0x4a40000000000000, 0x4bf0000000000000, 0x4920000000000000, 0x4890000000000000, - 0xd800000000000000, 0xd9b0000000000000, 0xdb60000000000000, 0xdad0000000000000, - 0xdec0000000000000, 0xdf70000000000000, 0xdda0000000000000, 0xdc10000000000000, - 0xd580000000000000, 0xd430000000000000, 0xd6e0000000000000, 0xd750000000000000, - 0xd340000000000000, 0xd2f0000000000000, 0xd020000000000000, 0xd190000000000000, - 0xc300000000000000, 0xc2b0000000000000, 0xc060000000000000, 0xc1d0000000000000, - 0xc5c0000000000000, 0xc470000000000000, 0xc6a0000000000000, 0xc710000000000000, - 0xce80000000000000, 0xcf30000000000000, 0xcde0000000000000, 0xcc50000000000000, - 0xc840000000000000, 0xc9f0000000000000, 0xcb20000000000000, 0xca90000000000000, - 0xee00000000000000, 0xefb0000000000000, 0xed60000000000000, 0xecd0000000000000, - 0xe8c0000000000000, 0xe970000000000000, 0xeba0000000000000, 0xea10000000000000, - 0xe380000000000000, 0xe230000000000000, 0xe0e0000000000000, 0xe150000000000000, - 0xe540000000000000, 0xe4f0000000000000, 0xe620000000000000, 0xe790000000000000, - 0xf500000000000000, 0xf4b0000000000000, 0xf660000000000000, 0xf7d0000000000000, - 0xf3c0000000000000, 0xf270000000000000, 0xf0a0000000000000, 0xf110000000000000, - 0xf880000000000000, 0xf930000000000000, 0xfbe0000000000000, 0xfa50000000000000, - 0xfe40000000000000, 0xfff0000000000000, 0xfd20000000000000, 0xfc90000000000000, - 0xb400000000000000, 0xb5b0000000000000, 0xb760000000000000, 0xb6d0000000000000, - 0xb2c0000000000000, 0xb370000000000000, 0xb1a0000000000000, 0xb010000000000000, - 0xb980000000000000, 0xb830000000000000, 0xbae0000000000000, 0xbb50000000000000, - 0xbf40000000000000, 0xbef0000000000000, 0xbc20000000000000, 0xbd90000000000000, - 0xaf00000000000000, 0xaeb0000000000000, 0xac60000000000000, 0xadd0000000000000, - 0xa9c0000000000000, 0xa870000000000000, 0xaaa0000000000000, 0xab10000000000000, - 0xa280000000000000, 0xa330000000000000, 0xa1e0000000000000, 0xa050000000000000, - 0xa440000000000000, 0xa5f0000000000000, 0xa720000000000000, 0xa690000000000000, - 0x8200000000000000, 0x83b0000000000000, 0x8160000000000000, 0x80d0000000000000, - 0x84c0000000000000, 0x8570000000000000, 0x87a0000000000000, 0x8610000000000000, - 0x8f80000000000000, 0x8e30000000000000, 0x8ce0000000000000, 0x8d50000000000000, - 0x8940000000000000, 0x88f0000000000000, 0x8a20000000000000, 0x8b90000000000000, - 0x9900000000000000, 0x98b0000000000000, 0x9a60000000000000, 0x9bd0000000000000, - 0x9fc0000000000000, 0x9e70000000000000, 0x9ca0000000000000, 0x9d10000000000000, - 0x9480000000000000, 0x9530000000000000, 0x97e0000000000000, 0x9650000000000000, - 0x9240000000000000, 0x93f0000000000000, 0x9120000000000000, 0x9090000000000000, +@private _crc64_table_iso_3306 := [256]u16{ + 0x0000, 0x01b0, 0x0360, 0x02d0, + 0x06c0, 0x0770, 0x05a0, 0x0410, + 0x0d80, 0x0c30, 0x0ee0, 0x0f50, + 0x0b40, 0x0af0, 0x0820, 0x0990, + 0x1b00, 0x1ab0, 0x1860, 0x19d0, + 0x1dc0, 0x1c70, 0x1ea0, 0x1f10, + 0x1680, 0x1730, 0x15e0, 0x1450, + 0x1040, 0x11f0, 0x1320, 0x1290, + 0x3600, 0x37b0, 0x3560, 0x34d0, + 0x30c0, 0x3170, 0x33a0, 0x3210, + 0x3b80, 0x3a30, 0x38e0, 0x3950, + 0x3d40, 0x3cf0, 0x3e20, 0x3f90, + 0x2d00, 0x2cb0, 0x2e60, 0x2fd0, + 0x2bc0, 0x2a70, 0x28a0, 0x2910, + 0x2080, 0x2130, 0x23e0, 0x2250, + 0x2640, 0x27f0, 0x2520, 0x2490, + 0x6c00, 0x6db0, 0x6f60, 0x6ed0, + 0x6ac0, 0x6b70, 0x69a0, 0x6810, + 0x6180, 0x6030, 0x62e0, 0x6350, + 0x6740, 0x66f0, 0x6420, 0x6590, + 0x7700, 0x76b0, 0x7460, 0x75d0, + 0x71c0, 0x7070, 0x72a0, 0x7310, + 0x7a80, 0x7b30, 0x79e0, 0x7850, + 0x7c40, 0x7df0, 0x7f20, 0x7e90, + 0x5a00, 0x5bb0, 0x5960, 0x58d0, + 0x5cc0, 0x5d70, 0x5fa0, 0x5e10, + 0x5780, 0x5630, 0x54e0, 0x5550, + 0x5140, 0x50f0, 0x5220, 0x5390, + 0x4100, 0x40b0, 0x4260, 0x43d0, + 0x47c0, 0x4670, 0x44a0, 0x4510, + 0x4c80, 0x4d30, 0x4fe0, 0x4e50, + 0x4a40, 0x4bf0, 0x4920, 0x4890, + 0xd800, 0xd9b0, 0xdb60, 0xdad0, + 0xdec0, 0xdf70, 0xdda0, 0xdc10, + 0xd580, 0xd430, 0xd6e0, 0xd750, + 0xd340, 0xd2f0, 0xd020, 0xd190, + 0xc300, 0xc2b0, 0xc060, 0xc1d0, + 0xc5c0, 0xc470, 0xc6a0, 0xc710, + 0xce80, 0xcf30, 0xcde0, 0xcc50, + 0xc840, 0xc9f0, 0xcb20, 0xca90, + 0xee00, 0xefb0, 0xed60, 0xecd0, + 0xe8c0, 0xe970, 0xeba0, 0xea10, + 0xe380, 0xe230, 0xe0e0, 0xe150, + 0xe540, 0xe4f0, 0xe620, 0xe790, + 0xf500, 0xf4b0, 0xf660, 0xf7d0, + 0xf3c0, 0xf270, 0xf0a0, 0xf110, + 0xf880, 0xf930, 0xfbe0, 0xfa50, + 0xfe40, 0xfff0, 0xfd20, 0xfc90, + 0xb400, 0xb5b0, 0xb760, 0xb6d0, + 0xb2c0, 0xb370, 0xb1a0, 0xb010, + 0xb980, 0xb830, 0xbae0, 0xbb50, + 0xbf40, 0xbef0, 0xbc20, 0xbd90, + 0xaf00, 0xaeb0, 0xac60, 0xadd0, + 0xa9c0, 0xa870, 0xaaa0, 0xab10, + 0xa280, 0xa330, 0xa1e0, 0xa050, + 0xa440, 0xa5f0, 0xa720, 0xa690, + 0x8200, 0x83b0, 0x8160, 0x80d0, + 0x84c0, 0x8570, 0x87a0, 0x8610, + 0x8f80, 0x8e30, 0x8ce0, 0x8d50, + 0x8940, 0x88f0, 0x8a20, 0x8b90, + 0x9900, 0x98b0, 0x9a60, 0x9bd0, + 0x9fc0, 0x9e70, 0x9ca0, 0x9d10, + 0x9480, 0x9530, 0x97e0, 0x9650, + 0x9240, 0x93f0, 0x9120, 0x9090, } \ No newline at end of file diff --git a/tests/core/hash/test_core_hash.odin b/tests/core/hash/test_core_hash.odin index 0102bdb08..8baa604b6 100644 --- a/tests/core/hash/test_core_hash.odin +++ b/tests/core/hash/test_core_hash.odin @@ -284,10 +284,10 @@ test_crc64_vectors :: proc(t: ^testing.T) { iso := hash.crc64_iso_3306(b) iso2 := hash.crc64_iso_3306_inverse(b) - ecma_error := fmt.tprintf("[ CRC-64 ECMA ] Expected: %016x. Got: %016x.", ecma, expected[0]) - xz_error := fmt.tprintf("[ CRC-64 XZ ] Expected: %016x. Got: %016x.", xz, expected[1]) - iso_error := fmt.tprintf("[ CRC-64 ISO 3306] Expected: %016x. Got: %016x.", iso, expected[2]) - iso2_error := fmt.tprintf("[~CRC-64 ISO 3306] Expected: %016x. Got: %016x.", iso2, expected[3]) + ecma_error := fmt.tprintf("[ CRC-64 ECMA ] Expected: %016x. Got: %016x.", expected[0], ecma) + xz_error := fmt.tprintf("[ CRC-64 XZ ] Expected: %016x. Got: %016x.", expected[1], xz) + iso_error := fmt.tprintf("[ CRC-64 ISO 3306] Expected: %016x. Got: %016x.", expected[2], iso) + iso2_error := fmt.tprintf("[~CRC-64 ISO 3306] Expected: %016x. Got: %016x.", expected[3], iso2) expect(t, ecma == expected[0], ecma_error) expect(t, xz == expected[1], xz_error)