mirror of
https://github.com/hashcat/hashcat.git
synced 2025-01-25 15:10:58 +00:00
applied speed improvements to modes 17220 and 17230
This commit is contained in:
parent
d9e5a86765
commit
06554f5071
@ -550,6 +550,15 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
LOCAL_VK u32 l_data[MAX_LOCAL];
|
||||
|
||||
for (u64 i = lid; i < MAX_LOCAL; i += lsz)
|
||||
{
|
||||
l_data[i] = esalt_bufs[digests_offset].hashes[0].data[i];
|
||||
}
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
if (gid >= gid_max) return;
|
||||
|
||||
/**
|
||||
@ -597,7 +606,8 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
u32x key1 = key1init;
|
||||
u32x key2 = key2init;
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
if (idx == 0) next = l_data[0];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -615,7 +625,8 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
if (idx == 0) next = l_data[1];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -633,7 +644,8 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
if (idx == 0) next = l_data[2];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -659,7 +671,8 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
|
||||
u8 tmp[TMPSIZ];
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
if (idx == 0) next = l_data[3];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -684,7 +697,8 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
|
||||
for (int i = 16; i < 36; i += 4)
|
||||
{
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[i / 4];
|
||||
if (idx == 0) next = l_data[i / 4];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[i / 4];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -801,6 +815,15 @@ KERNEL_FQ void m17220_mxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
LOCAL_VK u32 l_data[MAX_LOCAL];
|
||||
|
||||
for (u64 i = lid; i < MAX_LOCAL; i += lsz)
|
||||
{
|
||||
l_data[i] = esalt_bufs[digests_offset].hashes[0].data[i];
|
||||
}
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
if (gid >= gid_max) return;
|
||||
|
||||
/**
|
||||
@ -848,7 +871,8 @@ KERNEL_FQ void m17220_mxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
u32x key1 = key1init;
|
||||
u32x key2 = key2init;
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
if (idx == 0) next = l_data[0];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -866,7 +890,8 @@ KERNEL_FQ void m17220_mxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
if (idx == 0) next = l_data[1];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -884,7 +909,8 @@ KERNEL_FQ void m17220_mxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
if (idx == 0) next = l_data[2];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -910,7 +936,8 @@ KERNEL_FQ void m17220_mxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
|
||||
u8 tmp[TMPSIZ];
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
if (idx == 0) next = l_data[3];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -935,7 +962,8 @@ KERNEL_FQ void m17220_mxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
|
||||
for (int i = 16; i < 36; i += 4)
|
||||
{
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[i / 4];
|
||||
if (idx == 0) next = l_data[i / 4];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[i / 4];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
|
@ -548,6 +548,15 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
LOCAL_VK u32 l_data[MAX_LOCAL];
|
||||
|
||||
for (u64 i = lid; i < MAX_LOCAL; i += lsz)
|
||||
{
|
||||
l_data[i] = esalt_bufs[digests_offset].hashes[0].data[i];
|
||||
}
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
if (gid >= gid_max) return;
|
||||
|
||||
/**
|
||||
@ -597,7 +606,8 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
u32x key1 = key1init2;
|
||||
u32x key2 = key2init2;
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
if (idx == 0) next = l_data[0];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -615,7 +625,8 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
if (idx == 0) next = l_data[1];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -633,7 +644,8 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
if (idx == 0) next = l_data[2];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -659,7 +671,8 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
|
||||
u8 tmp[TMPSIZ];
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
if (idx == 0) next = l_data[3];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -684,7 +697,8 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
|
||||
for (int i = 16; i < 36; i += 4)
|
||||
{
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[i / 4];
|
||||
if (idx == 0) next = l_data[i / 4];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[i / 4];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -801,6 +815,15 @@ KERNEL_FQ void m17220_mxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
LOCAL_VK u32 l_data[MAX_LOCAL];
|
||||
|
||||
for (u64 i = lid; i < MAX_LOCAL; i += lsz)
|
||||
{
|
||||
l_data[i] = esalt_bufs[digests_offset].hashes[0].data[i];
|
||||
}
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
if (gid >= gid_max) return;
|
||||
|
||||
/**
|
||||
@ -850,7 +873,8 @@ KERNEL_FQ void m17220_mxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
u32x key1 = key1init2;
|
||||
u32x key2 = key2init2;
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
if (idx == 0) next = l_data[0];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -868,7 +892,8 @@ KERNEL_FQ void m17220_mxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
if (idx == 0) next = l_data[1];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -886,7 +911,8 @@ KERNEL_FQ void m17220_mxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
if (idx == 0) next = l_data[2];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -912,7 +938,8 @@ KERNEL_FQ void m17220_mxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
|
||||
u8 tmp[TMPSIZ];
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
if (idx == 0) next = l_data[3];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -937,7 +964,8 @@ KERNEL_FQ void m17220_mxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
|
||||
for (int i = 16; i < 36; i += 4)
|
||||
{
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[i / 4];
|
||||
if (idx == 0) next = l_data[i / 4];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[i / 4];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
|
@ -548,6 +548,15 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
LOCAL_VK u32 l_data[MAX_LOCAL];
|
||||
|
||||
for (u64 i = lid; i < MAX_LOCAL; i += lsz)
|
||||
{
|
||||
l_data[i] = esalt_bufs[digests_offset].hashes[0].data[i];
|
||||
}
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
if (gid >= gid_max) return;
|
||||
|
||||
/**
|
||||
@ -609,7 +618,8 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
u32x key1 = key1init;
|
||||
u32x key2 = key2init;
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
if (idx == 0) next = l_data[0];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -627,7 +637,8 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
if (idx == 0) next = l_data[1];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -645,7 +656,8 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
if (idx == 0) next = l_data[2];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -671,7 +683,8 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
|
||||
u8 tmp[TMPSIZ];
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
if (idx == 0) next = l_data[3];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -696,7 +709,8 @@ KERNEL_FQ void m17220_sxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
|
||||
for (int i = 16; i < 36; i += 4)
|
||||
{
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[i / 4];
|
||||
if (idx == 0) next = l_data[i / 4];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[i / 4];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -874,7 +888,8 @@ KERNEL_FQ void m17220_mxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
u32x key1 = key1init;
|
||||
u32x key2 = key2init;
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
if (idx == 0) next = l_data[0];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -892,7 +907,8 @@ KERNEL_FQ void m17220_mxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
if (idx == 0) next = l_data[1];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -910,7 +926,8 @@ KERNEL_FQ void m17220_mxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
if (idx == 0) next = l_data[2];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -936,7 +953,8 @@ KERNEL_FQ void m17220_mxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
|
||||
u8 tmp[TMPSIZ];
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
if (idx == 0) next = l_data[3];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -961,7 +979,8 @@ KERNEL_FQ void m17220_mxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
|
||||
for (int i = 16; i < 36; i += 4)
|
||||
{
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[i / 4];
|
||||
if (idx == 0) next = l_data[i / 4];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[i / 4];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
|
@ -243,6 +243,15 @@ KERNEL_FQ void m17230_sxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
LOCAL_VK u32 l_data[MAX_LOCAL];
|
||||
|
||||
for (u64 i = lid; i < MAX_LOCAL; i += lsz)
|
||||
{
|
||||
l_data[i] = esalt_bufs[digests_offset].hashes[0].data[i];
|
||||
}
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
if (gid >= gid_max) return;
|
||||
|
||||
/**
|
||||
@ -290,7 +299,8 @@ KERNEL_FQ void m17230_sxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
u32x key1 = key1init;
|
||||
u32x key2 = key2init;
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
if (idx == 0) next = l_data[0];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -308,7 +318,8 @@ KERNEL_FQ void m17230_sxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
if (idx == 0) next = l_data[1];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -326,7 +337,8 @@ KERNEL_FQ void m17230_sxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
if (idx == 0) next = l_data[2];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -346,7 +358,8 @@ KERNEL_FQ void m17230_sxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
if ((plain != (esalt_bufs[digests_offset].hashes[idx].checksum_from_crc >> 8)) && (plain != (esalt_bufs[digests_offset].hashes[idx].checksum_from_timestamp >> 8))) break;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
if (idx == 0) next = l_data[3];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -400,6 +413,15 @@ KERNEL_FQ void m17230_mxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
LOCAL_VK u32 l_data[MAX_LOCAL];
|
||||
|
||||
for (u64 i = lid; i < MAX_LOCAL; i += lsz)
|
||||
{
|
||||
l_data[i] = esalt_bufs[digests_offset].hashes[0].data[i];
|
||||
}
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
if (gid >= gid_max) return;
|
||||
|
||||
/**
|
||||
@ -447,7 +469,8 @@ KERNEL_FQ void m17230_mxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
u32x key1 = key1init;
|
||||
u32x key2 = key2init;
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
if (idx == 0) next = l_data[0];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -465,7 +488,8 @@ KERNEL_FQ void m17230_mxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
if (idx == 0) next = l_data[1];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -483,7 +507,8 @@ KERNEL_FQ void m17230_mxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
if (idx == 0) next = l_data[2];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -503,7 +528,8 @@ KERNEL_FQ void m17230_mxx (KERN_ATTR_RULES_ESALT (pkzip_t))
|
||||
if ((plain != (esalt_bufs[digests_offset].hashes[idx].checksum_from_crc >> 8)) && (plain != (esalt_bufs[digests_offset].hashes[idx].checksum_from_timestamp >> 8))) break;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
if (idx == 0) next = l_data[3];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
|
@ -241,161 +241,11 @@ KERNEL_FQ void m17230_sxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
if (gid >= gid_max) return;
|
||||
LOCAL_VK u32 l_data[MAX_LOCAL];
|
||||
|
||||
/**
|
||||
* prefetch from global memory
|
||||
*/
|
||||
|
||||
const u32 checksum_size = esalt_bufs[digests_offset].checksum_size;
|
||||
const u32 hash_count = esalt_bufs[digests_offset].hash_count;
|
||||
|
||||
/**
|
||||
* loop
|
||||
*/
|
||||
|
||||
u32x key0init = 0x12345678;
|
||||
u32x key1init = 0x23456789;
|
||||
u32x key2init = 0x34567890;
|
||||
|
||||
for (u32 i = 0, j = 0; i < pws[gid].pw_len; i += 4, j += 1)
|
||||
for (u64 i = lid; i < MAX_LOCAL; i += lsz)
|
||||
{
|
||||
if (pws[gid].pw_len >= (i + 1)) update_key012 (key0init, key1init, key2init, unpack_v8a_from_v32_S (pws[gid].i[j]), l_crc32tab);
|
||||
if (pws[gid].pw_len >= (i + 2)) update_key012 (key0init, key1init, key2init, unpack_v8b_from_v32_S (pws[gid].i[j]), l_crc32tab);
|
||||
if (pws[gid].pw_len >= (i + 3)) update_key012 (key0init, key1init, key2init, unpack_v8c_from_v32_S (pws[gid].i[j]), l_crc32tab);
|
||||
if (pws[gid].pw_len >= (i + 4)) update_key012 (key0init, key1init, key2init, unpack_v8d_from_v32_S (pws[gid].i[j]), l_crc32tab);
|
||||
}
|
||||
|
||||
for (u32 il_pos = 0; il_pos < il_cnt; il_pos++)
|
||||
{
|
||||
u32x key0init2 = key0init;
|
||||
u32x key1init2 = key1init;
|
||||
u32x key2init2 = key2init;
|
||||
|
||||
for (u32 i = 0, j = 0; i < combs_buf[il_pos].pw_len; i += 4, j += 1)
|
||||
{
|
||||
if (combs_buf[il_pos].pw_len >= (i + 1)) update_key012 (key0init2, key1init2, key2init2, unpack_v8a_from_v32_S (combs_buf[il_pos].i[j]), l_crc32tab);
|
||||
if (combs_buf[il_pos].pw_len >= (i + 2)) update_key012 (key0init2, key1init2, key2init2, unpack_v8b_from_v32_S (combs_buf[il_pos].i[j]), l_crc32tab);
|
||||
if (combs_buf[il_pos].pw_len >= (i + 3)) update_key012 (key0init2, key1init2, key2init2, unpack_v8c_from_v32_S (combs_buf[il_pos].i[j]), l_crc32tab);
|
||||
if (combs_buf[il_pos].pw_len >= (i + 4)) update_key012 (key0init2, key1init2, key2init2, unpack_v8d_from_v32_S (combs_buf[il_pos].i[j]), l_crc32tab);
|
||||
}
|
||||
|
||||
u32 plain;
|
||||
u32 key3;
|
||||
u32 next;
|
||||
|
||||
for (u32 idx = 0; idx < hash_count; idx++)
|
||||
{
|
||||
u32x key0 = key0init2;
|
||||
u32x key1 = key1init2;
|
||||
u32x key2 = key2init2;
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8b_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8c_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8b_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8c_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8b_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8c_from_v32_S (next) ^ key3;
|
||||
if ((checksum_size == 2) && ((esalt_bufs[digests_offset].hashes[idx].checksum_from_crc & 0xff) != plain) && ((esalt_bufs[digests_offset].hashes[idx].checksum_from_timestamp & 0xff) != plain)) break;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
if ((plain != (esalt_bufs[digests_offset].hashes[idx].checksum_from_crc >> 8)) && (plain != (esalt_bufs[digests_offset].hashes[idx].checksum_from_timestamp >> 8))) break;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
if ((plain & 6) == 0 || (plain & 6) == 6) break;
|
||||
|
||||
if (idx + 1 == esalt_bufs[digests_offset].hash_count)
|
||||
{
|
||||
/**
|
||||
* digest
|
||||
*/
|
||||
|
||||
const u32 search[4] =
|
||||
{
|
||||
esalt_bufs[digests_offset].hashes[0].checksum_from_crc,
|
||||
0,
|
||||
0,
|
||||
0
|
||||
};
|
||||
|
||||
const u32 r0 = esalt_bufs[digests_offset].hashes[0].checksum_from_crc;
|
||||
const u32 r1 = 0;
|
||||
const u32 r2 = 0;
|
||||
const u32 r3 = 0;
|
||||
|
||||
COMPARE_S_SIMD (r0, r1, r2, r3);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
KERNEL_FQ void m17230_mxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
{
|
||||
/**
|
||||
* modifier
|
||||
*/
|
||||
|
||||
const u64 gid = get_global_id (0);
|
||||
const u64 lid = get_local_id (0);
|
||||
const u64 lsz = get_local_size (0);
|
||||
|
||||
/**
|
||||
* sbox, kbox
|
||||
*/
|
||||
|
||||
LOCAL_VK u32 l_crc32tab[256];
|
||||
|
||||
for (u64 i = lid; i < 256; i += lsz)
|
||||
{
|
||||
l_crc32tab[i] = crc32tab[i];
|
||||
l_data[i] = esalt_bufs[digests_offset].hashes[0].data[i];
|
||||
}
|
||||
|
||||
SYNC_THREADS();
|
||||
@ -449,7 +299,8 @@ KERNEL_FQ void m17230_mxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
u32x key1 = key1init2;
|
||||
u32x key2 = key2init2;
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
if (idx == 0) next = l_data[0];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -467,7 +318,8 @@ KERNEL_FQ void m17230_mxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
if (idx == 0) next = l_data[1];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -485,7 +337,8 @@ KERNEL_FQ void m17230_mxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
if (idx == 0) next = l_data[2];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -505,7 +358,180 @@ KERNEL_FQ void m17230_mxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
if ((plain != (esalt_bufs[digests_offset].hashes[idx].checksum_from_crc >> 8)) && (plain != (esalt_bufs[digests_offset].hashes[idx].checksum_from_timestamp >> 8))) break;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
if (idx == 0) next = l_data[3];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
if ((plain & 6) == 0 || (plain & 6) == 6) break;
|
||||
|
||||
if (idx + 1 == esalt_bufs[digests_offset].hash_count)
|
||||
{
|
||||
/**
|
||||
* digest
|
||||
*/
|
||||
|
||||
const u32 search[4] =
|
||||
{
|
||||
esalt_bufs[digests_offset].hashes[0].checksum_from_crc,
|
||||
0,
|
||||
0,
|
||||
0
|
||||
};
|
||||
|
||||
const u32 r0 = esalt_bufs[digests_offset].hashes[0].checksum_from_crc;
|
||||
const u32 r1 = 0;
|
||||
const u32 r2 = 0;
|
||||
const u32 r3 = 0;
|
||||
|
||||
COMPARE_S_SIMD (r0, r1, r2, r3);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
KERNEL_FQ void m17230_mxx (KERN_ATTR_ESALT (pkzip_t))
|
||||
{
|
||||
/**
|
||||
* modifier
|
||||
*/
|
||||
|
||||
const u64 gid = get_global_id (0);
|
||||
const u64 lid = get_local_id (0);
|
||||
const u64 lsz = get_local_size (0);
|
||||
|
||||
/**
|
||||
* sbox, kbox
|
||||
*/
|
||||
|
||||
LOCAL_VK u32 l_crc32tab[256];
|
||||
|
||||
for (u64 i = lid; i < 256; i += lsz)
|
||||
{
|
||||
l_crc32tab[i] = crc32tab[i];
|
||||
}
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
LOCAL_VK u32 l_data[MAX_LOCAL];
|
||||
|
||||
for (u64 i = lid; i < MAX_LOCAL; i += lsz)
|
||||
{
|
||||
l_data[i] = esalt_bufs[digests_offset].hashes[0].data[i];
|
||||
}
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
if (gid >= gid_max) return;
|
||||
|
||||
/**
|
||||
* prefetch from global memory
|
||||
*/
|
||||
|
||||
const u32 checksum_size = esalt_bufs[digests_offset].checksum_size;
|
||||
const u32 hash_count = esalt_bufs[digests_offset].hash_count;
|
||||
|
||||
/**
|
||||
* loop
|
||||
*/
|
||||
|
||||
u32x key0init = 0x12345678;
|
||||
u32x key1init = 0x23456789;
|
||||
u32x key2init = 0x34567890;
|
||||
|
||||
for (u32 i = 0, j = 0; i < pws[gid].pw_len; i += 4, j += 1)
|
||||
{
|
||||
if (pws[gid].pw_len >= (i + 1)) update_key012 (key0init, key1init, key2init, unpack_v8a_from_v32_S (pws[gid].i[j]), l_crc32tab);
|
||||
if (pws[gid].pw_len >= (i + 2)) update_key012 (key0init, key1init, key2init, unpack_v8b_from_v32_S (pws[gid].i[j]), l_crc32tab);
|
||||
if (pws[gid].pw_len >= (i + 3)) update_key012 (key0init, key1init, key2init, unpack_v8c_from_v32_S (pws[gid].i[j]), l_crc32tab);
|
||||
if (pws[gid].pw_len >= (i + 4)) update_key012 (key0init, key1init, key2init, unpack_v8d_from_v32_S (pws[gid].i[j]), l_crc32tab);
|
||||
}
|
||||
|
||||
for (u32 il_pos = 0; il_pos < il_cnt; il_pos++)
|
||||
{
|
||||
u32x key0init2 = key0init;
|
||||
u32x key1init2 = key1init;
|
||||
u32x key2init2 = key2init;
|
||||
|
||||
for (u32 i = 0, j = 0; i < combs_buf[il_pos].pw_len; i += 4, j += 1)
|
||||
{
|
||||
if (combs_buf[il_pos].pw_len >= (i + 1)) update_key012 (key0init2, key1init2, key2init2, unpack_v8a_from_v32_S (combs_buf[il_pos].i[j]), l_crc32tab);
|
||||
if (combs_buf[il_pos].pw_len >= (i + 2)) update_key012 (key0init2, key1init2, key2init2, unpack_v8b_from_v32_S (combs_buf[il_pos].i[j]), l_crc32tab);
|
||||
if (combs_buf[il_pos].pw_len >= (i + 3)) update_key012 (key0init2, key1init2, key2init2, unpack_v8c_from_v32_S (combs_buf[il_pos].i[j]), l_crc32tab);
|
||||
if (combs_buf[il_pos].pw_len >= (i + 4)) update_key012 (key0init2, key1init2, key2init2, unpack_v8d_from_v32_S (combs_buf[il_pos].i[j]), l_crc32tab);
|
||||
}
|
||||
|
||||
u32 plain;
|
||||
u32 key3;
|
||||
u32 next;
|
||||
|
||||
for (u32 idx = 0; idx < hash_count; idx++)
|
||||
{
|
||||
u32x key0 = key0init2;
|
||||
u32x key1 = key1init2;
|
||||
u32x key2 = key2init2;
|
||||
|
||||
if (idx == 0) next = l_data[0];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8b_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8c_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
if (idx == 0) next = l_data[1];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8b_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8c_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
if (idx == 0) next = l_data[2];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8b_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8c_from_v32_S (next) ^ key3;
|
||||
if ((checksum_size == 2) && ((esalt_bufs[digests_offset].hashes[idx].checksum_from_crc & 0xff) != plain) && ((esalt_bufs[digests_offset].hashes[idx].checksum_from_timestamp & 0xff) != plain)) break;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
if ((plain != (esalt_bufs[digests_offset].hashes[idx].checksum_from_crc >> 8)) && (plain != (esalt_bufs[digests_offset].hashes[idx].checksum_from_timestamp >> 8))) break;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
if (idx == 0) next = l_data[3];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
|
@ -241,175 +241,11 @@ KERNEL_FQ void m17230_sxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
if (gid >= gid_max) return;
|
||||
LOCAL_VK u32 l_data[MAX_LOCAL];
|
||||
|
||||
/**
|
||||
* base
|
||||
*/
|
||||
|
||||
const u32 pw_len = pws[gid].pw_len;
|
||||
|
||||
u32x w[64] = { 0 };
|
||||
|
||||
for (int i = 0, idx = 0; i < pw_len; i += 4, idx += 1)
|
||||
for (u64 i = lid; i < MAX_LOCAL; i += lsz)
|
||||
{
|
||||
w[idx] = pws[gid].i[idx];
|
||||
}
|
||||
|
||||
/**
|
||||
* prefetch from global memory
|
||||
*/
|
||||
|
||||
const u32 checksum_size = esalt_bufs[digests_offset].checksum_size;
|
||||
const u32 hash_count = esalt_bufs[digests_offset].hash_count;
|
||||
|
||||
/**
|
||||
* loop
|
||||
*/
|
||||
|
||||
u32 w0l = w[0];
|
||||
|
||||
for (u32 il_pos = 0; il_pos < il_cnt; il_pos += VECT_SIZE)
|
||||
{
|
||||
const u32x w0r = words_buf_r[il_pos / VECT_SIZE];
|
||||
|
||||
const u32x w0 = w0l | w0r;
|
||||
|
||||
w[0] = w0;
|
||||
|
||||
u32x key0init = 0x12345678;
|
||||
u32x key1init = 0x23456789;
|
||||
u32x key2init = 0x34567890;
|
||||
|
||||
if (pw_len >= 1) update_key012 (key0init, key1init, key2init, unpack_v8a_from_v32_S (w0), l_crc32tab);
|
||||
if (pw_len >= 2) update_key012 (key0init, key1init, key2init, unpack_v8b_from_v32_S (w0), l_crc32tab);
|
||||
if (pw_len >= 3) update_key012 (key0init, key1init, key2init, unpack_v8c_from_v32_S (w0), l_crc32tab);
|
||||
if (pw_len >= 4) update_key012 (key0init, key1init, key2init, unpack_v8d_from_v32_S (w0), l_crc32tab);
|
||||
|
||||
for (u32 i = 4, j = 1; i < pw_len; i += 4, j += 1)
|
||||
{
|
||||
if (pw_len >= (i + 1)) update_key012 (key0init, key1init, key2init, unpack_v8a_from_v32_S (w[j]), l_crc32tab);
|
||||
if (pw_len >= (i + 2)) update_key012 (key0init, key1init, key2init, unpack_v8b_from_v32_S (w[j]), l_crc32tab);
|
||||
if (pw_len >= (i + 3)) update_key012 (key0init, key1init, key2init, unpack_v8c_from_v32_S (w[j]), l_crc32tab);
|
||||
if (pw_len >= (i + 4)) update_key012 (key0init, key1init, key2init, unpack_v8d_from_v32_S (w[j]), l_crc32tab);
|
||||
}
|
||||
|
||||
u32 plain;
|
||||
u32 key3;
|
||||
u32 next;
|
||||
|
||||
for (u32 idx = 0; idx < hash_count; idx++)
|
||||
{
|
||||
u32x key0 = key0init;
|
||||
u32x key1 = key1init;
|
||||
u32x key2 = key2init;
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8b_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8c_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8b_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8c_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8b_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8c_from_v32_S (next) ^ key3;
|
||||
if ((checksum_size == 2) && ((esalt_bufs[digests_offset].hashes[idx].checksum_from_crc & 0xff) != plain) && ((esalt_bufs[digests_offset].hashes[idx].checksum_from_timestamp & 0xff) != plain)) break;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
if ((plain != (esalt_bufs[digests_offset].hashes[idx].checksum_from_crc >> 8)) && (plain != (esalt_bufs[digests_offset].hashes[idx].checksum_from_timestamp >> 8))) break;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
if ((plain & 6) == 0 || (plain & 6) == 6) break;
|
||||
|
||||
if (idx + 1 == esalt_bufs[digests_offset].hash_count)
|
||||
{
|
||||
/**
|
||||
* digest
|
||||
*/
|
||||
|
||||
const u32 search[4] =
|
||||
{
|
||||
esalt_bufs[digests_offset].hashes[0].checksum_from_crc,
|
||||
0,
|
||||
0,
|
||||
0
|
||||
};
|
||||
|
||||
const u32 r0 = esalt_bufs[digests_offset].hashes[0].checksum_from_crc;
|
||||
const u32 r1 = 0;
|
||||
const u32 r2 = 0;
|
||||
const u32 r3 = 0;
|
||||
|
||||
COMPARE_S_SIMD (r0, r1, r2, r3);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
KERNEL_FQ void m17230_mxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
{
|
||||
/**
|
||||
* modifier
|
||||
*/
|
||||
|
||||
const u64 gid = get_global_id (0);
|
||||
const u64 lid = get_local_id (0);
|
||||
const u64 lsz = get_local_size (0);
|
||||
|
||||
/**
|
||||
* sbox, kbox
|
||||
*/
|
||||
|
||||
LOCAL_VK u32 l_crc32tab[256];
|
||||
|
||||
for (u64 i = lid; i < 256; i += lsz)
|
||||
{
|
||||
l_crc32tab[i] = crc32tab[i];
|
||||
l_data[i] = esalt_bufs[digests_offset].hashes[0].data[i];
|
||||
}
|
||||
|
||||
SYNC_THREADS();
|
||||
@ -477,7 +313,8 @@ KERNEL_FQ void m17230_mxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
u32x key1 = key1init;
|
||||
u32x key2 = key2init;
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
if (idx == 0) next = l_data[0];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -495,7 +332,8 @@ KERNEL_FQ void m17230_mxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
if (idx == 0) next = l_data[1];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -513,7 +351,8 @@ KERNEL_FQ void m17230_mxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
if (idx == 0) next = l_data[2];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
@ -533,7 +372,194 @@ KERNEL_FQ void m17230_mxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
if ((plain != (esalt_bufs[digests_offset].hashes[idx].checksum_from_crc >> 8)) && (plain != (esalt_bufs[digests_offset].hashes[idx].checksum_from_timestamp >> 8))) break;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
if (idx == 0) next = l_data[3];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
if ((plain & 6) == 0 || (plain & 6) == 6) break;
|
||||
|
||||
if (idx + 1 == hash_count)
|
||||
{
|
||||
/**
|
||||
* digest
|
||||
*/
|
||||
|
||||
const u32 search[4] =
|
||||
{
|
||||
esalt_bufs[digests_offset].hashes[0].checksum_from_crc,
|
||||
0,
|
||||
0,
|
||||
0
|
||||
};
|
||||
|
||||
const u32 r0 = esalt_bufs[digests_offset].hashes[0].checksum_from_crc;
|
||||
const u32 r1 = 0;
|
||||
const u32 r2 = 0;
|
||||
const u32 r3 = 0;
|
||||
|
||||
COMPARE_S_SIMD (r0, r1, r2, r3);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
KERNEL_FQ void m17230_mxx (KERN_ATTR_VECTOR_ESALT (pkzip_t))
|
||||
{
|
||||
/**
|
||||
* modifier
|
||||
*/
|
||||
|
||||
const u64 gid = get_global_id (0);
|
||||
const u64 lid = get_local_id (0);
|
||||
const u64 lsz = get_local_size (0);
|
||||
|
||||
/**
|
||||
* sbox, kbox
|
||||
*/
|
||||
|
||||
LOCAL_VK u32 l_crc32tab[256];
|
||||
|
||||
for (u64 i = lid; i < 256; i += lsz)
|
||||
{
|
||||
l_crc32tab[i] = crc32tab[i];
|
||||
}
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
LOCAL_VK u32 l_data[MAX_LOCAL];
|
||||
|
||||
for (u64 i = lid; i < MAX_LOCAL; i += lsz)
|
||||
{
|
||||
l_data[i] = esalt_bufs[digests_offset].hashes[0].data[i];
|
||||
}
|
||||
|
||||
SYNC_THREADS();
|
||||
|
||||
if (gid >= gid_max) return;
|
||||
|
||||
/**
|
||||
* base
|
||||
*/
|
||||
|
||||
const u32 pw_len = pws[gid].pw_len;
|
||||
|
||||
u32x w[64] = { 0 };
|
||||
|
||||
for (int i = 0, idx = 0; i < pw_len; i += 4, idx += 1)
|
||||
{
|
||||
w[idx] = pws[gid].i[idx];
|
||||
}
|
||||
|
||||
/**
|
||||
* prefetch from global memory
|
||||
*/
|
||||
|
||||
const u32 checksum_size = esalt_bufs[digests_offset].checksum_size;
|
||||
const u32 hash_count = esalt_bufs[digests_offset].hash_count;
|
||||
|
||||
/**
|
||||
* loop
|
||||
*/
|
||||
|
||||
u32 w0l = w[0];
|
||||
|
||||
for (u32 il_pos = 0; il_pos < il_cnt; il_pos += VECT_SIZE)
|
||||
{
|
||||
const u32x w0r = words_buf_r[il_pos / VECT_SIZE];
|
||||
|
||||
const u32x w0 = w0l | w0r;
|
||||
|
||||
w[0] = w0;
|
||||
|
||||
u32x key0init = 0x12345678;
|
||||
u32x key1init = 0x23456789;
|
||||
u32x key2init = 0x34567890;
|
||||
|
||||
if (pw_len >= 1) update_key012 (key0init, key1init, key2init, unpack_v8a_from_v32_S (w0), l_crc32tab);
|
||||
if (pw_len >= 2) update_key012 (key0init, key1init, key2init, unpack_v8b_from_v32_S (w0), l_crc32tab);
|
||||
if (pw_len >= 3) update_key012 (key0init, key1init, key2init, unpack_v8c_from_v32_S (w0), l_crc32tab);
|
||||
if (pw_len >= 4) update_key012 (key0init, key1init, key2init, unpack_v8d_from_v32_S (w0), l_crc32tab);
|
||||
|
||||
for (u32 i = 4, j = 1; i < pw_len; i += 4, j += 1)
|
||||
{
|
||||
if (pw_len >= (i + 1)) update_key012 (key0init, key1init, key2init, unpack_v8a_from_v32_S (w[j]), l_crc32tab);
|
||||
if (pw_len >= (i + 2)) update_key012 (key0init, key1init, key2init, unpack_v8b_from_v32_S (w[j]), l_crc32tab);
|
||||
if (pw_len >= (i + 3)) update_key012 (key0init, key1init, key2init, unpack_v8c_from_v32_S (w[j]), l_crc32tab);
|
||||
if (pw_len >= (i + 4)) update_key012 (key0init, key1init, key2init, unpack_v8d_from_v32_S (w[j]), l_crc32tab);
|
||||
}
|
||||
|
||||
u32 plain;
|
||||
u32 key3;
|
||||
u32 next;
|
||||
|
||||
for (u32 idx = 0; idx < hash_count; idx++)
|
||||
{
|
||||
u32x key0 = key0init;
|
||||
u32x key1 = key1init;
|
||||
u32x key2 = key2init;
|
||||
|
||||
if (idx == 0) next = l_data[0];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[0];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8b_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8c_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
if (idx == 0) next = l_data[1];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[1];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8b_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8c_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
if (idx == 0) next = l_data[2];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[2];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8b_from_v32_S (next) ^ key3;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8c_from_v32_S (next) ^ key3;
|
||||
if ((checksum_size == 2) && ((esalt_bufs[digests_offset].hashes[idx].checksum_from_crc & 0xff) != plain) && ((esalt_bufs[digests_offset].hashes[idx].checksum_from_timestamp & 0xff) != plain)) break;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8d_from_v32_S (next) ^ key3;
|
||||
if ((plain != (esalt_bufs[digests_offset].hashes[idx].checksum_from_crc >> 8)) && (plain != (esalt_bufs[digests_offset].hashes[idx].checksum_from_timestamp >> 8))) break;
|
||||
update_key012 (key0, key1, key2, plain, l_crc32tab);
|
||||
|
||||
if (idx == 0) next = l_data[3];
|
||||
else next = esalt_bufs[digests_offset].hashes[idx].data[3];
|
||||
|
||||
update_key3 (key2, key3);
|
||||
plain = unpack_v8a_from_v32_S (next) ^ key3;
|
||||
|
Loading…
Reference in New Issue
Block a user