summaryrefslogtreecommitdiff
path: root/arm9/lib/src
diff options
context:
space:
mode:
authorRevo <projectrevotpp@hotmail.com>2020-05-23 20:24:52 -0400
committerGitHub <noreply@github.com>2020-05-23 20:24:52 -0400
commitb4743f04e30937b19aca974bf2222de8fe3eb36e (patch)
tree9542fdb55f9b183b54ec043aa9f8b2c685bbd7d1 /arm9/lib/src
parenta3e439374e828ca8fa8e8d8c9041d267aa40b1ec (diff)
parent0b01c7d1c57c4e21fdb0069b3ac4f9c7276b3cc1 (diff)
Merge branch 'master' into pikalax_work
Diffstat (limited to 'arm9/lib/src')
-rw-r--r--arm9/lib/src/MATH_crc.c150
-rw-r--r--arm9/lib/src/MATH_dgt.c16
-rw-r--r--arm9/lib/src/MATH_pop.c12
3 files changed, 178 insertions, 0 deletions
diff --git a/arm9/lib/src/MATH_crc.c b/arm9/lib/src/MATH_crc.c
new file mode 100644
index 00000000..ec0ccad0
--- /dev/null
+++ b/arm9/lib/src/MATH_crc.c
@@ -0,0 +1,150 @@
+#include "global.h"
+#include "MATH_crc.h"
+
+ARM_FUNC void MATHi_CRC8InitTable(struct MATHCRC8Table *table, u8 poly) {
+ u32 r, i, j;
+ u8 *t = table->table;
+
+ for (i = 0; i < 256; i++) {
+ r = i;
+ for (j = 0; j < 8; j++) {
+ if (r & 0x80) {
+ r = (r << 1) ^ poly;
+ }
+ else {
+ r <<= 1;
+ }
+ }
+ t[i] = r;
+ }
+}
+
+ARM_FUNC void MATHi_CRC8Update(const struct MATHCRC8Table *table, MATHCRC8Context *context, const void *input, u32 length) {
+ u32 r, i;
+ const u8* t = table->table;
+ u8* data = (u8*)input;
+
+ r = *context;
+ for (i = 0; i < length; i++) {
+ r = t[(r ^ *data) & 0xff];
+ data++;
+ }
+ *context = r;
+}
+
+ARM_FUNC void MATHi_CRC16InitTable(struct MATHCRC16Table *table, u16 poly) {
+ u32 r, i, j;
+ u16 *t = table->table;
+
+ for (i = 0; i < 256; i++) {
+ r = i << 8;
+ for (j = 0; j < 8; j++) {
+ if (r & 0x8000) {
+ r = (r << 1) ^ poly;
+ }
+ else {
+ r <<= 1;
+ }
+ }
+ t[i] = r;
+ }
+}
+
+ARM_FUNC void MATHi_CRC16InitTableRev(struct MATHCRC16Table *table, u16 poly) {
+ u32 r, i, j;
+ u16 *t = table->table;
+
+ for (i = 0; i < 256; i++) {
+ r = i;
+ for (j = 0; j < 8; j++) {
+ if (r & 1) {
+ r = (r >> 1) ^ poly;
+ }
+ else {
+ r >>= 1;
+ }
+ }
+ t[i] = r;
+ }
+}
+
+ARM_FUNC void MATHi_CRC16Update(const struct MATHCRC16Table *table, MATHCRC16Context *context, const void *input, u32 length) {
+ u32 r, i;
+ const u16* t = table->table;
+ u8* data = (u8*)input;
+
+ r = *context;
+ for (i = 0; i < length; i++) {
+ r = (r << 8) ^ t[((r >> 8) ^ *data) & 0xff];
+ data++;
+ }
+ *context = r;
+}
+
+ARM_FUNC void MATHi_CRC16UpdateRev(const struct MATHCRC16Table *table, MATHCRC16Context *context, const void *input, u32 length) {
+ u32 r, i;
+ const u16* t = table->table;
+ u8* data = (u8*)input;
+
+ r = *context;
+ for (i = 0; i < length; i++) {
+ r = (r >> 8) ^ t[(r ^ *data) & 0xff];
+ data++;
+ }
+ *context = r;
+}
+
+ARM_FUNC void MATHi_CRC32InitTableRev(struct MATHCRC32Table *table, u32 poly) {
+ u32 r, i, j;
+ u32 *t = table->table;
+
+ for (i = 0; i < 256; i++) {
+ r = i;
+ for (j = 0; j < 8; j++) {
+ if (r & 1) {
+ r = (r >> 1) ^ poly;
+ }
+ else {
+ r >>= 1;
+ }
+ }
+ t[i] = r;
+ }
+}
+
+ARM_FUNC void MATHi_CRC32UpdateRev(const struct MATHCRC32Table *table, MATHCRC32Context *context, const void *input, u32 length) {
+ u32 r, i;
+ const u32* t = table->table;
+ u8* data = (u8*)input;
+
+ r = *context;
+ for (i = 0; i < length; i++) {
+ r = (r >> 8) ^ t[(r ^ *data) & 0xff];
+ data++;
+ }
+ *context = r;
+}
+
+ARM_FUNC u8 MATH_CalcCRC8(const struct MATHCRC8Table *table, const void *data, u32 dataLength) {
+ MATHCRC8Context ctx = 0;
+ MATHi_CRC8Update(table, &ctx, data, dataLength);
+ return ctx;
+}
+
+ARM_FUNC u16 MATH_CalcCRC16(const struct MATHCRC16Table *table, const void *data, u32 dataLength) {
+ MATHCRC16Context ctx = 0;
+ MATHi_CRC16UpdateRev(table, &ctx, data, dataLength);
+ return ctx;
+}
+
+ARM_FUNC u16 MATH_CalcCRC16CCITT(const struct MATHCRC16Table *table, const void *data, u32 dataLength) {
+ MATHCRC16Context ctx = 0xffff;
+ MATHi_CRC16Update(table, &ctx, data, dataLength);
+ return ctx;
+}
+
+ARM_FUNC u32 MATH_CalcCRC32(const struct MATHCRC32Table *table, const void *data, u32 dataLength) {
+ MATHCRC32Context ctx = ~0;
+ MATHi_CRC32UpdateRev(table, &ctx, data, dataLength);
+ return ~ctx;
+}
diff --git a/arm9/lib/src/MATH_dgt.c b/arm9/lib/src/MATH_dgt.c
new file mode 100644
index 00000000..6bb90d99
--- /dev/null
+++ b/arm9/lib/src/MATH_dgt.c
@@ -0,0 +1,16 @@
+#include "global.h"
+#include "MATH_dgt.h"
+
+ARM_FUNC void MATH_CalcMD5(void *digest, const void *data, u32 dataLength) {
+ MATHMD5Context context;
+ MATH_MD5Init(&context);
+ MATH_MD5Update(&context, data, dataLength);
+ MATH_MD5GetHash(&context, digest);
+}
+
+ARM_FUNC void MATH_CalcSHA1(void *digest, const void *data, u32 dataLength) {
+ MATHSHA1Context context;
+ MATH_SHA1Init(&context);
+ MATH_SHA1Update(&context, data, dataLength);
+ MATH_SHA1GetHash(&context, digest);
+}
diff --git a/arm9/lib/src/MATH_pop.c b/arm9/lib/src/MATH_pop.c
new file mode 100644
index 00000000..18582494
--- /dev/null
+++ b/arm9/lib/src/MATH_pop.c
@@ -0,0 +1,12 @@
+#include "global.h"
+#include "MATH_pop.h"
+
+ARM_FUNC u8 MATH_CountPopulation(u32 x) {
+ x -= (x >> 1) & 0x55555555;
+ x = (x & 0x33333333) + ((x >> 2) & 0x33333333);
+ x += x >> 4;
+ x &= 0x0f0f0f0f;
+ x += x >> 8;
+ x += x >> 16;
+ return (u8)x;
+}