crypto: testmgr - Add draft-ietf-ipsecme-chacha20-poly1305 test vector
Signed-off-by: Martin Willi <martin@strongswan.org> Acked-by: Steffen Klassert <steffen.klassert@secunet.com> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
This commit is contained in:
parent
4db4ad2609
commit
5900758df1
|
@ -3401,6 +3401,21 @@ static const struct alg_test_desc alg_test_descs[] = {
|
|||
},
|
||||
}
|
||||
}
|
||||
}, {
|
||||
.alg = "rfc7539esp(chacha20,poly1305)",
|
||||
.test = alg_test_aead,
|
||||
.suite = {
|
||||
.aead = {
|
||||
.enc = {
|
||||
.vecs = rfc7539esp_enc_tv_template,
|
||||
.count = RFC7539ESP_ENC_TEST_VECTORS
|
||||
},
|
||||
.dec = {
|
||||
.vecs = rfc7539esp_dec_tv_template,
|
||||
.count = RFC7539ESP_DEC_TEST_VECTORS
|
||||
},
|
||||
}
|
||||
}
|
||||
}, {
|
||||
.alg = "rmd128",
|
||||
.test = alg_test_hash,
|
||||
|
|
179
crypto/testmgr.h
179
crypto/testmgr.h
|
@ -21288,6 +21288,185 @@ static struct aead_testvec rfc7539_dec_tv_template[] = {
|
|||
},
|
||||
};
|
||||
|
||||
/*
|
||||
* draft-irtf-cfrg-chacha20-poly1305
|
||||
*/
|
||||
#define RFC7539ESP_DEC_TEST_VECTORS 1
|
||||
#define RFC7539ESP_ENC_TEST_VECTORS 1
|
||||
static struct aead_testvec rfc7539esp_enc_tv_template[] = {
|
||||
{
|
||||
.key = "\x1c\x92\x40\xa5\xeb\x55\xd3\x8a"
|
||||
"\xf3\x33\x88\x86\x04\xf6\xb5\xf0"
|
||||
"\x47\x39\x17\xc1\x40\x2b\x80\x09"
|
||||
"\x9d\xca\x5c\xbc\x20\x70\x75\xc0"
|
||||
"\x00\x00\x00\x00",
|
||||
.klen = 36,
|
||||
.iv = "\x01\x02\x03\x04\x05\x06\x07\x08",
|
||||
.assoc = "\xf3\x33\x88\x86\x00\x00\x00\x00"
|
||||
"\x00\x00\x4e\x91",
|
||||
.alen = 12,
|
||||
.input = "\x49\x6e\x74\x65\x72\x6e\x65\x74"
|
||||
"\x2d\x44\x72\x61\x66\x74\x73\x20"
|
||||
"\x61\x72\x65\x20\x64\x72\x61\x66"
|
||||
"\x74\x20\x64\x6f\x63\x75\x6d\x65"
|
||||
"\x6e\x74\x73\x20\x76\x61\x6c\x69"
|
||||
"\x64\x20\x66\x6f\x72\x20\x61\x20"
|
||||
"\x6d\x61\x78\x69\x6d\x75\x6d\x20"
|
||||
"\x6f\x66\x20\x73\x69\x78\x20\x6d"
|
||||
"\x6f\x6e\x74\x68\x73\x20\x61\x6e"
|
||||
"\x64\x20\x6d\x61\x79\x20\x62\x65"
|
||||
"\x20\x75\x70\x64\x61\x74\x65\x64"
|
||||
"\x2c\x20\x72\x65\x70\x6c\x61\x63"
|
||||
"\x65\x64\x2c\x20\x6f\x72\x20\x6f"
|
||||
"\x62\x73\x6f\x6c\x65\x74\x65\x64"
|
||||
"\x20\x62\x79\x20\x6f\x74\x68\x65"
|
||||
"\x72\x20\x64\x6f\x63\x75\x6d\x65"
|
||||
"\x6e\x74\x73\x20\x61\x74\x20\x61"
|
||||
"\x6e\x79\x20\x74\x69\x6d\x65\x2e"
|
||||
"\x20\x49\x74\x20\x69\x73\x20\x69"
|
||||
"\x6e\x61\x70\x70\x72\x6f\x70\x72"
|
||||
"\x69\x61\x74\x65\x20\x74\x6f\x20"
|
||||
"\x75\x73\x65\x20\x49\x6e\x74\x65"
|
||||
"\x72\x6e\x65\x74\x2d\x44\x72\x61"
|
||||
"\x66\x74\x73\x20\x61\x73\x20\x72"
|
||||
"\x65\x66\x65\x72\x65\x6e\x63\x65"
|
||||
"\x20\x6d\x61\x74\x65\x72\x69\x61"
|
||||
"\x6c\x20\x6f\x72\x20\x74\x6f\x20"
|
||||
"\x63\x69\x74\x65\x20\x74\x68\x65"
|
||||
"\x6d\x20\x6f\x74\x68\x65\x72\x20"
|
||||
"\x74\x68\x61\x6e\x20\x61\x73\x20"
|
||||
"\x2f\xe2\x80\x9c\x77\x6f\x72\x6b"
|
||||
"\x20\x69\x6e\x20\x70\x72\x6f\x67"
|
||||
"\x72\x65\x73\x73\x2e\x2f\xe2\x80"
|
||||
"\x9d",
|
||||
.ilen = 265,
|
||||
.result = "\x64\xa0\x86\x15\x75\x86\x1a\xf4"
|
||||
"\x60\xf0\x62\xc7\x9b\xe6\x43\xbd"
|
||||
"\x5e\x80\x5c\xfd\x34\x5c\xf3\x89"
|
||||
"\xf1\x08\x67\x0a\xc7\x6c\x8c\xb2"
|
||||
"\x4c\x6c\xfc\x18\x75\x5d\x43\xee"
|
||||
"\xa0\x9e\xe9\x4e\x38\x2d\x26\xb0"
|
||||
"\xbd\xb7\xb7\x3c\x32\x1b\x01\x00"
|
||||
"\xd4\xf0\x3b\x7f\x35\x58\x94\xcf"
|
||||
"\x33\x2f\x83\x0e\x71\x0b\x97\xce"
|
||||
"\x98\xc8\xa8\x4a\xbd\x0b\x94\x81"
|
||||
"\x14\xad\x17\x6e\x00\x8d\x33\xbd"
|
||||
"\x60\xf9\x82\xb1\xff\x37\xc8\x55"
|
||||
"\x97\x97\xa0\x6e\xf4\xf0\xef\x61"
|
||||
"\xc1\x86\x32\x4e\x2b\x35\x06\x38"
|
||||
"\x36\x06\x90\x7b\x6a\x7c\x02\xb0"
|
||||
"\xf9\xf6\x15\x7b\x53\xc8\x67\xe4"
|
||||
"\xb9\x16\x6c\x76\x7b\x80\x4d\x46"
|
||||
"\xa5\x9b\x52\x16\xcd\xe7\xa4\xe9"
|
||||
"\x90\x40\xc5\xa4\x04\x33\x22\x5e"
|
||||
"\xe2\x82\xa1\xb0\xa0\x6c\x52\x3e"
|
||||
"\xaf\x45\x34\xd7\xf8\x3f\xa1\x15"
|
||||
"\x5b\x00\x47\x71\x8c\xbc\x54\x6a"
|
||||
"\x0d\x07\x2b\x04\xb3\x56\x4e\xea"
|
||||
"\x1b\x42\x22\x73\xf5\x48\x27\x1a"
|
||||
"\x0b\xb2\x31\x60\x53\xfa\x76\x99"
|
||||
"\x19\x55\xeb\xd6\x31\x59\x43\x4e"
|
||||
"\xce\xbb\x4e\x46\x6d\xae\x5a\x10"
|
||||
"\x73\xa6\x72\x76\x27\x09\x7a\x10"
|
||||
"\x49\xe6\x17\xd9\x1d\x36\x10\x94"
|
||||
"\xfa\x68\xf0\xff\x77\x98\x71\x30"
|
||||
"\x30\x5b\xea\xba\x2e\xda\x04\xdf"
|
||||
"\x99\x7b\x71\x4d\x6c\x6f\x2c\x29"
|
||||
"\xa6\xad\x5c\xb4\x02\x2b\x02\x70"
|
||||
"\x9b\xee\xad\x9d\x67\x89\x0c\xbb"
|
||||
"\x22\x39\x23\x36\xfe\xa1\x85\x1f"
|
||||
"\x38",
|
||||
.rlen = 281,
|
||||
},
|
||||
};
|
||||
|
||||
static struct aead_testvec rfc7539esp_dec_tv_template[] = {
|
||||
{
|
||||
.key = "\x1c\x92\x40\xa5\xeb\x55\xd3\x8a"
|
||||
"\xf3\x33\x88\x86\x04\xf6\xb5\xf0"
|
||||
"\x47\x39\x17\xc1\x40\x2b\x80\x09"
|
||||
"\x9d\xca\x5c\xbc\x20\x70\x75\xc0"
|
||||
"\x00\x00\x00\x00",
|
||||
.klen = 36,
|
||||
.iv = "\x01\x02\x03\x04\x05\x06\x07\x08",
|
||||
.assoc = "\xf3\x33\x88\x86\x00\x00\x00\x00"
|
||||
"\x00\x00\x4e\x91",
|
||||
.alen = 12,
|
||||
.input = "\x64\xa0\x86\x15\x75\x86\x1a\xf4"
|
||||
"\x60\xf0\x62\xc7\x9b\xe6\x43\xbd"
|
||||
"\x5e\x80\x5c\xfd\x34\x5c\xf3\x89"
|
||||
"\xf1\x08\x67\x0a\xc7\x6c\x8c\xb2"
|
||||
"\x4c\x6c\xfc\x18\x75\x5d\x43\xee"
|
||||
"\xa0\x9e\xe9\x4e\x38\x2d\x26\xb0"
|
||||
"\xbd\xb7\xb7\x3c\x32\x1b\x01\x00"
|
||||
"\xd4\xf0\x3b\x7f\x35\x58\x94\xcf"
|
||||
"\x33\x2f\x83\x0e\x71\x0b\x97\xce"
|
||||
"\x98\xc8\xa8\x4a\xbd\x0b\x94\x81"
|
||||
"\x14\xad\x17\x6e\x00\x8d\x33\xbd"
|
||||
"\x60\xf9\x82\xb1\xff\x37\xc8\x55"
|
||||
"\x97\x97\xa0\x6e\xf4\xf0\xef\x61"
|
||||
"\xc1\x86\x32\x4e\x2b\x35\x06\x38"
|
||||
"\x36\x06\x90\x7b\x6a\x7c\x02\xb0"
|
||||
"\xf9\xf6\x15\x7b\x53\xc8\x67\xe4"
|
||||
"\xb9\x16\x6c\x76\x7b\x80\x4d\x46"
|
||||
"\xa5\x9b\x52\x16\xcd\xe7\xa4\xe9"
|
||||
"\x90\x40\xc5\xa4\x04\x33\x22\x5e"
|
||||
"\xe2\x82\xa1\xb0\xa0\x6c\x52\x3e"
|
||||
"\xaf\x45\x34\xd7\xf8\x3f\xa1\x15"
|
||||
"\x5b\x00\x47\x71\x8c\xbc\x54\x6a"
|
||||
"\x0d\x07\x2b\x04\xb3\x56\x4e\xea"
|
||||
"\x1b\x42\x22\x73\xf5\x48\x27\x1a"
|
||||
"\x0b\xb2\x31\x60\x53\xfa\x76\x99"
|
||||
"\x19\x55\xeb\xd6\x31\x59\x43\x4e"
|
||||
"\xce\xbb\x4e\x46\x6d\xae\x5a\x10"
|
||||
"\x73\xa6\x72\x76\x27\x09\x7a\x10"
|
||||
"\x49\xe6\x17\xd9\x1d\x36\x10\x94"
|
||||
"\xfa\x68\xf0\xff\x77\x98\x71\x30"
|
||||
"\x30\x5b\xea\xba\x2e\xda\x04\xdf"
|
||||
"\x99\x7b\x71\x4d\x6c\x6f\x2c\x29"
|
||||
"\xa6\xad\x5c\xb4\x02\x2b\x02\x70"
|
||||
"\x9b\xee\xad\x9d\x67\x89\x0c\xbb"
|
||||
"\x22\x39\x23\x36\xfe\xa1\x85\x1f"
|
||||
"\x38",
|
||||
.ilen = 281,
|
||||
.result = "\x49\x6e\x74\x65\x72\x6e\x65\x74"
|
||||
"\x2d\x44\x72\x61\x66\x74\x73\x20"
|
||||
"\x61\x72\x65\x20\x64\x72\x61\x66"
|
||||
"\x74\x20\x64\x6f\x63\x75\x6d\x65"
|
||||
"\x6e\x74\x73\x20\x76\x61\x6c\x69"
|
||||
"\x64\x20\x66\x6f\x72\x20\x61\x20"
|
||||
"\x6d\x61\x78\x69\x6d\x75\x6d\x20"
|
||||
"\x6f\x66\x20\x73\x69\x78\x20\x6d"
|
||||
"\x6f\x6e\x74\x68\x73\x20\x61\x6e"
|
||||
"\x64\x20\x6d\x61\x79\x20\x62\x65"
|
||||
"\x20\x75\x70\x64\x61\x74\x65\x64"
|
||||
"\x2c\x20\x72\x65\x70\x6c\x61\x63"
|
||||
"\x65\x64\x2c\x20\x6f\x72\x20\x6f"
|
||||
"\x62\x73\x6f\x6c\x65\x74\x65\x64"
|
||||
"\x20\x62\x79\x20\x6f\x74\x68\x65"
|
||||
"\x72\x20\x64\x6f\x63\x75\x6d\x65"
|
||||
"\x6e\x74\x73\x20\x61\x74\x20\x61"
|
||||
"\x6e\x79\x20\x74\x69\x6d\x65\x2e"
|
||||
"\x20\x49\x74\x20\x69\x73\x20\x69"
|
||||
"\x6e\x61\x70\x70\x72\x6f\x70\x72"
|
||||
"\x69\x61\x74\x65\x20\x74\x6f\x20"
|
||||
"\x75\x73\x65\x20\x49\x6e\x74\x65"
|
||||
"\x72\x6e\x65\x74\x2d\x44\x72\x61"
|
||||
"\x66\x74\x73\x20\x61\x73\x20\x72"
|
||||
"\x65\x66\x65\x72\x65\x6e\x63\x65"
|
||||
"\x20\x6d\x61\x74\x65\x72\x69\x61"
|
||||
"\x6c\x20\x6f\x72\x20\x74\x6f\x20"
|
||||
"\x63\x69\x74\x65\x20\x74\x68\x65"
|
||||
"\x6d\x20\x6f\x74\x68\x65\x72\x20"
|
||||
"\x74\x68\x61\x6e\x20\x61\x73\x20"
|
||||
"\x2f\xe2\x80\x9c\x77\x6f\x72\x6b"
|
||||
"\x20\x69\x6e\x20\x70\x72\x6f\x67"
|
||||
"\x72\x65\x73\x73\x2e\x2f\xe2\x80"
|
||||
"\x9d",
|
||||
.rlen = 265,
|
||||
},
|
||||
};
|
||||
|
||||
/*
|
||||
* ANSI X9.31 Continuous Pseudo-Random Number Generator (AES mode)
|
||||
* test vectors, taken from Appendix B.2.9 and B.2.10:
|
||||
|
|
Loading…
Reference in New Issue