mirror of
https://github.com/radareorg/radare2.git
synced 2025-01-20 20:55:32 +00:00
94 lines
2.4 KiB
C
94 lines
2.4 KiB
C
/* radare - LGPL - Copyright 2009-2016 pancake */
|
|
|
|
#include "r_hash.h"
|
|
|
|
/* TODO: do it more beautiful with structs and not spaguetis */
|
|
R_API int r_hash_calculate(RHash *ctx, ut64 algobit, const ut8 *buf, int len) {
|
|
if (len < 0) {
|
|
return 0;
|
|
}
|
|
if (algobit & R_HASH_MD4) {
|
|
r_hash_do_md4 (ctx, buf, len);
|
|
return R_HASH_SIZE_MD4;
|
|
}
|
|
if (algobit & R_HASH_MD5) {
|
|
r_hash_do_md5 (ctx, buf, len);
|
|
return R_HASH_SIZE_MD5;
|
|
}
|
|
if (algobit & R_HASH_SHA1) {
|
|
r_hash_do_sha1 (ctx, buf, len);
|
|
return R_HASH_SIZE_SHA1;
|
|
}
|
|
if (algobit & R_HASH_SHA256) {
|
|
r_hash_do_sha256 (ctx, buf, len);
|
|
return R_HASH_SIZE_SHA256;
|
|
}
|
|
if (algobit & R_HASH_SHA384) {
|
|
r_hash_do_sha384 (ctx, buf, len);
|
|
return R_HASH_SIZE_SHA384;
|
|
}
|
|
if (algobit & R_HASH_SHA512) {
|
|
r_hash_do_sha512 (ctx, buf, len);
|
|
return R_HASH_SIZE_SHA512;
|
|
}
|
|
if (algobit & R_HASH_CRC16) {
|
|
ut16 res = r_hash_crc16 (0, buf, len);
|
|
ctx->digest[1] = (res) & 0xff;
|
|
ctx->digest[0] = (res >> 8) & 0xff;
|
|
return R_HASH_SIZE_CRC16;
|
|
}
|
|
if (algobit & R_HASH_CRC32) {
|
|
ut32 res = r_hash_crc32 (buf, len);
|
|
ctx->digest[3] = res & 0xff;
|
|
ctx->digest[2] = (res >> 8) & 0xff;
|
|
ctx->digest[1] = (res >> 16) & 0xff;
|
|
ctx->digest[0] = (res >> 24) & 0xff;
|
|
return R_HASH_SIZE_CRC32;
|
|
}
|
|
if (algobit & R_HASH_XXHASH) {
|
|
ut32 res = r_hash_xxhash (buf, len);
|
|
memcpy (ctx->digest, &res, R_HASH_SIZE_XXHASH);
|
|
return R_HASH_SIZE_XXHASH;
|
|
}
|
|
if (algobit & R_HASH_ADLER32) {
|
|
ut32 res = r_hash_adler32 (buf, len);
|
|
memcpy (ctx->digest, &res, R_HASH_SIZE_ADLER32);
|
|
return R_HASH_SIZE_ADLER32;
|
|
}
|
|
if (algobit & R_HASH_HAMDIST) {
|
|
*ctx->digest = r_hash_hamdist (buf, len);
|
|
return R_HASH_SIZE_HAMDIST;
|
|
}
|
|
if (algobit & R_HASH_PCPRINT) {
|
|
*ctx->digest = r_hash_pcprint (buf, len);
|
|
return R_HASH_SIZE_PCPRINT;
|
|
}
|
|
if (algobit & R_HASH_PARITY) {
|
|
*ctx->digest = r_hash_parity (buf, len);
|
|
return R_HASH_SIZE_PARITY;
|
|
}
|
|
if (algobit & R_HASH_ENTROPY) {
|
|
memset (ctx->digest, 0, R_HASH_SIZE_ENTROPY);
|
|
*ctx->digest = (ut8)r_hash_entropy (buf, len);
|
|
return R_HASH_SIZE_ENTROPY;
|
|
}
|
|
if (algobit & R_HASH_XOR) {
|
|
*ctx->digest = r_hash_xor (buf, len);
|
|
return R_HASH_SIZE_XOR;
|
|
}
|
|
if (algobit & R_HASH_XORPAIR) {
|
|
ut16 res = r_hash_xorpair (buf, len);
|
|
memcpy (ctx->digest, &res, 2);
|
|
return R_HASH_SIZE_XORPAIR;
|
|
}
|
|
if (algobit & R_HASH_MOD255) {
|
|
*ctx->digest = r_hash_mod255 (buf, len);
|
|
return R_HASH_SIZE_MOD255;
|
|
}
|
|
if (algobit & R_HASH_LUHN) {
|
|
*ctx->digest = r_hash_luhn (buf, len);
|
|
return R_HASH_SIZE_LUHN;
|
|
}
|
|
return 0;
|
|
}
|