aboutsummaryrefslogtreecommitdiff
path: root/src/hash/crc.c
diff options
context:
space:
mode:
authorame <[email protected]>2024-03-27 13:34:34 -0500
committerame <[email protected]>2024-03-27 13:34:34 -0500
commit57d67eb910aa765df2495df9f625bfc00436014b (patch)
tree11db0e99732c9851c4a2c94f3e318da1cdec7716 /src/hash/crc.c
parentb1f57a05f31a04b6d0dfbdfaf358ce8adfd45dda (diff)
fixed a few hashes
Diffstat (limited to 'src/hash/crc.c')
-rw-r--r--src/hash/crc.c126
1 files changed, 99 insertions, 27 deletions
diff --git a/src/hash/crc.c b/src/hash/crc.c
index 5e4f8d7..7d9c41f 100644
--- a/src/hash/crc.c
+++ b/src/hash/crc.c
@@ -4,60 +4,132 @@
#include <stdio.h>
#include <stdint.h>
-uint32_t i_crc32(uint8_t *data, size_t len){
- uint32_t crc = 0xFFFFFFFF;
+struct crc32_hash crc32_init(){
+ return (struct crc32_hash){.crc = 0xFFFFFFFF};
+}
+void crc32_update(uint8_t* data, size_t len, struct crc32_hash* hash){
for(int i = 0; i < len; i++){
uint32_t extract = data[i];
for(int z = 0; z < 8; z++){
- uint32_t b = (extract^crc)&1;
- crc>>=1;
- if(b) crc^=0xEDB88320;
+ uint32_t b = (extract^hash->crc)&1;
+ hash->crc>>=1;
+ if(b) hash->crc^=0xEDB88320;
extract>>=1;
}
}
- return -(crc+1);
}
-uint16_t i_crc16(uint8_t *aa, size_t len){
- uint16_t crc = 0x0;
-
+uint32_t crc32_final(struct crc32_hash* hash){
+ return -(hash->crc+1);
+}
+
+uint32_t crc32(uint8_t* data, size_t len){
+ struct crc32_hash a = crc32_init();
+ crc32_update(data, len, &a);
+ return crc32_final(&a);
+}
+
+struct crc16_hash crc16_init(){
+ return (struct crc16_hash){.crc = 0x0};
+}
+
+void crc16_update(uint8_t *aa, size_t len, struct crc16_hash *hash){
for(int i = 0; i != len; i++){
uint8_t a = aa[i];
- crc ^= a;
+ hash->crc ^= a;
for (int z = 0; z < 8; z++){
- if (crc & 1) crc = (crc >> 1) ^ 0xA001;
- else crc = (crc >> 1);
+ if (hash->crc & 1) hash->crc = (hash->crc >> 1) ^ 0xA001;
+ else hash->crc = (hash->crc >> 1);
}
}
- return crc;
}
-uint8_t i_crc8(uint8_t *aa, size_t len){
- //crc8 maxim
- uint8_t crc = 0x00;
-
+uint16_t crc16_final(struct crc16_hash *hash){
+ return hash->crc;
+}
+
+uint16_t crc16(uint8_t *aa, size_t len){
+ struct crc16_hash a = crc16_init();
+ crc16_update(aa, len, &a);
+ return crc16_final(&a);
+}
+
+struct crc8_hash crc8_init(){
+ return (struct crc8_hash){.crc = 0x00};
+}
+
+void crc8_update(uint8_t *aa, size_t len, struct crc8_hash *hash){
for(int i = 0; i != len; i++){
uint8_t a = aa[i];
for (int z = 0; z < 8; z++){
- uint8_t b = (crc ^ a) & 1;
- crc >>= 1;
- if(b) crc ^= 0x8c;
+ uint8_t b = (hash->crc ^ a) & 1;
+ hash->crc >>= 1;
+ if(b) hash->crc ^= 0x8c;
a >>=1;
}
}
- return crc;
+}
+
+uint8_t crc8_final(struct crc8_hash *hash){
+ return hash->crc;
+}
+
+uint8_t crc8(uint8_t *aa, size_t len){
+ struct crc8_hash a = crc8_init();
+ crc8_update(aa, len, &a);
+ return crc8_final(&a);
+}
+
+common_hash_init_update(crc32);
+common_hash_init_update(crc16);
+common_hash_init_update(crc8);
+
+int l_crc8_final(lua_State* L){
+ lua_pushstring(L, "ud");
+ lua_gettable(L, 1);
+
+ struct crc8_hash* a = (struct crc8_hash*)lua_touserdata(L, -1);
+ uint32_t u = crc8_final(a);
+ char digest[8];
+ sprintf(digest,"%x",u);
+ lua_pushstring(L, digest);
+ return 1;
+}
+
+int l_crc16_final(lua_State* L){
+ lua_pushstring(L, "ud");
+ lua_gettable(L, 1);
+
+ struct crc16_hash* a = (struct crc16_hash*)lua_touserdata(L, -1);
+ uint32_t u = crc16_final(a);
+ char digest[16];
+ sprintf(digest,"%04x",u);
+ lua_pushstring(L, digest);
+ return 1;
+}
+
+int l_crc32_final(lua_State* L){
+ lua_pushstring(L, "ud");
+ lua_gettable(L, 1);
+
+ struct crc32_hash* a = (struct crc32_hash*)lua_touserdata(L, -1);
+ uint32_t u = crc32_final(a);
+ char digest[8];
+ sprintf(digest,"%08lx",u);
+ lua_pushstring(L, digest);
+ return 1;
}
int l_crc8(lua_State* L){
-
+ if(lua_gettop(L) == 0) return l_crc8_init(L);
size_t len = 0;
uint8_t* a = (uint8_t*)luaL_checklstring(L, 1, &len);
char digest[8];
- uint8_t u = i_crc8(a, len);
+ uint8_t u = crc8(a, len);
sprintf(digest,"%x",u);
lua_pushstring(L, digest);
@@ -65,13 +137,13 @@ int l_crc8(lua_State* L){
}
int l_crc16(lua_State* L){
-
+ if(lua_gettop(L) == 0) return l_crc16_init(L);
size_t len = 0;
uint8_t* a = (uint8_t*)luaL_checklstring(L, 1, &len);
char digest[16];
- uint16_t u = i_crc16(a, len);
+ uint16_t u = crc16(a, len);
sprintf(digest,"%x",u);
lua_pushstring(L, digest);
@@ -79,13 +151,13 @@ int l_crc16(lua_State* L){
}
int l_crc32(lua_State* L){
-
+ if(lua_gettop(L) == 0) return l_crc32_init(L);
size_t len = 0;
uint8_t* a = (uint8_t*)luaL_checklstring(L, 1, &len);
char digest[32];
- uint32_t u = i_crc32(a, len);
+ uint32_t u = crc32(a, len);
sprintf(digest,"%x",u);
lua_pushstring(L, digest);