1
0
mirror of https://github.com/hashcat/hashcat.git synced 2025-01-28 08:31:06 +00:00

Fix -m 10700

This commit is contained in:
jsteube 2015-12-19 18:17:19 +01:00
parent 91249942ab
commit 15da53da38
3 changed files with 53 additions and 53 deletions

View File

@ -455,7 +455,7 @@ __kernel void __attribute__((reqd_work_group_size (64, 1, 1))) m01800_loop (__gl
wpc_len[6] = 64 + salt_len + pw_len + pw_len; wpc_len[6] = 64 + salt_len + pw_len + pw_len;
wpc_len[7] = pw_len + salt_len + pw_len + 64; wpc_len[7] = pw_len + salt_len + pw_len + 64;
u64 wpc[8][16] = { { 0 } }; u64 wpc[8][16] = { 0 };
for (u32 i = 0; i < 8; i++) for (u32 i = 0; i < 8; i++)
{ {

View File

@ -181,22 +181,22 @@ static void sha384_transform (const u64 w0[4], const u64 w1[4], const u64 w2[4],
u64 g = digest[6]; u64 g = digest[6];
u64 h = digest[7]; u64 h = digest[7];
u64 w0_t = swap32 (w0[0]); u64 w0_t = swap64 (w0[0]);
u64 w1_t = swap32 (w0[1]); u64 w1_t = swap64 (w0[1]);
u64 w2_t = swap32 (w0[2]); u64 w2_t = swap64 (w0[2]);
u64 w3_t = swap32 (w0[3]); u64 w3_t = swap64 (w0[3]);
u64 w4_t = swap32 (w1[0]); u64 w4_t = swap64 (w1[0]);
u64 w5_t = swap32 (w1[1]); u64 w5_t = swap64 (w1[1]);
u64 w6_t = swap32 (w1[2]); u64 w6_t = swap64 (w1[2]);
u64 w7_t = swap32 (w1[3]); u64 w7_t = swap64 (w1[3]);
u64 w8_t = swap32 (w2[0]); u64 w8_t = swap64 (w2[0]);
u64 w9_t = swap32 (w2[1]); u64 w9_t = swap64 (w2[1]);
u64 wa_t = swap32 (w2[2]); u64 wa_t = swap64 (w2[2]);
u64 wb_t = swap32 (w2[3]); u64 wb_t = swap64 (w2[3]);
u64 wc_t = swap32 (w3[0]); u64 wc_t = swap64 (w3[0]);
u64 wd_t = swap32 (w3[1]); u64 wd_t = swap64 (w3[1]);
u64 we_t = swap32 (w3[2]); u64 we_t = swap64 (w3[2]);
u64 wf_t = swap32 (w3[3]); u64 wf_t = swap64 (w3[3]);
#define ROUND384_EXPAND() \ #define ROUND384_EXPAND() \
{ \ { \
@ -291,22 +291,22 @@ static void sha512_transform (const u64 w0[4], const u64 w1[4], const u64 w2[4],
u64 g = digest[6]; u64 g = digest[6];
u64 h = digest[7]; u64 h = digest[7];
u64 w0_t = swap32 (w0[0]); u64 w0_t = swap64 (w0[0]);
u64 w1_t = swap32 (w0[1]); u64 w1_t = swap64 (w0[1]);
u64 w2_t = swap32 (w0[2]); u64 w2_t = swap64 (w0[2]);
u64 w3_t = swap32 (w0[3]); u64 w3_t = swap64 (w0[3]);
u64 w4_t = swap32 (w1[0]); u64 w4_t = swap64 (w1[0]);
u64 w5_t = swap32 (w1[1]); u64 w5_t = swap64 (w1[1]);
u64 w6_t = swap32 (w1[2]); u64 w6_t = swap64 (w1[2]);
u64 w7_t = swap32 (w1[3]); u64 w7_t = swap64 (w1[3]);
u64 w8_t = swap32 (w2[0]); u64 w8_t = swap64 (w2[0]);
u64 w9_t = swap32 (w2[1]); u64 w9_t = swap64 (w2[1]);
u64 wa_t = swap32 (w2[2]); u64 wa_t = swap64 (w2[2]);
u64 wb_t = swap32 (w2[3]); u64 wb_t = swap64 (w2[3]);
u64 wc_t = swap32 (w3[0]); u64 wc_t = swap64 (w3[0]);
u64 wd_t = swap32 (w3[1]); u64 wd_t = swap64 (w3[1]);
u64 we_t = swap32 (w3[2]); u64 we_t = swap64 (w3[2]);
u64 wf_t = swap32 (w3[3]); u64 wf_t = swap64 (w3[3]);
#define ROUND512_EXPAND() \ #define ROUND512_EXPAND() \
{ \ { \
@ -1394,7 +1394,7 @@ static u32 do_round (const u32 *pw, const u32 pw_len, ctx_t *ctx, __local u32 s_
ctx->W64[12] = 0; ctx->W64[12] = 0;
ctx->W64[13] = 0; ctx->W64[13] = 0;
ctx->W64[14] = 0; ctx->W64[14] = 0;
ctx->W64[15] = swap32 ((u64) (final_len * 8)); ctx->W64[15] = swap64 ((u64) (final_len * 8));
ex = ctx->W64[7] >> 56; ex = ctx->W64[7] >> 56;
break; break;
case BLSZ512: make_w_with_offset (ctx, 64, offset, sc, pwbl_len, iv, rek, s_te0, s_te1, s_te2, s_te3, s_te4); case BLSZ512: make_w_with_offset (ctx, 64, offset, sc, pwbl_len, iv, rek, s_te0, s_te1, s_te2, s_te3, s_te4);
@ -1405,7 +1405,7 @@ static u32 do_round (const u32 *pw, const u32 pw_len, ctx_t *ctx, __local u32 s_
ctx->W64[12] = 0; ctx->W64[12] = 0;
ctx->W64[13] = 0; ctx->W64[13] = 0;
ctx->W64[14] = 0; ctx->W64[14] = 0;
ctx->W64[15] = swap32 ((u64) (final_len * 8)); ctx->W64[15] = swap64 ((u64) (final_len * 8));
ex = ctx->W64[7] >> 56; ex = ctx->W64[7] >> 56;
break; break;
} }
@ -1448,7 +1448,7 @@ static u32 do_round (const u32 *pw, const u32 pw_len, ctx_t *ctx, __local u32 s_
ctx->W64[12] = 0; ctx->W64[12] = 0;
ctx->W64[13] = 0; ctx->W64[13] = 0;
ctx->W64[14] = 0; ctx->W64[14] = 0;
ctx->W64[15] = swap32 ((u64) (final_len * 8)); ctx->W64[15] = swap64 ((u64) (final_len * 8));
break; break;
case BLSZ512: ex = ctx->W64[15] >> 56; case BLSZ512: ex = ctx->W64[15] >> 56;
ctx->W64[ 0] = 0x80; ctx->W64[ 0] = 0x80;
@ -1466,7 +1466,7 @@ static u32 do_round (const u32 *pw, const u32 pw_len, ctx_t *ctx, __local u32 s_
ctx->W64[12] = 0; ctx->W64[12] = 0;
ctx->W64[13] = 0; ctx->W64[13] = 0;
ctx->W64[14] = 0; ctx->W64[14] = 0;
ctx->W64[15] = swap32 ((u64) (final_len * 8)); ctx->W64[15] = swap64 ((u64) (final_len * 8));
break; break;
} }
} }
@ -1492,24 +1492,24 @@ static u32 do_round (const u32 *pw, const u32 pw_len, ctx_t *ctx, __local u32 s_
ctx->dgst32[15] = 0; ctx->dgst32[15] = 0;
break; break;
case BLSZ384: sha384_transform (&ctx->W64[ 0], &ctx->W64[ 4], &ctx->W64[ 8], &ctx->W64[12], ctx->dgst64); case BLSZ384: sha384_transform (&ctx->W64[ 0], &ctx->W64[ 4], &ctx->W64[ 8], &ctx->W64[12], ctx->dgst64);
ctx->dgst64[0] = swap32 (ctx->dgst64[0]); ctx->dgst64[0] = swap64 (ctx->dgst64[0]);
ctx->dgst64[1] = swap32 (ctx->dgst64[1]); ctx->dgst64[1] = swap64 (ctx->dgst64[1]);
ctx->dgst64[2] = swap32 (ctx->dgst64[2]); ctx->dgst64[2] = swap64 (ctx->dgst64[2]);
ctx->dgst64[3] = swap32 (ctx->dgst64[3]); ctx->dgst64[3] = swap64 (ctx->dgst64[3]);
ctx->dgst64[4] = swap32 (ctx->dgst64[4]); ctx->dgst64[4] = swap64 (ctx->dgst64[4]);
ctx->dgst64[5] = swap32 (ctx->dgst64[5]); ctx->dgst64[5] = swap64 (ctx->dgst64[5]);
ctx->dgst64[6] = 0; ctx->dgst64[6] = 0;
ctx->dgst64[7] = 0; ctx->dgst64[7] = 0;
break; break;
case BLSZ512: sha512_transform (&ctx->W64[ 0], &ctx->W64[ 4], &ctx->W64[ 8], &ctx->W64[12], ctx->dgst64); case BLSZ512: sha512_transform (&ctx->W64[ 0], &ctx->W64[ 4], &ctx->W64[ 8], &ctx->W64[12], ctx->dgst64);
ctx->dgst64[0] = swap32 (ctx->dgst64[0]); ctx->dgst64[0] = swap64 (ctx->dgst64[0]);
ctx->dgst64[1] = swap32 (ctx->dgst64[1]); ctx->dgst64[1] = swap64 (ctx->dgst64[1]);
ctx->dgst64[2] = swap32 (ctx->dgst64[2]); ctx->dgst64[2] = swap64 (ctx->dgst64[2]);
ctx->dgst64[3] = swap32 (ctx->dgst64[3]); ctx->dgst64[3] = swap64 (ctx->dgst64[3]);
ctx->dgst64[4] = swap32 (ctx->dgst64[4]); ctx->dgst64[4] = swap64 (ctx->dgst64[4]);
ctx->dgst64[5] = swap32 (ctx->dgst64[5]); ctx->dgst64[5] = swap64 (ctx->dgst64[5]);
ctx->dgst64[6] = swap32 (ctx->dgst64[6]); ctx->dgst64[6] = swap64 (ctx->dgst64[6]);
ctx->dgst64[7] = swap32 (ctx->dgst64[7]); ctx->dgst64[7] = swap64 (ctx->dgst64[7]);
break; break;
} }

View File

@ -284,8 +284,8 @@
#define SHA512_EXPAND(x,y,z,w) (SHA512_S3 (x) + y + SHA512_S2 (z) + w) #define SHA512_EXPAND(x,y,z,w) (SHA512_S3 (x) + y + SHA512_S2 (z) + w)
#define SHA512_S2_WO(x) (rotr64 ((x), 1) ^ rotr64 ((x), 8) ^ SHIFT_RIGHT_64 ((x), 7)) #define SHA512_S2_WO(x) (rotate ((x), 64- 1ull) ^ rotate ((x), 64- 8ull) ^ SHIFT_RIGHT_64 ((x), 7))
#define SHA512_S3_WO(x) (rotr64 ((x), 19) ^ rotr64 ((x), 61) ^ SHIFT_RIGHT_64 ((x), 6)) #define SHA512_S3_WO(x) (rotate ((x), 64-19ull) ^ rotate ((x), 64-61ull) ^ SHIFT_RIGHT_64 ((x), 6))
#define SHA512_EXPAND_WO(x,y,z,w) (SHA512_S3_WO (x) + y + SHA512_S2_WO (z) + w) #define SHA512_EXPAND_WO(x,y,z,w) (SHA512_S3_WO (x) + y + SHA512_S2_WO (z) + w)
#endif #endif