void lyra2re3_hash(const char* input, char* output) { sph_blake256_context ctx_blake; sph_cubehash256_context ctx_cubehash; sph_bmw256_context ctx_bmw; uint32_t hashA[8], hashB[8]; sph_blake256_init(&ctx_blake); sph_blake256(&ctx_blake, input, 80); sph_blake256_close (&ctx_blake, hashA); LYRA2_3(hashB, 32, hashA, 32, hashA, 32, 1, 4, 4); sph_cubehash256_init(&ctx_cubehash); sph_cubehash256(&ctx_cubehash, hashB, 32); sph_cubehash256_close(&ctx_cubehash, hashA); LYRA2_3(hashB, 32, hashA, 32, hashA, 32, 1, 4, 4); sph_bmw256_init(&ctx_bmw); sph_bmw256(&ctx_bmw, hashB, 32); sph_bmw256_close(&ctx_bmw, hashA); memcpy(output, hashA, 32); }
inline void lyra2rev2hash(void *state, const void *input) { sph_blake256_context ctx_blake; sph_bmw256_context ctx_bmw; sph_keccak256_context ctx_keccak; sph_skein256_context ctx_skein; sph_cubehash256_context ctx_cube; uint32_t hashA[8], hashB[8]; sph_blake256_init(&ctx_blake); sph_blake256 (&ctx_blake, input, 80); sph_blake256_close (&ctx_blake, hashA); sph_keccak256_init(&ctx_keccak); sph_keccak256 (&ctx_keccak,hashA, 32); sph_keccak256_close(&ctx_keccak, hashB); sph_cubehash256_init(&ctx_cube); sph_cubehash256(&ctx_cube, hashB, 32); sph_cubehash256_close(&ctx_cube, hashA); LYRA2(hashB, 32, hashA, 32, hashA, 32, 1, 4, 4); sph_skein256_init(&ctx_skein); sph_skein256 (&ctx_skein, hashB, 32); sph_skein256_close(&ctx_skein, hashA); sph_cubehash256_init(&ctx_cube); sph_cubehash256(&ctx_cube, hashA, 32); sph_cubehash256_close(&ctx_cube, hashB); sph_bmw256_init(&ctx_bmw); sph_bmw256 (&ctx_bmw, hashB, 32); sph_bmw256_close(&ctx_bmw, hashA); //printf("cpu hash %08x %08x %08x %08x\n",hashA[0],hashA[1],hashA[2],hashA[3]); memcpy(state, hashA, 32); }
/* see sph_bmw.h */ void sph_bmw256_addbits_and_close(void *cc, unsigned ub, unsigned n, void *dst) { bmw32_close(cc, ub, n, dst, 8); sph_bmw256_init(cc); }