Skip to content
Snippets Groups Projects
Commit 27e90cc8 authored by Niels Möller's avatar Niels Möller
Browse files

(aes_decrypt): Use the AES_LOAD macro.

Rev: src/nettle/x86/aes-decrypt.asm:1.3
parent 934c1628
No related branches found
No related tags found
No related merge requests found
...@@ -22,11 +22,12 @@ C MA 02111-1307, USA. ...@@ -22,11 +22,12 @@ C MA 02111-1307, USA.
C aes_decrypt(struct aes_context *ctx, C aes_decrypt(struct aes_context *ctx,
C unsigned length, uint8_t *dst, C unsigned length, uint8_t *dst,
C uint8_t *src) C uint8_t *src)
.text
.align 16 .align 16
.globl aes_decrypt .globl aes_decrypt
.type aes_decrypt,@function .type aes_decrypt,@function
aes_decrypt: aes_decrypt:
C // save all registers that need to be saved C save all registers that need to be saved
pushl %ebx C 16(%esp) pushl %ebx C 16(%esp)
pushl %ebp C 12(%esp) pushl %ebp C 12(%esp)
pushl %esi C 8(%esp) pushl %esi C 8(%esp)
...@@ -38,24 +39,28 @@ aes_decrypt: ...@@ -38,24 +39,28 @@ aes_decrypt:
C src = 32(%esp) C src = 32(%esp)
movl 24(%esp), %ebp movl 24(%esp), %ebp
C What's the right way to set the flags? testl %ebp,%ebp
addl $0, %ebp
jz .Ldecrypt_end jz .Ldecrypt_end
.Ldecrypt_block_loop: .Ldecrypt_block_loop:
movl 32(%esp),%esi C address of ciphertext movl 20(%esp),%esi C address of context struct ctx
movl (%esi),%eax C load ciphertext into registers movl 32(%esp),%ebp C address of plaintext
movl 4(%esi),%ebx AES_LOAD(%esi, %ebp)
movl 8(%esi),%ecx
movl 12(%esi),%edx
addl $16, 32(%esp) C Increment src pointer addl $16, 32(%esp) C Increment src pointer
movl 20(%esp),%esi C address of context struct ctx C movl 32(%esp),%esi C address of ciphertext
xorl (%esi),%eax C add first key to ciphertext C movl (%esi),%eax C load ciphertext into registers
xorl 4(%esi),%ebx C movl 4(%esi),%ebx
xorl 8(%esi),%ecx C movl 8(%esi),%ecx
xorl 12(%esi),%edx C movl 12(%esi),%edx
C
C addl $16, 32(%esp) C Increment src pointer
C
C movl 20(%esp),%esi C address of context struct ctx
C xorl (%esi),%eax C add first key to ciphertext
C xorl 4(%esi),%ebx
C xorl 8(%esi),%ecx
C xorl 12(%esi),%edx
movl AES_NROUNDS (%esi),%ebp C get number of rounds to do from struct movl AES_NROUNDS (%esi),%ebp C get number of rounds to do from struct
C shll $4,%ebp C shll $4,%ebp
C leal 240(%esi, %ebp),%esi C leal 240(%esi, %ebp),%esi
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment