|
@ -332,10 +332,8 @@ __device__ __forceinline__ void keccak_f1600_init(uint2* state) |
|
|
/* iota: a[0,0] ^= round constant */ |
|
|
/* iota: a[0,0] ^= round constant */ |
|
|
s[0] ^= vectorize(keccak_round_constants[23]); |
|
|
s[0] ^= vectorize(keccak_round_constants[23]); |
|
|
|
|
|
|
|
|
for(uint32_t i=0; i<12; i++) |
|
|
for(int i=0; i<12; ++i) |
|
|
{ |
|
|
|
|
|
state[i] = s[i]; |
|
|
state[i] = s[i]; |
|
|
} |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
__device__ __forceinline__ uint64_t keccak_f1600_final(uint2* state) |
|
|
__device__ __forceinline__ uint64_t keccak_f1600_final(uint2* state) |
|
@ -343,10 +341,9 @@ __device__ __forceinline__ uint64_t keccak_f1600_final(uint2* state) |
|
|
uint2 s[25]; |
|
|
uint2 s[25]; |
|
|
uint2 t[5], u, v; |
|
|
uint2 t[5], u, v; |
|
|
|
|
|
|
|
|
for (uint32_t i = 0; i<12; i++) |
|
|
for (int i = 0; i<12; ++i) |
|
|
{ |
|
|
|
|
|
s[i] = state[i]; |
|
|
s[i] = state[i]; |
|
|
} |
|
|
|
|
|
for (uint32_t i = 12; i < 25; i++) |
|
|
for (uint32_t i = 12; i < 25; i++) |
|
|
{ |
|
|
{ |
|
|
s[i] = make_uint2(0, 0); |
|
|
s[i] = make_uint2(0, 0); |
|
|