comparison libtomcrypt/src/ciphers/aes/aes.c @ 398:59c7938af2bd

merge of '1250b8af44b62d8f4fe0f8d9fc7e7a1cc34e7e1c' and '7f8670ac3bb975f40967f3979d09d2199b7e90c8'
author Matt Johnston <matt@ucc.asn.au>
date Sat, 03 Feb 2007 08:20:30 +0000
parents 0cbe8f6dbf9e
children eef377591301
comparison
equal deleted inserted replaced
396:e7c1a77d2921 398:59c7938af2bd
4 * algorithms in a highly modular and flexible manner. 4 * algorithms in a highly modular and flexible manner.
5 * 5 *
6 * The library is free for all purposes without any express 6 * The library is free for all purposes without any express
7 * guarantee it works. 7 * guarantee it works.
8 * 8 *
9 * Tom St Denis, [email protected], http://libtomcrypt.org 9 * Tom St Denis, [email protected], http://libtomcrypt.com
10 */ 10 */
11 11
12 /* AES implementation by Tom St Denis 12 /* AES implementation by Tom St Denis
13 * 13 *
14 * Derived from the Public Domain source code by 14 * Derived from the Public Domain source code by
48 { 48 {
49 "rijndael", 49 "rijndael",
50 6, 50 6,
51 16, 32, 16, 10, 51 16, 32, 16, 10,
52 SETUP, ECB_ENC, ECB_DEC, ECB_TEST, ECB_DONE, ECB_KS, 52 SETUP, ECB_ENC, ECB_DEC, ECB_TEST, ECB_DONE, ECB_KS,
53 NULL, NULL, NULL, NULL, NULL, NULL, NULL 53 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL
54 }; 54 };
55 #endif 55 #endif
56 56
57 const struct ltc_cipher_descriptor aes_desc = 57 const struct ltc_cipher_descriptor aes_desc =
58 { 58 {
59 "aes", 59 "aes",
60 6, 60 6,
61 16, 32, 16, 10, 61 16, 32, 16, 10,
62 SETUP, ECB_ENC, ECB_DEC, ECB_TEST, ECB_DONE, ECB_KS, 62 SETUP, ECB_ENC, ECB_DEC, ECB_TEST, ECB_DONE, ECB_KS,
63 NULL, NULL, NULL, NULL, NULL, NULL, NULL 63 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL
64 }; 64 };
65 65
66 #else 66 #else
67 67
68 #define SETUP rijndael_enc_setup 68 #define SETUP rijndael_enc_setup
74 { 74 {
75 "rijndael", 75 "rijndael",
76 6, 76 6,
77 16, 32, 16, 10, 77 16, 32, 16, 10,
78 SETUP, ECB_ENC, NULL, NULL, ECB_DONE, ECB_KS, 78 SETUP, ECB_ENC, NULL, NULL, ECB_DONE, ECB_KS,
79 NULL, NULL, NULL, NULL, NULL, NULL, NULL 79 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL
80 }; 80 };
81 81
82 const struct ltc_cipher_descriptor aes_enc_desc = 82 const struct ltc_cipher_descriptor aes_enc_desc =
83 { 83 {
84 "aes", 84 "aes",
85 6, 85 6,
86 16, 32, 16, 10, 86 16, 32, 16, 10,
87 SETUP, ECB_ENC, NULL, NULL, ECB_DONE, ECB_KS, 87 SETUP, ECB_ENC, NULL, NULL, ECB_DONE, ECB_KS,
88 NULL, NULL, NULL, NULL, NULL, NULL, NULL 88 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL
89 }; 89 };
90 90
91 #endif 91 #endif
92 92
93 #include "aes_tab.c" 93 #include "aes_tab.c"
281 /** 281 /**
282 Encrypts a block of text with AES 282 Encrypts a block of text with AES
283 @param pt The input plaintext (16 bytes) 283 @param pt The input plaintext (16 bytes)
284 @param ct The output ciphertext (16 bytes) 284 @param ct The output ciphertext (16 bytes)
285 @param skey The key as scheduled 285 @param skey The key as scheduled
286 @return CRYPT_OK if successful
286 */ 287 */
287 #ifdef LTC_CLEAN_STACK 288 #ifdef LTC_CLEAN_STACK
288 static void _rijndael_ecb_encrypt(const unsigned char *pt, unsigned char *ct, symmetric_key *skey) 289 static int _rijndael_ecb_encrypt(const unsigned char *pt, unsigned char *ct, symmetric_key *skey)
289 #else 290 #else
290 void ECB_ENC(const unsigned char *pt, unsigned char *ct, symmetric_key *skey) 291 int ECB_ENC(const unsigned char *pt, unsigned char *ct, symmetric_key *skey)
291 #endif 292 #endif
292 { 293 {
293 ulong32 s0, s1, s2, s3, t0, t1, t2, t3, *rk; 294 ulong32 s0, s1, s2, s3, t0, t1, t2, t3, *rk;
294 int Nr, r; 295 int Nr, r;
295 296
306 */ 307 */
307 LOAD32H(s0, pt ); s0 ^= rk[0]; 308 LOAD32H(s0, pt ); s0 ^= rk[0];
308 LOAD32H(s1, pt + 4); s1 ^= rk[1]; 309 LOAD32H(s1, pt + 4); s1 ^= rk[1];
309 LOAD32H(s2, pt + 8); s2 ^= rk[2]; 310 LOAD32H(s2, pt + 8); s2 ^= rk[2];
310 LOAD32H(s3, pt + 12); s3 ^= rk[3]; 311 LOAD32H(s3, pt + 12); s3 ^= rk[3];
311
312 312
313 #ifdef LTC_SMALL_CODE 313 #ifdef LTC_SMALL_CODE
314 314
315 for (r = 0; ; r++) { 315 for (r = 0; ; r++) {
316 rk += 4; 316 rk += 4;
440 (Te4_2[byte(t0, 2)]) ^ 440 (Te4_2[byte(t0, 2)]) ^
441 (Te4_1[byte(t1, 1)]) ^ 441 (Te4_1[byte(t1, 1)]) ^
442 (Te4_0[byte(t2, 0)]) ^ 442 (Te4_0[byte(t2, 0)]) ^
443 rk[3]; 443 rk[3];
444 STORE32H(s3, ct+12); 444 STORE32H(s3, ct+12);
445
446 return CRYPT_OK;
445 } 447 }
446 448
447 #ifdef LTC_CLEAN_STACK 449 #ifdef LTC_CLEAN_STACK
448 void ECB_ENC(const unsigned char *pt, unsigned char *ct, symmetric_key *skey) 450 int ECB_ENC(const unsigned char *pt, unsigned char *ct, symmetric_key *skey)
449 { 451 {
450 _rijndael_ecb_encrypt(pt, ct, skey); 452 int err = _rijndael_ecb_encrypt(pt, ct, skey);
451 burn_stack(sizeof(unsigned long)*8 + sizeof(unsigned long*) + sizeof(int)*2); 453 burn_stack(sizeof(unsigned long)*8 + sizeof(unsigned long*) + sizeof(int)*2);
454 return err;
452 } 455 }
453 #endif 456 #endif
454 457
455 #ifndef ENCRYPT_ONLY 458 #ifndef ENCRYPT_ONLY
456 459
457 /** 460 /**
458 Decrypts a block of text with AES 461 Decrypts a block of text with AES
459 @param ct The input ciphertext (16 bytes) 462 @param ct The input ciphertext (16 bytes)
460 @param pt The output plaintext (16 bytes) 463 @param pt The output plaintext (16 bytes)
461 @param skey The key as scheduled 464 @param skey The key as scheduled
465 @return CRYPT_OK if successful
462 */ 466 */
463 #ifdef LTC_CLEAN_STACK 467 #ifdef LTC_CLEAN_STACK
464 static void _rijndael_ecb_decrypt(const unsigned char *ct, unsigned char *pt, symmetric_key *skey) 468 static int _rijndael_ecb_decrypt(const unsigned char *ct, unsigned char *pt, symmetric_key *skey)
465 #else 469 #else
466 void ECB_DEC(const unsigned char *ct, unsigned char *pt, symmetric_key *skey) 470 int ECB_DEC(const unsigned char *ct, unsigned char *pt, symmetric_key *skey)
467 #endif 471 #endif
468 { 472 {
469 ulong32 s0, s1, s2, s3, t0, t1, t2, t3, *rk; 473 ulong32 s0, s1, s2, s3, t0, t1, t2, t3, *rk;
470 int Nr, r; 474 int Nr, r;
471 475
615 (Td4[byte(t2, 2)] & 0x00ff0000) ^ 619 (Td4[byte(t2, 2)] & 0x00ff0000) ^
616 (Td4[byte(t1, 1)] & 0x0000ff00) ^ 620 (Td4[byte(t1, 1)] & 0x0000ff00) ^
617 (Td4[byte(t0, 0)] & 0x000000ff) ^ 621 (Td4[byte(t0, 0)] & 0x000000ff) ^
618 rk[3]; 622 rk[3];
619 STORE32H(s3, pt+12); 623 STORE32H(s3, pt+12);
624
625 return CRYPT_OK;
620 } 626 }
621 627
622 628
623 #ifdef LTC_CLEAN_STACK 629 #ifdef LTC_CLEAN_STACK
624 void ECB_DEC(const unsigned char *ct, unsigned char *pt, symmetric_key *skey) 630 int ECB_DEC(const unsigned char *ct, unsigned char *pt, symmetric_key *skey)
625 { 631 {
626 _rijndael_ecb_decrypt(ct, pt, skey); 632 int err = _rijndael_ecb_decrypt(ct, pt, skey);
627 burn_stack(sizeof(unsigned long)*8 + sizeof(unsigned long*) + sizeof(int)*2); 633 burn_stack(sizeof(unsigned long)*8 + sizeof(unsigned long*) + sizeof(int)*2);
634 return err;
628 } 635 }
629 #endif 636 #endif
630 637
631 /** 638 /**
632 Performs a self-test of the AES block cipher 639 Performs a self-test of the AES block cipher
681 return err; 688 return err;
682 } 689 }
683 690
684 rijndael_ecb_encrypt(tests[i].pt, tmp[0], &key); 691 rijndael_ecb_encrypt(tests[i].pt, tmp[0], &key);
685 rijndael_ecb_decrypt(tmp[0], tmp[1], &key); 692 rijndael_ecb_decrypt(tmp[0], tmp[1], &key);
686 if (memcmp(tmp[0], tests[i].ct, 16) || memcmp(tmp[1], tests[i].pt, 16)) { 693 if (XMEMCMP(tmp[0], tests[i].ct, 16) || XMEMCMP(tmp[1], tests[i].pt, 16)) {
687 #if 0 694 #if 0
688 printf("\n\nTest %d failed\n", i); 695 printf("\n\nTest %d failed\n", i);
689 if (memcmp(tmp[0], tests[i].ct, 16)) { 696 if (XMEMCMP(tmp[0], tests[i].ct, 16)) {
690 printf("CT: "); 697 printf("CT: ");
691 for (i = 0; i < 16; i++) { 698 for (i = 0; i < 16; i++) {
692 printf("%02x ", tmp[0][i]); 699 printf("%02x ", tmp[0][i]);
693 } 700 }
694 printf("\n"); 701 printf("\n");
749 756
750 #endif 757 #endif
751 758
752 759
753 /* $Source: /cvs/libtom/libtomcrypt/src/ciphers/aes/aes.c,v $ */ 760 /* $Source: /cvs/libtom/libtomcrypt/src/ciphers/aes/aes.c,v $ */
754 /* $Revision: 1.8 $ */ 761 /* $Revision: 1.14 $ */
755 /* $Date: 2005/05/05 14:35:58 $ */ 762 /* $Date: 2006/11/08 23:01:06 $ */