mirror of
https://github.com/hashcat/hashcat.git
synced 2025-01-18 11:40:58 +00:00
Fix some bugs related to -a0, all caused by the same pitfall
This commit is contained in:
parent
737678284f
commit
b6f10a2a81
@ -113,13 +113,15 @@ __kernel void m04700_m04 (__global pw_t *pws, __global kernel_rule_t *rules_buf,
|
|||||||
|
|
||||||
w3[0] = 0;
|
w3[0] = 0;
|
||||||
w3[1] = 0;
|
w3[1] = 0;
|
||||||
w3[2] = pw_len * 8;
|
w3[2] = 0;
|
||||||
w3[3] = 0;
|
w3[3] = 0;
|
||||||
|
|
||||||
const u32 out_len = apply_rules (rules_buf[il_pos].cmds, w0, w1, pw_len);
|
const u32 out_len = apply_rules (rules_buf[il_pos].cmds, w0, w1, pw_len);
|
||||||
|
|
||||||
append_0x80_2x4 (w0, w1, out_len);
|
append_0x80_2x4 (w0, w1, out_len);
|
||||||
|
|
||||||
|
w3[2] = out_len * 8;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* md5
|
* md5
|
||||||
*/
|
*/
|
||||||
@ -451,13 +453,15 @@ __kernel void m04700_s04 (__global pw_t *pws, __global kernel_rule_t *rules_buf,
|
|||||||
|
|
||||||
w3[0] = 0;
|
w3[0] = 0;
|
||||||
w3[1] = 0;
|
w3[1] = 0;
|
||||||
w3[2] = pw_len * 8;
|
w3[2] = 0;
|
||||||
w3[3] = 0;
|
w3[3] = 0;
|
||||||
|
|
||||||
const u32 out_len = apply_rules (rules_buf[il_pos].cmds, w0, w1, pw_len);
|
const u32 out_len = apply_rules (rules_buf[il_pos].cmds, w0, w1, pw_len);
|
||||||
|
|
||||||
append_0x80_2x4 (w0, w1, out_len);
|
append_0x80_2x4 (w0, w1, out_len);
|
||||||
|
|
||||||
|
w3[2] = out_len * 8;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* md5
|
* md5
|
||||||
*/
|
*/
|
||||||
|
@ -846,7 +846,7 @@ __kernel void m06900_m04 (__global pw_t *pws, __global kernel_rule_t * rules_bu
|
|||||||
|
|
||||||
u32 tmp[8];
|
u32 tmp[8];
|
||||||
|
|
||||||
if (pw_len > 0)
|
if (out_len > 0)
|
||||||
{
|
{
|
||||||
PASS0 (state, tmp, state_m, data_m, s_tables);
|
PASS0 (state, tmp, state_m, data_m, s_tables);
|
||||||
PASS2 (state, tmp, state_m, data_m, s_tables);
|
PASS2 (state, tmp, state_m, data_m, s_tables);
|
||||||
@ -1106,7 +1106,7 @@ __kernel void m06900_s04 (__global pw_t *pws, __global kernel_rule_t * rules_bu
|
|||||||
|
|
||||||
u32 tmp[8];
|
u32 tmp[8];
|
||||||
|
|
||||||
if (pw_len > 0)
|
if (out_len > 0)
|
||||||
{
|
{
|
||||||
PASS0 (state, tmp, state_m, data_m, s_tables);
|
PASS0 (state, tmp, state_m, data_m, s_tables);
|
||||||
PASS2 (state, tmp, state_m, data_m, s_tables);
|
PASS2 (state, tmp, state_m, data_m, s_tables);
|
||||||
|
@ -174,7 +174,7 @@ __kernel void m07600_m04 (__global pw_t *pws, __global kernel_rule_t *rules_buf,
|
|||||||
u32 wc_t = swap32 (w3[0]);
|
u32 wc_t = swap32 (w3[0]);
|
||||||
u32 wd_t = swap32 (w3[1]);
|
u32 wd_t = swap32 (w3[1]);
|
||||||
u32 we_t = 0;
|
u32 we_t = 0;
|
||||||
u32 wf_t = pw_len * 8;
|
u32 wf_t = out_len * 8;
|
||||||
|
|
||||||
u32 a = SHA1M_A;
|
u32 a = SHA1M_A;
|
||||||
u32 b = SHA1M_B;
|
u32 b = SHA1M_B;
|
||||||
@ -769,7 +769,7 @@ __kernel void m07600_s04 (__global pw_t *pws, __global kernel_rule_t *rules_buf,
|
|||||||
u32 wc_t = swap32 (w3[0]);
|
u32 wc_t = swap32 (w3[0]);
|
||||||
u32 wd_t = swap32 (w3[1]);
|
u32 wd_t = swap32 (w3[1]);
|
||||||
u32 we_t = 0;
|
u32 we_t = 0;
|
||||||
u32 wf_t = pw_len * 8;
|
u32 wf_t = out_len * 8;
|
||||||
|
|
||||||
u32 a = SHA1M_A;
|
u32 a = SHA1M_A;
|
||||||
u32 b = SHA1M_B;
|
u32 b = SHA1M_B;
|
||||||
|
@ -280,7 +280,7 @@ __kernel void m08300_m04 (__global pw_t *pws, __global kernel_rule_t *rules_buf,
|
|||||||
|
|
||||||
switch_buffer_by_offset_le (w0_t, w1_t, w2_t, w3_t, 1);
|
switch_buffer_by_offset_le (w0_t, w1_t, w2_t, w3_t, 1);
|
||||||
|
|
||||||
w0_t[0] |= pw_len & 0xff;
|
w0_t[0] |= out_len & 0xff;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* salt
|
* salt
|
||||||
@ -588,7 +588,7 @@ __kernel void m08300_s04 (__global pw_t *pws, __global kernel_rule_t *rules_buf,
|
|||||||
|
|
||||||
switch_buffer_by_offset_le (w0_t, w1_t, w2_t, w3_t, 1);
|
switch_buffer_by_offset_le (w0_t, w1_t, w2_t, w3_t, 1);
|
||||||
|
|
||||||
w0_t[0] |= pw_len & 0xff;
|
w0_t[0] |= out_len & 0xff;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* salt
|
* salt
|
||||||
|
@ -300,7 +300,7 @@ __kernel void m08400_m04 (__global pw_t *pws, __global kernel_rule_t *rules_buf,
|
|||||||
w3_t[0] = swap32 (w3[0]);
|
w3_t[0] = swap32 (w3[0]);
|
||||||
w3_t[1] = swap32 (w3[1]);
|
w3_t[1] = swap32 (w3[1]);
|
||||||
w3_t[2] = 0;
|
w3_t[2] = 0;
|
||||||
w3_t[3] = pw_len * 8;
|
w3_t[3] = out_len * 8;
|
||||||
|
|
||||||
u32 digest[5];
|
u32 digest[5];
|
||||||
|
|
||||||
@ -607,7 +607,7 @@ __kernel void m08400_s04 (__global pw_t *pws, __global kernel_rule_t *rules_buf,
|
|||||||
w3_t[0] = swap32 (w3[0]);
|
w3_t[0] = swap32 (w3[0]);
|
||||||
w3_t[1] = swap32 (w3[1]);
|
w3_t[1] = swap32 (w3[1]);
|
||||||
w3_t[2] = 0;
|
w3_t[2] = 0;
|
||||||
w3_t[3] = pw_len * 8;
|
w3_t[3] = out_len * 8;
|
||||||
|
|
||||||
u32 digest[5];
|
u32 digest[5];
|
||||||
|
|
||||||
|
@ -345,24 +345,24 @@ __kernel void m08600_m04 (__global pw_t *pws, __global kernel_rule_t *rules_buf,
|
|||||||
* padding
|
* padding
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (pw_len < 16)
|
if (out_len < 16)
|
||||||
{
|
{
|
||||||
pad (&w[ 0], pw_len & 0xf);
|
pad (&w[ 0], out_len & 0xf);
|
||||||
}
|
}
|
||||||
else if (pw_len < 32)
|
else if (out_len < 32)
|
||||||
{
|
{
|
||||||
pad (&w[ 4], pw_len & 0xf);
|
pad (&w[ 4], out_len & 0xf);
|
||||||
}
|
}
|
||||||
else if (pw_len < 48)
|
else if (out_len < 48)
|
||||||
{
|
{
|
||||||
pad (&w[ 8], pw_len & 0xf);
|
pad (&w[ 8], out_len & 0xf);
|
||||||
}
|
}
|
||||||
else if (pw_len < 64)
|
else if (out_len < 64)
|
||||||
{
|
{
|
||||||
pad (&w[12], pw_len & 0xf);
|
pad (&w[12], out_len & 0xf);
|
||||||
}
|
}
|
||||||
|
|
||||||
domino_big_md (w, pw_len, state, s_lotus_magic_table);
|
domino_big_md (w, out_len, state, s_lotus_magic_table);
|
||||||
|
|
||||||
const u32 r0 = state[0];
|
const u32 r0 = state[0];
|
||||||
const u32 r1 = state[1];
|
const u32 r1 = state[1];
|
||||||
@ -504,24 +504,24 @@ __kernel void m08600_s04 (__global pw_t *pws, __global kernel_rule_t *rules_buf,
|
|||||||
* padding
|
* padding
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (pw_len < 16)
|
if (out_len < 16)
|
||||||
{
|
{
|
||||||
pad (&w[ 0], pw_len & 0xf);
|
pad (&w[ 0], out_len & 0xf);
|
||||||
}
|
}
|
||||||
else if (pw_len < 32)
|
else if (out_len < 32)
|
||||||
{
|
{
|
||||||
pad (&w[ 4], pw_len & 0xf);
|
pad (&w[ 4], out_len & 0xf);
|
||||||
}
|
}
|
||||||
else if (pw_len < 48)
|
else if (out_len < 48)
|
||||||
{
|
{
|
||||||
pad (&w[ 8], pw_len & 0xf);
|
pad (&w[ 8], out_len & 0xf);
|
||||||
}
|
}
|
||||||
else if (pw_len < 64)
|
else if (out_len < 64)
|
||||||
{
|
{
|
||||||
pad (&w[12], pw_len & 0xf);
|
pad (&w[12], out_len & 0xf);
|
||||||
}
|
}
|
||||||
|
|
||||||
domino_big_md (w, pw_len, state, s_lotus_magic_table);
|
domino_big_md (w, out_len, state, s_lotus_magic_table);
|
||||||
|
|
||||||
const u32 r0 = state[0];
|
const u32 r0 = state[0];
|
||||||
const u32 r1 = state[1];
|
const u32 r1 = state[1];
|
||||||
|
@ -401,24 +401,24 @@ __kernel void m08700_m04 (__global pw_t *pws, __global kernel_rule_t *rules_buf,
|
|||||||
* padding
|
* padding
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (pw_len < 16)
|
if (out_len < 16)
|
||||||
{
|
{
|
||||||
pad (&w[ 0], pw_len & 0xf);
|
pad (&w[ 0], out_len & 0xf);
|
||||||
}
|
}
|
||||||
else if (pw_len < 32)
|
else if (out_len < 32)
|
||||||
{
|
{
|
||||||
pad (&w[ 4], pw_len & 0xf);
|
pad (&w[ 4], out_len & 0xf);
|
||||||
}
|
}
|
||||||
else if (pw_len < 48)
|
else if (out_len < 48)
|
||||||
{
|
{
|
||||||
pad (&w[ 8], pw_len & 0xf);
|
pad (&w[ 8], out_len & 0xf);
|
||||||
}
|
}
|
||||||
else if (pw_len < 64)
|
else if (out_len < 64)
|
||||||
{
|
{
|
||||||
pad (&w[12], pw_len & 0xf);
|
pad (&w[12], out_len & 0xf);
|
||||||
}
|
}
|
||||||
|
|
||||||
domino_big_md (w, pw_len, state, s_lotus_magic_table);
|
domino_big_md (w, out_len, state, s_lotus_magic_table);
|
||||||
|
|
||||||
const u32 w0_t = uint_to_hex_upper8 ((state[0] >> 0) & 255) << 0
|
const u32 w0_t = uint_to_hex_upper8 ((state[0] >> 0) & 255) << 0
|
||||||
| uint_to_hex_upper8 ((state[0] >> 8) & 255) << 16;
|
| uint_to_hex_upper8 ((state[0] >> 8) & 255) << 16;
|
||||||
@ -626,24 +626,24 @@ __kernel void m08700_s04 (__global pw_t *pws, __global kernel_rule_t *rules_buf,
|
|||||||
* padding
|
* padding
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (pw_len < 16)
|
if (out_len < 16)
|
||||||
{
|
{
|
||||||
pad (&w[ 0], pw_len & 0xf);
|
pad (&w[ 0], out_len & 0xf);
|
||||||
}
|
}
|
||||||
else if (pw_len < 32)
|
else if (out_len < 32)
|
||||||
{
|
{
|
||||||
pad (&w[ 4], pw_len & 0xf);
|
pad (&w[ 4], out_len & 0xf);
|
||||||
}
|
}
|
||||||
else if (pw_len < 48)
|
else if (out_len < 48)
|
||||||
{
|
{
|
||||||
pad (&w[ 8], pw_len & 0xf);
|
pad (&w[ 8], out_len & 0xf);
|
||||||
}
|
}
|
||||||
else if (pw_len < 64)
|
else if (out_len < 64)
|
||||||
{
|
{
|
||||||
pad (&w[12], pw_len & 0xf);
|
pad (&w[12], out_len & 0xf);
|
||||||
}
|
}
|
||||||
|
|
||||||
domino_big_md (w, pw_len, state, s_lotus_magic_table);
|
domino_big_md (w, out_len, state, s_lotus_magic_table);
|
||||||
|
|
||||||
const u32 w0_t = uint_to_hex_upper8 ((state[0] >> 0) & 255) << 0
|
const u32 w0_t = uint_to_hex_upper8 ((state[0] >> 0) & 255) << 0
|
||||||
| uint_to_hex_upper8 ((state[0] >> 8) & 255) << 16;
|
| uint_to_hex_upper8 ((state[0] >> 8) & 255) << 16;
|
||||||
|
Loading…
Reference in New Issue
Block a user