mirror of
https://github.com/pineappleEA/pineapple-src.git
synced 2024-12-12 16:18:24 -05:00
1865 lines
24 KiB
ArmAsm
1865 lines
24 KiB
ArmAsm
|
; 1 "crypto/sha/sha256-masm-x86_64.S.tmp"
|
||
|
; 1 "<built-in>" 1
|
||
|
; 1 "<built-in>" 3
|
||
|
; 340 "<built-in>" 3
|
||
|
; 1 "<command line>" 1
|
||
|
; 1 "<built-in>" 2
|
||
|
; 1 "crypto/sha/sha256-masm-x86_64.S.tmp" 2
|
||
|
OPTION DOTNAME
|
||
|
|
||
|
; 1 "./crypto/x86_arch.h" 1
|
||
|
|
||
|
|
||
|
; 16 "./crypto/x86_arch.h"
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
; 40 "./crypto/x86_arch.h"
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
; 3 "crypto/sha/sha256-masm-x86_64.S.tmp" 2
|
||
|
.text$ SEGMENT ALIGN(64) 'CODE'
|
||
|
|
||
|
PUBLIC sha256_block_data_order
|
||
|
|
||
|
ALIGN 16
|
||
|
sha256_block_data_order PROC PUBLIC
|
||
|
mov QWORD PTR[8+rsp],rdi ;WIN64 prologue
|
||
|
mov QWORD PTR[16+rsp],rsi
|
||
|
mov rax,rsp
|
||
|
$L$SEH_begin_sha256_block_data_order::
|
||
|
mov rdi,rcx
|
||
|
mov rsi,rdx
|
||
|
mov rdx,r8
|
||
|
mov rcx,r9
|
||
|
|
||
|
|
||
|
push rbx
|
||
|
push rbp
|
||
|
push r12
|
||
|
push r13
|
||
|
push r14
|
||
|
push r15
|
||
|
mov r11,rsp
|
||
|
shl rdx,4
|
||
|
sub rsp,16*4+4*8
|
||
|
lea rdx,QWORD PTR[rdx*4+rsi]
|
||
|
and rsp,-64
|
||
|
mov QWORD PTR[((64+0))+rsp],rdi
|
||
|
mov QWORD PTR[((64+8))+rsp],rsi
|
||
|
mov QWORD PTR[((64+16))+rsp],rdx
|
||
|
mov QWORD PTR[((64+24))+rsp],r11
|
||
|
$L$prologue::
|
||
|
|
||
|
lea rbp,QWORD PTR[K256]
|
||
|
|
||
|
mov eax,DWORD PTR[rdi]
|
||
|
mov ebx,DWORD PTR[4+rdi]
|
||
|
mov ecx,DWORD PTR[8+rdi]
|
||
|
mov edx,DWORD PTR[12+rdi]
|
||
|
mov r8d,DWORD PTR[16+rdi]
|
||
|
mov r9d,DWORD PTR[20+rdi]
|
||
|
mov r10d,DWORD PTR[24+rdi]
|
||
|
mov r11d,DWORD PTR[28+rdi]
|
||
|
jmp $L$loop
|
||
|
|
||
|
ALIGN 16
|
||
|
$L$loop::
|
||
|
xor rdi,rdi
|
||
|
mov r12d,DWORD PTR[rsi]
|
||
|
mov r13d,r8d
|
||
|
mov r14d,eax
|
||
|
bswap r12d
|
||
|
ror r13d,14
|
||
|
mov r15d,r9d
|
||
|
mov DWORD PTR[rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,r8d
|
||
|
xor r15d,r10d
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,r11d
|
||
|
xor r14d,eax
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,r8d
|
||
|
mov r11d,ebx
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,r8d
|
||
|
xor r15d,r10d
|
||
|
|
||
|
xor r11d,ecx
|
||
|
xor r14d,eax
|
||
|
add r12d,r15d
|
||
|
mov r15d,ebx
|
||
|
|
||
|
ror r13d,6
|
||
|
and r11d,eax
|
||
|
and r15d,ecx
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add r11d,r15d
|
||
|
|
||
|
add edx,r12d
|
||
|
add r11d,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add r11d,r14d
|
||
|
|
||
|
mov r12d,DWORD PTR[4+rsi]
|
||
|
mov r13d,edx
|
||
|
mov r14d,r11d
|
||
|
bswap r12d
|
||
|
ror r13d,14
|
||
|
mov r15d,r8d
|
||
|
mov DWORD PTR[4+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,edx
|
||
|
xor r15d,r9d
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,r10d
|
||
|
xor r14d,r11d
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,edx
|
||
|
mov r10d,eax
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,edx
|
||
|
xor r15d,r9d
|
||
|
|
||
|
xor r10d,ebx
|
||
|
xor r14d,r11d
|
||
|
add r12d,r15d
|
||
|
mov r15d,eax
|
||
|
|
||
|
ror r13d,6
|
||
|
and r10d,r11d
|
||
|
and r15d,ebx
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add r10d,r15d
|
||
|
|
||
|
add ecx,r12d
|
||
|
add r10d,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add r10d,r14d
|
||
|
|
||
|
mov r12d,DWORD PTR[8+rsi]
|
||
|
mov r13d,ecx
|
||
|
mov r14d,r10d
|
||
|
bswap r12d
|
||
|
ror r13d,14
|
||
|
mov r15d,edx
|
||
|
mov DWORD PTR[8+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,ecx
|
||
|
xor r15d,r8d
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,r9d
|
||
|
xor r14d,r10d
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,ecx
|
||
|
mov r9d,r11d
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,ecx
|
||
|
xor r15d,r8d
|
||
|
|
||
|
xor r9d,eax
|
||
|
xor r14d,r10d
|
||
|
add r12d,r15d
|
||
|
mov r15d,r11d
|
||
|
|
||
|
ror r13d,6
|
||
|
and r9d,r10d
|
||
|
and r15d,eax
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add r9d,r15d
|
||
|
|
||
|
add ebx,r12d
|
||
|
add r9d,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add r9d,r14d
|
||
|
|
||
|
mov r12d,DWORD PTR[12+rsi]
|
||
|
mov r13d,ebx
|
||
|
mov r14d,r9d
|
||
|
bswap r12d
|
||
|
ror r13d,14
|
||
|
mov r15d,ecx
|
||
|
mov DWORD PTR[12+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,ebx
|
||
|
xor r15d,edx
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,r8d
|
||
|
xor r14d,r9d
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,ebx
|
||
|
mov r8d,r10d
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,ebx
|
||
|
xor r15d,edx
|
||
|
|
||
|
xor r8d,r11d
|
||
|
xor r14d,r9d
|
||
|
add r12d,r15d
|
||
|
mov r15d,r10d
|
||
|
|
||
|
ror r13d,6
|
||
|
and r8d,r9d
|
||
|
and r15d,r11d
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add r8d,r15d
|
||
|
|
||
|
add eax,r12d
|
||
|
add r8d,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add r8d,r14d
|
||
|
|
||
|
mov r12d,DWORD PTR[16+rsi]
|
||
|
mov r13d,eax
|
||
|
mov r14d,r8d
|
||
|
bswap r12d
|
||
|
ror r13d,14
|
||
|
mov r15d,ebx
|
||
|
mov DWORD PTR[16+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,eax
|
||
|
xor r15d,ecx
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,edx
|
||
|
xor r14d,r8d
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,eax
|
||
|
mov edx,r9d
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,eax
|
||
|
xor r15d,ecx
|
||
|
|
||
|
xor edx,r10d
|
||
|
xor r14d,r8d
|
||
|
add r12d,r15d
|
||
|
mov r15d,r9d
|
||
|
|
||
|
ror r13d,6
|
||
|
and edx,r8d
|
||
|
and r15d,r10d
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add edx,r15d
|
||
|
|
||
|
add r11d,r12d
|
||
|
add edx,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add edx,r14d
|
||
|
|
||
|
mov r12d,DWORD PTR[20+rsi]
|
||
|
mov r13d,r11d
|
||
|
mov r14d,edx
|
||
|
bswap r12d
|
||
|
ror r13d,14
|
||
|
mov r15d,eax
|
||
|
mov DWORD PTR[20+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,r11d
|
||
|
xor r15d,ebx
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,ecx
|
||
|
xor r14d,edx
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,r11d
|
||
|
mov ecx,r8d
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,r11d
|
||
|
xor r15d,ebx
|
||
|
|
||
|
xor ecx,r9d
|
||
|
xor r14d,edx
|
||
|
add r12d,r15d
|
||
|
mov r15d,r8d
|
||
|
|
||
|
ror r13d,6
|
||
|
and ecx,edx
|
||
|
and r15d,r9d
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add ecx,r15d
|
||
|
|
||
|
add r10d,r12d
|
||
|
add ecx,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add ecx,r14d
|
||
|
|
||
|
mov r12d,DWORD PTR[24+rsi]
|
||
|
mov r13d,r10d
|
||
|
mov r14d,ecx
|
||
|
bswap r12d
|
||
|
ror r13d,14
|
||
|
mov r15d,r11d
|
||
|
mov DWORD PTR[24+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,r10d
|
||
|
xor r15d,eax
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,ebx
|
||
|
xor r14d,ecx
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,r10d
|
||
|
mov ebx,edx
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,r10d
|
||
|
xor r15d,eax
|
||
|
|
||
|
xor ebx,r8d
|
||
|
xor r14d,ecx
|
||
|
add r12d,r15d
|
||
|
mov r15d,edx
|
||
|
|
||
|
ror r13d,6
|
||
|
and ebx,ecx
|
||
|
and r15d,r8d
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add ebx,r15d
|
||
|
|
||
|
add r9d,r12d
|
||
|
add ebx,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add ebx,r14d
|
||
|
|
||
|
mov r12d,DWORD PTR[28+rsi]
|
||
|
mov r13d,r9d
|
||
|
mov r14d,ebx
|
||
|
bswap r12d
|
||
|
ror r13d,14
|
||
|
mov r15d,r10d
|
||
|
mov DWORD PTR[28+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,r9d
|
||
|
xor r15d,r11d
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,eax
|
||
|
xor r14d,ebx
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,r9d
|
||
|
mov eax,ecx
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,r9d
|
||
|
xor r15d,r11d
|
||
|
|
||
|
xor eax,edx
|
||
|
xor r14d,ebx
|
||
|
add r12d,r15d
|
||
|
mov r15d,ecx
|
||
|
|
||
|
ror r13d,6
|
||
|
and eax,ebx
|
||
|
and r15d,edx
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add eax,r15d
|
||
|
|
||
|
add r8d,r12d
|
||
|
add eax,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add eax,r14d
|
||
|
|
||
|
mov r12d,DWORD PTR[32+rsi]
|
||
|
mov r13d,r8d
|
||
|
mov r14d,eax
|
||
|
bswap r12d
|
||
|
ror r13d,14
|
||
|
mov r15d,r9d
|
||
|
mov DWORD PTR[32+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,r8d
|
||
|
xor r15d,r10d
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,r11d
|
||
|
xor r14d,eax
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,r8d
|
||
|
mov r11d,ebx
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,r8d
|
||
|
xor r15d,r10d
|
||
|
|
||
|
xor r11d,ecx
|
||
|
xor r14d,eax
|
||
|
add r12d,r15d
|
||
|
mov r15d,ebx
|
||
|
|
||
|
ror r13d,6
|
||
|
and r11d,eax
|
||
|
and r15d,ecx
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add r11d,r15d
|
||
|
|
||
|
add edx,r12d
|
||
|
add r11d,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add r11d,r14d
|
||
|
|
||
|
mov r12d,DWORD PTR[36+rsi]
|
||
|
mov r13d,edx
|
||
|
mov r14d,r11d
|
||
|
bswap r12d
|
||
|
ror r13d,14
|
||
|
mov r15d,r8d
|
||
|
mov DWORD PTR[36+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,edx
|
||
|
xor r15d,r9d
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,r10d
|
||
|
xor r14d,r11d
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,edx
|
||
|
mov r10d,eax
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,edx
|
||
|
xor r15d,r9d
|
||
|
|
||
|
xor r10d,ebx
|
||
|
xor r14d,r11d
|
||
|
add r12d,r15d
|
||
|
mov r15d,eax
|
||
|
|
||
|
ror r13d,6
|
||
|
and r10d,r11d
|
||
|
and r15d,ebx
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add r10d,r15d
|
||
|
|
||
|
add ecx,r12d
|
||
|
add r10d,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add r10d,r14d
|
||
|
|
||
|
mov r12d,DWORD PTR[40+rsi]
|
||
|
mov r13d,ecx
|
||
|
mov r14d,r10d
|
||
|
bswap r12d
|
||
|
ror r13d,14
|
||
|
mov r15d,edx
|
||
|
mov DWORD PTR[40+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,ecx
|
||
|
xor r15d,r8d
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,r9d
|
||
|
xor r14d,r10d
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,ecx
|
||
|
mov r9d,r11d
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,ecx
|
||
|
xor r15d,r8d
|
||
|
|
||
|
xor r9d,eax
|
||
|
xor r14d,r10d
|
||
|
add r12d,r15d
|
||
|
mov r15d,r11d
|
||
|
|
||
|
ror r13d,6
|
||
|
and r9d,r10d
|
||
|
and r15d,eax
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add r9d,r15d
|
||
|
|
||
|
add ebx,r12d
|
||
|
add r9d,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add r9d,r14d
|
||
|
|
||
|
mov r12d,DWORD PTR[44+rsi]
|
||
|
mov r13d,ebx
|
||
|
mov r14d,r9d
|
||
|
bswap r12d
|
||
|
ror r13d,14
|
||
|
mov r15d,ecx
|
||
|
mov DWORD PTR[44+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,ebx
|
||
|
xor r15d,edx
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,r8d
|
||
|
xor r14d,r9d
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,ebx
|
||
|
mov r8d,r10d
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,ebx
|
||
|
xor r15d,edx
|
||
|
|
||
|
xor r8d,r11d
|
||
|
xor r14d,r9d
|
||
|
add r12d,r15d
|
||
|
mov r15d,r10d
|
||
|
|
||
|
ror r13d,6
|
||
|
and r8d,r9d
|
||
|
and r15d,r11d
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add r8d,r15d
|
||
|
|
||
|
add eax,r12d
|
||
|
add r8d,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add r8d,r14d
|
||
|
|
||
|
mov r12d,DWORD PTR[48+rsi]
|
||
|
mov r13d,eax
|
||
|
mov r14d,r8d
|
||
|
bswap r12d
|
||
|
ror r13d,14
|
||
|
mov r15d,ebx
|
||
|
mov DWORD PTR[48+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,eax
|
||
|
xor r15d,ecx
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,edx
|
||
|
xor r14d,r8d
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,eax
|
||
|
mov edx,r9d
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,eax
|
||
|
xor r15d,ecx
|
||
|
|
||
|
xor edx,r10d
|
||
|
xor r14d,r8d
|
||
|
add r12d,r15d
|
||
|
mov r15d,r9d
|
||
|
|
||
|
ror r13d,6
|
||
|
and edx,r8d
|
||
|
and r15d,r10d
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add edx,r15d
|
||
|
|
||
|
add r11d,r12d
|
||
|
add edx,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add edx,r14d
|
||
|
|
||
|
mov r12d,DWORD PTR[52+rsi]
|
||
|
mov r13d,r11d
|
||
|
mov r14d,edx
|
||
|
bswap r12d
|
||
|
ror r13d,14
|
||
|
mov r15d,eax
|
||
|
mov DWORD PTR[52+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,r11d
|
||
|
xor r15d,ebx
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,ecx
|
||
|
xor r14d,edx
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,r11d
|
||
|
mov ecx,r8d
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,r11d
|
||
|
xor r15d,ebx
|
||
|
|
||
|
xor ecx,r9d
|
||
|
xor r14d,edx
|
||
|
add r12d,r15d
|
||
|
mov r15d,r8d
|
||
|
|
||
|
ror r13d,6
|
||
|
and ecx,edx
|
||
|
and r15d,r9d
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add ecx,r15d
|
||
|
|
||
|
add r10d,r12d
|
||
|
add ecx,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add ecx,r14d
|
||
|
|
||
|
mov r12d,DWORD PTR[56+rsi]
|
||
|
mov r13d,r10d
|
||
|
mov r14d,ecx
|
||
|
bswap r12d
|
||
|
ror r13d,14
|
||
|
mov r15d,r11d
|
||
|
mov DWORD PTR[56+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,r10d
|
||
|
xor r15d,eax
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,ebx
|
||
|
xor r14d,ecx
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,r10d
|
||
|
mov ebx,edx
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,r10d
|
||
|
xor r15d,eax
|
||
|
|
||
|
xor ebx,r8d
|
||
|
xor r14d,ecx
|
||
|
add r12d,r15d
|
||
|
mov r15d,edx
|
||
|
|
||
|
ror r13d,6
|
||
|
and ebx,ecx
|
||
|
and r15d,r8d
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add ebx,r15d
|
||
|
|
||
|
add r9d,r12d
|
||
|
add ebx,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add ebx,r14d
|
||
|
|
||
|
mov r12d,DWORD PTR[60+rsi]
|
||
|
mov r13d,r9d
|
||
|
mov r14d,ebx
|
||
|
bswap r12d
|
||
|
ror r13d,14
|
||
|
mov r15d,r10d
|
||
|
mov DWORD PTR[60+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,r9d
|
||
|
xor r15d,r11d
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,eax
|
||
|
xor r14d,ebx
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,r9d
|
||
|
mov eax,ecx
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,r9d
|
||
|
xor r15d,r11d
|
||
|
|
||
|
xor eax,edx
|
||
|
xor r14d,ebx
|
||
|
add r12d,r15d
|
||
|
mov r15d,ecx
|
||
|
|
||
|
ror r13d,6
|
||
|
and eax,ebx
|
||
|
and r15d,edx
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add eax,r15d
|
||
|
|
||
|
add r8d,r12d
|
||
|
add eax,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add eax,r14d
|
||
|
|
||
|
jmp $L$rounds_16_xx
|
||
|
ALIGN 16
|
||
|
$L$rounds_16_xx::
|
||
|
mov r13d,DWORD PTR[4+rsp]
|
||
|
mov r14d,DWORD PTR[56+rsp]
|
||
|
mov r12d,r13d
|
||
|
mov r15d,r14d
|
||
|
|
||
|
ror r12d,11
|
||
|
xor r12d,r13d
|
||
|
shr r13d,3
|
||
|
|
||
|
ror r12d,7
|
||
|
xor r13d,r12d
|
||
|
mov r12d,DWORD PTR[36+rsp]
|
||
|
|
||
|
ror r15d,2
|
||
|
xor r15d,r14d
|
||
|
shr r14d,10
|
||
|
|
||
|
ror r15d,17
|
||
|
add r12d,r13d
|
||
|
xor r14d,r15d
|
||
|
|
||
|
add r12d,DWORD PTR[rsp]
|
||
|
mov r13d,r8d
|
||
|
add r12d,r14d
|
||
|
mov r14d,eax
|
||
|
ror r13d,14
|
||
|
mov r15d,r9d
|
||
|
mov DWORD PTR[rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,r8d
|
||
|
xor r15d,r10d
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,r11d
|
||
|
xor r14d,eax
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,r8d
|
||
|
mov r11d,ebx
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,r8d
|
||
|
xor r15d,r10d
|
||
|
|
||
|
xor r11d,ecx
|
||
|
xor r14d,eax
|
||
|
add r12d,r15d
|
||
|
mov r15d,ebx
|
||
|
|
||
|
ror r13d,6
|
||
|
and r11d,eax
|
||
|
and r15d,ecx
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add r11d,r15d
|
||
|
|
||
|
add edx,r12d
|
||
|
add r11d,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add r11d,r14d
|
||
|
|
||
|
mov r13d,DWORD PTR[8+rsp]
|
||
|
mov r14d,DWORD PTR[60+rsp]
|
||
|
mov r12d,r13d
|
||
|
mov r15d,r14d
|
||
|
|
||
|
ror r12d,11
|
||
|
xor r12d,r13d
|
||
|
shr r13d,3
|
||
|
|
||
|
ror r12d,7
|
||
|
xor r13d,r12d
|
||
|
mov r12d,DWORD PTR[40+rsp]
|
||
|
|
||
|
ror r15d,2
|
||
|
xor r15d,r14d
|
||
|
shr r14d,10
|
||
|
|
||
|
ror r15d,17
|
||
|
add r12d,r13d
|
||
|
xor r14d,r15d
|
||
|
|
||
|
add r12d,DWORD PTR[4+rsp]
|
||
|
mov r13d,edx
|
||
|
add r12d,r14d
|
||
|
mov r14d,r11d
|
||
|
ror r13d,14
|
||
|
mov r15d,r8d
|
||
|
mov DWORD PTR[4+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,edx
|
||
|
xor r15d,r9d
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,r10d
|
||
|
xor r14d,r11d
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,edx
|
||
|
mov r10d,eax
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,edx
|
||
|
xor r15d,r9d
|
||
|
|
||
|
xor r10d,ebx
|
||
|
xor r14d,r11d
|
||
|
add r12d,r15d
|
||
|
mov r15d,eax
|
||
|
|
||
|
ror r13d,6
|
||
|
and r10d,r11d
|
||
|
and r15d,ebx
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add r10d,r15d
|
||
|
|
||
|
add ecx,r12d
|
||
|
add r10d,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add r10d,r14d
|
||
|
|
||
|
mov r13d,DWORD PTR[12+rsp]
|
||
|
mov r14d,DWORD PTR[rsp]
|
||
|
mov r12d,r13d
|
||
|
mov r15d,r14d
|
||
|
|
||
|
ror r12d,11
|
||
|
xor r12d,r13d
|
||
|
shr r13d,3
|
||
|
|
||
|
ror r12d,7
|
||
|
xor r13d,r12d
|
||
|
mov r12d,DWORD PTR[44+rsp]
|
||
|
|
||
|
ror r15d,2
|
||
|
xor r15d,r14d
|
||
|
shr r14d,10
|
||
|
|
||
|
ror r15d,17
|
||
|
add r12d,r13d
|
||
|
xor r14d,r15d
|
||
|
|
||
|
add r12d,DWORD PTR[8+rsp]
|
||
|
mov r13d,ecx
|
||
|
add r12d,r14d
|
||
|
mov r14d,r10d
|
||
|
ror r13d,14
|
||
|
mov r15d,edx
|
||
|
mov DWORD PTR[8+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,ecx
|
||
|
xor r15d,r8d
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,r9d
|
||
|
xor r14d,r10d
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,ecx
|
||
|
mov r9d,r11d
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,ecx
|
||
|
xor r15d,r8d
|
||
|
|
||
|
xor r9d,eax
|
||
|
xor r14d,r10d
|
||
|
add r12d,r15d
|
||
|
mov r15d,r11d
|
||
|
|
||
|
ror r13d,6
|
||
|
and r9d,r10d
|
||
|
and r15d,eax
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add r9d,r15d
|
||
|
|
||
|
add ebx,r12d
|
||
|
add r9d,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add r9d,r14d
|
||
|
|
||
|
mov r13d,DWORD PTR[16+rsp]
|
||
|
mov r14d,DWORD PTR[4+rsp]
|
||
|
mov r12d,r13d
|
||
|
mov r15d,r14d
|
||
|
|
||
|
ror r12d,11
|
||
|
xor r12d,r13d
|
||
|
shr r13d,3
|
||
|
|
||
|
ror r12d,7
|
||
|
xor r13d,r12d
|
||
|
mov r12d,DWORD PTR[48+rsp]
|
||
|
|
||
|
ror r15d,2
|
||
|
xor r15d,r14d
|
||
|
shr r14d,10
|
||
|
|
||
|
ror r15d,17
|
||
|
add r12d,r13d
|
||
|
xor r14d,r15d
|
||
|
|
||
|
add r12d,DWORD PTR[12+rsp]
|
||
|
mov r13d,ebx
|
||
|
add r12d,r14d
|
||
|
mov r14d,r9d
|
||
|
ror r13d,14
|
||
|
mov r15d,ecx
|
||
|
mov DWORD PTR[12+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,ebx
|
||
|
xor r15d,edx
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,r8d
|
||
|
xor r14d,r9d
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,ebx
|
||
|
mov r8d,r10d
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,ebx
|
||
|
xor r15d,edx
|
||
|
|
||
|
xor r8d,r11d
|
||
|
xor r14d,r9d
|
||
|
add r12d,r15d
|
||
|
mov r15d,r10d
|
||
|
|
||
|
ror r13d,6
|
||
|
and r8d,r9d
|
||
|
and r15d,r11d
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add r8d,r15d
|
||
|
|
||
|
add eax,r12d
|
||
|
add r8d,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add r8d,r14d
|
||
|
|
||
|
mov r13d,DWORD PTR[20+rsp]
|
||
|
mov r14d,DWORD PTR[8+rsp]
|
||
|
mov r12d,r13d
|
||
|
mov r15d,r14d
|
||
|
|
||
|
ror r12d,11
|
||
|
xor r12d,r13d
|
||
|
shr r13d,3
|
||
|
|
||
|
ror r12d,7
|
||
|
xor r13d,r12d
|
||
|
mov r12d,DWORD PTR[52+rsp]
|
||
|
|
||
|
ror r15d,2
|
||
|
xor r15d,r14d
|
||
|
shr r14d,10
|
||
|
|
||
|
ror r15d,17
|
||
|
add r12d,r13d
|
||
|
xor r14d,r15d
|
||
|
|
||
|
add r12d,DWORD PTR[16+rsp]
|
||
|
mov r13d,eax
|
||
|
add r12d,r14d
|
||
|
mov r14d,r8d
|
||
|
ror r13d,14
|
||
|
mov r15d,ebx
|
||
|
mov DWORD PTR[16+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,eax
|
||
|
xor r15d,ecx
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,edx
|
||
|
xor r14d,r8d
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,eax
|
||
|
mov edx,r9d
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,eax
|
||
|
xor r15d,ecx
|
||
|
|
||
|
xor edx,r10d
|
||
|
xor r14d,r8d
|
||
|
add r12d,r15d
|
||
|
mov r15d,r9d
|
||
|
|
||
|
ror r13d,6
|
||
|
and edx,r8d
|
||
|
and r15d,r10d
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add edx,r15d
|
||
|
|
||
|
add r11d,r12d
|
||
|
add edx,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add edx,r14d
|
||
|
|
||
|
mov r13d,DWORD PTR[24+rsp]
|
||
|
mov r14d,DWORD PTR[12+rsp]
|
||
|
mov r12d,r13d
|
||
|
mov r15d,r14d
|
||
|
|
||
|
ror r12d,11
|
||
|
xor r12d,r13d
|
||
|
shr r13d,3
|
||
|
|
||
|
ror r12d,7
|
||
|
xor r13d,r12d
|
||
|
mov r12d,DWORD PTR[56+rsp]
|
||
|
|
||
|
ror r15d,2
|
||
|
xor r15d,r14d
|
||
|
shr r14d,10
|
||
|
|
||
|
ror r15d,17
|
||
|
add r12d,r13d
|
||
|
xor r14d,r15d
|
||
|
|
||
|
add r12d,DWORD PTR[20+rsp]
|
||
|
mov r13d,r11d
|
||
|
add r12d,r14d
|
||
|
mov r14d,edx
|
||
|
ror r13d,14
|
||
|
mov r15d,eax
|
||
|
mov DWORD PTR[20+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,r11d
|
||
|
xor r15d,ebx
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,ecx
|
||
|
xor r14d,edx
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,r11d
|
||
|
mov ecx,r8d
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,r11d
|
||
|
xor r15d,ebx
|
||
|
|
||
|
xor ecx,r9d
|
||
|
xor r14d,edx
|
||
|
add r12d,r15d
|
||
|
mov r15d,r8d
|
||
|
|
||
|
ror r13d,6
|
||
|
and ecx,edx
|
||
|
and r15d,r9d
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add ecx,r15d
|
||
|
|
||
|
add r10d,r12d
|
||
|
add ecx,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add ecx,r14d
|
||
|
|
||
|
mov r13d,DWORD PTR[28+rsp]
|
||
|
mov r14d,DWORD PTR[16+rsp]
|
||
|
mov r12d,r13d
|
||
|
mov r15d,r14d
|
||
|
|
||
|
ror r12d,11
|
||
|
xor r12d,r13d
|
||
|
shr r13d,3
|
||
|
|
||
|
ror r12d,7
|
||
|
xor r13d,r12d
|
||
|
mov r12d,DWORD PTR[60+rsp]
|
||
|
|
||
|
ror r15d,2
|
||
|
xor r15d,r14d
|
||
|
shr r14d,10
|
||
|
|
||
|
ror r15d,17
|
||
|
add r12d,r13d
|
||
|
xor r14d,r15d
|
||
|
|
||
|
add r12d,DWORD PTR[24+rsp]
|
||
|
mov r13d,r10d
|
||
|
add r12d,r14d
|
||
|
mov r14d,ecx
|
||
|
ror r13d,14
|
||
|
mov r15d,r11d
|
||
|
mov DWORD PTR[24+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,r10d
|
||
|
xor r15d,eax
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,ebx
|
||
|
xor r14d,ecx
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,r10d
|
||
|
mov ebx,edx
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,r10d
|
||
|
xor r15d,eax
|
||
|
|
||
|
xor ebx,r8d
|
||
|
xor r14d,ecx
|
||
|
add r12d,r15d
|
||
|
mov r15d,edx
|
||
|
|
||
|
ror r13d,6
|
||
|
and ebx,ecx
|
||
|
and r15d,r8d
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add ebx,r15d
|
||
|
|
||
|
add r9d,r12d
|
||
|
add ebx,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add ebx,r14d
|
||
|
|
||
|
mov r13d,DWORD PTR[32+rsp]
|
||
|
mov r14d,DWORD PTR[20+rsp]
|
||
|
mov r12d,r13d
|
||
|
mov r15d,r14d
|
||
|
|
||
|
ror r12d,11
|
||
|
xor r12d,r13d
|
||
|
shr r13d,3
|
||
|
|
||
|
ror r12d,7
|
||
|
xor r13d,r12d
|
||
|
mov r12d,DWORD PTR[rsp]
|
||
|
|
||
|
ror r15d,2
|
||
|
xor r15d,r14d
|
||
|
shr r14d,10
|
||
|
|
||
|
ror r15d,17
|
||
|
add r12d,r13d
|
||
|
xor r14d,r15d
|
||
|
|
||
|
add r12d,DWORD PTR[28+rsp]
|
||
|
mov r13d,r9d
|
||
|
add r12d,r14d
|
||
|
mov r14d,ebx
|
||
|
ror r13d,14
|
||
|
mov r15d,r10d
|
||
|
mov DWORD PTR[28+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,r9d
|
||
|
xor r15d,r11d
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,eax
|
||
|
xor r14d,ebx
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,r9d
|
||
|
mov eax,ecx
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,r9d
|
||
|
xor r15d,r11d
|
||
|
|
||
|
xor eax,edx
|
||
|
xor r14d,ebx
|
||
|
add r12d,r15d
|
||
|
mov r15d,ecx
|
||
|
|
||
|
ror r13d,6
|
||
|
and eax,ebx
|
||
|
and r15d,edx
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add eax,r15d
|
||
|
|
||
|
add r8d,r12d
|
||
|
add eax,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add eax,r14d
|
||
|
|
||
|
mov r13d,DWORD PTR[36+rsp]
|
||
|
mov r14d,DWORD PTR[24+rsp]
|
||
|
mov r12d,r13d
|
||
|
mov r15d,r14d
|
||
|
|
||
|
ror r12d,11
|
||
|
xor r12d,r13d
|
||
|
shr r13d,3
|
||
|
|
||
|
ror r12d,7
|
||
|
xor r13d,r12d
|
||
|
mov r12d,DWORD PTR[4+rsp]
|
||
|
|
||
|
ror r15d,2
|
||
|
xor r15d,r14d
|
||
|
shr r14d,10
|
||
|
|
||
|
ror r15d,17
|
||
|
add r12d,r13d
|
||
|
xor r14d,r15d
|
||
|
|
||
|
add r12d,DWORD PTR[32+rsp]
|
||
|
mov r13d,r8d
|
||
|
add r12d,r14d
|
||
|
mov r14d,eax
|
||
|
ror r13d,14
|
||
|
mov r15d,r9d
|
||
|
mov DWORD PTR[32+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,r8d
|
||
|
xor r15d,r10d
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,r11d
|
||
|
xor r14d,eax
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,r8d
|
||
|
mov r11d,ebx
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,r8d
|
||
|
xor r15d,r10d
|
||
|
|
||
|
xor r11d,ecx
|
||
|
xor r14d,eax
|
||
|
add r12d,r15d
|
||
|
mov r15d,ebx
|
||
|
|
||
|
ror r13d,6
|
||
|
and r11d,eax
|
||
|
and r15d,ecx
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add r11d,r15d
|
||
|
|
||
|
add edx,r12d
|
||
|
add r11d,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add r11d,r14d
|
||
|
|
||
|
mov r13d,DWORD PTR[40+rsp]
|
||
|
mov r14d,DWORD PTR[28+rsp]
|
||
|
mov r12d,r13d
|
||
|
mov r15d,r14d
|
||
|
|
||
|
ror r12d,11
|
||
|
xor r12d,r13d
|
||
|
shr r13d,3
|
||
|
|
||
|
ror r12d,7
|
||
|
xor r13d,r12d
|
||
|
mov r12d,DWORD PTR[8+rsp]
|
||
|
|
||
|
ror r15d,2
|
||
|
xor r15d,r14d
|
||
|
shr r14d,10
|
||
|
|
||
|
ror r15d,17
|
||
|
add r12d,r13d
|
||
|
xor r14d,r15d
|
||
|
|
||
|
add r12d,DWORD PTR[36+rsp]
|
||
|
mov r13d,edx
|
||
|
add r12d,r14d
|
||
|
mov r14d,r11d
|
||
|
ror r13d,14
|
||
|
mov r15d,r8d
|
||
|
mov DWORD PTR[36+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,edx
|
||
|
xor r15d,r9d
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,r10d
|
||
|
xor r14d,r11d
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,edx
|
||
|
mov r10d,eax
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,edx
|
||
|
xor r15d,r9d
|
||
|
|
||
|
xor r10d,ebx
|
||
|
xor r14d,r11d
|
||
|
add r12d,r15d
|
||
|
mov r15d,eax
|
||
|
|
||
|
ror r13d,6
|
||
|
and r10d,r11d
|
||
|
and r15d,ebx
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add r10d,r15d
|
||
|
|
||
|
add ecx,r12d
|
||
|
add r10d,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add r10d,r14d
|
||
|
|
||
|
mov r13d,DWORD PTR[44+rsp]
|
||
|
mov r14d,DWORD PTR[32+rsp]
|
||
|
mov r12d,r13d
|
||
|
mov r15d,r14d
|
||
|
|
||
|
ror r12d,11
|
||
|
xor r12d,r13d
|
||
|
shr r13d,3
|
||
|
|
||
|
ror r12d,7
|
||
|
xor r13d,r12d
|
||
|
mov r12d,DWORD PTR[12+rsp]
|
||
|
|
||
|
ror r15d,2
|
||
|
xor r15d,r14d
|
||
|
shr r14d,10
|
||
|
|
||
|
ror r15d,17
|
||
|
add r12d,r13d
|
||
|
xor r14d,r15d
|
||
|
|
||
|
add r12d,DWORD PTR[40+rsp]
|
||
|
mov r13d,ecx
|
||
|
add r12d,r14d
|
||
|
mov r14d,r10d
|
||
|
ror r13d,14
|
||
|
mov r15d,edx
|
||
|
mov DWORD PTR[40+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,ecx
|
||
|
xor r15d,r8d
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,r9d
|
||
|
xor r14d,r10d
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,ecx
|
||
|
mov r9d,r11d
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,ecx
|
||
|
xor r15d,r8d
|
||
|
|
||
|
xor r9d,eax
|
||
|
xor r14d,r10d
|
||
|
add r12d,r15d
|
||
|
mov r15d,r11d
|
||
|
|
||
|
ror r13d,6
|
||
|
and r9d,r10d
|
||
|
and r15d,eax
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add r9d,r15d
|
||
|
|
||
|
add ebx,r12d
|
||
|
add r9d,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add r9d,r14d
|
||
|
|
||
|
mov r13d,DWORD PTR[48+rsp]
|
||
|
mov r14d,DWORD PTR[36+rsp]
|
||
|
mov r12d,r13d
|
||
|
mov r15d,r14d
|
||
|
|
||
|
ror r12d,11
|
||
|
xor r12d,r13d
|
||
|
shr r13d,3
|
||
|
|
||
|
ror r12d,7
|
||
|
xor r13d,r12d
|
||
|
mov r12d,DWORD PTR[16+rsp]
|
||
|
|
||
|
ror r15d,2
|
||
|
xor r15d,r14d
|
||
|
shr r14d,10
|
||
|
|
||
|
ror r15d,17
|
||
|
add r12d,r13d
|
||
|
xor r14d,r15d
|
||
|
|
||
|
add r12d,DWORD PTR[44+rsp]
|
||
|
mov r13d,ebx
|
||
|
add r12d,r14d
|
||
|
mov r14d,r9d
|
||
|
ror r13d,14
|
||
|
mov r15d,ecx
|
||
|
mov DWORD PTR[44+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,ebx
|
||
|
xor r15d,edx
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,r8d
|
||
|
xor r14d,r9d
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,ebx
|
||
|
mov r8d,r10d
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,ebx
|
||
|
xor r15d,edx
|
||
|
|
||
|
xor r8d,r11d
|
||
|
xor r14d,r9d
|
||
|
add r12d,r15d
|
||
|
mov r15d,r10d
|
||
|
|
||
|
ror r13d,6
|
||
|
and r8d,r9d
|
||
|
and r15d,r11d
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add r8d,r15d
|
||
|
|
||
|
add eax,r12d
|
||
|
add r8d,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add r8d,r14d
|
||
|
|
||
|
mov r13d,DWORD PTR[52+rsp]
|
||
|
mov r14d,DWORD PTR[40+rsp]
|
||
|
mov r12d,r13d
|
||
|
mov r15d,r14d
|
||
|
|
||
|
ror r12d,11
|
||
|
xor r12d,r13d
|
||
|
shr r13d,3
|
||
|
|
||
|
ror r12d,7
|
||
|
xor r13d,r12d
|
||
|
mov r12d,DWORD PTR[20+rsp]
|
||
|
|
||
|
ror r15d,2
|
||
|
xor r15d,r14d
|
||
|
shr r14d,10
|
||
|
|
||
|
ror r15d,17
|
||
|
add r12d,r13d
|
||
|
xor r14d,r15d
|
||
|
|
||
|
add r12d,DWORD PTR[48+rsp]
|
||
|
mov r13d,eax
|
||
|
add r12d,r14d
|
||
|
mov r14d,r8d
|
||
|
ror r13d,14
|
||
|
mov r15d,ebx
|
||
|
mov DWORD PTR[48+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,eax
|
||
|
xor r15d,ecx
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,edx
|
||
|
xor r14d,r8d
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,eax
|
||
|
mov edx,r9d
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,eax
|
||
|
xor r15d,ecx
|
||
|
|
||
|
xor edx,r10d
|
||
|
xor r14d,r8d
|
||
|
add r12d,r15d
|
||
|
mov r15d,r9d
|
||
|
|
||
|
ror r13d,6
|
||
|
and edx,r8d
|
||
|
and r15d,r10d
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add edx,r15d
|
||
|
|
||
|
add r11d,r12d
|
||
|
add edx,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add edx,r14d
|
||
|
|
||
|
mov r13d,DWORD PTR[56+rsp]
|
||
|
mov r14d,DWORD PTR[44+rsp]
|
||
|
mov r12d,r13d
|
||
|
mov r15d,r14d
|
||
|
|
||
|
ror r12d,11
|
||
|
xor r12d,r13d
|
||
|
shr r13d,3
|
||
|
|
||
|
ror r12d,7
|
||
|
xor r13d,r12d
|
||
|
mov r12d,DWORD PTR[24+rsp]
|
||
|
|
||
|
ror r15d,2
|
||
|
xor r15d,r14d
|
||
|
shr r14d,10
|
||
|
|
||
|
ror r15d,17
|
||
|
add r12d,r13d
|
||
|
xor r14d,r15d
|
||
|
|
||
|
add r12d,DWORD PTR[52+rsp]
|
||
|
mov r13d,r11d
|
||
|
add r12d,r14d
|
||
|
mov r14d,edx
|
||
|
ror r13d,14
|
||
|
mov r15d,eax
|
||
|
mov DWORD PTR[52+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,r11d
|
||
|
xor r15d,ebx
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,ecx
|
||
|
xor r14d,edx
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,r11d
|
||
|
mov ecx,r8d
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,r11d
|
||
|
xor r15d,ebx
|
||
|
|
||
|
xor ecx,r9d
|
||
|
xor r14d,edx
|
||
|
add r12d,r15d
|
||
|
mov r15d,r8d
|
||
|
|
||
|
ror r13d,6
|
||
|
and ecx,edx
|
||
|
and r15d,r9d
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add ecx,r15d
|
||
|
|
||
|
add r10d,r12d
|
||
|
add ecx,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add ecx,r14d
|
||
|
|
||
|
mov r13d,DWORD PTR[60+rsp]
|
||
|
mov r14d,DWORD PTR[48+rsp]
|
||
|
mov r12d,r13d
|
||
|
mov r15d,r14d
|
||
|
|
||
|
ror r12d,11
|
||
|
xor r12d,r13d
|
||
|
shr r13d,3
|
||
|
|
||
|
ror r12d,7
|
||
|
xor r13d,r12d
|
||
|
mov r12d,DWORD PTR[28+rsp]
|
||
|
|
||
|
ror r15d,2
|
||
|
xor r15d,r14d
|
||
|
shr r14d,10
|
||
|
|
||
|
ror r15d,17
|
||
|
add r12d,r13d
|
||
|
xor r14d,r15d
|
||
|
|
||
|
add r12d,DWORD PTR[56+rsp]
|
||
|
mov r13d,r10d
|
||
|
add r12d,r14d
|
||
|
mov r14d,ecx
|
||
|
ror r13d,14
|
||
|
mov r15d,r11d
|
||
|
mov DWORD PTR[56+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,r10d
|
||
|
xor r15d,eax
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,ebx
|
||
|
xor r14d,ecx
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,r10d
|
||
|
mov ebx,edx
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,r10d
|
||
|
xor r15d,eax
|
||
|
|
||
|
xor ebx,r8d
|
||
|
xor r14d,ecx
|
||
|
add r12d,r15d
|
||
|
mov r15d,edx
|
||
|
|
||
|
ror r13d,6
|
||
|
and ebx,ecx
|
||
|
and r15d,r8d
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add ebx,r15d
|
||
|
|
||
|
add r9d,r12d
|
||
|
add ebx,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add ebx,r14d
|
||
|
|
||
|
mov r13d,DWORD PTR[rsp]
|
||
|
mov r14d,DWORD PTR[52+rsp]
|
||
|
mov r12d,r13d
|
||
|
mov r15d,r14d
|
||
|
|
||
|
ror r12d,11
|
||
|
xor r12d,r13d
|
||
|
shr r13d,3
|
||
|
|
||
|
ror r12d,7
|
||
|
xor r13d,r12d
|
||
|
mov r12d,DWORD PTR[32+rsp]
|
||
|
|
||
|
ror r15d,2
|
||
|
xor r15d,r14d
|
||
|
shr r14d,10
|
||
|
|
||
|
ror r15d,17
|
||
|
add r12d,r13d
|
||
|
xor r14d,r15d
|
||
|
|
||
|
add r12d,DWORD PTR[60+rsp]
|
||
|
mov r13d,r9d
|
||
|
add r12d,r14d
|
||
|
mov r14d,ebx
|
||
|
ror r13d,14
|
||
|
mov r15d,r10d
|
||
|
mov DWORD PTR[60+rsp],r12d
|
||
|
|
||
|
ror r14d,9
|
||
|
xor r13d,r9d
|
||
|
xor r15d,r11d
|
||
|
|
||
|
ror r13d,5
|
||
|
add r12d,eax
|
||
|
xor r14d,ebx
|
||
|
|
||
|
add r12d,DWORD PTR[rdi*4+rbp]
|
||
|
and r15d,r9d
|
||
|
mov eax,ecx
|
||
|
|
||
|
ror r14d,11
|
||
|
xor r13d,r9d
|
||
|
xor r15d,r11d
|
||
|
|
||
|
xor eax,edx
|
||
|
xor r14d,ebx
|
||
|
add r12d,r15d
|
||
|
mov r15d,ecx
|
||
|
|
||
|
ror r13d,6
|
||
|
and eax,ebx
|
||
|
and r15d,edx
|
||
|
|
||
|
ror r14d,2
|
||
|
add r12d,r13d
|
||
|
add eax,r15d
|
||
|
|
||
|
add r8d,r12d
|
||
|
add eax,r12d
|
||
|
lea rdi,QWORD PTR[1+rdi]
|
||
|
add eax,r14d
|
||
|
|
||
|
cmp rdi,64
|
||
|
jb $L$rounds_16_xx
|
||
|
|
||
|
mov rdi,QWORD PTR[((64+0))+rsp]
|
||
|
lea rsi,QWORD PTR[64+rsi]
|
||
|
|
||
|
add eax,DWORD PTR[rdi]
|
||
|
add ebx,DWORD PTR[4+rdi]
|
||
|
add ecx,DWORD PTR[8+rdi]
|
||
|
add edx,DWORD PTR[12+rdi]
|
||
|
add r8d,DWORD PTR[16+rdi]
|
||
|
add r9d,DWORD PTR[20+rdi]
|
||
|
add r10d,DWORD PTR[24+rdi]
|
||
|
add r11d,DWORD PTR[28+rdi]
|
||
|
|
||
|
cmp rsi,QWORD PTR[((64+16))+rsp]
|
||
|
|
||
|
mov DWORD PTR[rdi],eax
|
||
|
mov DWORD PTR[4+rdi],ebx
|
||
|
mov DWORD PTR[8+rdi],ecx
|
||
|
mov DWORD PTR[12+rdi],edx
|
||
|
mov DWORD PTR[16+rdi],r8d
|
||
|
mov DWORD PTR[20+rdi],r9d
|
||
|
mov DWORD PTR[24+rdi],r10d
|
||
|
mov DWORD PTR[28+rdi],r11d
|
||
|
jb $L$loop
|
||
|
|
||
|
mov rsi,QWORD PTR[((64+24))+rsp]
|
||
|
mov r15,QWORD PTR[rsi]
|
||
|
mov r14,QWORD PTR[8+rsi]
|
||
|
mov r13,QWORD PTR[16+rsi]
|
||
|
mov r12,QWORD PTR[24+rsi]
|
||
|
mov rbp,QWORD PTR[32+rsi]
|
||
|
mov rbx,QWORD PTR[40+rsi]
|
||
|
lea rsp,QWORD PTR[48+rsi]
|
||
|
$L$epilogue::
|
||
|
mov rdi,QWORD PTR[8+rsp] ;WIN64 epilogue
|
||
|
mov rsi,QWORD PTR[16+rsp]
|
||
|
DB 0F3h,0C3h ;repret
|
||
|
$L$SEH_end_sha256_block_data_order::
|
||
|
sha256_block_data_order ENDP
|
||
|
ALIGN 64
|
||
|
|
||
|
K256::
|
||
|
DD 0428a2f98h,071374491h,0b5c0fbcfh,0e9b5dba5h
|
||
|
DD 03956c25bh,059f111f1h,0923f82a4h,0ab1c5ed5h
|
||
|
DD 0d807aa98h,012835b01h,0243185beh,0550c7dc3h
|
||
|
DD 072be5d74h,080deb1feh,09bdc06a7h,0c19bf174h
|
||
|
DD 0e49b69c1h,0efbe4786h,00fc19dc6h,0240ca1cch
|
||
|
DD 02de92c6fh,04a7484aah,05cb0a9dch,076f988dah
|
||
|
DD 0983e5152h,0a831c66dh,0b00327c8h,0bf597fc7h
|
||
|
DD 0c6e00bf3h,0d5a79147h,006ca6351h,014292967h
|
||
|
DD 027b70a85h,02e1b2138h,04d2c6dfch,053380d13h
|
||
|
DD 0650a7354h,0766a0abbh,081c2c92eh,092722c85h
|
||
|
DD 0a2bfe8a1h,0a81a664bh,0c24b8b70h,0c76c51a3h
|
||
|
DD 0d192e819h,0d6990624h,0f40e3585h,0106aa070h
|
||
|
DD 019a4c116h,01e376c08h,02748774ch,034b0bcb5h
|
||
|
DD 0391c0cb3h,04ed8aa4ah,05b9cca4fh,0682e6ff3h
|
||
|
DD 0748f82eeh,078a5636fh,084c87814h,08cc70208h
|
||
|
DD 090befffah,0a4506cebh,0bef9a3f7h,0c67178f2h
|
||
|
|
||
|
.text$ ENDS
|
||
|
END
|
||
|
|