diff options
author | David Phillips <david@sighup.nz> | 2018-07-13 22:52:32 +1200 |
---|---|---|
committer | David Phillips <david@sighup.nz> | 2018-07-13 22:53:24 +1200 |
commit | 615d0c5cf3ddc749a6d0a1288789cf882df80a5a (patch) | |
tree | 4216353e471d1e3871151a99d36180c14d3e9cf2 /cl | |
parent | 2d0a9e8f9db2b10a5abdfd5529f2e3d07ad357b9 (diff) | |
download | sand-leek-615d0c5cf3ddc749a6d0a1288789cf882df80a5a.tar.xz |
Revert "Marginally improve GPU comparison speed"
This reverts commit 133dd90a0de29b7c24217ca87af57ede4da1247b.
That commit introduced silly bugs
Diffstat (limited to 'cl')
-rw-r--r-- | cl/onion.cl | 46 |
1 files changed, 7 insertions, 39 deletions
diff --git a/cl/onion.cl b/cl/onion.cl index e6835b9..66075a9 100644 --- a/cl/onion.cl +++ b/cl/onion.cl @@ -120,6 +120,7 @@ __kernel void key_brute( const unsigned int bitmask) { unsigned int tx = get_global_id(0); + unsigned int ty = get_global_id(1); unsigned int i,j; struct sha_data ctx; @@ -158,48 +159,15 @@ __kernel void key_brute( ctx.data[INITIAL_DATA_LEN + 3] = i; ///////////////////////////////////////////////////////////// sha_final(&digest, &ctx); - int all_clear; - switch (raw_length) { - case 10: /* nop */ break; - case 9: all_clear = (search[9] & bitmask) == (bitmask & (ctx.c >> 24)); break; - case 8: all_clear = (search[8] & bitmask) == (bitmask & (ctx.b )); break; - case 7: all_clear = (search[7] & bitmask) == (bitmask & (ctx.b >> 8)); break; - case 6: all_clear = (search[6] & bitmask) == (bitmask & (ctx.b >> 16)); break; - case 5: /* nop */ break; - case 4: all_clear = (search[4] & bitmask) == (bitmask & (ctx.b >> 24)); break; - case 3: all_clear = (search[3] & bitmask) == (bitmask & (ctx.a )); break; - case 2: all_clear = (search[2] & bitmask) == (bitmask & (ctx.a >> 8)); break; - case 1: all_clear = (search[1] & bitmask) == (bitmask & (ctx.a >> 16)); break; - case 0: all_clear = (search[0] & bitmask) == (bitmask & (ctx.a >> 24)); break; - - } - - switch (raw_length) { - case 10: all_clear &= (search[9] == ctx.c >> 16); /* fallthrough */ - case 9: all_clear &= (search[8] == ctx.c >> 24); /* fallthrough */ - case 8: all_clear &= (search[7] == ctx.b); /* fallthrough */ - case 7: all_clear &= (search[6] == ctx.b >> 8); /* fallthrough */ - case 6: all_clear &= (search[5] == ctx.b >> 16); /* fallthrough */ - case 5: all_clear &= (search[4] == ctx.b >> 24); /* fallthrough */ - case 4: all_clear &= (search[3] == ctx.a); /* fallthrough */ - case 3: all_clear &= (search[2] == ctx.a >> 8); /* fallthrough */ - case 2: all_clear &= (search[1] == ctx.a >> 16); /* fallthrough */ - case 1: all_clear &= (search[0] == ctx.a >> 24); /* fallthrough */ - case 0: /* nop */; + int all_clear = 1; + for (j = 0; j < raw_length; j++) { + if (search[j] != digest[j]) { + all_clear = 0; + } } - if (all_clear != 0) { + if (all_clear == 1 && (digest[j] & bitmask) == (search[j] & bitmask)) { results[tx] = i; } - -// int all_clear = 1; -// for (j = 0; j < raw_length; j++) { -// if (search[j] != digest[j]) { -// all_clear = 0; -// } -// } -// if (all_clear == 1 && (digest[j] & bitmask) == (search[j] & bitmask)) { -// results[tx] = i; -// } } return; |