diff options
-rw-r--r-- | crypto/tcrypt.c | 2 | ||||
-rw-r--r-- | crypto/testmgr.c | 30 | ||||
-rw-r--r-- | crypto/testmgr.h | 393 |
3 files changed, 423 insertions, 2 deletions
diff --git a/crypto/tcrypt.c b/crypto/tcrypt.c index 0c4e80f34651..ac9e4d2a63b8 100644 --- a/crypto/tcrypt.c +++ b/crypto/tcrypt.c | |||
@@ -793,6 +793,8 @@ static int do_test(int m) | |||
793 | 793 | ||
794 | case 9: | 794 | case 9: |
795 | ret += tcrypt_test("ecb(serpent)"); | 795 | ret += tcrypt_test("ecb(serpent)"); |
796 | ret += tcrypt_test("cbc(serpent)"); | ||
797 | ret += tcrypt_test("ctr(serpent)"); | ||
796 | break; | 798 | break; |
797 | 799 | ||
798 | case 10: | 800 | case 10: |
diff --git a/crypto/testmgr.c b/crypto/testmgr.c index e91c1eb1722a..49436b900081 100644 --- a/crypto/testmgr.c +++ b/crypto/testmgr.c | |||
@@ -1675,6 +1675,21 @@ static const struct alg_test_desc alg_test_descs[] = { | |||
1675 | } | 1675 | } |
1676 | } | 1676 | } |
1677 | }, { | 1677 | }, { |
1678 | .alg = "cbc(serpent)", | ||
1679 | .test = alg_test_skcipher, | ||
1680 | .suite = { | ||
1681 | .cipher = { | ||
1682 | .enc = { | ||
1683 | .vecs = serpent_cbc_enc_tv_template, | ||
1684 | .count = SERPENT_CBC_ENC_TEST_VECTORS | ||
1685 | }, | ||
1686 | .dec = { | ||
1687 | .vecs = serpent_cbc_dec_tv_template, | ||
1688 | .count = SERPENT_CBC_DEC_TEST_VECTORS | ||
1689 | } | ||
1690 | } | ||
1691 | } | ||
1692 | }, { | ||
1678 | .alg = "cbc(twofish)", | 1693 | .alg = "cbc(twofish)", |
1679 | .test = alg_test_skcipher, | 1694 | .test = alg_test_skcipher, |
1680 | .suite = { | 1695 | .suite = { |
@@ -1771,6 +1786,21 @@ static const struct alg_test_desc alg_test_descs[] = { | |||
1771 | } | 1786 | } |
1772 | } | 1787 | } |
1773 | }, { | 1788 | }, { |
1789 | .alg = "ctr(serpent)", | ||
1790 | .test = alg_test_skcipher, | ||
1791 | .suite = { | ||
1792 | .cipher = { | ||
1793 | .enc = { | ||
1794 | .vecs = serpent_ctr_enc_tv_template, | ||
1795 | .count = SERPENT_CTR_ENC_TEST_VECTORS | ||
1796 | }, | ||
1797 | .dec = { | ||
1798 | .vecs = serpent_ctr_dec_tv_template, | ||
1799 | .count = SERPENT_CTR_DEC_TEST_VECTORS | ||
1800 | } | ||
1801 | } | ||
1802 | } | ||
1803 | }, { | ||
1774 | .alg = "ctr(twofish)", | 1804 | .alg = "ctr(twofish)", |
1775 | .test = alg_test_skcipher, | 1805 | .test = alg_test_skcipher, |
1776 | .suite = { | 1806 | .suite = { |
diff --git a/crypto/testmgr.h b/crypto/testmgr.h index 37b4d8f45447..ed4aec950faf 100644 --- a/crypto/testmgr.h +++ b/crypto/testmgr.h | |||
@@ -3096,12 +3096,18 @@ static struct cipher_testvec tf_ctr_dec_tv_template[] = { | |||
3096 | * Serpent test vectors. These are backwards because Serpent writes | 3096 | * Serpent test vectors. These are backwards because Serpent writes |
3097 | * octet sequences in right-to-left mode. | 3097 | * octet sequences in right-to-left mode. |
3098 | */ | 3098 | */ |
3099 | #define SERPENT_ENC_TEST_VECTORS 4 | 3099 | #define SERPENT_ENC_TEST_VECTORS 5 |
3100 | #define SERPENT_DEC_TEST_VECTORS 4 | 3100 | #define SERPENT_DEC_TEST_VECTORS 5 |
3101 | 3101 | ||
3102 | #define TNEPRES_ENC_TEST_VECTORS 4 | 3102 | #define TNEPRES_ENC_TEST_VECTORS 4 |
3103 | #define TNEPRES_DEC_TEST_VECTORS 4 | 3103 | #define TNEPRES_DEC_TEST_VECTORS 4 |
3104 | 3104 | ||
3105 | #define SERPENT_CBC_ENC_TEST_VECTORS 1 | ||
3106 | #define SERPENT_CBC_DEC_TEST_VECTORS 1 | ||
3107 | |||
3108 | #define SERPENT_CTR_ENC_TEST_VECTORS 2 | ||
3109 | #define SERPENT_CTR_DEC_TEST_VECTORS 2 | ||
3110 | |||
3105 | static struct cipher_testvec serpent_enc_tv_template[] = { | 3111 | static struct cipher_testvec serpent_enc_tv_template[] = { |
3106 | { | 3112 | { |
3107 | .input = "\x00\x01\x02\x03\x04\x05\x06\x07" | 3113 | .input = "\x00\x01\x02\x03\x04\x05\x06\x07" |
@@ -3140,6 +3146,50 @@ static struct cipher_testvec serpent_enc_tv_template[] = { | |||
3140 | .result = "\xdd\xd2\x6b\x98\xa5\xff\xd8\x2c" | 3146 | .result = "\xdd\xd2\x6b\x98\xa5\xff\xd8\x2c" |
3141 | "\x05\x34\x5a\x9d\xad\xbf\xaf\x49", | 3147 | "\x05\x34\x5a\x9d\xad\xbf\xaf\x49", |
3142 | .rlen = 16, | 3148 | .rlen = 16, |
3149 | }, { /* Generated with Crypto++ */ | ||
3150 | .key = "\x85\x62\x3F\x1C\xF9\xD6\x1C\xF9" | ||
3151 | "\xD6\xB3\x90\x6D\x4A\x90\x6D\x4A" | ||
3152 | "\x27\x04\xE1\x27\x04\xE1\xBE\x9B" | ||
3153 | "\x78\xBE\x9B\x78\x55\x32\x0F\x55", | ||
3154 | .klen = 32, | ||
3155 | .input = "\x56\xED\x84\x1B\x8F\x26\xBD\x31" | ||
3156 | "\xC8\x5F\xF6\x6A\x01\x98\x0C\xA3" | ||
3157 | "\x3A\xD1\x45\xDC\x73\x0A\x7E\x15" | ||
3158 | "\xAC\x20\xB7\x4E\xE5\x59\xF0\x87" | ||
3159 | "\x1E\x92\x29\xC0\x34\xCB\x62\xF9" | ||
3160 | "\x6D\x04\x9B\x0F\xA6\x3D\xD4\x48" | ||
3161 | "\xDF\x76\x0D\x81\x18\xAF\x23\xBA" | ||
3162 | "\x51\xE8\x5C\xF3\x8A\x21\x95\x2C" | ||
3163 | "\xC3\x37\xCE\x65\xFC\x70\x07\x9E" | ||
3164 | "\x12\xA9\x40\xD7\x4B\xE2\x79\x10" | ||
3165 | "\x84\x1B\xB2\x26\xBD\x54\xEB\x5F" | ||
3166 | "\xF6\x8D\x01\x98\x2F\xC6\x3A\xD1" | ||
3167 | "\x68\xFF\x73\x0A\xA1\x15\xAC\x43" | ||
3168 | "\xDA\x4E\xE5\x7C\x13\x87\x1E\xB5" | ||
3169 | "\x29\xC0\x57\xEE\x62\xF9\x90\x04" | ||
3170 | "\x9B\x32\xC9\x3D\xD4\x6B\x02\x76" | ||
3171 | "\x0D\xA4\x18\xAF\x46\xDD\x51\xE8" | ||
3172 | "\x7F\x16\x8A\x21\xB8\x2C\xC3\x5A", | ||
3173 | .ilen = 144, | ||
3174 | .result = "\xFB\xB0\x5D\xDE\xC0\xFE\xFC\xEB" | ||
3175 | "\xB1\x80\x10\x43\xDE\x62\x70\xBD" | ||
3176 | "\xFA\x8A\x93\xEA\x6B\xF7\xC5\xD7" | ||
3177 | "\x0C\xD1\xBB\x29\x25\x14\x4C\x22" | ||
3178 | "\x77\xA6\x38\x00\xDB\xB9\xE2\x07" | ||
3179 | "\xD1\xAC\x82\xBA\xEA\x67\xAA\x39" | ||
3180 | "\x99\x34\x89\x5B\x54\xE9\x12\x13" | ||
3181 | "\x3B\x04\xE5\x12\x42\xC5\x79\xAB" | ||
3182 | "\x0D\xC7\x3C\x58\x2D\xA3\x98\xF6" | ||
3183 | "\xE4\x61\x9E\x17\x0B\xCE\xE8\xAA" | ||
3184 | "\xB5\x6C\x1A\x3A\x67\x52\x81\x6A" | ||
3185 | "\x04\xFF\x8A\x1B\x96\xFE\xE6\x87" | ||
3186 | "\x3C\xD4\x39\x7D\x36\x9B\x03\xD5" | ||
3187 | "\xB6\xA0\x75\x3C\x83\xE6\x1C\x73" | ||
3188 | "\x9D\x74\x2B\x77\x53\x2D\xE5\xBD" | ||
3189 | "\x69\xDA\x7A\x01\xF5\x6A\x70\x39" | ||
3190 | "\x30\xD4\x2C\xF2\x8E\x06\x4B\x39" | ||
3191 | "\xB3\x12\x1D\xB3\x17\x46\xE6\xD6", | ||
3192 | .rlen = 144, | ||
3143 | }, | 3193 | }, |
3144 | }; | 3194 | }; |
3145 | 3195 | ||
@@ -3231,6 +3281,50 @@ static struct cipher_testvec serpent_dec_tv_template[] = { | |||
3231 | .ilen = 16, | 3281 | .ilen = 16, |
3232 | .result = zeroed_string, | 3282 | .result = zeroed_string, |
3233 | .rlen = 16, | 3283 | .rlen = 16, |
3284 | }, { /* Generated with Crypto++ */ | ||
3285 | .key = "\x85\x62\x3F\x1C\xF9\xD6\x1C\xF9" | ||
3286 | "\xD6\xB3\x90\x6D\x4A\x90\x6D\x4A" | ||
3287 | "\x27\x04\xE1\x27\x04\xE1\xBE\x9B" | ||
3288 | "\x78\xBE\x9B\x78\x55\x32\x0F\x55", | ||
3289 | .klen = 32, | ||
3290 | .input = "\xFB\xB0\x5D\xDE\xC0\xFE\xFC\xEB" | ||
3291 | "\xB1\x80\x10\x43\xDE\x62\x70\xBD" | ||
3292 | "\xFA\x8A\x93\xEA\x6B\xF7\xC5\xD7" | ||
3293 | "\x0C\xD1\xBB\x29\x25\x14\x4C\x22" | ||
3294 | "\x77\xA6\x38\x00\xDB\xB9\xE2\x07" | ||
3295 | "\xD1\xAC\x82\xBA\xEA\x67\xAA\x39" | ||
3296 | "\x99\x34\x89\x5B\x54\xE9\x12\x13" | ||
3297 | "\x3B\x04\xE5\x12\x42\xC5\x79\xAB" | ||
3298 | "\x0D\xC7\x3C\x58\x2D\xA3\x98\xF6" | ||
3299 | "\xE4\x61\x9E\x17\x0B\xCE\xE8\xAA" | ||
3300 | "\xB5\x6C\x1A\x3A\x67\x52\x81\x6A" | ||
3301 | "\x04\xFF\x8A\x1B\x96\xFE\xE6\x87" | ||
3302 | "\x3C\xD4\x39\x7D\x36\x9B\x03\xD5" | ||
3303 | "\xB6\xA0\x75\x3C\x83\xE6\x1C\x73" | ||
3304 | "\x9D\x74\x2B\x77\x53\x2D\xE5\xBD" | ||
3305 | "\x69\xDA\x7A\x01\xF5\x6A\x70\x39" | ||
3306 | "\x30\xD4\x2C\xF2\x8E\x06\x4B\x39" | ||
3307 | "\xB3\x12\x1D\xB3\x17\x46\xE6\xD6", | ||
3308 | .ilen = 144, | ||
3309 | .result = "\x56\xED\x84\x1B\x8F\x26\xBD\x31" | ||
3310 | "\xC8\x5F\xF6\x6A\x01\x98\x0C\xA3" | ||
3311 | "\x3A\xD1\x45\xDC\x73\x0A\x7E\x15" | ||
3312 | "\xAC\x20\xB7\x4E\xE5\x59\xF0\x87" | ||
3313 | "\x1E\x92\x29\xC0\x34\xCB\x62\xF9" | ||
3314 | "\x6D\x04\x9B\x0F\xA6\x3D\xD4\x48" | ||
3315 | "\xDF\x76\x0D\x81\x18\xAF\x23\xBA" | ||
3316 | "\x51\xE8\x5C\xF3\x8A\x21\x95\x2C" | ||
3317 | "\xC3\x37\xCE\x65\xFC\x70\x07\x9E" | ||
3318 | "\x12\xA9\x40\xD7\x4B\xE2\x79\x10" | ||
3319 | "\x84\x1B\xB2\x26\xBD\x54\xEB\x5F" | ||
3320 | "\xF6\x8D\x01\x98\x2F\xC6\x3A\xD1" | ||
3321 | "\x68\xFF\x73\x0A\xA1\x15\xAC\x43" | ||
3322 | "\xDA\x4E\xE5\x7C\x13\x87\x1E\xB5" | ||
3323 | "\x29\xC0\x57\xEE\x62\xF9\x90\x04" | ||
3324 | "\x9B\x32\xC9\x3D\xD4\x6B\x02\x76" | ||
3325 | "\x0D\xA4\x18\xAF\x46\xDD\x51\xE8" | ||
3326 | "\x7F\x16\x8A\x21\xB8\x2C\xC3\x5A", | ||
3327 | .rlen = 144, | ||
3234 | }, | 3328 | }, |
3235 | }; | 3329 | }; |
3236 | 3330 | ||
@@ -3275,6 +3369,301 @@ static struct cipher_testvec tnepres_dec_tv_template[] = { | |||
3275 | }, | 3369 | }, |
3276 | }; | 3370 | }; |
3277 | 3371 | ||
3372 | static struct cipher_testvec serpent_cbc_enc_tv_template[] = { | ||
3373 | { /* Generated with Crypto++ */ | ||
3374 | .key = "\x85\x62\x3F\x1C\xF9\xD6\x1C\xF9" | ||
3375 | "\xD6\xB3\x90\x6D\x4A\x90\x6D\x4A" | ||
3376 | "\x27\x04\xE1\x27\x04\xE1\xBE\x9B" | ||
3377 | "\x78\xBE\x9B\x78\x55\x32\x0F\x55", | ||
3378 | .klen = 32, | ||
3379 | .iv = "\xE2\x24\x89\xEE\x53\xB8\x1D\x5F" | ||
3380 | "\xC4\x29\x8E\xF3\x35\x9A\xFF\x64", | ||
3381 | .input = "\x56\xED\x84\x1B\x8F\x26\xBD\x31" | ||
3382 | "\xC8\x5F\xF6\x6A\x01\x98\x0C\xA3" | ||
3383 | "\x3A\xD1\x45\xDC\x73\x0A\x7E\x15" | ||
3384 | "\xAC\x20\xB7\x4E\xE5\x59\xF0\x87" | ||
3385 | "\x1E\x92\x29\xC0\x34\xCB\x62\xF9" | ||
3386 | "\x6D\x04\x9B\x0F\xA6\x3D\xD4\x48" | ||
3387 | "\xDF\x76\x0D\x81\x18\xAF\x23\xBA" | ||
3388 | "\x51\xE8\x5C\xF3\x8A\x21\x95\x2C" | ||
3389 | "\xC3\x37\xCE\x65\xFC\x70\x07\x9E" | ||
3390 | "\x12\xA9\x40\xD7\x4B\xE2\x79\x10" | ||
3391 | "\x84\x1B\xB2\x26\xBD\x54\xEB\x5F" | ||
3392 | "\xF6\x8D\x01\x98\x2F\xC6\x3A\xD1" | ||
3393 | "\x68\xFF\x73\x0A\xA1\x15\xAC\x43" | ||
3394 | "\xDA\x4E\xE5\x7C\x13\x87\x1E\xB5" | ||
3395 | "\x29\xC0\x57\xEE\x62\xF9\x90\x04" | ||
3396 | "\x9B\x32\xC9\x3D\xD4\x6B\x02\x76" | ||
3397 | "\x0D\xA4\x18\xAF\x46\xDD\x51\xE8" | ||
3398 | "\x7F\x16\x8A\x21\xB8\x2C\xC3\x5A", | ||
3399 | .ilen = 144, | ||
3400 | .result = "\x80\xCF\x11\x41\x1A\xB9\x4B\x9C" | ||
3401 | "\xFF\xB7\x6C\xEA\xF0\xAF\x77\x6E" | ||
3402 | "\x71\x75\x95\x9D\x4E\x1C\xCF\xAD" | ||
3403 | "\x81\x34\xE9\x8F\xAE\x5A\x91\x1C" | ||
3404 | "\x38\x63\x35\x7E\x79\x18\x0A\xE8" | ||
3405 | "\x67\x06\x76\xD5\xFF\x22\x2F\xDA" | ||
3406 | "\xB6\x2D\x57\x13\xB6\x3C\xBC\x97" | ||
3407 | "\xFE\x53\x75\x35\x97\x7F\x51\xEA" | ||
3408 | "\xDF\x5D\xE8\x9D\xCC\xD9\xAE\xE7" | ||
3409 | "\x62\x67\xFF\x04\xC2\x18\x22\x5F" | ||
3410 | "\x2E\x06\xC1\xE2\x26\xCD\xC6\x1E" | ||
3411 | "\xE5\x2C\x4E\x87\x23\xDD\xF0\x41" | ||
3412 | "\x08\xA5\xB4\x3E\x07\x1E\x0B\xBB" | ||
3413 | "\x72\x84\xF8\x0A\x3F\x38\x5E\x91" | ||
3414 | "\x15\x26\xE1\xDB\xA4\x3D\x74\xD2" | ||
3415 | "\x41\x1E\x3F\xA9\xC6\x7D\x2A\xAB" | ||
3416 | "\x27\xDF\x89\x1D\x86\x3E\xF7\x5A" | ||
3417 | "\xF6\xE3\x0F\xC7\x6B\x4C\x96\x7C", | ||
3418 | .rlen = 144, | ||
3419 | }, | ||
3420 | }; | ||
3421 | |||
3422 | static struct cipher_testvec serpent_cbc_dec_tv_template[] = { | ||
3423 | { /* Generated with Crypto++ */ | ||
3424 | .key = "\x85\x62\x3F\x1C\xF9\xD6\x1C\xF9" | ||
3425 | "\xD6\xB3\x90\x6D\x4A\x90\x6D\x4A" | ||
3426 | "\x27\x04\xE1\x27\x04\xE1\xBE\x9B" | ||
3427 | "\x78\xBE\x9B\x78\x55\x32\x0F\x55", | ||
3428 | .klen = 32, | ||
3429 | .iv = "\xE2\x24\x89\xEE\x53\xB8\x1D\x5F" | ||
3430 | "\xC4\x29\x8E\xF3\x35\x9A\xFF\x64", | ||
3431 | .input = "\x80\xCF\x11\x41\x1A\xB9\x4B\x9C" | ||
3432 | "\xFF\xB7\x6C\xEA\xF0\xAF\x77\x6E" | ||
3433 | "\x71\x75\x95\x9D\x4E\x1C\xCF\xAD" | ||
3434 | "\x81\x34\xE9\x8F\xAE\x5A\x91\x1C" | ||
3435 | "\x38\x63\x35\x7E\x79\x18\x0A\xE8" | ||
3436 | "\x67\x06\x76\xD5\xFF\x22\x2F\xDA" | ||
3437 | "\xB6\x2D\x57\x13\xB6\x3C\xBC\x97" | ||
3438 | "\xFE\x53\x75\x35\x97\x7F\x51\xEA" | ||
3439 | "\xDF\x5D\xE8\x9D\xCC\xD9\xAE\xE7" | ||
3440 | "\x62\x67\xFF\x04\xC2\x18\x22\x5F" | ||
3441 | "\x2E\x06\xC1\xE2\x26\xCD\xC6\x1E" | ||
3442 | "\xE5\x2C\x4E\x87\x23\xDD\xF0\x41" | ||
3443 | "\x08\xA5\xB4\x3E\x07\x1E\x0B\xBB" | ||
3444 | "\x72\x84\xF8\x0A\x3F\x38\x5E\x91" | ||
3445 | "\x15\x26\xE1\xDB\xA4\x3D\x74\xD2" | ||
3446 | "\x41\x1E\x3F\xA9\xC6\x7D\x2A\xAB" | ||
3447 | "\x27\xDF\x89\x1D\x86\x3E\xF7\x5A" | ||
3448 | "\xF6\xE3\x0F\xC7\x6B\x4C\x96\x7C", | ||
3449 | .ilen = 144, | ||
3450 | .result = "\x56\xED\x84\x1B\x8F\x26\xBD\x31" | ||
3451 | "\xC8\x5F\xF6\x6A\x01\x98\x0C\xA3" | ||
3452 | "\x3A\xD1\x45\xDC\x73\x0A\x7E\x15" | ||
3453 | "\xAC\x20\xB7\x4E\xE5\x59\xF0\x87" | ||
3454 | "\x1E\x92\x29\xC0\x34\xCB\x62\xF9" | ||
3455 | "\x6D\x04\x9B\x0F\xA6\x3D\xD4\x48" | ||
3456 | "\xDF\x76\x0D\x81\x18\xAF\x23\xBA" | ||
3457 | "\x51\xE8\x5C\xF3\x8A\x21\x95\x2C" | ||
3458 | "\xC3\x37\xCE\x65\xFC\x70\x07\x9E" | ||
3459 | "\x12\xA9\x40\xD7\x4B\xE2\x79\x10" | ||
3460 | "\x84\x1B\xB2\x26\xBD\x54\xEB\x5F" | ||
3461 | "\xF6\x8D\x01\x98\x2F\xC6\x3A\xD1" | ||
3462 | "\x68\xFF\x73\x0A\xA1\x15\xAC\x43" | ||
3463 | "\xDA\x4E\xE5\x7C\x13\x87\x1E\xB5" | ||
3464 | "\x29\xC0\x57\xEE\x62\xF9\x90\x04" | ||
3465 | "\x9B\x32\xC9\x3D\xD4\x6B\x02\x76" | ||
3466 | "\x0D\xA4\x18\xAF\x46\xDD\x51\xE8" | ||
3467 | "\x7F\x16\x8A\x21\xB8\x2C\xC3\x5A", | ||
3468 | .rlen = 144, | ||
3469 | }, | ||
3470 | }; | ||
3471 | |||
3472 | static struct cipher_testvec serpent_ctr_enc_tv_template[] = { | ||
3473 | { /* Generated with Crypto++ */ | ||
3474 | .key = "\x85\x62\x3F\x1C\xF9\xD6\x1C\xF9" | ||
3475 | "\xD6\xB3\x90\x6D\x4A\x90\x6D\x4A" | ||
3476 | "\x27\x04\xE1\x27\x04\xE1\xBE\x9B" | ||
3477 | "\x78\xBE\x9B\x78\x55\x32\x0F\x55", | ||
3478 | .klen = 32, | ||
3479 | .iv = "\xE2\x24\x89\xEE\x53\xB8\x1D\x5F" | ||
3480 | "\xC4\x29\x8E\xF3\x35\x9A\xFF\x64", | ||
3481 | .input = "\x56\xED\x84\x1B\x8F\x26\xBD\x31" | ||
3482 | "\xC8\x5F\xF6\x6A\x01\x98\x0C\xA3" | ||
3483 | "\x3A\xD1\x45\xDC\x73\x0A\x7E\x15" | ||
3484 | "\xAC\x20\xB7\x4E\xE5\x59\xF0\x87" | ||
3485 | "\x1E\x92\x29\xC0\x34\xCB\x62\xF9" | ||
3486 | "\x6D\x04\x9B\x0F\xA6\x3D\xD4\x48" | ||
3487 | "\xDF\x76\x0D\x81\x18\xAF\x23\xBA" | ||
3488 | "\x51\xE8\x5C\xF3\x8A\x21\x95\x2C" | ||
3489 | "\xC3\x37\xCE\x65\xFC\x70\x07\x9E" | ||
3490 | "\x12\xA9\x40\xD7\x4B\xE2\x79\x10" | ||
3491 | "\x84\x1B\xB2\x26\xBD\x54\xEB\x5F" | ||
3492 | "\xF6\x8D\x01\x98\x2F\xC6\x3A\xD1" | ||
3493 | "\x68\xFF\x73\x0A\xA1\x15\xAC\x43" | ||
3494 | "\xDA\x4E\xE5\x7C\x13\x87\x1E\xB5" | ||
3495 | "\x29\xC0\x57\xEE\x62\xF9\x90\x04" | ||
3496 | "\x9B\x32\xC9\x3D\xD4\x6B\x02\x76" | ||
3497 | "\x0D\xA4\x18\xAF\x46\xDD\x51\xE8" | ||
3498 | "\x7F\x16\x8A\x21\xB8\x2C\xC3\x5A", | ||
3499 | .ilen = 144, | ||
3500 | .result = "\x84\x68\xEC\xF2\x1C\x88\x20\xCA" | ||
3501 | "\x37\x69\xE3\x3A\x22\x85\x48\x46" | ||
3502 | "\x70\xAA\x25\xB4\xCD\x8B\x04\x4E" | ||
3503 | "\x8D\x15\x2B\x98\xDF\x7B\x6D\xB9" | ||
3504 | "\xE0\x4A\x73\x00\x65\xB6\x1A\x0D" | ||
3505 | "\x5C\x60\xDF\x34\xDC\x60\x4C\xDF" | ||
3506 | "\xB5\x1F\x26\x8C\xDA\xC1\x11\xA8" | ||
3507 | "\x80\xFA\x37\x7A\x89\xAA\xAE\x7B" | ||
3508 | "\x92\x6E\xB9\xDC\xC9\x62\x4F\x88" | ||
3509 | "\x0A\x5D\x97\x2F\x6B\xAC\x03\x7C" | ||
3510 | "\x22\xF6\x55\x5A\xFA\x35\xA5\x17" | ||
3511 | "\xA1\x5C\x5E\x2B\x63\x2D\xB9\x91" | ||
3512 | "\x3E\x83\x26\x00\x4E\xD5\xBE\xCE" | ||
3513 | "\x79\xC4\x3D\xFC\x70\xA0\xAD\x96" | ||
3514 | "\xBA\x58\x2A\x1C\xDF\xC2\x3A\xA5" | ||
3515 | "\x7C\xB5\x12\x89\xED\xBF\xB6\x09" | ||
3516 | "\x13\x4F\x7D\x61\x3C\x5C\x27\xFC" | ||
3517 | "\x5D\xE1\x4F\xA1\xEA\xB3\xCA\xB9", | ||
3518 | .rlen = 144, | ||
3519 | }, { /* Generated with Crypto++ */ | ||
3520 | .key = "\x85\x62\x3F\x1C\xF9\xD6\x1C\xF9" | ||
3521 | "\xD6\xB3\x90\x6D\x4A\x90\x6D\x4A" | ||
3522 | "\x27\x04\xE1\x27\x04\xE1\xBE\x9B" | ||
3523 | "\x78\xBE\x9B\x78\x55\x32\x0F\x55", | ||
3524 | .klen = 32, | ||
3525 | .iv = "\xE2\x24\x89\xEE\x53\xB8\x1D\x5F" | ||
3526 | "\xC4\x29\x8E\xF3\x35\x9A\xFF\x64", | ||
3527 | .input = "\x56\xED\x84\x1B\x8F\x26\xBD\x31" | ||
3528 | "\xC8\x5F\xF6\x6A\x01\x98\x0C\xA3" | ||
3529 | "\x3A\xD1\x45\xDC\x73\x0A\x7E\x15" | ||
3530 | "\xAC\x20\xB7\x4E\xE5\x59\xF0\x87" | ||
3531 | "\x1E\x92\x29\xC0\x34\xCB\x62\xF9" | ||
3532 | "\x6D\x04\x9B\x0F\xA6\x3D\xD4\x48" | ||
3533 | "\xDF\x76\x0D\x81\x18\xAF\x23\xBA" | ||
3534 | "\x51\xE8\x5C\xF3\x8A\x21\x95\x2C" | ||
3535 | "\xC3\x37\xCE\x65\xFC\x70\x07\x9E" | ||
3536 | "\x12\xA9\x40\xD7\x4B\xE2\x79\x10" | ||
3537 | "\x84\x1B\xB2\x26\xBD\x54\xEB\x5F" | ||
3538 | "\xF6\x8D\x01\x98\x2F\xC6\x3A\xD1" | ||
3539 | "\x68\xFF\x73\x0A\xA1\x15\xAC\x43" | ||
3540 | "\xDA\x4E\xE5\x7C\x13\x87\x1E\xB5" | ||
3541 | "\x29\xC0\x57\xEE\x62\xF9\x90\x04" | ||
3542 | "\x9B\x32\xC9\x3D\xD4\x6B\x02\x76" | ||
3543 | "\x0D\xA4\x18\xAF\x46\xDD\x51\xE8" | ||
3544 | "\x7F\x16\x8A\x21\xB8\x2C\xC3\x5A" | ||
3545 | "\xF1\x65\xFC", | ||
3546 | .ilen = 147, | ||
3547 | .result = "\x84\x68\xEC\xF2\x1C\x88\x20\xCA" | ||
3548 | "\x37\x69\xE3\x3A\x22\x85\x48\x46" | ||
3549 | "\x70\xAA\x25\xB4\xCD\x8B\x04\x4E" | ||
3550 | "\x8D\x15\x2B\x98\xDF\x7B\x6D\xB9" | ||
3551 | "\xE0\x4A\x73\x00\x65\xB6\x1A\x0D" | ||
3552 | "\x5C\x60\xDF\x34\xDC\x60\x4C\xDF" | ||
3553 | "\xB5\x1F\x26\x8C\xDA\xC1\x11\xA8" | ||
3554 | "\x80\xFA\x37\x7A\x89\xAA\xAE\x7B" | ||
3555 | "\x92\x6E\xB9\xDC\xC9\x62\x4F\x88" | ||
3556 | "\x0A\x5D\x97\x2F\x6B\xAC\x03\x7C" | ||
3557 | "\x22\xF6\x55\x5A\xFA\x35\xA5\x17" | ||
3558 | "\xA1\x5C\x5E\x2B\x63\x2D\xB9\x91" | ||
3559 | "\x3E\x83\x26\x00\x4E\xD5\xBE\xCE" | ||
3560 | "\x79\xC4\x3D\xFC\x70\xA0\xAD\x96" | ||
3561 | "\xBA\x58\x2A\x1C\xDF\xC2\x3A\xA5" | ||
3562 | "\x7C\xB5\x12\x89\xED\xBF\xB6\x09" | ||
3563 | "\x13\x4F\x7D\x61\x3C\x5C\x27\xFC" | ||
3564 | "\x5D\xE1\x4F\xA1\xEA\xB3\xCA\xB9" | ||
3565 | "\xE6\xD0\x97", | ||
3566 | .rlen = 147, | ||
3567 | }, | ||
3568 | }; | ||
3569 | |||
3570 | static struct cipher_testvec serpent_ctr_dec_tv_template[] = { | ||
3571 | { /* Generated with Crypto++ */ | ||
3572 | .key = "\x85\x62\x3F\x1C\xF9\xD6\x1C\xF9" | ||
3573 | "\xD6\xB3\x90\x6D\x4A\x90\x6D\x4A" | ||
3574 | "\x27\x04\xE1\x27\x04\xE1\xBE\x9B" | ||
3575 | "\x78\xBE\x9B\x78\x55\x32\x0F\x55", | ||
3576 | .klen = 32, | ||
3577 | .iv = "\xE2\x24\x89\xEE\x53\xB8\x1D\x5F" | ||
3578 | "\xC4\x29\x8E\xF3\x35\x9A\xFF\x64", | ||
3579 | .input = "\x84\x68\xEC\xF2\x1C\x88\x20\xCA" | ||
3580 | "\x37\x69\xE3\x3A\x22\x85\x48\x46" | ||
3581 | "\x70\xAA\x25\xB4\xCD\x8B\x04\x4E" | ||
3582 | "\x8D\x15\x2B\x98\xDF\x7B\x6D\xB9" | ||
3583 | "\xE0\x4A\x73\x00\x65\xB6\x1A\x0D" | ||
3584 | "\x5C\x60\xDF\x34\xDC\x60\x4C\xDF" | ||
3585 | "\xB5\x1F\x26\x8C\xDA\xC1\x11\xA8" | ||
3586 | "\x80\xFA\x37\x7A\x89\xAA\xAE\x7B" | ||
3587 | "\x92\x6E\xB9\xDC\xC9\x62\x4F\x88" | ||
3588 | "\x0A\x5D\x97\x2F\x6B\xAC\x03\x7C" | ||
3589 | "\x22\xF6\x55\x5A\xFA\x35\xA5\x17" | ||
3590 | "\xA1\x5C\x5E\x2B\x63\x2D\xB9\x91" | ||
3591 | "\x3E\x83\x26\x00\x4E\xD5\xBE\xCE" | ||
3592 | "\x79\xC4\x3D\xFC\x70\xA0\xAD\x96" | ||
3593 | "\xBA\x58\x2A\x1C\xDF\xC2\x3A\xA5" | ||
3594 | "\x7C\xB5\x12\x89\xED\xBF\xB6\x09" | ||
3595 | "\x13\x4F\x7D\x61\x3C\x5C\x27\xFC" | ||
3596 | "\x5D\xE1\x4F\xA1\xEA\xB3\xCA\xB9", | ||
3597 | .ilen = 144, | ||
3598 | .result = "\x56\xED\x84\x1B\x8F\x26\xBD\x31" | ||
3599 | "\xC8\x5F\xF6\x6A\x01\x98\x0C\xA3" | ||
3600 | "\x3A\xD1\x45\xDC\x73\x0A\x7E\x15" | ||
3601 | "\xAC\x20\xB7\x4E\xE5\x59\xF0\x87" | ||
3602 | "\x1E\x92\x29\xC0\x34\xCB\x62\xF9" | ||
3603 | "\x6D\x04\x9B\x0F\xA6\x3D\xD4\x48" | ||
3604 | "\xDF\x76\x0D\x81\x18\xAF\x23\xBA" | ||
3605 | "\x51\xE8\x5C\xF3\x8A\x21\x95\x2C" | ||
3606 | "\xC3\x37\xCE\x65\xFC\x70\x07\x9E" | ||
3607 | "\x12\xA9\x40\xD7\x4B\xE2\x79\x10" | ||
3608 | "\x84\x1B\xB2\x26\xBD\x54\xEB\x5F" | ||
3609 | "\xF6\x8D\x01\x98\x2F\xC6\x3A\xD1" | ||
3610 | "\x68\xFF\x73\x0A\xA1\x15\xAC\x43" | ||
3611 | "\xDA\x4E\xE5\x7C\x13\x87\x1E\xB5" | ||
3612 | "\x29\xC0\x57\xEE\x62\xF9\x90\x04" | ||
3613 | "\x9B\x32\xC9\x3D\xD4\x6B\x02\x76" | ||
3614 | "\x0D\xA4\x18\xAF\x46\xDD\x51\xE8" | ||
3615 | "\x7F\x16\x8A\x21\xB8\x2C\xC3\x5A", | ||
3616 | .rlen = 144, | ||
3617 | }, { /* Generated with Crypto++ */ | ||
3618 | .key = "\x85\x62\x3F\x1C\xF9\xD6\x1C\xF9" | ||
3619 | "\xD6\xB3\x90\x6D\x4A\x90\x6D\x4A" | ||
3620 | "\x27\x04\xE1\x27\x04\xE1\xBE\x9B" | ||
3621 | "\x78\xBE\x9B\x78\x55\x32\x0F\x55", | ||
3622 | .klen = 32, | ||
3623 | .iv = "\xE2\x24\x89\xEE\x53\xB8\x1D\x5F" | ||
3624 | "\xC4\x29\x8E\xF3\x35\x9A\xFF\x64", | ||
3625 | .input = "\x84\x68\xEC\xF2\x1C\x88\x20\xCA" | ||
3626 | "\x37\x69\xE3\x3A\x22\x85\x48\x46" | ||
3627 | "\x70\xAA\x25\xB4\xCD\x8B\x04\x4E" | ||
3628 | "\x8D\x15\x2B\x98\xDF\x7B\x6D\xB9" | ||
3629 | "\xE0\x4A\x73\x00\x65\xB6\x1A\x0D" | ||
3630 | "\x5C\x60\xDF\x34\xDC\x60\x4C\xDF" | ||
3631 | "\xB5\x1F\x26\x8C\xDA\xC1\x11\xA8" | ||
3632 | "\x80\xFA\x37\x7A\x89\xAA\xAE\x7B" | ||
3633 | "\x92\x6E\xB9\xDC\xC9\x62\x4F\x88" | ||
3634 | "\x0A\x5D\x97\x2F\x6B\xAC\x03\x7C" | ||
3635 | "\x22\xF6\x55\x5A\xFA\x35\xA5\x17" | ||
3636 | "\xA1\x5C\x5E\x2B\x63\x2D\xB9\x91" | ||
3637 | "\x3E\x83\x26\x00\x4E\xD5\xBE\xCE" | ||
3638 | "\x79\xC4\x3D\xFC\x70\xA0\xAD\x96" | ||
3639 | "\xBA\x58\x2A\x1C\xDF\xC2\x3A\xA5" | ||
3640 | "\x7C\xB5\x12\x89\xED\xBF\xB6\x09" | ||
3641 | "\x13\x4F\x7D\x61\x3C\x5C\x27\xFC" | ||
3642 | "\x5D\xE1\x4F\xA1\xEA\xB3\xCA\xB9" | ||
3643 | "\xE6\xD0\x97", | ||
3644 | .ilen = 147, | ||
3645 | .result = "\x56\xED\x84\x1B\x8F\x26\xBD\x31" | ||
3646 | "\xC8\x5F\xF6\x6A\x01\x98\x0C\xA3" | ||
3647 | "\x3A\xD1\x45\xDC\x73\x0A\x7E\x15" | ||
3648 | "\xAC\x20\xB7\x4E\xE5\x59\xF0\x87" | ||
3649 | "\x1E\x92\x29\xC0\x34\xCB\x62\xF9" | ||
3650 | "\x6D\x04\x9B\x0F\xA6\x3D\xD4\x48" | ||
3651 | "\xDF\x76\x0D\x81\x18\xAF\x23\xBA" | ||
3652 | "\x51\xE8\x5C\xF3\x8A\x21\x95\x2C" | ||
3653 | "\xC3\x37\xCE\x65\xFC\x70\x07\x9E" | ||
3654 | "\x12\xA9\x40\xD7\x4B\xE2\x79\x10" | ||
3655 | "\x84\x1B\xB2\x26\xBD\x54\xEB\x5F" | ||
3656 | "\xF6\x8D\x01\x98\x2F\xC6\x3A\xD1" | ||
3657 | "\x68\xFF\x73\x0A\xA1\x15\xAC\x43" | ||
3658 | "\xDA\x4E\xE5\x7C\x13\x87\x1E\xB5" | ||
3659 | "\x29\xC0\x57\xEE\x62\xF9\x90\x04" | ||
3660 | "\x9B\x32\xC9\x3D\xD4\x6B\x02\x76" | ||
3661 | "\x0D\xA4\x18\xAF\x46\xDD\x51\xE8" | ||
3662 | "\x7F\x16\x8A\x21\xB8\x2C\xC3\x5A" | ||
3663 | "\xF1\x65\xFC", | ||
3664 | .rlen = 147, | ||
3665 | }, | ||
3666 | }; | ||
3278 | 3667 | ||
3279 | /* Cast6 test vectors from RFC 2612 */ | 3668 | /* Cast6 test vectors from RFC 2612 */ |
3280 | #define CAST6_ENC_TEST_VECTORS 3 | 3669 | #define CAST6_ENC_TEST_VECTORS 3 |