Skip to content

Instantly share code, notes, and snippets.

@mrecachinas
Last active April 14, 2020 15:05
Show Gist options
  • Save mrecachinas/7451fc93219dc0d57c13db405b8f7788 to your computer and use it in GitHub Desktop.
Save mrecachinas/7451fc93219dc0d57c13db405b8f7788 to your computer and use it in GitHub Desktop.
Tiny-Keccac Testing
[package]
name = "keccak-test"
version = "0.1.0"
authors = ["Michael Recachinas <mike@recachinas.dev>"]
edition = "2018"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[dependencies]
tiny-keccak = { version = "2.0", features = ["cshake", "kmac"] }
sp800-185 = "0.2.0"
use tiny_keccak::{CShake, Kmac, Hasher};
fn main() {
let name = b"";
let key = b"\x40\x41\x42\x43\x44\x45\x46\x47\x48\x49\x4A\x4B\x4C\x4D\x4E\x4F\x50\x51\x52\x53\x54\x55\x56\x57\x58\x59\x5A\x5B\x5C\x5D\x5E\x5F";
let customization = b"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA";
let mut c128 = CShake::v128(name, customization);
let mut c256 = CShake::v256(name, customization);
let mut k128 = Kmac::v128(key, customization);
let mut k256 = Kmac::v256(key, customization);
let data = b"\x00\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0A\x0B\x0C\x0D\x0E\x0F\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1A\x1B\x1C\x1D\x1E\x1F\x20\x21\x22\x23\x24\x25\x26\x27\x28\x29\x2A\x2B\x2C\x2D\x2E\x2F\x30\x31\x32\x33\x34\x35\x36\x37\x38\x39\x3A\x3B\x3C\x3D\x3E\x3F\x40\x41\x42\x43\x44\x45\x46\x47\x48\x49\x4A\x4B\x4C\x4D\x4E\x4F\x50\x51\x52\x53\x54\x55\x56\x57\x58\x59\x5A\x5B\x5C\x5D\x5E\x5F\x60\x61\x62\x63\x64\x65\x66\x67\x68\x69\x6A\x6B\x6C\x6D\x6E\x6F\x70\x71\x72\x73\x74\x75\x76\x77\x78\x79\x7A\x7B\x7C\x7D\x7E\x7F\x80\x81\x82\x83\x84\x85\x86\x87\x88\x89\x8A\x8B\x8C\x8D\x8E\x8F\x90\x91\x92\x93\x94\x95\x96\x97\x98\x99\x9A\x9B\x9C\x9D\x9E\x9F\xA0\xA1\xA2\xA3\xA4\xA5\xA6\xA7\xA8\xA9\xAA\xAB\xAC\xAD\xAE\xAF\xB0\xB1\xB2\xB3\xB4\xB5\xB6\xB7\xB8\xB9\xBA\xBB\xBC\xBD\xBE\xBF\xC0\xC1\xC2\xC3\xC4\xC5\xC6\xC7";
let mut output_c128 = [0u8; 32];
let mut output_c256 = [0u8; 64];
let mut output_k128 = [0u8; 32];
let mut output_k256 = [0u8; 64];
c128.update(data);
c128.finalize(&mut output_c128);
c256.update(data);
c256.finalize(&mut output_c256);
k128.update(data);
k128.finalize(&mut output_k128);
k256.update(data);
k256.finalize(&mut output_k256);
println!("CShake128 -- {:?}", output_c128);
print!("Cshake256 -- [ ");
for i in 0..64 {
print!("{:?}, ", output_c256[i]);
}
print!("]\n");
println!("Kmac128 -- {:?}", output_k128);
print!("Kmac256 -- [ ");
for i in 0..64 {
print!("{:?}, ", output_k256[i]);
}
print!("]\n");
}

Tiny-Keccak Results

CShake128 -- [228, 228, 65, 38, 51, 38, 115, 20, 49, 32, 248, 241, 209, 96, 237, 16, 59, 67, 39, 119, 135, 173, 246, 79, 197, 248, 110, 208, 143, 30, 1, 221]
Cshake256 -- [ 108, 59, 192, 211, 89, 50, 222, 84, 49, 23, 6, 102, 143, 234, 74, 3, 208, 68, 179, 46, 194, 237, 108, 181, 37, 214, 37, 85, 108, 117, 177, 48, 163, 61, 131, 102, 48, 214, 42, 198, 16, 196, 226, 200, 117, 55, 131, 188, 91, 16, 70, 203, 149, 250, 192, 55, 126, 195, 238, 6, 82, 86, 81, 184, ]
Kmac128 -- [48, 142, 218, 241, 196, 255, 172, 0, 79, 221, 98, 218, 92, 82, 1, 17, 89, 192, 244, 95, 182, 203, 86, 73, 64, 217, 91, 206, 196, 184, 227, 105]
Kmac256 -- [ 175, 78, 174, 182, 159, 95, 223, 52, 224, 144, 186, 246, 234, 171, 30, 57, 133, 248, 190, 240, 42, 119, 185, 79, 96, 39, 14, 127, 166, 19, 44, 168, 200, 153, 173, 44, 142, 122, 118, 128, 217, 209, 151, 3, 156, 114, 186, 100, 10, 32, 229, 204, 233, 120, 54, 87, 145, 80, 35, 134, 205, 127, 19, 184, ]

SP800-185 Results

CShake128 -- [228, 228, 65, 38, 51, 38, 115, 20, 49, 32, 248, 241, 209, 96, 237, 16, 59, 67, 39, 119, 135, 173, 246, 79, 197, 248, 110, 208, 143, 30, 1, 221]
Cshake256 -- [ 108, 59, 192, 211, 89, 50, 222, 84, 49, 23, 6, 102, 143, 234, 74, 3, 208, 68, 179, 46, 194, 237, 108, 181, 37, 214, 37, 85, 108, 117, 177, 48, 163, 61, 131, 102, 48, 214, 42, 198, 16, 196, 226, 200, 117, 55, 131, 188, 91, 16, 70, 203, 149, 250, 192, 55, 126, 195, 238, 6, 82, 86, 81, 184, ]
Kmac128 -- [48, 142, 218, 241, 196, 255, 172, 0, 79, 221, 98, 218, 92, 82, 1, 17, 89, 192, 244, 95, 182, 203, 86, 73, 64, 217, 91, 206, 196, 184, 227, 105]
Kmac256 -- [ 175, 78, 174, 182, 159, 95, 223, 52, 224, 144, 186, 246, 234, 171, 30, 57, 133, 248, 190, 240, 42, 119, 185, 79, 96, 39, 14, 127, 166, 19, 44, 168, 200, 153, 173, 44, 142, 122, 118, 128, 217, 209, 151, 3, 156, 114, 186, 100, 10, 32, 229, 204, 233, 120, 54, 87, 145, 80, 35, 134, 205, 127, 19, 184, ]
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment