1
0
mirror of https://github.com/hashcat/hashcat.git synced 2025-01-03 04:11:06 +00:00

Increase bcrypt speed for NV

This commit is contained in:
jsteube 2015-12-22 23:43:39 +01:00
parent 67058ca7d4
commit 84568e5b3d
3 changed files with 20 additions and 25 deletions

View File

@ -354,7 +354,7 @@ __constant u32 c_sbox3[256] =
L ^= P[17]; \ L ^= P[17]; \
} }
static void expand_key (u32 E[34], const u32 W[16], const u32 len) static void expand_key (u32 E[18], const u32 W[16], const u32 len)
{ {
u8 *E_cur = (u8 *) E; u8 *E_cur = (u8 *) E;
u8 *E_stop = E_cur + 72; u8 *E_stop = E_cur + 72;
@ -406,7 +406,7 @@ __kernel void __attribute__((reqd_work_group_size (8, 1, 1))) m03200_init (__glo
w[14] = pws[gid].i[14]; w[14] = pws[gid].i[14];
w[15] = pws[gid].i[15]; w[15] = pws[gid].i[15];
u32 E[34]; u32 E[18];
expand_key (E, w, pw_len); expand_key (E, w, pw_len);
@ -429,6 +429,11 @@ __kernel void __attribute__((reqd_work_group_size (8, 1, 1))) m03200_init (__glo
E[16] = swap32 (E[16]); E[16] = swap32 (E[16]);
E[17] = swap32 (E[17]); E[17] = swap32 (E[17]);
for (u32 i = 0; i < 18; i++)
{
tmps[gid].E[i] = E[i];
}
/** /**
* salt * salt
*/ */
@ -619,33 +624,19 @@ __kernel void __attribute__((reqd_work_group_size (8, 1, 1))) m03200_loop (__glo
w[14] = pws[gid].i[14]; w[14] = pws[gid].i[14];
w[15] = pws[gid].i[15]; w[15] = pws[gid].i[15];
u32 E[34];
expand_key (E, w, pw_len);
E[ 0] = swap32 (E[ 0]);
E[ 1] = swap32 (E[ 1]);
E[ 2] = swap32 (E[ 2]);
E[ 3] = swap32 (E[ 3]);
E[ 4] = swap32 (E[ 4]);
E[ 5] = swap32 (E[ 5]);
E[ 6] = swap32 (E[ 6]);
E[ 7] = swap32 (E[ 7]);
E[ 8] = swap32 (E[ 8]);
E[ 9] = swap32 (E[ 9]);
E[10] = swap32 (E[10]);
E[11] = swap32 (E[11]);
E[12] = swap32 (E[12]);
E[13] = swap32 (E[13]);
E[14] = swap32 (E[14]);
E[15] = swap32 (E[15]);
E[16] = swap32 (E[16]);
E[17] = swap32 (E[17]);
// load // load
u32 E[18];
#pragma unroll
for (u32 i = 0; i < 18; i++)
{
E[i] = tmps[gid].E[i];
}
u32 P[18]; u32 P[18];
#pragma unroll
for (u32 i = 0; i < 18; i++) for (u32 i = 0; i < 18; i++)
{ {
P[i] = tmps[gid].P[i]; P[i] = tmps[gid].P[i];

View File

@ -652,6 +652,8 @@ typedef struct
typedef struct typedef struct
{ {
u32 E[18];
u32 P[18]; u32 P[18];
u32 S0[256]; u32 S0[256];

View File

@ -298,6 +298,8 @@ typedef struct
typedef struct typedef struct
{ {
uint E[18];
uint P[18]; uint P[18];
uint S0[256]; uint S0[256];