summaryrefslogtreecommitdiff
path: root/tools/nitrobanner/crc16.cpp
diff options
context:
space:
mode:
authorRémi Calixte <remicalixte.rmc@gmail.com>2021-08-22 15:10:58 +0200
committerRémi Calixte <remicalixte.rmc@gmail.com>2021-08-22 15:10:58 +0200
commit23071e67d75ab4a52d68ef4fdecd090215216506 (patch)
tree49b432bf55bddacbcfb5112668cb69323c22d824 /tools/nitrobanner/crc16.cpp
parentd789398ef7fc5a2955199ac4f87be40b90182405 (diff)
parentd08722a7381c4c05a40ee59bb6de556616e1dfc2 (diff)
Merge branch 'master' into unk_02006D98
Diffstat (limited to 'tools/nitrobanner/crc16.cpp')
-rw-r--r--tools/nitrobanner/crc16.cpp22
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;
+}