Adds test vectors specified in skein v1.3 specification. The main code is still in staging directory, but this is required to eventually be moved to the crypto directory. Signed-off-by: Juan Manuel Torres Palma <j.m.torrespalma@xxxxxxxxx> --- crypto/testmgr.c | 21 ++++++ crypto/testmgr.h | 203 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 224 insertions(+) diff --git a/crypto/testmgr.c b/crypto/testmgr.c index 11e45352fd0b..9fa08cbc8852 100644 --- a/crypto/testmgr.c +++ b/crypto/testmgr.c @@ -3453,6 +3453,27 @@ static const struct alg_test_desc alg_test_descs[] = { .suite = { .hash = __VECS(sha512_tv_template) } + }, { + .alg = "skein1024", + .test = alg_test_hash, + .fips_allowed = 1, + .suite = { + .hash = __VECS(skein1024_tv_template) + } + }, { + .alg = "skein256", + .test = alg_test_hash, + .fips_allowed = 1, + .suite = { + .hash = __VECS(skein256_tv_template) + } + }, { + .alg = "skein512", + .test = alg_test_hash, + .fips_allowed = 1, + .suite = { + .hash = __VECS(skein512_tv_template) + } }, { .alg = "sm3", .test = alg_test_hash, diff --git a/crypto/testmgr.h b/crypto/testmgr.h index b950aa234e43..50239e84e283 100644 --- a/crypto/testmgr.h +++ b/crypto/testmgr.h @@ -1699,6 +1699,209 @@ static const struct hash_testvec sha3_512_tv_template[] = { }, }; +/* + * Skein test vectors from skein specification v1.3 + */ +static const struct hash_testvec skein256_tv_template[] = { + { + .plaintext = "\xff", + .psize = 1, + .digest = "\x0b\x98\xdc\xd1\x98\xea\x0e\x50" + "\xa7\xa2\x44\xc4\x44\xe2\x5c\x23" + "\xda\x30\xc1\x0f\xc9\xa1\xf2\x70" + "\xa6\x63\x7f\x1f\x34\xe6\x7e\xd2", + }, { + .plaintext = "\xff\xfe\xfd\xfc\xfb\xfa\xf9\xf8" + "\xf7\xf6\xf5\xf4\xf3\xf2\xf1\xf0" + "\xef\xee\xed\xec\xeb\xea\xe9\xe8" + "\xe7\xe6\xe5\xe4\xe3\xe2\xe1\xe0", + .psize = 32, + .digest = "\x8d\x0f\xa4\xef\x77\x7f\xd7\x59" + "\xdf\xd4\x04\x4e\x6f\x6a\x5a\xc3" + "\xc7\x74\xae\xc9\x43\xdc\xfc\x07" + "\x92\x7b\x72\x3b\x5d\xbf\x40\x8b", + }, { + .plaintext = "\xff\xfe\xfd\xfc\xfb\xfa\xf9\xf8" + "\xf7\xf6\xf5\xf4\xf3\xf2\xf1\xf0" + "\xef\xee\xed\xec\xeb\xea\xe9\xe8" + "\xe7\xe6\xe5\xe4\xe3\xe2\xe1\xe0" + "\xdf\xde\xdd\xdc\xdb\xda\xd9\xd8" + "\xd7\xd6\xd5\xd4\xd3\xd2\xd1\xd0" + "\xcf\xce\xcd\xcc\xcb\xca\xc9\xc8" + "\xc7\xc6\xc5\xc4\xc3\xc2\xc1\xc0", + .psize = 64, + .digest = "\xdf\x28\xe9\x16\x63\x0d\x0b\x44" + "\xc4\xa8\x49\xdc\x9a\x02\xf0\x7a" + "\x07\xcb\x30\xf7\x32\x31\x82\x56" + "\xb1\x5d\x86\x5a\xc4\xae\x16\x2f", + } +}; + +static const struct hash_testvec skein512_tv_template[] = { + { + .plaintext = "\xff", + .psize = 1, + .digest = "\x71\xb7\xbc\xe6\xfe\x64\x52\x22" + "\x7b\x9c\xed\x60\x14\x24\x9e\x5b" + "\xf9\xa9\x75\x4c\x3a\xd6\x18\xcc" + "\xc4\xe0\xaa\xe1\x6b\x31\x6c\xc8" + "\xca\x69\x8d\x86\x43\x07\xed\x3e" + "\x80\xb6\xef\x15\x70\x81\x2a\xc5" + "\x27\x2d\xc4\x09\xb5\xa0\x12\xdf" + "\x2a\x57\x91\x02\xf3\x40\x61\x7a", + }, { + .plaintext = "\xff\xfe\xfd\xfc\xfb\xfa\xf9\xf8" + "\xf7\xf6\xf5\xf4\xf3\xf2\xf1\xf0" + "\xef\xee\xed\xec\xeb\xea\xe9\xe8" + "\xe7\xe6\xe5\xe4\xe3\xe2\xe1\xe0" + "\xdf\xde\xdd\xdc\xdb\xda\xd9\xd8" + "\xd7\xd6\xd5\xd4\xd3\xd2\xd1\xd0" + "\xcf\xce\xcd\xcc\xcb\xca\xc9\xc8" + "\xc7\xc6\xc5\xc4\xc3\xc2\xc1\xc0", + .psize = 64, + .digest = "\x45\x86\x3b\xa3\xbe\x0c\x4d\xfc" + "\x27\xe7\x5d\x35\x84\x96\xf4\xac" + "\x9a\x73\x6a\x50\x5d\x93\x13\xb4" + "\x2b\x2f\x5e\xad\xa7\x9f\xc1\x7f" + "\x63\x86\x1e\x94\x7a\xfb\x1d\x05" + "\x6a\xa1\x99\x57\x5a\xd3\xf8\xc9" + "\xa3\xcc\x17\x80\xb5\xe5\xfa\x4c" + "\xae\x05\x0e\x98\x98\x76\x62\x5b", + }, { + .plaintext = "\xff\xfe\xfd\xfc\xfb\xfa\xf9\xf8" + "\xf7\xf6\xf5\xf4\xf3\xf2\xf1\xf0" + "\xef\xee\xed\xec\xeb\xea\xe9\xe8" + "\xe7\xe6\xe5\xe4\xe3\xe2\xe1\xe0" + "\xdf\xde\xdd\xdc\xdb\xda\xd9\xd8" + "\xd7\xd6\xd5\xd4\xd3\xd2\xd1\xd0" + "\xcf\xce\xcd\xcc\xcb\xca\xc9\xc8" + "\xc7\xc6\xc5\xc4\xc3\xc2\xc1\xc0" + "\xbf\xbe\xbd\xbc\xbb\xba\xb9\xb8" + "\xb7\xb6\xb5\xb4\xb3\xb2\xb1\xb0" + "\xaf\xae\xad\xac\xab\xaa\xa9\xa8" + "\xa7\xa6\xa5\xa4\xa3\xa2\xa1\xa0" + "\x9f\x9e\x9d\x9c\x9b\x9a\x99\x98" + "\x97\x96\x95\x94\x93\x92\x91\x90" + "\x8f\x8e\x8d\x8c\x8b\x8a\x89\x88" + "\x87\x86\x85\x84\x83\x82\x81\x80", + .psize = 128, + .digest = "\x91\xcc\xa5\x10\xc2\x63\xc4\xdd" + "\xd0\x10\x53\x0a\x33\x07\x33\x09" + "\x62\x86\x31\xf3\x08\x74\x7e\x1b" + "\xcb\xaa\x90\xe4\x51\xca\xb9\x2e" + "\x51\x88\x08\x7a\xf4\x18\x87\x73" + "\xa3\x32\x30\x3e\x66\x67\xa7\xa2" + "\x10\x85\x6f\x74\x21\x39\x00\x00" + "\x71\xf4\x8e\x8b\xa2\xa5\xad\xb7", + } +}; + +static const struct hash_testvec skein1024_tv_template[] = { + { + .plaintext = "\xff", + .psize = 1, + .digest = "\xe6\x2c\x05\x80\x2e\xa0\x15\x24" + "\x07\xcd\xd8\x78\x7f\xda\x9e\x35" + "\x70\x3d\xe8\x62\xa4\xfb\xc1\x19" + "\xcf\xf8\x59\x0a\xfe\x79\x25\x0b" + "\xcc\xc8\xb3\xfa\xf1\xbd\x24\x22" + "\xab\x5c\x0d\x26\x3f\xb2\xf8\xaf" + "\xb3\xf7\x96\xf0\x48\x00\x03\x81" + "\x53\x1b\x6f\x00\xd8\x51\x61\xbc" + "\x0f\xff\x4b\xef\x24\x86\xb1\xeb" + "\xcd\x37\x73\xfa\xbf\x50\xad\x4a" + "\xd5\x63\x9a\xf9\x04\x0e\x3f\x29" + "\xc6\xc9\x31\x30\x1b\xf7\x98\x32" + "\xe9\xda\x09\x85\x7e\x83\x1e\x82" + "\xef\x8b\x46\x91\xc2\x35\x65\x65" + "\x15\xd4\x37\xd2\xbd\xa3\x3b\xce" + "\xc0\x01\xc6\x7f\xfd\xe1\x5b\xa8", + }, { + .plaintext = "\xff\xfe\xfd\xfc\xfb\xfa\xf9\xf8" + "\xf7\xf6\xf5\xf4\xf3\xf2\xf1\xf0" + "\xef\xee\xed\xec\xeb\xea\xe9\xe8" + "\xe7\xe6\xe5\xe4\xe3\xe2\xe1\xe0" + "\xdf\xde\xdd\xdc\xdb\xda\xd9\xd8" + "\xd7\xd6\xd5\xd4\xd3\xd2\xd1\xd0" + "\xcf\xce\xcd\xcc\xcb\xca\xc9\xc8" + "\xc7\xc6\xc5\xc4\xc3\xc2\xc1\xc0" + "\xbf\xbe\xbd\xbc\xbb\xba\xb9\xb8" + "\xb7\xb6\xb5\xb4\xb3\xb2\xb1\xb0" + "\xaf\xae\xad\xac\xab\xaa\xa9\xa8" + "\xa7\xa6\xa5\xa4\xa3\xa2\xa1\xa0" + "\x9f\x9e\x9d\x9c\x9b\x9a\x99\x98" + "\x97\x96\x95\x94\x93\x92\x91\x90" + "\x8f\x8e\x8d\x8c\x8b\x8a\x89\x88" + "\x87\x86\x85\x84\x83\x82\x81\x80", + .psize = 128, + .digest = "\x1f\x3e\x02\xc4\x6f\xb8\x0a\x3f" + "\xcd\x2d\xfb\xbc\x7c\x17\x38\x00" + "\xb4\x0c\x60\xc2\x35\x4a\xf5\x51" + "\x18\x9e\xbf\x43\x3c\x3d\x85\xf9" + "\xff\x18\x03\xe6\xd9\x20\x49\x31" + "\x79\xed\x7a\xe7\xfc\xe6\x9c\x35" + "\x81\xa5\xa2\xf8\x2d\x3e\x0c\x7a" + "\x29\x55\x74\xd0\xcd\x7d\x21\x7c" + "\x48\x4d\x2f\x63\x13\xd5\x9a\x77" + "\x18\xea\xd0\x7d\x07\x29\xc2\x48" + "\x51\xd7\xe7\xd2\x49\x1b\x90\x2d" + "\x48\x91\x94\xe6\xb7\xd3\x69\xdb" + "\x0a\xb7\xaa\x10\x6f\x0e\xe0\xa3" + "\x9a\x42\xef\xc5\x4f\x18\xd9\x37" + "\x76\x08\x09\x85\xf9\x07\x57\x4f" + "\x99\x5e\xc6\xa3\x71\x53\xa5\x78", + }, { + .plaintext = "\xff\xfe\xfd\xfc\xfb\xfa\xf9\xf8" + "\xf7\xf6\xf5\xf4\xf3\xf2\xf1\xf0" + "\xef\xee\xed\xec\xeb\xea\xe9\xe8" + "\xe7\xe6\xe5\xe4\xe3\xe2\xe1\xe0" + "\xdf\xde\xdd\xdc\xdb\xda\xd9\xd8" + "\xd7\xd6\xd5\xd4\xd3\xd2\xd1\xd0" + "\xcf\xce\xcd\xcc\xcb\xca\xc9\xc8" + "\xc7\xc6\xc5\xc4\xc3\xc2\xc1\xc0" + "\xbf\xbe\xbd\xbc\xbb\xba\xb9\xb8" + "\xb7\xb6\xb5\xb4\xb3\xb2\xb1\xb0" + "\xaf\xae\xad\xac\xab\xaa\xa9\xa8" + "\xa7\xa6\xa5\xa4\xa3\xa2\xa1\xa0" + "\x9f\x9e\x9d\x9c\x9b\x9a\x99\x98" + "\x97\x96\x95\x94\x93\x92\x91\x90" + "\x8f\x8e\x8d\x8c\x8b\x8a\x89\x88" + "\x87\x86\x85\x84\x83\x82\x81\x80" + "\x7f\x7e\x7d\x7c\x7b\x7a\x79\x78" + "\x77\x76\x75\x74\x73\x72\x71\x70" + "\x6f\x6e\x6d\x6c\x6b\x6a\x69\x68" + "\x67\x66\x65\x64\x63\x62\x61\x60" + "\x5f\x5e\x5d\x5c\x5b\x5a\x59\x58" + "\x57\x56\x55\x54\x53\x52\x51\x50" + "\x4f\x4e\x4d\x4c\x4b\x4a\x49\x48" + "\x47\x46\x45\x44\x43\x42\x41\x40" + "\x3f\x3e\x3d\x3c\x3b\x3a\x39\x38" + "\x37\x36\x35\x34\x33\x32\x31\x30" + "\x2f\x2e\x2d\x2c\x2b\x2a\x29\x28" + "\x27\x26\x25\x24\x23\x22\x21\x20" + "\x1f\x1e\x1d\x1c\x1b\x1a\x19\x18" + "\x17\x16\x15\x14\x13\x12\x11\x10" + "\x0f\x0e\x0d\x0c\x0b\x0a\x09\x08" + "\x07\x06\x05\x04\x03\x02\x01\x00", + .psize = 256, + .digest = "\x84\x2a\x53\xc9\x9c\x12\xb0\xcf" + "\x80\xcf\x69\x49\x1b\xe5\xe2\xf7" + "\x51\x5d\xe8\x73\x3b\x6e\xa9\x42" + "\x2d\xfd\x67\x66\x65\xb5\xfa\x42" + "\xff\xb3\xa9\xc4\x8c\x21\x77\x77" + "\x95\x08\x48\xce\xcd\xb4\x8f\x64" + "\x0f\x81\xfb\x92\xbe\xf6\xf8\x8f" + "\x7a\x85\xc1\xf7\xcd\x14\x46\xc9" + "\x16\x1c\x0a\xfe\x8f\x25\xae\x44" + "\x4f\x40\xd3\x68\x00\x81\xc3\x5a" + "\xa4\x3f\x64\x0f\xd5\xfa\x3c\x3c" + "\x03\x0b\xcc\x06\xab\xac\x01\xd0" + "\x98\xbc\xc9\x84\xeb\xd8\x32\x27" + "\x12\x92\x1e\x00\xb1\xba\x07\xd6" + "\xd0\x1f\x26\x90\x70\x50\x25\x5e" + "\xf2\xc8\xe2\x4f\x71\x6c\x52\xa5", + } +}; /* * MD5 test vectors from RFC1321 -- 2.14.4