aboutsummaryrefslogtreecommitdiffstats
path: root/crypto
diff options
context:
space:
mode:
authorJussi Kivilinna <jussi.kivilinna@iki.fi>2013-04-07 09:43:51 -0400
committerHerbert Xu <herbert@gondor.apana.org.au>2013-04-25 09:01:47 -0400
commite9b7441a9926b8091c01431f10231c9ceac52c8f (patch)
tree67a2e0e634fc932d3b6cb032477f729172c8e5a3 /crypto
parentd733ac90f9fe8ac284e523f9920b507555b12f6d (diff)
crypto: testmgr - add AES GMAC test vectors
Signed-off-by: Jussi Kivilinna <jussi.kivilinna@iki.fi> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Diffstat (limited to 'crypto')
-rw-r--r--crypto/tcrypt.c4
-rw-r--r--crypto/testmgr.c17
-rw-r--r--crypto/testmgr.h89
3 files changed, 108 insertions, 2 deletions
diff --git a/crypto/tcrypt.c b/crypto/tcrypt.c
index 87ef7d66bc20..6b911ef8df8b 100644
--- a/crypto/tcrypt.c
+++ b/crypto/tcrypt.c
@@ -1225,6 +1225,10 @@ static int do_test(int m)
1225 ret += tcrypt_test("rfc4106(gcm(aes))"); 1225 ret += tcrypt_test("rfc4106(gcm(aes))");
1226 break; 1226 break;
1227 1227
1228 case 152:
1229 ret += tcrypt_test("rfc4543(gcm(aes))");
1230 break;
1231
1228 case 200: 1232 case 200:
1229 test_cipher_speed("ecb(aes)", ENCRYPT, sec, NULL, 0, 1233 test_cipher_speed("ecb(aes)", ENCRYPT, sec, NULL, 0,
1230 speed_template_16_24_32); 1234 speed_template_16_24_32);
diff --git a/crypto/testmgr.c b/crypto/testmgr.c
index efd8b20e13dc..442ddb46bbe5 100644
--- a/crypto/testmgr.c
+++ b/crypto/testmgr.c
@@ -2696,8 +2696,6 @@ static const struct alg_test_desc alg_test_descs[] = {
2696 } 2696 }
2697 } 2697 }
2698 }, { 2698 }, {
2699
2700
2701 .alg = "rfc4309(ccm(aes))", 2699 .alg = "rfc4309(ccm(aes))",
2702 .test = alg_test_aead, 2700 .test = alg_test_aead,
2703 .fips_allowed = 1, 2701 .fips_allowed = 1,
@@ -2714,6 +2712,21 @@ static const struct alg_test_desc alg_test_descs[] = {
2714 } 2712 }
2715 } 2713 }
2716 }, { 2714 }, {
2715 .alg = "rfc4543(gcm(aes))",
2716 .test = alg_test_aead,
2717 .suite = {
2718 .aead = {
2719 .enc = {
2720 .vecs = aes_gcm_rfc4543_enc_tv_template,
2721 .count = AES_GCM_4543_ENC_TEST_VECTORS
2722 },
2723 .dec = {
2724 .vecs = aes_gcm_rfc4543_dec_tv_template,
2725 .count = AES_GCM_4543_DEC_TEST_VECTORS
2726 },
2727 }
2728 }
2729 }, {
2717 .alg = "rmd128", 2730 .alg = "rmd128",
2718 .test = alg_test_hash, 2731 .test = alg_test_hash,
2719 .suite = { 2732 .suite = {
diff --git a/crypto/testmgr.h b/crypto/testmgr.h
index b5721e0b979c..92db37dda757 100644
--- a/crypto/testmgr.h
+++ b/crypto/testmgr.h
@@ -12680,6 +12680,8 @@ static struct cipher_testvec cast6_xts_dec_tv_template[] = {
12680#define AES_GCM_DEC_TEST_VECTORS 8 12680#define AES_GCM_DEC_TEST_VECTORS 8
12681#define AES_GCM_4106_ENC_TEST_VECTORS 7 12681#define AES_GCM_4106_ENC_TEST_VECTORS 7
12682#define AES_GCM_4106_DEC_TEST_VECTORS 7 12682#define AES_GCM_4106_DEC_TEST_VECTORS 7
12683#define AES_GCM_4543_ENC_TEST_VECTORS 1
12684#define AES_GCM_4543_DEC_TEST_VECTORS 2
12683#define AES_CCM_ENC_TEST_VECTORS 7 12685#define AES_CCM_ENC_TEST_VECTORS 7
12684#define AES_CCM_DEC_TEST_VECTORS 7 12686#define AES_CCM_DEC_TEST_VECTORS 7
12685#define AES_CCM_4309_ENC_TEST_VECTORS 7 12687#define AES_CCM_4309_ENC_TEST_VECTORS 7
@@ -18193,6 +18195,93 @@ static struct aead_testvec aes_gcm_rfc4106_dec_tv_template[] = {
18193 } 18195 }
18194}; 18196};
18195 18197
18198static struct aead_testvec aes_gcm_rfc4543_enc_tv_template[] = {
18199 { /* From draft-mcgrew-gcm-test-01 */
18200 .key = "\x4c\x80\xcd\xef\xbb\x5d\x10\xda"
18201 "\x90\x6a\xc7\x3c\x36\x13\xa6\x34"
18202 "\x22\x43\x3c\x64",
18203 .klen = 20,
18204 .iv = zeroed_string,
18205 .assoc = "\x00\x00\x43\x21\x00\x00\x00\x07",
18206 .alen = 8,
18207 .input = "\x45\x00\x00\x30\xda\x3a\x00\x00"
18208 "\x80\x01\xdf\x3b\xc0\xa8\x00\x05"
18209 "\xc0\xa8\x00\x01\x08\x00\xc6\xcd"
18210 "\x02\x00\x07\x00\x61\x62\x63\x64"
18211 "\x65\x66\x67\x68\x69\x6a\x6b\x6c"
18212 "\x6d\x6e\x6f\x70\x71\x72\x73\x74"
18213 "\x01\x02\x02\x01",
18214 .ilen = 52,
18215 .result = "\x45\x00\x00\x30\xda\x3a\x00\x00"
18216 "\x80\x01\xdf\x3b\xc0\xa8\x00\x05"
18217 "\xc0\xa8\x00\x01\x08\x00\xc6\xcd"
18218 "\x02\x00\x07\x00\x61\x62\x63\x64"
18219 "\x65\x66\x67\x68\x69\x6a\x6b\x6c"
18220 "\x6d\x6e\x6f\x70\x71\x72\x73\x74"
18221 "\x01\x02\x02\x01\xf2\xa9\xa8\x36"
18222 "\xe1\x55\x10\x6a\xa8\xdc\xd6\x18"
18223 "\xe4\x09\x9a\xaa",
18224 .rlen = 68,
18225 }
18226};
18227
18228static struct aead_testvec aes_gcm_rfc4543_dec_tv_template[] = {
18229 { /* From draft-mcgrew-gcm-test-01 */
18230 .key = "\x4c\x80\xcd\xef\xbb\x5d\x10\xda"
18231 "\x90\x6a\xc7\x3c\x36\x13\xa6\x34"
18232 "\x22\x43\x3c\x64",
18233 .klen = 20,
18234 .iv = zeroed_string,
18235 .assoc = "\x00\x00\x43\x21\x00\x00\x00\x07",
18236 .alen = 8,
18237 .input = "\x45\x00\x00\x30\xda\x3a\x00\x00"
18238 "\x80\x01\xdf\x3b\xc0\xa8\x00\x05"
18239 "\xc0\xa8\x00\x01\x08\x00\xc6\xcd"
18240 "\x02\x00\x07\x00\x61\x62\x63\x64"
18241 "\x65\x66\x67\x68\x69\x6a\x6b\x6c"
18242 "\x6d\x6e\x6f\x70\x71\x72\x73\x74"
18243 "\x01\x02\x02\x01\xf2\xa9\xa8\x36"
18244 "\xe1\x55\x10\x6a\xa8\xdc\xd6\x18"
18245 "\xe4\x09\x9a\xaa",
18246 .ilen = 68,
18247 .result = "\x45\x00\x00\x30\xda\x3a\x00\x00"
18248 "\x80\x01\xdf\x3b\xc0\xa8\x00\x05"
18249 "\xc0\xa8\x00\x01\x08\x00\xc6\xcd"
18250 "\x02\x00\x07\x00\x61\x62\x63\x64"
18251 "\x65\x66\x67\x68\x69\x6a\x6b\x6c"
18252 "\x6d\x6e\x6f\x70\x71\x72\x73\x74"
18253 "\x01\x02\x02\x01",
18254 .rlen = 52,
18255 }, { /* nearly same as previous, but should fail */
18256 .key = "\x4c\x80\xcd\xef\xbb\x5d\x10\xda"
18257 "\x90\x6a\xc7\x3c\x36\x13\xa6\x34"
18258 "\x22\x43\x3c\x64",
18259 .klen = 20,
18260 .iv = zeroed_string,
18261 .assoc = "\x00\x00\x43\x21\x00\x00\x00\x07",
18262 .alen = 8,
18263 .input = "\x45\x00\x00\x30\xda\x3a\x00\x00"
18264 "\x80\x01\xdf\x3b\xc0\xa8\x00\x05"
18265 "\xc0\xa8\x00\x01\x08\x00\xc6\xcd"
18266 "\x02\x00\x07\x00\x61\x62\x63\x64"
18267 "\x65\x66\x67\x68\x69\x6a\x6b\x6c"
18268 "\x6d\x6e\x6f\x70\x71\x72\x73\x74"
18269 "\x01\x02\x02\x01\xf2\xa9\xa8\x36"
18270 "\xe1\x55\x10\x6a\xa8\xdc\xd6\x18"
18271 "\x00\x00\x00\x00",
18272 .ilen = 68,
18273 .novrfy = 1,
18274 .result = "\x45\x00\x00\x30\xda\x3a\x00\x00"
18275 "\x80\x01\xdf\x3b\xc0\xa8\x00\x05"
18276 "\xc0\xa8\x00\x01\x08\x00\xc6\xcd"
18277 "\x02\x00\x07\x00\x61\x62\x63\x64"
18278 "\x65\x66\x67\x68\x69\x6a\x6b\x6c"
18279 "\x6d\x6e\x6f\x70\x71\x72\x73\x74"
18280 "\x01\x02\x02\x01",
18281 .rlen = 52,
18282 },
18283};
18284
18196static struct aead_testvec aes_ccm_enc_tv_template[] = { 18285static struct aead_testvec aes_ccm_enc_tv_template[] = {
18197 { /* From RFC 3610 */ 18286 { /* From RFC 3610 */
18198 .key = "\xc0\xc1\xc2\xc3\xc4\xc5\xc6\xc7" 18287 .key = "\xc0\xc1\xc2\xc3\xc4\xc5\xc6\xc7"