2017-09-24 22:13:16 +03:00
|
|
|
|
2017-10-23 02:15:23 +00:00
|
|
|
void Keccak(u32 r, const u8 *in, u64 inLen, u8 sfx, u8 *out, u64 outLen);
|
2017-09-24 22:13:16 +03:00
|
|
|
|
|
|
|
#define FIPS202_SHA3_224_LEN 28
|
|
|
|
#define FIPS202_SHA3_256_LEN 32
|
|
|
|
#define FIPS202_SHA3_384_LEN 48
|
|
|
|
#define FIPS202_SHA3_512_LEN 64
|
|
|
|
|
2017-10-23 02:15:23 +00:00
|
|
|
static inline void FIPS202_SHAKE128(const u8 *in, u64 inLen, u8 *out, u64 outLen) { Keccak(1344, in, inLen, 0x1F, out, outLen); }
|
|
|
|
static inline void FIPS202_SHAKE256(const u8 *in, u64 inLen, u8 *out, u64 outLen) { Keccak(1088, in, inLen, 0x1F, out, outLen); }
|
|
|
|
static inline void FIPS202_SHA3_224(const u8 *in, u64 inLen, u8 *out) { Keccak(1152, in, inLen, 0x06, out, 28); }
|
|
|
|
static inline void FIPS202_SHA3_256(const u8 *in, u64 inLen, u8 *out) { Keccak(1088, in, inLen, 0x06, out, 32); }
|
|
|
|
static inline void FIPS202_SHA3_384(const u8 *in, u64 inLen, u8 *out) { Keccak(832, in, inLen, 0x06, out, 48); }
|
|
|
|
static inline void FIPS202_SHA3_512(const u8 *in, u64 inLen, u8 *out) { Keccak(576, in, inLen, 0x06, out, 64); }
|