diff options
author | Rémi Calixte <remicalixte.rmc@gmail.com> | 2021-08-22 15:10:58 +0200 |
---|---|---|
committer | Rémi Calixte <remicalixte.rmc@gmail.com> | 2021-08-22 15:10:58 +0200 |
commit | 23071e67d75ab4a52d68ef4fdecd090215216506 (patch) | |
tree | 49b432bf55bddacbcfb5112668cb69323c22d824 /tools/nitrobanner/crc16.cpp | |
parent | d789398ef7fc5a2955199ac4f87be40b90182405 (diff) | |
parent | d08722a7381c4c05a40ee59bb6de556616e1dfc2 (diff) |
Merge branch 'master' into unk_02006D98
Diffstat (limited to 'tools/nitrobanner/crc16.cpp')
-rw-r--r-- | tools/nitrobanner/crc16.cpp | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/tools/nitrobanner/crc16.cpp b/tools/nitrobanner/crc16.cpp new file mode 100644 index 00000000..bac64b57 --- /dev/null +++ b/tools/nitrobanner/crc16.cpp @@ -0,0 +1,22 @@ +#include <array> +#include "banner.h" +#include "crc16.h" + +u16 CalculateCRC16FromBannerData(const u8* banner_data) { + const std::array<u16, 16> crc_table = { + 0x0000, 0xCC01, 0xD801, 0x1400, + 0xF001, 0x3C00, 0x2800, 0xE401, + 0xA001, 0x6C00, 0x7800, 0xB401, + 0x5000, 0x9C01, 0x8801, 0x4400, + }; + + u16 checksum = 0xFFFF; + + const std::size_t data_size = sizeof(Banner) - offsetof(Banner, bitmap); + for (std::size_t i = 0; i < data_size; i++) { + u16 lookup_index = crc_table[banner_data[i] & 0xF] ^ (checksum >> 4) ^ crc_table[checksum & 0xF]; + checksum = crc_table[banner_data[i] >> 4] ^ (lookup_index >> 4) ^ crc_table[lookup_index & 0xF]; + } + + return checksum; +} |