1
0
mirror of https://github.com/hashcat/hashcat.git synced 2025-01-24 22:50:58 +00:00

Replace md5_complete_no_limit() code with functions from emu_inc_hash_md5.h

This commit is contained in:
jsteube 2019-03-28 09:21:32 +01:00
parent 7806be32c2
commit 9d6d2cb2b8
4 changed files with 39 additions and 237 deletions

View File

@ -47,68 +47,18 @@ const char *module_st_pass (MAYBE_UNUSED const hashconfig_t *hashconfig,
static void md5_complete_no_limit (u32 digest[4], const u32 *plain, const u32 plain_len) static void md5_complete_no_limit (u32 digest[4], const u32 *plain, const u32 plain_len)
{ {
digest[0] = MD5M_A; // plain = u32 tmp_md5_buf[64] so this is compatible
digest[1] = MD5M_B;
digest[2] = MD5M_C;
digest[3] = MD5M_D;
int block_total_len = 16 * 4; // sizeof (block) md5_ctx_t md5_ctx;
u8 *plain_ptr = (u8 *) plain; md5_init (&md5_ctx);
md5_update (&md5_ctx, plain, plain_len);
md5_final (&md5_ctx);
// init digest[0] = md5_ctx.h[0];
digest[1] = md5_ctx.h[1];
int remaining_len = (int) plain_len; digest[2] = md5_ctx.h[2];
digest[3] = md5_ctx.h[3];
// loop
u32 loop = 1;
while (loop)
{
loop = (remaining_len > 55);
int cur_len = MIN (block_total_len, remaining_len);
int copy_len = MAX (cur_len, 0); // should never be negative of course
// initialize the block
u32 block[16] = { 0 };
// copy the bytes from the plain pointer (plain_ptr)
memcpy (block, plain, (size_t) copy_len);
/*
* final block
*/
// set 0x80 if needed
if (cur_len >= 0)
{
if (copy_len < block_total_len)
{
u8 *block_ptr = (u8 *) block;
block_ptr[copy_len] = 0x80;
}
}
// set block[14] set to total_len
if (! loop) block[14] = plain_len * 8;
/*
* md5 ()
*/
md5_transform (block + 0, block + 4, block + 8, block + 12, digest);
remaining_len -= block_total_len;
plain_ptr += 64;
}
} }
static void precompute_salt_md5 (const u32 *salt_buf, const u32 salt_len, u8 *salt_pc) static void precompute_salt_md5 (const u32 *salt_buf, const u32 salt_len, u8 *salt_pc)

View File

@ -49,68 +49,18 @@ const char *module_st_pass (MAYBE_UNUSED const hashconfig_t *hashconfig,
static void md5_complete_no_limit (u32 digest[4], const u32 *plain, const u32 plain_len) static void md5_complete_no_limit (u32 digest[4], const u32 *plain, const u32 plain_len)
{ {
digest[0] = MD5M_A; // plain = u32 tmp_md5_buf[64] so this is compatible
digest[1] = MD5M_B;
digest[2] = MD5M_C;
digest[3] = MD5M_D;
int block_total_len = 16 * 4; // sizeof (block) md5_ctx_t md5_ctx;
u8 *plain_ptr = (u8 *) plain; md5_init (&md5_ctx);
md5_update (&md5_ctx, plain, plain_len);
md5_final (&md5_ctx);
// init digest[0] = md5_ctx.h[0];
digest[1] = md5_ctx.h[1];
int remaining_len = (int) plain_len; digest[2] = md5_ctx.h[2];
digest[3] = md5_ctx.h[3];
// loop
u32 loop = 1;
while (loop)
{
loop = (remaining_len > 55);
int cur_len = MIN (block_total_len, remaining_len);
int copy_len = MAX (cur_len, 0); // should never be negative of course
// initialize the block
u32 block[16] = { 0 };
// copy the bytes from the plain pointer (plain_ptr)
memcpy (block, plain, (size_t) copy_len);
/*
* final block
*/
// set 0x80 if needed
if (cur_len >= 0)
{
if (copy_len < block_total_len)
{
u8 *block_ptr = (u8 *) block;
block_ptr[copy_len] = 0x80;
}
}
// set block[14] set to total_len
if (! loop) block[14] = plain_len * 8;
/*
* md5 ()
*/
md5_transform (block + 0, block + 4, block + 8, block + 12, digest);
remaining_len -= block_total_len;
plain_ptr += 64;
}
} }
static void precompute_salt_md5 (const u32 *salt_buf, const u32 salt_len, u8 *salt_pc) static void precompute_salt_md5 (const u32 *salt_buf, const u32 salt_len, u8 *salt_pc)

View File

@ -74,68 +74,18 @@ static const char *SIGNATURE_PDF = "$pdf$";
static void md5_complete_no_limit (u32 digest[4], const u32 *plain, const u32 plain_len) static void md5_complete_no_limit (u32 digest[4], const u32 *plain, const u32 plain_len)
{ {
digest[0] = MD5M_A; // plain = u32 tmp_md5_buf[64] so this is compatible
digest[1] = MD5M_B;
digest[2] = MD5M_C;
digest[3] = MD5M_D;
int block_total_len = 16 * 4; // sizeof (block) md5_ctx_t md5_ctx;
u8 *plain_ptr = (u8 *) plain; md5_init (&md5_ctx);
md5_update (&md5_ctx, plain, plain_len);
md5_final (&md5_ctx);
// init digest[0] = md5_ctx.h[0];
digest[1] = md5_ctx.h[1];
int remaining_len = (int) plain_len; digest[2] = md5_ctx.h[2];
digest[3] = md5_ctx.h[3];
// loop
u32 loop = 1;
while (loop)
{
loop = (remaining_len > 55);
int cur_len = MIN (block_total_len, remaining_len);
int copy_len = MAX (cur_len, 0); // should never be negative of course
// initialize the block
u32 block[16] = { 0 };
// copy the bytes from the plain pointer (plain_ptr)
memcpy (block, plain, (size_t) copy_len);
/*
* final block
*/
// set 0x80 if needed
if (cur_len >= 0)
{
if (copy_len < block_total_len)
{
u8 *block_ptr = (u8 *) block;
block_ptr[copy_len] = 0x80;
}
}
// set block[14] set to total_len
if (! loop) block[14] = plain_len * 8;
/*
* md5 ()
*/
md5_transform (block + 0, block + 4, block + 8, block + 12, digest);
remaining_len -= block_total_len;
plain_ptr += 64;
}
} }
u64 module_esalt_size (MAYBE_UNUSED const hashconfig_t *hashconfig, MAYBE_UNUSED const user_options_t *user_options, MAYBE_UNUSED const user_options_extra_t *user_options_extra) u64 module_esalt_size (MAYBE_UNUSED const hashconfig_t *hashconfig, MAYBE_UNUSED const user_options_t *user_options, MAYBE_UNUSED const user_options_extra_t *user_options_extra)

View File

@ -57,68 +57,18 @@ static const char *SIGNATURE_SIP_AUTH = "$sip$";
static void md5_complete_no_limit (u32 digest[4], const u32 *plain, const u32 plain_len) static void md5_complete_no_limit (u32 digest[4], const u32 *plain, const u32 plain_len)
{ {
digest[0] = MD5M_A; // plain = u32 tmp_md5_buf[64] so this is compatible
digest[1] = MD5M_B;
digest[2] = MD5M_C;
digest[3] = MD5M_D;
int block_total_len = 16 * 4; // sizeof (block) md5_ctx_t md5_ctx;
u8 *plain_ptr = (u8 *) plain; md5_init (&md5_ctx);
md5_update (&md5_ctx, plain, plain_len);
md5_final (&md5_ctx);
// init digest[0] = md5_ctx.h[0];
digest[1] = md5_ctx.h[1];
int remaining_len = (int) plain_len; digest[2] = md5_ctx.h[2];
digest[3] = md5_ctx.h[3];
// loop
u32 loop = 1;
while (loop)
{
loop = (remaining_len > 55);
int cur_len = MIN (block_total_len, remaining_len);
int copy_len = MAX (cur_len, 0); // should never be negative of course
// initialize the block
u32 block[16] = { 0 };
// copy the bytes from the plain pointer (plain_ptr)
memcpy (block, plain, (size_t) copy_len);
/*
* final block
*/
// set 0x80 if needed
if (cur_len >= 0)
{
if (copy_len < block_total_len)
{
u8 *block_ptr = (u8 *) block;
block_ptr[copy_len] = 0x80;
}
}
// set block[14] set to total_len
if (! loop) block[14] = plain_len * 8;
/*
* md5 ()
*/
md5_transform (block + 0, block + 4, block + 8, block + 12, digest);
remaining_len -= block_total_len;
plain_ptr += 64;
}
} }
u64 module_esalt_size (MAYBE_UNUSED const hashconfig_t *hashconfig, MAYBE_UNUSED const user_options_t *user_options, MAYBE_UNUSED const user_options_extra_t *user_options_extra) u64 module_esalt_size (MAYBE_UNUSED const hashconfig_t *hashconfig, MAYBE_UNUSED const user_options_t *user_options, MAYBE_UNUSED const user_options_extra_t *user_options_extra)
@ -310,7 +260,9 @@ int module_hash_decode (MAYBE_UNUSED const hashconfig_t *hashconfig, MAYBE_UNUSE
hc_strncat (tmp_md5_ptr, pcsep, 1); hc_strncat (tmp_md5_ptr, pcsep, 1);
} }
u32 tmp_digest[4] = { 0 }; memset (tmp_md5_ptr + md5_len, 0, sizeof (tmp_md5_buf) - md5_len);
u32 tmp_digest[4];
md5_complete_no_limit (tmp_digest, tmp_md5_buf, md5_len); md5_complete_no_limit (tmp_digest, tmp_md5_buf, md5_len);