diff options
author | PikalaxALT <pikalaxalt@gmail.com> | 2021-08-22 08:17:16 -0400 |
---|---|---|
committer | PikalaxALT <pikalaxalt@gmail.com> | 2021-08-22 08:17:16 -0400 |
commit | a1016647f68e2f9a1be452240204d34874f89338 (patch) | |
tree | 662f2acf2b558e676d2524c1689ffd09318ba82f /tools/nitrobanner/crc16.cpp | |
parent | 6a0b937064907c1790447f7ddd0c60e66e49cd70 (diff) | |
parent | d08722a7381c4c05a40ee59bb6de556616e1dfc2 (diff) |
Merge remote-tracking branch 'origin/master' into pikalax_work
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; +} |