diff options
author | lloyd <[email protected]> | 2006-08-15 11:34:48 +0000 |
---|---|---|
committer | lloyd <[email protected]> | 2006-08-15 11:34:48 +0000 |
commit | 12a48f7ffac24d0342a9572d489b0b543fa46df7 (patch) | |
tree | 201b5a9ff4f1b356be784e22ebbcae2bc8057901 /modules/alg_ia32/serp_asm.S | |
parent | beb7706fde4cd40ed74e5526a8e9dd51aa1531b0 (diff) |
Implement the Serpent key schedule in assembly as well, so the C++
versions of the Sboxes can be removed.
Add some parens inside the asm macros
Diffstat (limited to 'modules/alg_ia32/serp_asm.S')
-rw-r--r-- | modules/alg_ia32/serp_asm.S | 90 |
1 files changed, 90 insertions, 0 deletions
diff --git a/modules/alg_ia32/serp_asm.S b/modules/alg_ia32/serp_asm.S index ec84ffbc5..e6c8c3cb3 100644 --- a/modules/alg_ia32/serp_asm.S +++ b/modules/alg_ia32/serp_asm.S @@ -438,6 +438,9 @@ START_LISTING(serp_asm.S) XOR(C, ARRAY4(EDI, (4*N+2))) ; \ XOR(D, ARRAY4(EDI, (4*N+3))) ; \ +/************************************************* +* Serpent Encryption * +*************************************************/ START_FUNCTION(serpent_encrypt) SPILL_REGS() @@ -506,6 +509,9 @@ START_FUNCTION(serpent_encrypt) RESTORE_REGS() END_FUNCTION(serpent_encrypt) +/************************************************* +* Serpent Decryption * +*************************************************/ START_FUNCTION(serpent_decrypt) SPILL_REGS() @@ -572,3 +578,87 @@ START_FUNCTION(serpent_decrypt) RESTORE_REGS() END_FUNCTION(serpent_decrypt) +/************************************************* +* Serpent Key Schedule * +*************************************************/ +START_FUNCTION(serpent_key_schedule) + SPILL_REGS() + + ASSIGN(EDI, ARG(1)) /* round keys */ + ASSIGN(ESI, IMM(8)) + ADD_IMM(EDI, 32) + +START_LOOP(.EXPANSION) + + ASSIGN(EAX, ESI) + SUB_IMM(EAX, 8) + + XOR(EAX, ARRAY4(EDI, -1)) + XOR(EAX, ARRAY4(EDI, -3)) + XOR(EAX, ARRAY4(EDI, -5)) + XOR(EAX, ARRAY4(EDI, -8)) + XOR(EAX, IMM(0x9E3779B9)) + + ROTL_IMM(EAX, 11) + + ASSIGN(ARRAY4(EDI, 0), EAX) + + ADD_IMM(EDI, 4) + ADD_IMM(ESI, 1) +LOOP_UNTIL(ESI, IMM(140), .EXPANSION) + + + ASSIGN(EDI, ARG(1)) /* round keys */ + +#define LOAD_AND_SBOX(MSG, SBOX) \ + ASSIGN(EAX, ARRAY4(EDI, (4*MSG+ 8))) ; \ + ASSIGN(EBX, ARRAY4(EDI, (4*MSG+ 9))) ; \ + ASSIGN(ECX, ARRAY4(EDI, (4*MSG+10))) ; \ + ASSIGN(EDX, ARRAY4(EDI, (4*MSG+11))) ; \ + SBOX(EAX, EBX, ECX, EDX, EBP) ; \ + ASSIGN(ARRAY4(EDI, (4*MSG+ 8)), EAX) ; \ + ASSIGN(ARRAY4(EDI, (4*MSG+ 9)), EBX) ; \ + ASSIGN(ARRAY4(EDI, (4*MSG+10)), ECX) ; \ + ASSIGN(ARRAY4(EDI, (4*MSG+11)), EDX) + + LOAD_AND_SBOX( 0, SBOX_E4) + LOAD_AND_SBOX( 1, SBOX_E3) + LOAD_AND_SBOX( 2, SBOX_E2) + LOAD_AND_SBOX( 3, SBOX_E1) + + LOAD_AND_SBOX( 4, SBOX_E8) + LOAD_AND_SBOX( 5, SBOX_E7) + LOAD_AND_SBOX( 6, SBOX_E6) + LOAD_AND_SBOX( 7, SBOX_E5) + LOAD_AND_SBOX( 8, SBOX_E4) + LOAD_AND_SBOX( 9, SBOX_E3) + LOAD_AND_SBOX(10, SBOX_E2) + LOAD_AND_SBOX(11, SBOX_E1) + + LOAD_AND_SBOX(12, SBOX_E8) + LOAD_AND_SBOX(13, SBOX_E7) + LOAD_AND_SBOX(14, SBOX_E6) + LOAD_AND_SBOX(15, SBOX_E5) + LOAD_AND_SBOX(16, SBOX_E4) + LOAD_AND_SBOX(17, SBOX_E3) + LOAD_AND_SBOX(18, SBOX_E2) + LOAD_AND_SBOX(19, SBOX_E1) + + LOAD_AND_SBOX(20, SBOX_E8) + LOAD_AND_SBOX(21, SBOX_E7) + LOAD_AND_SBOX(22, SBOX_E6) + LOAD_AND_SBOX(23, SBOX_E5) + LOAD_AND_SBOX(24, SBOX_E4) + LOAD_AND_SBOX(25, SBOX_E3) + LOAD_AND_SBOX(26, SBOX_E2) + LOAD_AND_SBOX(27, SBOX_E1) + + LOAD_AND_SBOX(28, SBOX_E8) + LOAD_AND_SBOX(29, SBOX_E7) + LOAD_AND_SBOX(30, SBOX_E6) + LOAD_AND_SBOX(31, SBOX_E5) + LOAD_AND_SBOX(32, SBOX_E4) + + RESTORE_REGS() +END_FUNCTION(serpent_key_schedule) + |