radare2/libr/hash/hash.c
pancake 3b8c1e1b32 * Add support for incremental hashing in rahash2
- Enables working with huge files
  - Use -B to per-block-hash
* Initial dummy for 'ax' command
* Add 'pdb' command
2011-09-27 10:27:13 +02:00

127 lines
3.3 KiB
C

/* radare - LGPL - Copyright 2007-2011 pancake<@nopcode.org> */
#include "r_hash.h"
/* returns 0-100 */
R_API int r_hash_pcprint(const ut8 *buffer, ut64 len) {
const ut8 *end = buffer + len;
int n;
for (n=0; buffer<end; buffer++)
if (IS_PRINTABLE (*buffer))
n++;
return ((100*n)/len);
}
R_API int r_hash_parity(const ut8 *buf, ut64 len) {
const ut8 *end = buf+len;
ut32 ones = 0;
for (;buf<end;buf++) {
ut8 x = buf[0];
ones += ((x&128)?1:0) + ((x&64)?1:0) + ((x&32)?1:0) + ((x&16)?1:0) +
((x&8)?1:0) + ((x&4)?1:0) + ((x&2)?1:0) + ((x&1)?1:0);
}
return ones%2;
}
/* These functions comes from 0xFFFF */
/* fmi: nopcode.org/0xFFFF */
R_API ut16 r_hash_xorpair(const ut8 *a, ut64 len) {
ut16 *b = (ut16 *)a;
ut16 result = 0;
for (len>>=1; len--; b++)
result ^= *b;
return result;
}
R_API ut8 r_hash_xor(const ut8 *b, ut64 len) {
ut8 res = 0;
for (; len--; b++)
res ^= *b;
return res;
}
R_API ut8 r_hash_mod255(const ut8 *b, ut64 len) {
int i, c = 0;
/* from gdb */
for (i = 0; i < len; i++)
c += b[i];
return c%255;
}
R_API ut8 r_hash_deviation(const ut8 *b, ut64 len) {
int i, c;
for (c = i = 0, --len; i < len; i++)
c += R_ABS (b[i+1] - b[i]);
return c;
}
/* TODO: rewrite in a non-spaguetty way */
R_API const char *r_hash_name(int bit) {
if (bit & R_HASH_MD4) return "md4";
if (bit & R_HASH_MD5) return "md5";
if (bit & R_HASH_SHA1) return "sha1";
if (bit & R_HASH_SHA256) return "sha256";
if (bit & R_HASH_SHA384) return "sha384";
if (bit & R_HASH_SHA512) return "sha512";
if (bit & R_HASH_PARITY) return "parity";
if (bit & R_HASH_ENTROPY) return "entropy";
if (bit & R_HASH_XOR) return "xor";
if (bit & R_HASH_XORPAIR) return "xorpair";
if (bit & R_HASH_MOD255) return "mod255";
if (bit & R_HASH_PCPRINT) return "pcprint";
return "";
}
R_API int r_hash_size(int bit) {
if (bit & R_HASH_MD4) return R_HASH_SIZE_MD4;
if (bit & R_HASH_MD5) return R_HASH_SIZE_MD5;
if (bit & R_HASH_SHA1) return R_HASH_SIZE_SHA1;
if (bit & R_HASH_SHA256) return 0;
if (bit & R_HASH_SHA384) return 0;
if (bit & R_HASH_SHA512) return 0;
if (bit & R_HASH_PARITY) return 1;
if (bit & R_HASH_ENTROPY) return 0;
if (bit & R_HASH_XOR) return 1;
if (bit & R_HASH_XORPAIR) return 1;
if (bit & R_HASH_MOD255) return 1;
if (bit & R_HASH_PCPRINT) return 1;
return "";
}
/* TODO: ignore case.. we have to use strcasestr */
R_API ut64 r_hash_name_to_bits(const char *name) {
ut64 bits = R_HASH_NONE;
if (strstr (name, "all"))
return 0xffffffff;
if (strstr (name, "md4"))
bits |= R_HASH_MD4;
if (strstr (name, "md5"))
bits |= R_HASH_MD5;
if (strstr (name, "sha1"))
bits |= R_HASH_SHA1;
if (strstr (name, "sha256"))
bits |= R_HASH_SHA256;
if (strstr (name, "sha384"))
bits |= R_HASH_SHA384;
if (strstr (name, "sha512"))
bits |= R_HASH_SHA512;
if (strstr (name, "crc16"))
bits |= R_HASH_CRC16;
if (strstr (name, "crc32"))
bits |= R_HASH_CRC32;
if (strstr (name, "xorpair"))
bits |= R_HASH_XORPAIR;
else if (strstr (name, "xor")) /* XXX: hacky elsif solution */
bits |= R_HASH_XOR;
if (strstr (name, "parity"))
bits |= R_HASH_PARITY;
if (strstr (name, "entropy"))
bits |= R_HASH_ENTROPY;
if (strstr (name, "hamdist"))
bits |= R_HASH_HAMDIST;
if (strstr (name, "pcprint"))
bits |= R_HASH_PCPRINT;
if (strstr (name, "mod255"))
bits |= R_HASH_MOD255;
return bits;
}